kernel-mode #1
@ -39,16 +39,16 @@ def name_from_insn(ins: int):
|
|||||||
if isinstance(dec, str):
|
if isinstance(dec, str):
|
||||||
return dec
|
return dec
|
||||||
|
|
||||||
fun = funct3(ins)
|
fun3 = funct3(ins)
|
||||||
if fun not in dec:
|
if fun3 not in dec:
|
||||||
print_ins(ins)
|
print_ins(ins)
|
||||||
raise RuntimeError(f"Invalid funct3: {fun:0x} in insn {ins:x}")
|
raise RuntimeError(f"Invalid funct3: {fun3:0x} in insn {ins:x}")
|
||||||
|
|
||||||
dec = dec[fun]
|
dec = dec[fun3]
|
||||||
if isinstance(dec, str):
|
if isinstance(dec, str):
|
||||||
return dec
|
return dec
|
||||||
|
|
||||||
if opcode == 0x1c and fun == 0:
|
if opcode == 0x1c and fun3 == 0:
|
||||||
# we have ecall/ebreak
|
# we have ecall/ebreak
|
||||||
token = imm110(ins)
|
token = imm110(ins)
|
||||||
if token in dec:
|
if token in dec:
|
||||||
@ -56,17 +56,13 @@ def name_from_insn(ins: int):
|
|||||||
print_ins(ins)
|
print_ins(ins)
|
||||||
raise RuntimeError(f"Invalid instruction in ebreak/ecall region: {ins:x}")
|
raise RuntimeError(f"Invalid instruction in ebreak/ecall region: {ins:x}")
|
||||||
|
|
||||||
fun = funct7(ins)
|
fun7 = funct7(ins)
|
||||||
if fun in dec:
|
if fun7 in dec:
|
||||||
if opcode == 0x0C or (opcode == 0x04 and fun == 5):
|
if opcode == 0x0C or (opcode == 0x04 and fun3 == 5):
|
||||||
mode = imm110(ins)
|
dec = dec[fun7]
|
||||||
dec = dec[fun]
|
return dec
|
||||||
if mode in dec:
|
print("unknown instruction?!")
|
||||||
return dec[mode]
|
return dec[fun7]
|
||||||
print_ins(ins)
|
|
||||||
raise RuntimeError("Unknown instruction!")
|
|
||||||
|
|
||||||
return dec[fun]
|
|
||||||
|
|
||||||
print_ins(ins)
|
print_ins(ins)
|
||||||
raise RuntimeError(f"Invalid instruction: {ins:x}")
|
raise RuntimeError(f"Invalid instruction: {ins:x}")
|
||||||
|
Loading…
Reference in New Issue
Block a user