How to Compile Ns2 on Windows 95

The following is an installation guide for Ns2 from its source code on Windows 95. Courtesy of Matthew Marchant.

Before installing Ns2 it is important to note that a pre-compiled version already exists for Windows 95. This serves as an excellent trial tool for anyone getting started with Ns2. For those who plan on implementing an extension for Ns2 you will have to compile it from its source distribution. This guide is designed to clarify this.

What is required

Setting the environment variables

Before compiling Ns2 the proper functionality of certain VC++ command-line tools such as CL.EXE and LINK.EXE must be assured. These tools require that the environment variables be set properly. The batch file VCVARS32.BAT is used to set these variables.

Source Code Organization

Organize the source code for Ns2 in the following directories:

Modifying Makefiles

Makefiles contain the instructions necessary to build a project with Nmake. The instructions include paths indicating the location of source code and VC++ libraries. To install Ns2 successfully you will need to modify the makefiles for Ns2 and its components. To assist you in this task I have added functional makefiles which represent a typical system configuration. You can modify these makefiles and copy them into the proper directories or use them as examples for changing existing makefiles. If you choose to modify these makefiles simply modify the lines specified in each makefile.

Note: makefile.win for tclcl and ns2 is found in the respective directories for each ..\conf, while makefile.vc resides in their base directory. otcl only has makefile.vc but not makefile.win. Here are some sample makefiles.

Using Nmake to compile Ns2

Nmake is the command line C++ compiler that is provided with Visual C++. The argument that Nmake receives is a makefile. Nmake is run from an MS-DOS Prompt. Cd into the directory containing the source code. Type the following: <nmake_dir>\nmake /f makefile.vc . Since this command will have to be used for every component of Ns2 create a few batch files. The following would be the contents of a typical batch file for running nmake:
cd D:\NetSim\ns-2.1b6-current

c:\progra~1\micros~3\vc98\bin\nmake /f makefile.vc

Batch files are saved with the extension .bat.

Notes on installation

Compile each component of Ns in the order given at the top of the page.

Compiling TCL is done in two steps. For the first step use nmake /f makefile.vc. After this use nmake /f makefile.vc install. The install option will creates directories for binary, include and library files.

The file mkd.bat in TCl8.0.5\win and TK8.0.5\win needs to be modified. Every instance of "md" should be changed to "mkdir". This is because the DOS command to make a directory is "mkdir" and not "md"

Validation

Now that ns2 and its components have been installed they must be validated to ensure their proper functionality. Two tools are needed to run the validation under Windows 95/NT. The first tool is named Cygwin and the second is named Perl.

What is Cygwin?

The Cygwin tools are ports of the popular GNU development tools for Windows NT, 95, and 98. They run thanks to the Cygwin library which provides the UNIX system calls and environment these programs expect.

Dowloading Cygwin

Go to ftp://go.cygnus.com/pub/sourceware.cygnus.com/pub/cygwin/latest/full.exe. This will give the most recent version of Cygwin. Also see the Cygwin web page.

What is Perl?

Short for Practical Extraction and Report Language, Perl is a programming language developed by Larry Wall, especially for processing text. Because of its strong text processing abilities, Perl has become one of the most popular languages for writing CGI scripts and other Internet applications. Perl is an interpretive language which makes it easy to build and test simple programs. However, Perl is also robust enough to allow for the creation of complex programs. Because Perl is extremely useful in "gluing" together smaller programs into larger applications, it has often been referred to as "the duct tape of the Internet."

Dowloading Perl

Running the validation

To run the validation on win95 a patch must be applied to test-all-template1 which resides in ~ns/tcl/test/. Download and run the patch.exe program included in Cygwin. A description of the syntax for "patch" is available by typing patch --help. If you prefer having it in a text file, --> --type

	patch --help > out.txt

The following patch to ~ns/tcl/test/test-all-template1 is required to get around the \r\n problem:
+++ test-all-template1.win      Fri Jul  2 14:33:25 1999
@@ -116,14 +116,16 @@
            cp $datafile.bk $datafile
            mv $datafile.Z $directory/$t.Z
        else
-           uncompress -c $directory/$t.Z | cmp -s - $datafile
+#          uncompress -c $directory/$t.Z | cmp -s - $datafile
+           gzip -dc $directory/$t.Z | perl -ne 'print $_;' | cmp -s - $datafile 
            if [ $? = 0 ]; then
                echo Test output agrees with reference output
            else
                echo Test output differs from reference output
                success="false"
                cp $datafile $directory/$t.test
-               uncompress -c $directory/$t.Z > $directory/$t
+#              uncompress -c $directory/$t.Z > $directory/$t
+               gzip -dc $directory/$t.Z > $directory/$t
                echo "Diagnose with: diff $directory/$t.test $directory/$t"
                echo "Differences due to floating-point formatting are not significant."
Some of the test suites will fail on win32 platform. As of Feburary 26, 1999 snapshot of ns, the following test suites fail:
 ./test-all-simple ./test-all-tcp ./test-all-red ./test-all-sack
 ./test-all-schedule ./test-all-red-v1 ./test-all-sack-v1 ./test-all-v1
 ./test-all-vegas-v1 ./test-all-ecn ./test-all-manual-routing
 ./test-all-intserv ./test-all-webcache ./test-all-srm
However, the above test suites failed because of floating point rounding differences on win32 and on unix, or because of incompatibilities of the unix awk program and its cygwin variation. We will test current ns snapshots and update the results here. Thanks to Christian Joensson for providing these information.
You are now ready to run the validation. Cd to <ns_dir> and type ./validate. Once again you can redirect the output to a text file by using ./validate > out.txt.


Go back to ns
ns-users@mash.cs.berkeley.edu