Because some key files have changed, V3.0 should be unzipped to a clean directory. 1. New Features in 3.0-0 1.1 SCP and Libraries - Added ASSIGN/DEASSIGN (logical name) commands. - Changed RESTORE to unconditionally detach files. - Added E11 and TPC format support to magtape library. - Fixed bug in SHOW CONNECTIONS. - Added USE_ADDR64 support 1.2 All magtapes - Magtapes support SIMH format, E11 format, and TPC format (read only). - SET <tape_unit> FORMAT=format sets the specified tape unit's format. - SHOW <tape_unit> FORMAT displays the specified tape unit's format. - Tape format can also be set as part of the ATTACH command, using the -F switch. 1.3 VAX - VAX can be compiled without USE_INT64. - If compiled with USE_INT64 and USE_ADDR64, RQ and TQ controllers support files > 2GB. - VAX ROM has speed control (SET ROM DELAY/NODELAY). 2. Bugs Fixed in 3.01-0 2.1 VAX - Fixed CVTfi bug: integer overflow not set if exponent out of range - Fixed EMODx bugs: o First and second operands reversed o Separated fraction received wrong exponent o Overflow calculation on separated integer incorrect o Fraction not set to zero if exponent out of range - Fixed interval timer and ROM access to pass power-up self-test even on very fast host processors (fixes from Mark Pizzolato). 2.2 1401 - Fixed mnemonic, instruction lengths, and reverse scan length check bug for MCS. - Fixed MCE bug, BS off by 1 if zero suppress. - Fixed chaining bug, D lost if return to SCP. - Fixed H branch, branch occurs after continue. - Added check for invalid 8 character MCW, LCA. - Fixed magtape load-mode end of record response. 2.3 Nova - Fixed DSK variable size interaction with restore. 2.4 PDP-1 - Fixed DT variable size interaction with restore. 2.5 PDP-11 - Fixed DT variable size interaction with restore. - Fixed bug in MMR1 update (found by Tim Stark). - Added XQ features and fixed bugs: o Corrected XQ interrupts on IE state transition (code by Tom Evans). o Added XQ interrupt clear on soft reset. o Removed XQ interrupt when setting XL or RL (multiple people). o Added SET/SHOW XQ STATS. o Added SHOW XQ FILTERS. o Added ability to split received packet into multiple buffers. o Added explicit runt and giant packet processing. 2.6 PDP-18B - Fixed DT, RF variable size interaction with restore. - Fixed MT bug in MTTR. 2.7 PDP-8 - Fixed DT, DF, RF, RX variable size interaction with restore. - Fixed MT bug in SKTR. 2.8 HP2100 - Fixed bug in DP (13210A controller only), DQ read status. - Fixed bug in DP, DQ seek complete. 2.9 GRI - Fixed bug in SC queue pointer management. 3. New Features in 3.0 vs prior releases N/A 4. Bugs Fixed in 3.0 vs prior releases N/A 5. General Notes WARNING: The RESTORE command has changed. RESTORE will now detach an attached file on a unit, if that unit did not have an attached file in the saved configuration. This is required to assure that the unit flags and the file state are consistent. WARNING: The compilation scheme for the PDP-10, PDP-11, and VAX has changed. Use one of the supplied build files, or read the documentation carefully, before compiling any of these simulators.
339 lines
8.9 KiB
Makefile
339 lines
8.9 KiB
Makefile
# CC Command
|
|
#
|
|
# Note: -O2 is sometimes broken in GCC when setjump/longjump is being
|
|
# used. Try -O2 only with released simulators.
|
|
#
|
|
ifeq ($(WIN32),)
|
|
#Unix Environments
|
|
CC = gcc -O2 -lm -I .
|
|
#CC = gcc -O2 -g -lm -I .
|
|
ifeq ($(USE_NETWORK),)
|
|
else
|
|
NETWORK_OPT = -DUSE_NETWORK -lpcap
|
|
endif
|
|
else
|
|
#Win32 Environments
|
|
LDFLAGS = -lm -lwsock32
|
|
CC = gcc -O0 -I.
|
|
EXE = .exe
|
|
ifeq ($(USE_NETWORK),)
|
|
else
|
|
NETWORK_OPT = -DUSE_NETWORK -lwpcap -lpacket
|
|
endif
|
|
endif
|
|
|
|
|
|
#
|
|
# Common Libraries
|
|
#
|
|
BIN = BIN/
|
|
SIM = scp.c scp_tty.c sim_sock.c sim_tmxr.c sim_ether.c sim_tape.c
|
|
|
|
|
|
|
|
#
|
|
# Emulator source files and compile time options
|
|
#
|
|
PDP1D = PDP1/
|
|
PDP1 = ${PDP1D}pdp1_lp.c ${PDP1D}pdp1_cpu.c ${PDP1D}pdp1_stddev.c \
|
|
${PDP1D}pdp1_sys.c ${PDP1D}pdp1_dt.c ${PDP1D}pdp1_drm.c
|
|
PDP1_OPT = -I ${PDP1D}
|
|
|
|
|
|
NOVAD = NOVA/
|
|
NOVA = ${NOVAD}nova_sys.c ${NOVAD}nova_cpu.c ${NOVAD}nova_dkp.c \
|
|
${NOVAD}nova_dsk.c ${NOVAD}nova_lp.c ${NOVAD}nova_mta.c \
|
|
${NOVAD}nova_plt.c ${NOVAD}nova_pt.c ${NOVAD}nova_clk.c \
|
|
${NOVAD}nova_tt.c ${NOVAD}nova_tt1.c
|
|
NOVA_OPT = -I ${NOVAD}
|
|
|
|
|
|
|
|
ECLIPSE = ${NOVAD}eclipse_cpu.c ${NOVAD}eclipse_tt.c ${NOVAD}nova_sys.c \
|
|
${NOVAD}nova_dkp.c ${NOVAD}nova_dsk.c ${NOVAD}nova_lp.c \
|
|
${NOVAD}nova_mta.c ${NOVAD}nova_plt.c ${NOVAD}nova_pt.c \
|
|
${NOVAD}nova_clk.c ${NOVAD}nova_tt1.c
|
|
ECLIPSE_OPT = -I ${NOVAD} -DECLIPSE
|
|
|
|
|
|
|
|
PDP18BD = PDP18B/
|
|
PDP18B = ${PDP18BD}pdp18b_dt.c ${PDP18BD}pdp18b_drm.c ${PDP18BD}pdp18b_cpu.c \
|
|
${PDP18BD}pdp18b_lp.c ${PDP18BD}pdp18b_mt.c ${PDP18BD}pdp18b_rf.c \
|
|
${PDP18BD}pdp18b_rp.c ${PDP18BD}pdp18b_stddev.c ${PDP18BD}pdp18b_sys.c \
|
|
${PDP18BD}pdp18b_rb.c ${PDP18BD}pdp18b_tt1.c
|
|
PDP4_OPT = -DPDP4 -I ${PDP18BD}
|
|
PDP7_OPT = -DPDP7 -I ${PDP18BD}
|
|
PDP9_OPT = -DPDP9 -I ${PDP18BD}
|
|
PDP15_OPT = -DPDP15 -I ${PDP18BD}
|
|
|
|
|
|
|
|
PDP11D = PDP11/
|
|
PDP11 = ${PDP11D}pdp11_fp.c ${PDP11D}pdp11_cpu.c ${PDP11D}pdp11_dz.c \
|
|
${PDP11D}pdp11_cis.c ${PDP11D}pdp11_lp.c ${PDP11D}pdp11_rk.c \
|
|
${PDP11D}pdp11_rl.c ${PDP11D}pdp11_rp.c ${PDP11D}pdp11_rx.c \
|
|
${PDP11D}pdp11_stddev.c ${PDP11D}pdp11_sys.c ${PDP11D}pdp11_tc.c \
|
|
${PDP11D}pdp11_tm.c ${PDP11D}pdp11_ts.c ${PDP11D}pdp11_io.c \
|
|
${PDP11D}pdp11_rq.c ${PDP11D}pdp11_tq.c ${PDP11D}pdp11_pclk.c \
|
|
${PDP11D}pdp11_ry.c ${PDP11D}pdp11_pt.c ${PDP11D}pdp11_hk.c \
|
|
${PDP11D}pdp11_xq.c ${PDP11D}pdp11_xu.c
|
|
PDP11_OPT = -DVM_PDP11 -I ${PDP11D} ${NETWORK_OPT}
|
|
|
|
|
|
|
|
VAXD = VAX/
|
|
VAX = ${VAXD}vax_cpu1.c ${VAXD}vax_cpu.c ${VAXD}vax_fpa.c ${VAXD}vax_io.c \
|
|
${VAXD}vax_mmu.c ${VAXD}vax_stddev.c ${VAXD}vax_sys.c \
|
|
${VAXD}vax_sysdev.c \
|
|
${PDP11D}pdp11_rl.c ${PDP11D}pdp11_rq.c ${PDP11D}pdp11_ts.c \
|
|
${PDP11D}pdp11_dz.c ${PDP11D}pdp11_lp.c ${PDP11D}pdp11_tq.c \
|
|
${PDP11D}pdp11_pt.c ${PDP11D}pdp11_xq.c
|
|
VAX_OPT = -DVM_VAX -DUSE_INT64 -I ${VAXD} -I ${PDP11D} ${NETWORK_OPT}
|
|
|
|
|
|
|
|
PDP10D = PDP10/
|
|
PDP10 = ${PDP10D}pdp10_fe.c ${PDP11D}pdp11_dz.c ${PDP10D}pdp10_cpu.c \
|
|
${PDP10D}pdp10_ksio.c ${PDP10D}pdp10_lp20.c ${PDP10D}pdp10_mdfp.c \
|
|
${PDP10D}pdp10_pag.c ${PDP10D}pdp10_rp.c ${PDP10D}pdp10_sys.c \
|
|
${PDP10D}pdp10_tim.c ${PDP10D}pdp10_tu.c ${PDP10D}pdp10_xtnd.c \
|
|
${PDP11D}pdp11_pt.c ${PDP11D}pdp11_ry.c ${PDP11D}pdp11_xu.c
|
|
PDP10_OPT = -DVM_PDP10 -DUSE_INT64 -I ${PDP10D} -I ${PDP11D} -I ${VAXD}
|
|
|
|
|
|
|
|
PDP8D = PDP8/
|
|
PDP8 = ${PDP8D}pdp8_cpu.c ${PDP8D}pdp8_clk.c ${PDP8D}pdp8_df.c \
|
|
${PDP8D}pdp8_dt.c ${PDP8D}pdp8_lp.c ${PDP8D}pdp8_mt.c \
|
|
${PDP8D}pdp8_pt.c ${PDP8D}pdp8_rf.c ${PDP8D}pdp8_rk.c \
|
|
${PDP8D}pdp8_rx.c ${PDP8D}pdp8_sys.c ${PDP8D}pdp8_tt.c \
|
|
${PDP8D}pdp8_ttx.c ${PDP8D}pdp8_rl.c
|
|
PDP8_OPT = -I ${PDP8D}
|
|
|
|
|
|
|
|
H316D = H316/
|
|
H316 = ${H316D}h316_stddev.c ${H316D}h316_lp.c ${H316D}h316_cpu.c \
|
|
${H316D}h316_sys.c
|
|
H316_OPT = -I ${H316D}
|
|
|
|
|
|
|
|
HP2100D = HP2100/
|
|
HP2100 = ${HP2100D}hp2100_stddev.c ${HP2100D}hp2100_dp.c ${HP2100D}hp2100_dq.c \
|
|
${HP2100D}hp2100_dr.c ${HP2100D}hp2100_lps.c ${HP2100D}hp2100_ms.c \
|
|
${HP2100D}hp2100_mt.c ${HP2100D}hp2100_mux.c ${HP2100D}hp2100_cpu.c \
|
|
${HP2100D}hp2100_fp.c ${HP2100D}hp2100_sys.c ${HP2100D}hp2100_lpt.c \
|
|
${HP2100D}hp2100_ipl.c
|
|
HP2100_OPT = -I ${HP2100D}
|
|
|
|
|
|
|
|
I1401D = I1401/
|
|
I1401 = ${I1401D}i1401_lp.c ${I1401D}i1401_cpu.c ${I1401D}i1401_iq.c \
|
|
${I1401D}i1401_cd.c ${I1401D}i1401_mt.c ${I1401D}i1401_dp.c \
|
|
${I1401D}i1401_sys.c
|
|
I1401_OPT = -I ${I1401D}
|
|
|
|
|
|
|
|
I1620D = I1620/
|
|
I1620 = ${I1620D}i1620_cd.c ${I1620D}i1620_dp.c ${I1620D}i1620_pt.c \
|
|
${I1620D}i1620_tty.c ${I1620D}i1620_cpu.c ${I1620D}i1620_lp.c \
|
|
${I1620D}i1620_fp.c ${I1620D}i1620_sys.c
|
|
I1620_OPT = -I ${I1620D}
|
|
|
|
|
|
|
|
IBM1130D = Ibm1130/
|
|
IBM1130 = ${IBM1130D}ibm1130_cpu.c ${IBM1130D}ibm1130_cr.c \
|
|
${IBM1130D}ibm1130_disk.c ${IBM1130D}ibm1130_stddev.c \
|
|
${IBM1130D}ibm1130_sys.c ${IBM1130D}ibm1130_gdu.c \
|
|
${IBM1130D}ibm1130_gui.c ${IBM1130D}ibm1130_prt.c
|
|
IBM1130_OPT = -I ${IBM1130D}
|
|
|
|
|
|
|
|
ID16D = Interdata/
|
|
ID16 = ${ID16D}id16_cpu.c ${ID16D}id16_sys.c ${ID16D}id_dp.c \
|
|
${ID16D}id_fd.c ${ID16D}id_fp.c ${ID16D}id_idc.c ${ID16D}id_io.c \
|
|
${ID16D}id_lp.c ${ID16D}id_mt.c ${ID16D}id_pas.c ${ID16D}id_pt.c \
|
|
${ID16D}id_tt.c ${ID16D}id_uvc.c ${ID16D}id16_dboot.c ${ID16D}id_ttp.c
|
|
ID16_OPT = -I ${ID16D}
|
|
|
|
|
|
|
|
ID32D = Interdata/
|
|
ID32 = ${ID32D}id32_cpu.c ${ID32D}id32_sys.c ${ID32D}id_dp.c \
|
|
${ID32D}id_fd.c ${ID32D}id_fp.c ${ID32D}id_idc.c ${ID32D}id_io.c \
|
|
${ID32D}id_lp.c ${ID32D}id_mt.c ${ID32D}id_pas.c ${ID32D}id_pt.c \
|
|
${ID32D}id_tt.c ${ID32D}id_uvc.c ${ID32D}id32_dboot.c ${ID32D}id_ttp.c
|
|
ID32_OPT = -I ${ID32D}
|
|
|
|
|
|
|
|
S3D = S3/
|
|
S3 = ${S3D}s3_cd.c ${S3D}s3_cpu.c ${S3D}s3_disk.c ${S3D}s3_lp.c \
|
|
${S3D}s3_pkb.c ${S3D}s3_sys.c
|
|
S3_OPT = -I ${S3D}
|
|
|
|
|
|
|
|
ALTAIRD = ALTAIR/
|
|
ALTAIR = ${ALTAIRD}altair_sio.c ${ALTAIRD}altair_cpu.c ${ALTAIRD}altair_dsk.c \
|
|
${ALTAIRD}altair_sys.c
|
|
ALTAIR_OPT = -I ${ALTAIRD}
|
|
|
|
|
|
|
|
ALTAIRZ80D = AltairZ80/
|
|
ALTAIRZ80 = ${ALTAIRZ80D}altairz80_cpu.c ${ALTAIRZ80D}altairz80_dsk.c \
|
|
${ALTAIRZ80D}altairz80_sio.c ${ALTAIRZ80D}altairz80_sys.c \
|
|
${ALTAIRZ80D}altairz80_hdsk.c
|
|
ALTAIRZ80_OPT = -I ${ALTAIRZ80D}
|
|
|
|
|
|
|
|
GRID = GRI/
|
|
GRI = ${GRID}gri_cpu.c ${GRID}gri_stddev.c ${GRID}gri_sys.c
|
|
GRI_OPT = -I ${GRID}
|
|
|
|
|
|
|
|
SDSD = SDS/
|
|
SDS = ${SDSD}sds_cpu.c ${SDSD}sds_drm.c ${SDSD}sds_dsk.c ${SDSD}sds_io.c \
|
|
${SDSD}sds_lp.c ${SDSD}sds_mt.c ${SDSD}sds_mux.c ${SDSD}sds_rad.c \
|
|
${SDSD}sds_stddev.c ${SDSD}sds_sys.c
|
|
SDS_OPT = -I ${SDSD}
|
|
|
|
|
|
|
|
#
|
|
# Build everything
|
|
#
|
|
ALL = ${BIN}pdp1${EXE} ${BIN}pdp4${EXE} ${BIN}pdp7${EXE} ${BIN}pdp8${EXE} \
|
|
${BIN}pdp9${EXE} ${BIN}pdp15${EXE} ${BIN}pdp11${EXE} ${BIN}pdp10${EXE} \
|
|
${BIN}vax${EXE} ${BIN}nova${EXE} ${BIN}eclipse${EXE} ${BIN}h316${EXE} \
|
|
${BIN}hp2100${EXE} ${BIN}i1401${EXE} ${BIN}i1620${EXE} ${BIN}s3${EXE} \
|
|
${BIN}altair${EXE} ${BIN}altairz80${EXE} ${BIN}gri${EXE} \
|
|
${BIN}i1620${EXE} ${BIN}ibm1130${EXE} ${BIN}id16${EXE} \
|
|
${BIN}id32${EXE} ${BIN}sds${EXE}
|
|
|
|
all : ${ALL}
|
|
|
|
clean :
|
|
ifeq ($(WIN32),)
|
|
${RM} ${ALL}
|
|
else
|
|
if exist BIN\*.exe del /q BIN\*.exe
|
|
endif
|
|
#
|
|
# Individual builds
|
|
#
|
|
${BIN}pdp1${EXE} : ${PDP1} ${SIM}
|
|
${CC} ${PDP1} ${SIM} ${PDP1_OPT} -o $@ ${LDFLAGS}
|
|
|
|
|
|
|
|
${BIN}pdp4${EXE} : ${PDP18B} ${SIM}
|
|
${CC} ${PDP18B} ${SIM} ${PDP4_OPT} -o $@ ${LDFLAGS}
|
|
|
|
|
|
|
|
${BIN}pdp7${EXE} : ${PDP18B} ${SIM}
|
|
${CC} ${PDP18B} ${SIM} ${PDP7_OPT} -o $@ ${LDFLAGS}
|
|
|
|
|
|
|
|
${BIN}pdp8${EXE} : ${PDP8} ${SIM}
|
|
${CC} ${PDP8} ${SIM} ${PDP8_OPT} -o $@ ${LDFLAGS}
|
|
|
|
|
|
|
|
${BIN}pdp9${EXE} : ${PDP18B} ${SIM}
|
|
${CC} ${PDP18B} ${SIM} ${PDP9_OPT} -o $@ ${LDFLAGS}
|
|
|
|
|
|
|
|
${BIN}pdp15${EXE} : ${PDP18B} ${SIM}
|
|
${CC} ${PDP18B} ${SIM} ${PDP15_OPT} -o $@ ${LDFLAGS}
|
|
|
|
|
|
|
|
${BIN}pdp10${EXE} : ${PDP10} ${SIM}
|
|
${CC} ${PDP10} ${SIM} ${PDP10_OPT} -o $@ ${LDFLAGS}
|
|
|
|
|
|
|
|
${BIN}pdp11${EXE} : ${PDP11} ${SIM}
|
|
${CC} ${PDP11} ${SIM} ${PDP11_OPT} -o $@ ${LDFLAGS}
|
|
|
|
|
|
|
|
${BIN}vax${EXE} : ${VAX} ${SIM}
|
|
${CC} ${VAX} ${SIM} ${VAX_OPT} -o $@ ${LDFLAGS}
|
|
|
|
|
|
|
|
${BIN}nova${EXE} : ${NOVA} ${SIM}
|
|
${CC} ${NOVA} ${SIM} ${NOVA_OPT} -o $@ ${LDFLAGS}
|
|
|
|
|
|
|
|
${BIN}eclipse${EXE} : ${ECLIPSE} ${SIM}
|
|
${CC} ${ECLIPSE} ${SIM} ${ECLIPSE_OPT} -o $@ ${LDFLAGS}
|
|
|
|
|
|
|
|
${BIN}h316${EXE} : ${H316} ${SIM}
|
|
${CC} ${H316} ${SIM} ${H316_OPT} -o $@ ${LDFLAGS}
|
|
|
|
|
|
|
|
${BIN}hp2100${EXE} : ${HP2100} ${SIM}
|
|
${CC} ${HP2100} ${SIM} ${HP2100_OPT} -o $@ ${LDFLAGS}
|
|
|
|
|
|
|
|
${BIN}i1401${EXE} : ${I1401} ${SIM}
|
|
${CC} ${I1401} ${SIM} ${I1401_OPT} -o $@ ${LDFLAGS}
|
|
|
|
|
|
|
|
${BIN}i1620${EXE} : ${I1620} ${SIM}
|
|
${CC} ${I1620} ${SIM} ${I1620_OPT} -o $@ ${LDFLAGS}
|
|
|
|
|
|
${BIN}ibm1130${EXE} : ${IBM1130}
|
|
${CC} ${IBM1130} ${SIM} ${IBM1130_OPT} -o $@ ${LDFLAGS}
|
|
|
|
|
|
${BIN}s3${EXE} : ${S3} ${SIM}
|
|
${CC} ${S3} ${SIM} ${S3_OPT} -o $@ ${LDFLAGS}
|
|
|
|
|
|
${BIN}altair${EXE} : ${ALTAIR} ${SIM}
|
|
${CC} ${ALTAIR} ${SIM} ${ALTAIR_OPT} -o $@ ${LDFLAGS}
|
|
|
|
|
|
${BIN}altairz80${EXE} : ${ALTAIRZ80} ${SIM}
|
|
${CC} ${ALTAIRZ80} ${SIM} ${ALTAIRZ80_OPT} -o $@ ${LDFLAGS}
|
|
|
|
|
|
${BIN}gri${EXE} : ${GRI} ${SIM}
|
|
${CC} ${GRI} ${SIM} ${GRI_OPT} -o $@ ${LDFLAGS}
|
|
|
|
|
|
${BIN}id16${EXE} : ${ID16} ${SIM}
|
|
${CC} ${ID16} ${SIM} ${ID16_OPT} -o $@ ${LDFLAGS}
|
|
|
|
|
|
${BIN}id32${EXE} : ${ID32} ${SIM}
|
|
${CC} ${ID32} ${SIM} ${ID32_OPT} -o $@ ${LDFLAGS}
|
|
|
|
|
|
${BIN}sds${EXE} : ${SDS} ${SIM}
|
|
${CC} ${SDS} ${SIM} ${SDS_OPT} -o $@ ${LDFLAGS}
|
|
|
|
|