mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-24 01:28:29 -04:00
Tools: flesh out decode-ICSR tool
This commit is contained in:
parent
6711c479de
commit
29775f310e
@ -52,22 +52,69 @@ def decoder_m4_vectactive(value):
|
|||||||
|
|
||||||
sys.stdout.write(" (%s)" % exception)
|
sys.stdout.write(" (%s)" % exception)
|
||||||
|
|
||||||
|
def decoder_m4_retobase(value):
|
||||||
|
if value:
|
||||||
|
out = "no (or no more) active exceptions"
|
||||||
|
else:
|
||||||
|
out = "preempted active exceptions"
|
||||||
|
sys.stdout.write(" (%s)" % out)
|
||||||
|
|
||||||
|
def decoder_m4_vectpending(value):
|
||||||
|
return decoder_m4_vectactive(value)
|
||||||
|
|
||||||
|
def decoder_m4_isrpending(value):
|
||||||
|
if value:
|
||||||
|
out = "Interrupt pending"
|
||||||
|
else:
|
||||||
|
out = "No pending interupt"
|
||||||
|
sys.stdout.write(" (%s)" % out)
|
||||||
|
|
||||||
|
def decoder_m4_pendstclr(value):
|
||||||
|
sys.stdout.write(" (WO clears SysTick exception)")
|
||||||
|
|
||||||
|
def decoder_m4_pendstset(value):
|
||||||
|
if value:
|
||||||
|
out = "SysTick pending"
|
||||||
|
else:
|
||||||
|
out = "SysTick not pending"
|
||||||
|
sys.stdout.write(" (%s)" % out)
|
||||||
|
|
||||||
|
def decoder_m4_pendsvclr(value):
|
||||||
|
sys.stdout.write(" (WO clears pendsv exception)")
|
||||||
|
|
||||||
|
def decoder_m4_pendsvset(value):
|
||||||
|
if value:
|
||||||
|
out = "PendSV pending"
|
||||||
|
else:
|
||||||
|
out = "PendSV not pending"
|
||||||
|
sys.stdout.write(" (%s)" % out)
|
||||||
|
|
||||||
|
def decoder_m4_nmipendset(value):
|
||||||
|
if value:
|
||||||
|
out = "NMI pending"
|
||||||
|
else:
|
||||||
|
out = "NMI not pending"
|
||||||
|
sys.stdout.write(" (%s)" % out)
|
||||||
|
|
||||||
|
# this ICSR-bit-assignment-table table also looks valid for M7 - page 195 of dm00237416-stm32f7-series-and-stm32h7-series-cortexm7-processor-programming-manual-stmicroelectronics.pdf
|
||||||
M4_BITS = [
|
M4_BITS = [
|
||||||
("0-8", "VECTACTIVE", decoder_m4_vectactive),
|
("0-8", "VECTACTIVE", decoder_m4_vectactive),
|
||||||
("9-10", "RESERVED1", None),
|
("9-10", "RESERVED1", None),
|
||||||
("11", "RETOBASE", None),
|
("11", "RETOBASE", decoder_m4_retobase),
|
||||||
("12-18", "VECTPENDING", None),
|
("12-18", "VECTPENDING", decoder_m4_vectpending),
|
||||||
("19-21", "RESERVED2", None),
|
("19-21", "RESERVED2", None),
|
||||||
("22", "ISRPENDING", None),
|
("22", "ISRPENDING", decoder_m4_isrpending),
|
||||||
("23-24", "RESERVED3", None),
|
("23-24", "RESERVED3", None),
|
||||||
("25", "PENDSTCLR", None),
|
("25", "PENDSTCLR", decoder_m4_pendstclr),
|
||||||
("27", "PENDSVCLR", None),
|
("26", "PENDSTSET", decoder_m4_pendstset),
|
||||||
("28", "PENDSVSET", None),
|
("27", "PENDSVCLR", decoder_m4_pendsvclr),
|
||||||
|
("28", "PENDSVSET", decoder_m4_pendstset),
|
||||||
("29-30", "RESERVED4", None),
|
("29-30", "RESERVED4", None),
|
||||||
("31", "NMIPENDSET", None),
|
("31", "NMIPENDSET", decoder_m4_nmipendset),
|
||||||
]
|
]
|
||||||
|
|
||||||
|
complete_mask = 0
|
||||||
|
|
||||||
for bit in M4_BITS:
|
for bit in M4_BITS:
|
||||||
(bits, name, decoder) = bit
|
(bits, name, decoder) = bit
|
||||||
if "-" in bits:
|
if "-" in bits:
|
||||||
@ -80,8 +127,12 @@ for bit in M4_BITS:
|
|||||||
mask = 0
|
mask = 0
|
||||||
for i in range(start_bit, stop_bit+1):
|
for i in range(start_bit, stop_bit+1):
|
||||||
mask |= (1 << i)
|
mask |= (1 << i)
|
||||||
|
complete_mask |= mask
|
||||||
value = (ICSR & mask) >> start_bit
|
value = (ICSR & mask) >> start_bit
|
||||||
sys.stdout.write("%s: %u" % (name, value)),
|
sys.stdout.write("%s: %u" % (name, value)),
|
||||||
if decoder is not None:
|
if decoder is not None:
|
||||||
decoder(value)
|
decoder(value)
|
||||||
print("")
|
print("")
|
||||||
|
|
||||||
|
if complete_mask != 0b11111111111111111111111111111111:
|
||||||
|
raise Exception("Mask incomplete")
|
||||||
|
Loading…
Reference in New Issue
Block a user