This file is indexed.

/usr/share/openmsx/scripts/_cpuregs.tcl is in openmsx-data 0.10.1-2.

This file is owned by root:root, with mode 0o644.

The actual contents of the file can be viewed below.

  1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
namespace eval cpuregs {

# reg command

set_help_text reg \
{Convenience procs to read or write Z80 registers.
Usage is similar to the builtin Tcl proc 'set'

 usage:
   reg <reg>            read from a Z80 register
   reg <reg> <value>    write to a Z80 register

     <reg> must be one of
        A   F   B   C   D   E   H   L
        A2  F2  B2  C2  D2  E3  H2  L2
        IXl IXh IYl IYh PCh PCl SPh SPl
        I   R   IM  IFF
        AF  BC  DE  HL
        AF2 BC2 DE2 HL2
        IX  IY  PC  SP

 examples:
   reg E           read register E
   reg HL          read register HL
   reg C 7         write 7 to register C
   reg AF 0x1234   write 0x12 to register A and 0x34 to F
}

variable regB [dict create \
	A    0    F    1    B    2    C    3 \
	D    4    E    5    H    6    L    7 \
	A2   8    F2   9    B2  10    C2  11 \
	D2  12    E2  13    H2  14    L2  15 \
	IXH 16    IXL 17    IYH 18    IYL 19 \
	PCH 20    PCL 21    SPH 22    SPL 23 \
	I   24    R   25    IM  26    IFF 27 ]

variable regW [dict create \
	AF   0    BC   2    DE   4    HL   6 \
	AF2  8    BC2 10    DE2 12    HL2 14 \
	IX  16    IY  18    PC  20    SP  22 ]

set_tabcompletion_proc reg [namespace code tab_reg] false

proc tab_reg {args} {
	variable regB
	variable regW
	concat [dict keys $regB] [dict keys $regW]
}

proc reg {name {val ""}} {
	variable regB
	variable regW

	set name [string toupper $name]
	if {[dict exists $regB $name]} {
		set i [dict get $regB $name]
		set single 1
	} elseif {[dict exists $regW $name]} {
		set i [dict get $regW $name]
		set single 0
	} else {
		error "Unknown Z80 register: $name"
	}
	set d "CPU regs"
	if {$val eq ""} {
		if {$single} {
			return [debug read $d $i]
		} else {
			return [expr {256 * [debug read $d $i] + [debug read $d [expr {$i + 1}]]}]
		}
	} else {
		if {$single} {
			debug write $d $i $val
		} else {
			debug write $d $i [expr {$val / 256}]
			debug write $d [expr {$i + 1}] [expr {$val & 255}]
		}
	}
}


# cpuregs command

set_help_text cpuregs "Gives an overview of all Z80 registers."

proc cw {reg} {format "%04X" [reg $reg]}
proc cb {reg} {format "%02X" [reg $reg]}

proc cpuregs {} {
	set result ""
	append result "AF =[cw AF ]  BC =[cw BC ]  DE =[cw DE ]  HL =[cw HL ]\n"
	append result "AF'=[cw AF2]  BC'=[cw BC2]  DE'=[cw DE2]  HL'=[cw HL2]\n"
	append result "IX =[cw IX ]  IY =[cw IY ]  PC =[cw PC ]  SP =[cw SP ]\n"
	append result "I  =[cb I  ]    R  =[cb R]    IM =[cb IM]    IFF=[cb IFF]"
	return $result
}


# get_active_cpu

set_help_text get_active_cpu "Returns the name of the active CPU ('z80' or 'r800')."

proc get_active_cpu {} {
	set result "z80"
	catch {
		# On non-turbor machines this debuggable doesn't exist
		if {([debug read "S1990 regs" 6] & 0x20) == 0} {
			set result "r800"
		}
	}
	return $result
}


namespace export reg
namespace export cpuregs
namespace export get_active_cpu

} ;# namespace cpuregs

namespace import cpuregs::*