25 lines
582 B
Tcl
25 lines
582 B
Tcl
proc iswithin { ADDRESS BASE LEN } {
|
|
return [expr ((($ADDRESS - $BASE) > 0) && (($ADDRESS - $BASE + $LEN) > 0))]
|
|
}
|
|
|
|
proc memorytype { ADDRESS } {
|
|
for { set chip 0 } { $chip < $N_CHIP } { incr chip } {
|
|
if { iswithin $ADDRESS $FLASH($chip,BASE) $FLASH($chip,LEN) } {
|
|
return "flash"
|
|
}
|
|
}
|
|
|
|
for { set chip 0 } { $chip < $N_RAM } { incr chip } {
|
|
if { iswithin $ADDRESS $RAM($chip,BASE) $RAM($chip,LEN) } {
|
|
return "ram"
|
|
}
|
|
}
|
|
}
|
|
|
|
# default to 32bit reads.
|
|
proc isreadable { ADDRESS } {
|
|
return isreadable32 $ADDRESS
|
|
}
|
|
|
|
proc isreadable32 { ADDRESS } {
|
|
|