Difference between revisions of "Connectivity"

From DOSBoxWiki
Jump to: navigation, search
(Moved in info from duplicated articles)
 
(11 intermediate revisions by 5 users not shown)
Line 2: Line 2:
  
 
== IPX emulation ==
 
== IPX emulation ==
First, we must enable IPX networking emulation.
+
First, [[Dosbox.conf#%5Bipx%5D|enable IPX]].
 
+
Find and open the '''dosbox.conf''' file (the configuration file for DOSBox); it should be located in the DOSBox directory.
+
 
+
You can find the '''dosbox.conf''' by browsing '''Start > All Programs > Dosbox'''
+
 
+
[[Image:Dosbox_config.png]]
+
 
+
Inside the file, search for an entry labeled [ipx]. Below the explanation comment (marked with #), change the configuration line from ipx=false to ipx=true as shown in the example below.
+
 
+
[ipx]
+
# ipx -- Enable ipx over UDP/IP emulation.
+
+
ipx=true
+
 
+
You might find it hard to believe, but this is ALL of the tampering with the configuration files you will need.
+
  
 
=== Start IPX server ===
 
=== Start IPX server ===
Line 44: Line 29:
 
  ipxnet connect <IP> [UDP port]
 
  ipxnet connect <IP> [UDP port]
  
Specifically, in my case:
+
For example:
  
 
  ipxnet connect 192.168.2.100  
 
  ipxnet connect 192.168.2.100  
Line 55: Line 40:
 
  ipxnet connect 192.168.2.100 19900
 
  ipxnet connect 192.168.2.100 19900
  
You now have the network running. You can confirm it by:
+
You now have the network running. You can confirm it by typing:
 
   IPXNET STATUS
 
   IPXNET STATUS
 
If you want to check the speed and/or see the list of server and all clients, type:
 
If you want to check the speed and/or see the list of server and all clients, type:
Line 74: Line 59:
 
Whatever TCP port is chosen (including the default 5000), '''it must be forwarded and open to the outside network if a server is hidden behind a router (NAT)'''.
 
Whatever TCP port is chosen (including the default 5000), '''it must be forwarded and open to the outside network if a server is hidden behind a router (NAT)'''.
  
==The game's modem options==
+
===The game's modem options===
 
You must enter the game's modem options and:
 
You must enter the game's modem options and:
 
* Define the same COM number as you chose in DOSBox. If the game is hardcoded to a certain COM number, this must be the one you choose in DOSBox.
 
* Define the same COM number as you chose in DOSBox. If the game is hardcoded to a certain COM number, this must be the one you choose in DOSBox.
 
* Choose the highest modem's speed the game allows.
 
* Choose the highest modem's speed the game allows.
 
* <sup>''For [[#Emulating making a call|clients only]]''</sup> If there's an address book, you can define the server in advance. Actually, some games might refuse to call anyone that's not listed in advance in the address book.
 
* <sup>''For [[#Emulating making a call|clients only]]''</sup> If there's an address book, you can define the server in advance. Actually, some games might refuse to call anyone that's not listed in advance in the address book.
* The other game's modem options don't matter in DOSBox.
+
* The game's other modem options don't matter in DOSBox.
  
 
Exit the settings, enter the game itself and find the call/answer menu entry.
 
Exit the settings, enter the game itself and find the call/answer menu entry.
  
===Emulating answering a call===
+
====Emulating answering a call====
 
Some games may want you to define an auto-answer command in advance, while others may want you to answer manually when the call comes in. Some may allow both modes.
 
Some games may want you to define an auto-answer command in advance, while others may want you to answer manually when the call comes in. Some may allow both modes.
  
Line 90: Line 75:
 
In the second mode, the server should choose the "answer call" option when the game announces a call is coming in. If the game wants you to type a manual command, use "ATA".
 
In the second mode, the server should choose the "answer call" option when the game announces a call is coming in. If the game wants you to type a manual command, use "ATA".
  
===Emulating making a call===
+
====Emulating making a call====
 
The client should choose the "make a call" option in their game. Then supply the server's hostname or IP address.
 
The client should choose the "make a call" option in their game. Then supply the server's hostname or IP address.
  
 
If the game wants you to type a manual command, use "ATDT<IP>". For example, if the server is "hosty" <1.2.3.4>, type:
 
If the game wants you to type a manual command, use "ATDT<IP>". For example, if the server is "hosty" <1.2.3.4>, type:
 
  ATDT1.2.3.4
 
  ATDT1.2.3.4
or
+
or "ATDT<HOST>". For example, in the case of "hosty":
 
  ATDThosty
 
  ATDThosty
  
== How to obtain computer's IP address==
+
== How to obtain a computer's IP address==
===The quick and advanced way===
+
If you're not afraid of the command prompt (surely if you use DOSBox without a frontend), browse to '''Start > All Programs > Accessories > Command Prompt'''. Once there, type "ipconfig".
+
  
===The long but user friendly way===
+
If connecting to others on the Internet, search for your [http://www.whatismyip.com/ external IP address] and make sure you forwarded the ports on your router to your computer.
  
Go to "My Network Place"
+
If on a LAN (local network):
 +
 
 +
On GNU/Linux:
 +
ifconfig
 +
 
 +
On Mac: Press Cmd-Space, type network, press enter, and select the connection. The IP address is to the right.
 +
 
 +
===Windows===
 +
 
 +
Go to "My Network Places"
  
 
Click on "View My Network Connections"
 
Click on "View My Network Connections"
Line 113: Line 105:
  
 
[[Image:Network_settings2.png]]
 
[[Image:Network_settings2.png]]
 +
 +
==Dedicated server==
 +
 +
You may wish to run a public facing dedicated server, doing this will allow multiple clients (e.g. players behind NAT on their respective broadband connections) to connect outbound to your server and thus see each others games without needing to port forward.
 +
 +
Several implementations exist...
 +
 +
====A Linux version by Michał Siejak (MasterM)====
 +
* http://www.vogons.org/viewtopic.php?t=22994#p171180
 +
* http://www.youtube.com/watch?v=uy-a0PzCw1E
 +
* http://github.com/intangir/ipxnet
 +
 +
====A Perl version by Alexander Clouter (diGriz)====
 +
* http://www.vogons.org/viewtopic.php?t=22994#p179078
 +
* http://github.com/steveschnepp/ipxserver
 +
 +
====A Java version by Ralf Grillenberger (H-A-L-9000)====
 +
* http://www.vogons.org/viewtopic.php?t=22994#p171196
 +
* http://home.arcor.de/h-a-l-9000/tunnelserver.html
 +
 +
====A Windows version by Joe Petrie (CodeJunkie)====
 +
* http://www.vogons.org/viewtopic.php?t=22994#p185381
 +
* http://www.classicgamingarena.com/downloads
 +
 +
====A Linux and Windows version by Hans Peter Anvin (hpa)====
 +
* http://www.vogons.org/viewtopic.php?t=22994&start=20#p209067
 +
* http://git.zytor.com/games/dosbox/ipxrelay.git/
  
 
==External links==
 
==External links==
 
* [http://www.dedoimedo.com/games/reviving/dosbox_multiplayer.html dedoimedo.com] (the original article plus screenshots from actual multiplayer games)
 
* [http://www.dedoimedo.com/games/reviving/dosbox_multiplayer.html dedoimedo.com] (the original article plus screenshots from actual multiplayer games)

Latest revision as of 23:22, 9 April 2016

DOSBox networking works in a client-server architecture, where one machine acts as a server and all the others connect to it as its clients. DOSBox emulates outdated protocols and actually routes them to Internet's own IP protocol (TCP/IP for serial/modem emulation and the even better UDP/IP for IPX emulation).

IPX emulation

First, enable IPX.

Start IPX server

Power on DOSBox on all the computers that you want to participate in the LAN games. One of these computers will have to act as a server. The rest will be clients.

On the server machine, execute the following command:

ipxnet startserver [UDP port]

See screenshot below:

Dosbox lan 02.png

UDP port is optional. Otherwise it defaults to 213 (the assigned IANA port for IPX tunnelling). If you want another port, for example, port 19900, type:

ipxnet startserver 19900

If you change the default, it's customary to choose something above 1024 as anything below is considered reserved. In Linux specifically, only root (or superuser) can use port numbers lower than 1024.

Whatever UDP port is chosen (including the default), it must be forwarded and open to the outside network if a server is hidden behind a router (NAT).

Start client(s)

On each one of the clients, run the following command to connect to the server:

ipxnet connect <IP> [UDP port]

For example:

ipxnet connect 192.168.2.100 

See screenshot below:

Dosbox lan 03.png

Port is optional. The same rules apply as in #Start IPX server. For example:

ipxnet connect 192.168.2.100 19900

You now have the network running. You can confirm it by typing:

 IPXNET STATUS

If you want to check the speed and/or see the list of server and all clients, type:

 IPXNET PING

Start your game

If you're done, but want to remain in DOSBox, the clients can optionally use the following commands:

 IPXNET DISCONNECT 

and only after all clients disconnect (or you'll risk locking them up), the server can type:

 IPXNET STOPSERVER

Modem emulation

First, define Configuration:SerialPort.

If you change the default TCP port, it's customary to choose something above 1024 as anything below is considered reserved. In Linux specifically, only root (or superuser) can use port numbers lower than 1024.

Whatever TCP port is chosen (including the default 5000), it must be forwarded and open to the outside network if a server is hidden behind a router (NAT).

The game's modem options

You must enter the game's modem options and:

  • Define the same COM number as you chose in DOSBox. If the game is hardcoded to a certain COM number, this must be the one you choose in DOSBox.
  • Choose the highest modem's speed the game allows.
  • For clients only If there's an address book, you can define the server in advance. Actually, some games might refuse to call anyone that's not listed in advance in the address book.
  • The game's other modem options don't matter in DOSBox.

Exit the settings, enter the game itself and find the call/answer menu entry.

Emulating answering a call

Some games may want you to define an auto-answer command in advance, while others may want you to answer manually when the call comes in. Some may allow both modes.

In the first mode, the server should choose the "wait for calls" option in their game. If the game wants you to type a manual command, use "ATS0=1" (answer on first call).

In the second mode, the server should choose the "answer call" option when the game announces a call is coming in. If the game wants you to type a manual command, use "ATA".

Emulating making a call

The client should choose the "make a call" option in their game. Then supply the server's hostname or IP address.

If the game wants you to type a manual command, use "ATDT<IP>". For example, if the server is "hosty" <1.2.3.4>, type:

ATDT1.2.3.4

or "ATDT<HOST>". For example, in the case of "hosty":

ATDThosty

How to obtain a computer's IP address

If connecting to others on the Internet, search for your external IP address and make sure you forwarded the ports on your router to your computer.

If on a LAN (local network):

On GNU/Linux:

ifconfig

On Mac: Press Cmd-Space, type network, press enter, and select the connection. The IP address is to the right.

Windows

Go to "My Network Places"

Click on "View My Network Connections"

Network settings1.png

Right Click the Network that you are using and choose "Status", then, you will be able to obtain the computer's IP address in a local network.

Network settings2.png

Dedicated server

You may wish to run a public facing dedicated server, doing this will allow multiple clients (e.g. players behind NAT on their respective broadband connections) to connect outbound to your server and thus see each others games without needing to port forward.

Several implementations exist...

A Linux version by Michał Siejak (MasterM)

A Perl version by Alexander Clouter (diGriz)

A Java version by Ralf Grillenberger (H-A-L-9000)

A Windows version by Joe Petrie (CodeJunkie)

A Linux and Windows version by Hans Peter Anvin (hpa)

External links

  • dedoimedo.com (the original article plus screenshots from actual multiplayer games)