Skip to content

Latest commit

 

History

History
390 lines (283 loc) · 15.5 KB

com0com.md

File metadata and controls

390 lines (283 loc) · 15.5 KB
             =============================
             Null-modem emulator (com0com)
             =============================

INTRODUCTION

The Null-modem emulator is an open source kernel-mode virtual serial port driver for Windows, available freely under GPL license. You can create an unlimited number of virtual COM port pairs and use any pair to connect one application to another. Each COM port pair provides two COM ports with default names starting at CNCA0 and CNCB0. The output to one port is the input from other port and vice versa.

Usually one port of the pair is used by Windows application that requires a COM port to communicate with a device and other port is used by device emulation program.

For example, to send/receive faxes over IP you can connect Windows Fax application to CNCA0 port and t38modem (http://t38modem.sourceforge.net/) to CNCB0 port. In this case the t38modem is a fax modem emulation program.

In conjunction with the hub4com the com0com allows you to

  • handle data and signals from a single real serial device by a number of different applications. For example, several applications can share data from one GPS device;
  • use real serial ports of remote computer like if they exist on the local computer (supports RFC 2217).

The homepage for com0com project is http://com0com.sourceforge.net/.

INSTALLING

NOTE (x64-based Windows Vista/Windows Server 2008/Windows 7/8): The com0com.sys is a test-signed kernel-mode driver that will not load by default. To enable test signing, enter command:

bcdedit.exe -set TESTSIGNING ON

and reboot the computer.

NOTE: Enabling test signing will impair computer security.

Simply run the installer (setup.exe). An installation wizard will guide you through the required steps. If the Found New Hardware Wizard will pop up then

  • select "No, not this time" and click Next;
  • select "Install the software automatically (Recommended)" and click Next. The one COM port pair with names CNCA0 and CNCB0 will be available on your system after the installation.

You can add more pairs with the Setup Command Prompt:

  1. Launch the Setup Command Prompt shortcut.

  2. Enter the install command, for example:

    command> install - -

The system will create 3 new virtual devices. One of the devices has name "com0com - bus for serial port pair emulator" and other two of them have name "com0com - serial port emulator" and located on CNCAn and CNCBn ports.

To get more info enter the help command, for example:

   command> help

Alternatively to setup ports you can invoke GUI-based setup utility by launching Setup shortcut (Microsoft .NET Framework 2.0 is required).

TESTING

  1. Start the HyperTerminal on CNCA0 port.
  2. Start the HyperTerminal on CNCB0 port.
  3. The output to CNCA0 port should be the input from CNCB0 port and vice versa.

UNINSTALLING

Simply launch the com0com's Uninstall shortcut in the Start Menu or remove the "Null-modem emulator (com0com)" entry from the "Add/Remove Programs" section in the Control Panel. An uninstallation wizard will guide you through the required steps.

HINT: To uninstall the old version of com0com (distributed w/o installer) install the new one and then uninstall it.

FAQs & HOWTOs

Q. Is it possible to run com0com on Windows 9x platform? A. No, it is not possible. You need Windows 2000 platform or newer.

Q. Is it possible to install or uninstall com0com silently (with no user intervention and no user interface)? A. Yes, it's possible with /S option, for example:

 setup.exe /S
 "%ProgramFiles%\com0com\uninstall.exe" /S

You can specify the installation directory with /D option, for example:

 setup.exe /S /D=C:\Program Files\com0com

NOTE: Silent installation of com0com will not install any port pairs by default {it can be overriden by setting CNC_INSTALL_CNCA0_CNCB0_PORTS and/or CNC_INSTALL_COMX_COMX_PORTS environment variables).

Q. What are the other setup.exe command line options? A. The command line options of setup.exe and uninstall.exe listed in NSIS Users Manual, section 3.2 Installer Usage:

 http://nsis.sourceforge.net/Docs/Chapter3.html#3.2

Additionally the following environment variables can be used.

To change behaviour of setup.exe:

 CNC_INSTALL_START_MENU_SHORTCUTS={YES|NO}   - select/unselect "Start Menu Shortcuts"
 CNC_INSTALL_CNCA0_CNCB0_PORTS={YES|NO}      - select/unselect "CNCA0 <-> CNCB0"
 CNC_INSTALL_COMX_COMX_PORTS={YES|NO}        - select/unselect "COM# <-> COM#"
 CNC_INSTALL_SKIP_SETUP_PREINSTALL={YES|NO}  - skip preinstalling/updating driver

To change behaviour of uninstall.exe:

 CNC_UNINSTALL_SKIP_SETUP_UNINSTALL={YES|NO} - skip uninstalling devices and driver

Q. Is it possible to change the names CNCA0 and CNCB0 to COM8 and COM9? A. Yes, it's possible. To change the names:

  1. Launch the Setup Command Prompt shortcut.

  2. Enter the change commands, for example:

    command> change CNCA0 PortName=COM8 command> change CNCB0 PortName=COM9

Alternatively you can set names to 'COM#', for example:

  command> change CNCA0 PortName=COM#
  command> change CNCB0 PortName=COM#

If parameter 'PortName=COM#' is used then the Ports class installer will be invoked to set the real port name. The Ports class installer selects the COM port number and sets the real port name to COM, where is the selected port number. After installing the Ports class port you can use the list command to get the real port name and the parameter RealPortName=COM to change the real port name, for example:

  command> list
         CNCA0 PortName=COM#,RealPortName=COM3
         CNCB0 PortName=COM#,RealPortName=COM4
  command> change CNCA0 RealPortName=COM8
  command> change CNCB0 RealPortName=COM9
  command> list
         CNCA0 PortName=COM#,RealPortName=COM8
         CNCB0 PortName=COM#,RealPortName=COM9

Q. The baud rate setting does not seem to make a difference: data is always transferred at the same speed. How to enable the baud rate emulation? A. To enable baud rate emulation for transferring data from CNCA0 to CNCB0:

  1. Launch the Setup Command Prompt shortcut.

  2. Enter the change command, for example:

    command> change CNCA0 EmuBR=yes

Q. The HyperTerminal test succeeds, but I get a failure when trying to open the port with CreateFile("CNCA0", ...). GetLastError() returns ERROR_FILE_NOT_FOUND. A. You must prefix the port name with the special characters "\.". Try to open the port with CreateFile("\\.\CNCA0", ...).

Q. My application hangs during its startup when it sends anything to one paired COM port. The only way to unhang it is to start HyperTerminal, which is connected to the other paired COM port. I didn't have this problem with physical serial ports. A. Your application can hang because receive buffer overrun is disabled by default. You can fix the problem by enabling receive buffer overrun for the receiving port. Also, to prevent some flow control issues you need to enable baud rate emulation for the sending port. So, if your application use port CNCA0 and other paired port is CNCB0, then:

  1. Launch the Setup Command Prompt shortcut.

  2. Enter the change commands, for example:

    command> change CNCB0 EmuOverrun=yes command> change CNCA0 EmuBR=yes

Q. When the corresponding port of a pair is not open, some characters will remain in the ouput buffer of the sending port and be output upon the next connection. Any clue on a possible workaround? A. It's a correct behavior if receive buffer overrun is disabled (by default). If you need behavior where those characters should be lost (like real null modem do) then enable receive buffer overrun for the receiving port. Also, to prevent some flow control issues enable baud rate emulation for the sending port. So, if sending port is CNCA0 and receiving port is CNCB0, then:

  1. Launch the Setup Command Prompt shortcut.

  2. Enter the change commands, for example:

    command> change CNCB0 EmuOverrun=yes command> change CNCA0 EmuBR=yes

Q. I have to write an application connected to one side of the com0com port pair, and I don't want users to 'see' all the virtual ports created by com0com, but only the really available ones. A. if your application use port CNCB0 and other (used by users) paired port is CNCA0, then CNCB0 can be 'hidden' and CNCA0 can be 'shown' on opening CNCB0 by your application. To enable it:

  1. Launch the Setup Command Prompt shortcut.

  2. Enter the change commands:

    command> change CNCB0 ExclusiveMode=yes command> change CNCA0 PlugInMode=yes

Q. When I add a port pair, why does Windows XP always pops up a Found New Hardware Wizard? The drivers are already there and it can install them silently in the background and report when the device is ready. A. It's because there is not signed com0com.cat catalog file. It can be created on your test computer by this way:

  1. Create a catalog file, for example:

    cd "C:\Program Files\com0com" inf2cat /driver:. /os:XP_X86

  2. Create a test certificate, for example:

    makecert -r -n "CN=com0com (test)" -sv com0com.pvk com0com.cer pvk2pfx -pvk com0com.pvk -spc com0com.cer -pfx com0com.pfx

  3. Sign the catalog file by test certificate, for example:

    signtool sign /v /f com0com.pfx com0com.cat

  4. Install a test certificate to the Trusted Root Certification Authorities certificate store and the Trusted Publishers certificate store, for example:

    certmgr -add com0com.cer -s -r localMachine root certmgr -add com0com.cer -s -r localMachine trustedpublisher

The inf2cat, makecert, pvk2pfx, signtool and certmgr tools are included in the Windows Driver Kit (WDK).

Alternatively you can cancel Found New Hardware Wizard and install driver by update command, for example:

  setupc install - -
  setupc update

Additionally you can temporary suppress Plug and Play-related UI messages, for example:

  reg add HKLM\Software\Policies\Microsoft\Windows\DeviceInstall\Settings /v SuppressNewHWUI /t REG_DWORD /d 1 /f
  setupc install - -
  setupc update
  reg add HKLM\Software\Policies\Microsoft\Windows\DeviceInstall\Settings /v SuppressNewHWUI /t REG_DWORD /d 0 /f

See http://support.microsoft.com/kb/938596 for more info.

Q. How to monitor and get the paired port settings (baud rate, byte size, parity and stop bits)? A. It can be done with extended IOCTL_SERIAL_LSRMST_INSERT. See example in

http://com0com.sourceforge.net/examples/LSRMST_INSERT/tstser.cpp

Q. To transfer state to CTS and DSR they wired to RTS and DTR. How to transfer state to DCD and RING? A. The OUT1 can be wired to DCD and OUT2 to RING. Use extended IOCTL_SERIAL_SET_MODEM_CONTROL and IOCTL_SERIAL_GET_MODEM_CONTROL to change state of OUT1 and OUT2. See example in

http://com0com.sourceforge.net/examples/MODEM_CONTROL/tstser.cpp

Q. What version am I running? A. In the device manager, the driver properties page shows the version and date of the INF files, while the driver details page shows a version of com0com.sys file. The version of com0com.sys file is the version that you are running.

Q. I'm able to use some application to talk to some hardware using com2tcp when both the com2tcp 'server' and 'client' are running on the same computer. When I try to move the client to a remote computer the application gives me a timeout message and has no settings to increase the timeout. How to fix the problem? A. Try to ajust AddRTTO and AddRITO params for application's COM port:

  1. Launch the Setup Command Prompt shortcut.

  2. Enter the change command, for example:

    command> change CNCA0 AddRTTO=100,AddRITO=100

Q. I would like to be able to add, remove and rename virtual comm ports from my own custom application. Is there an API that I can use or some command line utility that will do the job? A. The setupc.exe is a command line utility that will do the job. To get more info enter:

  setupc help

BTW: The setupg.exe is a GUI wrapper for setupc.exe.

Q. I need to use com0com ports with an application that doesn't recognize com0com ports as "real" com ports. It does not see a com0com port even though I have changed it's name to COMx. Is there a com0com settings that will make the port appear to be a "real" com port? A. Yes, it is. You should put the port to the Ports class, for example:

  1. Launch the Setup Command Prompt shortcut.

  2. Install the pair of ports, were one of them has name COM#, for example:

    command> install PortName=COM# -

Q. I have to somehow add a "fake" PNP device in device manager and have it connected under COM3. I use PNPComSimulator (http://www.bds.dogma.net/pnp_part2.htm), which can fake a PNP Serial device's response when polled by DevManager. Is it possible to have the device manager look for PNP equipement via com0com? A. Yes, it is. The simplest way is to put the port to the Ports class, for example:

  1. Launch the Setup Command Prompt shortcut.

  2. Install the pair of ports, were one of them has name COM#, for example:

    command> install 0 PortName=COM# -

After installing the Ports class port you can use the list command to get the real port name, for example:

  command> list
         CNCA0 PortName=COM#,RealPortName=COM3
         CNCB0 PortName=-

Q. Is it possible to configure the com0com to randomly corrupt the data? It would be nice to have this feature so that we can test our application robustness. A. Yes, it's possible by setting EmuNoise parameter:

  1. Launch the Setup Command Prompt shortcut.

  2. Enter the change command, for example:

    command> change CNCA0 EmuNoise=0.00001,EmuBR=yes,EmuOverrun=yes command> change CNCB0 EmuNoise=0.00001,EmuBR=yes,EmuOverrun=yes

Now each character frame (including idle frames) will be corrupted with probability 0.00001.

Q. What is the maximum number of port pairs that can be defined? A. It depends from your system. The com0com itself has internal limit 1000000 port pairs.

Q. In my application, users could be installing up to 250 com port pairs. Initially, the installation is fairly quick, but each additional com port generally takes longer to install than the previous one. It quickly becomes unacceptable for a user to be expected to wait for the installation. A. It's because the installing of each next port pair requires to update driver for all installed pairs. You can speed up installing of multiple com port pairs by using install commands with --no-update option and then use install command w/o --no-update option, for example:

  command> --no-update install - -
  command> --no-update install - -
  ...
  command> --no-update install - -
  command> install

The example of the batch program:

  cd /D "%ProgramFiles%\com0com"
  FOR /L %%i IN (0,1,249) DO setupc --no-update install - -
  setupc install

Q. I am using the 64-bit version of com0com and I am having trouble. I'd like to debug this, but I can not find any free serial port monitor software, like portmon that works with a 64-bit OS. Does anyone know of any? A. You can try to use internal com0com's tracing for debuging:

  - get trace.reg file from com0com's source;
  - import trace.reg to the Registry;
  - reload driver (or reboot system);
  - do your tests and watch results in C:\com0com.log file.

To disable tracing reinstall com0com or import trace_disable.reg to the Registry and reload driver.