1
0
mirror of https://github.com/wfjm/w11.git synced 2026-01-13 15:37:43 +00:00
wfjm.w11/tools/xxdp/ekbee1_patch_w11a.tcl
wfjm ef5c6b1ee3 pdp11_sequencer: implement MMR0,MMR2 instruction complete
- rtl/w11a
  - pdp11.vhd: dm_stat_se_type: rename vfetch -> vstart;
               mmu_moni_type: drop pc,idone, add vstart,vflow
               pdp11_mmu_mmr12: add VADDR port
  - pdp11_dmcmon.vhd: dm_stat_se_type: rename vfetch -> vstart
  - pdp11_mmu.vhd: implement MMR0 instruction complete
  - pdp11_mmu_mmr12.vhd: implement MMR2 instruction complete
  - pdp11_sequencer.vhd: implement MMR0,MMR2 instruction complete
  - pdp11_sys70.vhd: dm_stat_se_type: rename vfetch -> vstart
- tools
  - tbench/w11a_pcnt/test_pcnt_basics.tcl: rename vfetch -> vstart
  - tbench/w11a_pcnt/test_pcnt_codes.tcl: rename vfetch -> vstart
  - tcl/rw11/dmcmon.tcl: rename vfetch -> vstart
  - tcl/rw11/dmpcnt.tcl: rename vfetch -> vstart
  - tcode/cpu_mmu.mac: rename C2.7 -> C2.10, add C2.7-9
  - xxdp/ekbee1_patch_w11a.tcl: now patch for MMR1, not longer skip
2022-12-16 19:18:50 +01:00

102 lines
4.0 KiB
Tcl

# $Id: ekbee1_patch_w11a.tcl 1330 2022-12-16 17:52:40Z mueller $
# SPDX-License-Identifier: GPL-3.0-or-later
# Copyright 2022- by Walter F.J. Mueller <W.F.J.Mueller@gsi.de>
#
# Patch set ekbee1 for w11a -- w11a -- w11a -- w11a -- w11a -- w11a
#
# Note: Tcl has default radix 10 --> all octal numbers must start with '0' !!
#
# AP: skip test 046: 18-bit mapping adder ------------------------------------
# uses maintenance bit, unsupported in SimH
# Note: all par/pdr setup's done, only tests skiped
# the next tests seem to depend on the par/pdr settings
#
dep 047720 000412
dep 050006 000412
dep 050074 000412
dep 050162 000412
dep 050250 000412
dep 050336 000412
dep 050424 000412
dep 050512 000412
dep 050600 000412
dep 050666 000412
dep 050754 000412
dep 051042 000412
#
# AP: patch test 50: 22-bit mapping carry propagation ------------------------
# The test does an access to 17000000, the first word of the UNIBUS
# window. It expects CPUERR 020 because UBMAP is disabled in MMR3.
# w11 doesn't simulate the UNIBUS window and has a memory hole instead.
# So access aborts with NXM instead of timeout.
# Patch the testing instruction to it expects NXM in CPUERR.
;
dep 052212 000040
#
# AP: patch test 55: ACF = 1 -------------------------------------------------
# AP: patch test 56: ACF = 4 -------------------------------------------------
# AP: patch test 57: ACF = 5 -------------------------------------------------
# Tests 055, 056, and 057 verify trap response and check mmr0(6:1) which
# isn't frozen for traps. The instruction is 'mov mmr0,pmmr0' with the
# scr page 7 (IO page) and dst page 1 (where variables are). The test
# expects for mmr0 011003, the destination page. On w11 one gets 011017,
# the source page. Simply different flows. Certainly not an error.
# Patch the locations to avoid the diagnostic message.
#
dep 054152 011017
dep 054302 011017
dep 054366 011017
dep 054564 011017
#
# AP: skip test 061: no MMU trap when MMU reg accessed -----------------------
# Test verifies that no MMU traps are issued when MMU regs are accessed.
# This is not implemented in w11, thus test skipped.
#
dep 054764 000137
dep 054766 055204
#
# AP: skip test 063: proper timing of MMU traps ------------------------------
# Test tests also the trap behavior when MMU registers are accessed
# This suppression is not implemented in w11, thus test skipped.
#
dep 055404 000137
dep 055406 055554
#
# AP: skip test 067: verify MMR0(7) ------------------------------------------
# w11 implements MMR0(7) instruction complete but has a different MMR1
# response. The 11/70 decrements SP twice before the 1st push, MMR1 has
# therefore 173366 after a 1st push abort. The w11 decrements SP before
# each push, MMR1 has therefore 000366 1st push abort. Test is patched.
#
dep 057010 000366
#
# AP: patch test 122: KT BEND ------------------------------------------------
# Tests MMU vs NXM,ODD,RED behavior
# The 1st part tests NXM vs MMU. On a KB11-C handles NXM earlier then MMU (!)
# On a KB11-E MMU takes precedence (as one expects and SimH, e11, and w11 do).
# It is tempting to patch the code such that KB11-E behavior is tested. But
# that code path is buggy, doesn't clear MMR0, and causes a followup error in
# the following test (at 076414) because MMR0 isn't cleared. Therefore, the
# patch just inhibits the error print, and MMR0 is cleared afterwards.
#
dep 076300 000240
#
# The 2nd part tests RED vs MMU. On a 11/70 the MMR0 abort bits are not set
# in case of a stack in a non-resident page with an address below STKLIM.
# w11 does set the MMR0 abort bit, and take a fatal stack error.
# Patch test to ignore that (beq 10$ -> br 10$) MMR0 abort bit is set.
# MMR0 is re-written at 76444 in the following test.
#
dep 076376 000407
#
# HACKS and DEBUG
#
# HP: skip test 071: MMR2 pattern test ---------------------------------------
# this test tries all PC's in user mode --> skip to ease setting breakpoints
# and skip in GHDL simulation, it's just a waste of time
#
if {[rlink::issim]} {
dep 057532 000137
dep 057534 057766
}