simh-testsetgenerator/Visual Studio Projects/0ReadMe_Projects.txt
Mark Pizzolato 56ed67e2bf Visual Studio Projects: Provide a command line VS build procedure
Similar to the build_ming.bat procedure which will invoke MinGW to
biuild siimulators, this procedure will rebuild all of SIMH simulators using
Visual Studio.

If this procedure is not invoked from a Developer Command Prompt
then the VS2008 tools are preferred if VS2008 is installed,
otherwise the installed Visual Studio tools will be used
prefering newer Visual Studio versions over older ones.

If this procedure is invoked from a Developer Command Prompt
then the tool chain provided with the command prompt is used
to build the simh projects.

A single argument to this procedure may be the word Debug, which
will cause Debug binaries to be build rather than the Release
binaries which is the default.
2019-12-21 09:37:51 -08:00

70 lines
No EOL
3.3 KiB
Text

This dirctory contains a set of Visual Studio 2008 build projects for the
current simh code base. When used (with Visual Studio Express 2008 or
or a later Visual Studio version) it populates a directory tree under the
BIN directory of the Simh distribution for temporary build files and
produces resulting executables in the BIN/NT/Win32-Debug or
BIN/NT/Win32-Release directories (depending on whether you target a Debug
or Release build).
These projects, when used with Visual Studio 2008, will produce Release
build binaries that will run on Windows versions from XP onward. Building
with later versions of Visual Studio will have different Windows version
compatibility.
The Visual Studio Projects expect that various dependent packages that
the simh code depends on are available in a directory parallel to the
simh directory.
For Example, the directory structure should look like:
.../simh/sim-master/VAX/vax_cpu.c
.../simh/sim-master/scp.c
.../simh/sim-master/Visual Studio Projects/simh.sln
.../simh/sim-master/Visual Studio Projects/VAX.vcproj
.../simh/sim-master/BIN/Nt/Win32-Release/vax.exe
.../simh/windows-build/pthreads/pthread.h
.../simh/windows-build/winpcap/WpdPack/Include/pcap.h
.../simh/windows-build/libSDL/SDL2-2.0.3/include/SDL.h
If you have a command line version of git installed in your environment
then the windows-build repository will be downloaded and updated
automatically. If not, then the contents of the windows-build directory
can be downloaded from:
https://github.com/simh/windows-build/archive/windows-build.zip
Download and extract the contents of this zip file into the appropriate
place in your directory structure. You do not need to do anything else
but have this directory properly located.
Network devices are capable of using pthreads to enhance their performance.
To realize these benefits, you must build the desire simulator with
USE_READER_THREAD defined. The relevant simulators which have network
support are all of the VAX simulators, the PDP11 simulator and the various
PDP10 simulators.
Additionally, simulators which contain devices that use the asynchronous
APIs in sim_disk.c and sim_tape.c can also achieve greater performance by
leveraging pthreads to perform blocking I/O in separate threads. Currently
the simulators which have such devices are all of the VAX simulators and
the PDP11. To achieve these benefits the simulators must be built with
SIM_ASYNCH_IO defined.
The project files in this directory build these simulators with support for
both network and asynchronous I/O.
To build any of the supported simulators you should open the simh.sln file
in this directory.
The installer for Visual Studio 2008 SP1 is available from:
http://download.microsoft.com/download/E/8/E/E8EEB394-7F42-4963-A2D8-29559B738298/VS2008ExpressWithSP1ENUX1504728.iso
If you are using a version of Visual Studio beyond Visual Studio 2008, then
your later version of Visual Studio will automatically convert the Visual
Studio 2008 project files. You should ignore any warnings produced by the
conversion process.
If you have a version of Visual Studio installed and want to build all the
simulators from a command prompt, the file build_vstudio.bat in the root
of the simh source tree will do that without any furthur interaction.