Add system register and embedded debug register support.
Add two more as test files for user special and system register. Fix typo. 2013-12-17 Kuan-Lin Chen <kuanlinchentw@gmail.com> * gas/nds32/nds32.exp: Add system and user special register tests. * gas/nds32/sys-reg.s: New test. * gas/nds32/sys-reg.d: Likewise. * gas/nds32/usr-spe-reg.s: Likewise. * gas/nds32/usr-spe-reg.d: Likewise. * gas/nds32/alu-2.d: Delete the new blank line at EOF. * gas/nds32/br-1.d: Likewise. * gas/nds32/br-2.d: Likewise. * gas/nds32/ji-jr.d: Likewise. * gas/nds32/lsi.d: Likewise. * nds32-dis.c (sr_map): Add system register table for disassembling. (usr_map): Fix typo. * nds32-asm.c (keyword_sr): Add embedded debug registers.
This commit is contained in:
parent
64c46ce4ac
commit
6b9d3259c3
@ -1,3 +1,16 @@
|
||||
2013-12-17 Kuan-Lin Chen <kuanlinchentw@gmail.com>
|
||||
|
||||
* gas/nds32/nds32.exp: Add system and user special register tests.
|
||||
* gas/nds32/sys-reg.s: New test.
|
||||
* gas/nds32/sys-reg.d: Likewise.
|
||||
* gas/nds32/usr-spe-reg.s: Likewise.
|
||||
* gas/nds32/usr-spe-reg.d: Likewise.
|
||||
* gas/nds32/alu-2.d: Delete the new blank line at EOF.
|
||||
* gas/nds32/br-1.d: Likewise.
|
||||
* gas/nds32/br-2.d: Likewise.
|
||||
* gas/nds32/ji-jr.d: Likewise.
|
||||
* gas/nds32/lsi.d: Likewise.
|
||||
|
||||
2013-12-17 Michael Zolotukhin <michael.v.zolotukhin@gmail.com>
|
||||
|
||||
* gas/i386/disassem.s: New.
|
||||
|
@ -39,4 +39,3 @@ Disassembly of section .text:
|
||||
0+0074 <[^>]*> msubr32 \$r0, \$r1, \$r2
|
||||
0+0078 <[^>]*> mulr64 \$r0, \$r1, \$r2
|
||||
0+007c <[^>]*> mulsr64 \$r0, \$r1, \$r2
|
||||
|
||||
|
@ -12,4 +12,3 @@ Disassembly of section .text:
|
||||
0: R_NDS32_RELAX_ENTRY .text
|
||||
0+0004 <[^>]*> bne \$r0, \$r1, 00000004 <foo\+0x4>
|
||||
4: R_NDS32_15_PCREL_RELA .text
|
||||
|
||||
|
@ -22,4 +22,3 @@ Disassembly of section .text:
|
||||
14: R_NDS32_17_PCREL_RELA .text
|
||||
0+0018 <[^>]*> bltzal \$r0, 00000018 <foo\+0x18>
|
||||
18: R_NDS32_17_PCREL_RELA .text
|
||||
|
||||
|
@ -15,4 +15,3 @@ Disassembly of section .text:
|
||||
0+0006 <[^>]*> jr \$r0
|
||||
0+000a <[^>]*> jral \$lp, \$r0
|
||||
0+000e <[^>]*> ret \$lp
|
||||
|
||||
|
@ -23,4 +23,3 @@ Disassembly of section .text:
|
||||
0+0034 <[^>]*> swi.bi \$r0, \[\$r1\], #4
|
||||
0+0038 <[^>]*> shi.bi \$r0, \[\$r1\], #2
|
||||
0+003c <[^>]*> sbi.bi \$r0, \[\$r1\], #1
|
||||
|
||||
|
@ -27,4 +27,6 @@ if { [istarget nds32*] } {
|
||||
run_dump_test "to-16bit-v1"
|
||||
run_dump_test "to-16bit-v2"
|
||||
run_dump_test "to-16bit-v3"
|
||||
run_dump_test "usr-spe-reg"
|
||||
run_dump_test "sys-reg"
|
||||
}
|
||||
|
118
gas/testsuite/gas/nds32/sys-reg.d
Normal file
118
gas/testsuite/gas/nds32/sys-reg.d
Normal file
@ -0,0 +1,118 @@
|
||||
#objdump: -d --prefix-addresses
|
||||
#name: nds32 sys-reg instructions
|
||||
#as:
|
||||
|
||||
# Test system register instructions
|
||||
|
||||
.*: file format .*
|
||||
|
||||
|
||||
Disassembly of section .text:
|
||||
0+0000 <[^>]*> mfsr \$r0, \$CPU_VER
|
||||
0+0004 <[^>]*> mfsr \$r0, \$CORE_ID
|
||||
0+0008 <[^>]*> mfsr \$r0, \$ICM_CFG
|
||||
0+000c <[^>]*> mfsr \$r0, \$DCM_CFG
|
||||
0+0010 <[^>]*> mfsr \$r0, \$MMU_CFG
|
||||
0+0014 <[^>]*> mfsr \$r0, \$MSC_CFG
|
||||
0+0018 <[^>]*> mfsr \$r0, \$PSW
|
||||
0+001c <[^>]*> mfsr \$r0, \$IPSW
|
||||
0+0020 <[^>]*> mfsr \$r0, \$P_IPSW
|
||||
0+0024 <[^>]*> mfsr \$r0, \$IVB
|
||||
0+0028 <[^>]*> mfsr \$r0, \$INT_CTRL
|
||||
0+002c <[^>]*> mfsr \$r0, \$EVA
|
||||
0+0030 <[^>]*> mfsr \$r0, \$P_EVA
|
||||
0+0034 <[^>]*> mfsr \$r0, \$ITYPE
|
||||
0+0038 <[^>]*> mfsr \$r0, \$P_ITYPE
|
||||
0+003c <[^>]*> mfsr \$r0, \$MERR
|
||||
0+0040 <[^>]*> mfsr \$r0, \$IPC
|
||||
0+0044 <[^>]*> mfsr \$r0, \$P_IPC
|
||||
0+0048 <[^>]*> mfsr \$r0, \$OIPC
|
||||
0+004c <[^>]*> mfsr \$r0, \$P_P0
|
||||
0+0050 <[^>]*> mfsr \$r0, \$P_P1
|
||||
0+0054 <[^>]*> mfsr \$r0, \$INT_MASK
|
||||
0+0058 <[^>]*> mfsr \$r0, \$INT_MASK2
|
||||
0+005c <[^>]*> mfsr \$r0, \$INT_PEND
|
||||
0+0060 <[^>]*> mfsr \$r0, \$INT_PEND2
|
||||
0+0064 <[^>]*> mfsr \$r0, \$INT_TRIGGER
|
||||
0+0068 <[^>]*> mfsr \$r0, \$SP_USR
|
||||
0+006c <[^>]*> mfsr \$r0, \$SP_PRIV
|
||||
0+0070 <[^>]*> mfsr \$r0, \$INT_PRI
|
||||
0+0074 <[^>]*> mfsr \$r0, \$INT_PRI2
|
||||
0+0078 <[^>]*> mfsr \$r0, \$MMU_CTL
|
||||
0+007c <[^>]*> mfsr \$r0, \$L1_PPTB
|
||||
0+0080 <[^>]*> mfsr \$r0, \$TLB_VPN
|
||||
0+0084 <[^>]*> mfsr \$r0, \$TLB_DATA
|
||||
0+0088 <[^>]*> mfsr \$r0, \$TLB_MISC
|
||||
0+008c <[^>]*> mfsr \$r0, \$VLPT_IDX
|
||||
0+0090 <[^>]*> mfsr \$r0, \$ILMB
|
||||
0+0094 <[^>]*> mfsr \$r0, \$DLMB
|
||||
0+0098 <[^>]*> mfsr \$r0, \$CACHE_CTL
|
||||
0+009c <[^>]*> mfsr \$r0, \$HSMP_SADDR
|
||||
0+00a0 <[^>]*> mfsr \$r0, \$HSMP_EADDR
|
||||
0+00a4 <[^>]*> mfsr \$r0, \$SDZ_CTL
|
||||
0+00a8 <[^>]*> mfsr \$r0, \$MISC_CTL
|
||||
0+00ac <[^>]*> mfsr \$r0, \$BPC0
|
||||
0+00b0 <[^>]*> mfsr \$r0, \$BPC1
|
||||
0+00b4 <[^>]*> mfsr \$r0, \$BPC2
|
||||
0+00b8 <[^>]*> mfsr \$r0, \$BPC3
|
||||
0+00bc <[^>]*> mfsr \$r0, \$BPC4
|
||||
0+00c0 <[^>]*> mfsr \$r0, \$BPC5
|
||||
0+00c4 <[^>]*> mfsr \$r0, \$BPC6
|
||||
0+00c8 <[^>]*> mfsr \$r0, \$BPC7
|
||||
0+00cc <[^>]*> mfsr \$r0, \$BPA0
|
||||
0+00d0 <[^>]*> mfsr \$r0, \$BPA1
|
||||
0+00d4 <[^>]*> mfsr \$r0, \$BPA2
|
||||
0+00d8 <[^>]*> mfsr \$r0, \$BPA3
|
||||
0+00dc <[^>]*> mfsr \$r0, \$BPA4
|
||||
0+00e0 <[^>]*> mfsr \$r0, \$BPA5
|
||||
0+00e4 <[^>]*> mfsr \$r0, \$BPA6
|
||||
0+00e8 <[^>]*> mfsr \$r0, \$BPA7
|
||||
0+00ec <[^>]*> mfsr \$r0, \$BPAM0
|
||||
0+00f0 <[^>]*> mfsr \$r0, \$BPAM1
|
||||
0+00f4 <[^>]*> mfsr \$r0, \$BPAM2
|
||||
0+00f8 <[^>]*> mfsr \$r0, \$BPAM3
|
||||
0+00fc <[^>]*> mfsr \$r0, \$BPAM4
|
||||
0+0100 <[^>]*> mfsr \$r0, \$BPAM5
|
||||
0+0104 <[^>]*> mfsr \$r0, \$BPAM6
|
||||
0+0108 <[^>]*> mfsr \$r0, \$BPAM7
|
||||
0+010c <[^>]*> mfsr \$r0, \$BPV0
|
||||
0+0110 <[^>]*> mfsr \$r0, \$BPV1
|
||||
0+0114 <[^>]*> mfsr \$r0, \$BPV2
|
||||
0+0118 <[^>]*> mfsr \$r0, \$BPV3
|
||||
0+011c <[^>]*> mfsr \$r0, \$BPV4
|
||||
0+0120 <[^>]*> mfsr \$r0, \$BPV5
|
||||
0+0124 <[^>]*> mfsr \$r0, \$BPV6
|
||||
0+0128 <[^>]*> mfsr \$r0, \$BPV7
|
||||
0+012c <[^>]*> mfsr \$r0, \$BPCID0
|
||||
0+0130 <[^>]*> mfsr \$r0, \$BPCID1
|
||||
0+0134 <[^>]*> mfsr \$r0, \$BPCID2
|
||||
0+0138 <[^>]*> mfsr \$r0, \$BPCID3
|
||||
0+013c <[^>]*> mfsr \$r0, \$BPCID4
|
||||
0+0140 <[^>]*> mfsr \$r0, \$BPCID5
|
||||
0+0144 <[^>]*> mfsr \$r0, \$BPCID6
|
||||
0+0148 <[^>]*> mfsr \$r0, \$BPCID7
|
||||
0+014c <[^>]*> mfsr \$r0, \$EDM_CFG
|
||||
0+0150 <[^>]*> mfsr \$r0, \$EDMSW
|
||||
0+0154 <[^>]*> mfsr \$r0, \$EDM_CTL
|
||||
0+0158 <[^>]*> mfsr \$r0, \$EDM_DTR
|
||||
0+015c <[^>]*> mfsr \$r0, \$BPMTC
|
||||
0+0160 <[^>]*> mfsr \$r0, \$DIMBR
|
||||
0+0164 <[^>]*> mfsr \$r0, \$TECR0
|
||||
0+0168 <[^>]*> mfsr \$r0, \$TECR1
|
||||
0+016c <[^>]*> mfsr \$r0, \$PFMC0
|
||||
0+0170 <[^>]*> mfsr \$r0, \$PFMC1
|
||||
0+0174 <[^>]*> mfsr \$r0, \$PFMC2
|
||||
0+0178 <[^>]*> mfsr \$r0, \$PFM_CTL
|
||||
0+017c <[^>]*> mfsr \$r0, \$PRUSR_ACC_CTL
|
||||
0+0180 <[^>]*> mfsr \$r0, \$FUCOP_CTL
|
||||
0+0184 <[^>]*> mfsr \$r0, \$DMA_CFG
|
||||
0+0188 <[^>]*> mfsr \$r0, \$DMA_GCSW
|
||||
0+018c <[^>]*> mfsr \$r0, \$DMA_CHNSEL
|
||||
0+0190 <[^>]*> mfsr \$r0, \$DMA_ACT
|
||||
0+0194 <[^>]*> mfsr \$r0, \$DMA_SETUP
|
||||
0+0198 <[^>]*> mfsr \$r0, \$DMA_ISADDR
|
||||
0+019c <[^>]*> mfsr \$r0, \$DMA_ESADDR
|
||||
0+01a0 <[^>]*> mfsr \$r0, \$DMA_TCNT
|
||||
0+01a4 <[^>]*> mfsr \$r0, \$DMA_STATUS
|
||||
0+01a8 <[^>]*> mfsr \$r0, \$DMA_2DSET
|
||||
0+01ac <[^>]*> mfsr \$r0, \$DMA_2DSCTL
|
114
gas/testsuite/gas/nds32/sys-reg.s
Normal file
114
gas/testsuite/gas/nds32/sys-reg.s
Normal file
@ -0,0 +1,114 @@
|
||||
foo:
|
||||
mfsr $r0 ,$CPU_VER
|
||||
mfsr $r0 ,$CORE_ID
|
||||
mfsr $r0 ,$ICM_CFG
|
||||
mfsr $r0 ,$DCM_CFG
|
||||
mfsr $r0 ,$MMU_CFG
|
||||
mfsr $r0 ,$MSC_CFG
|
||||
|
||||
mfsr $r0 ,$PSW
|
||||
mfsr $r0 ,$IPSW
|
||||
mfsr $r0 ,$P_IPSW
|
||||
mfsr $r0 ,$IVB
|
||||
mfsr $r0 ,$INT_CTRL
|
||||
mfsr $r0 ,$EVA
|
||||
mfsr $r0 ,$P_EVA
|
||||
mfsr $r0 ,$ITYPE
|
||||
mfsr $r0 ,$P_ITYPE
|
||||
mfsr $r0 ,$MERR
|
||||
mfsr $r0 ,$IPC
|
||||
mfsr $r0 ,$P_IPC
|
||||
mfsr $r0 ,$OIPC
|
||||
mfsr $r0 ,$P_P0
|
||||
mfsr $r0 ,$P_P1
|
||||
mfsr $r0 ,$INT_MASK
|
||||
mfsr $r0 ,$INT_MASK2
|
||||
mfsr $r0 ,$INT_PEND
|
||||
mfsr $r0 ,$INT_PEND2
|
||||
mfsr $r0 ,$INT_TRIGGER
|
||||
mfsr $r0 ,$SP_USR
|
||||
mfsr $r0 ,$SP_PRIV
|
||||
mfsr $r0 ,$INT_PRI
|
||||
mfsr $r0 ,$INT_PRI2
|
||||
|
||||
mfsr $r0 ,$MMU_CTL
|
||||
mfsr $r0 ,$L1_PPTB
|
||||
mfsr $r0 ,$TLB_VPN
|
||||
mfsr $r0 ,$TLB_DATA
|
||||
mfsr $r0 ,$TLB_MISC
|
||||
mfsr $r0 ,$VLPT_IDX
|
||||
mfsr $r0 ,$ILMB
|
||||
mfsr $r0 ,$DLMB
|
||||
mfsr $r0 ,$CACHE_CTL
|
||||
mfsr $r0 ,$HSMP_SADDR
|
||||
mfsr $r0 ,$HSMP_EADDR
|
||||
mfsr $r0 ,$SDZ_CTL
|
||||
mfsr $r0 ,$MISC_CTL
|
||||
|
||||
mfsr $r0 ,$BPC0
|
||||
mfsr $r0 ,$BPC1
|
||||
mfsr $r0 ,$BPC2
|
||||
mfsr $r0 ,$BPC3
|
||||
mfsr $r0 ,$BPC4
|
||||
mfsr $r0 ,$BPC5
|
||||
mfsr $r0 ,$BPC6
|
||||
mfsr $r0 ,$BPC7
|
||||
mfsr $r0 ,$BPA0
|
||||
mfsr $r0 ,$BPA1
|
||||
mfsr $r0 ,$BPA2
|
||||
mfsr $r0 ,$BPA3
|
||||
mfsr $r0 ,$BPA4
|
||||
mfsr $r0 ,$BPA5
|
||||
mfsr $r0 ,$BPA6
|
||||
mfsr $r0 ,$BPA7
|
||||
mfsr $r0 ,$BPAM0
|
||||
mfsr $r0 ,$BPAM1
|
||||
mfsr $r0 ,$BPAM2
|
||||
mfsr $r0 ,$BPAM3
|
||||
mfsr $r0 ,$BPAM4
|
||||
mfsr $r0 ,$BPAM5
|
||||
mfsr $r0 ,$BPAM6
|
||||
mfsr $r0 ,$BPAM7
|
||||
mfsr $r0 ,$BPV0
|
||||
mfsr $r0 ,$BPV1
|
||||
mfsr $r0 ,$BPV2
|
||||
mfsr $r0 ,$BPV3
|
||||
mfsr $r0 ,$BPV4
|
||||
mfsr $r0 ,$BPV5
|
||||
mfsr $r0 ,$BPV6
|
||||
mfsr $r0 ,$BPV7
|
||||
mfsr $r0 ,$BPCID0
|
||||
mfsr $r0 ,$BPCID1
|
||||
mfsr $r0 ,$BPCID2
|
||||
mfsr $r0 ,$BPCID3
|
||||
mfsr $r0 ,$BPCID4
|
||||
mfsr $r0 ,$BPCID5
|
||||
mfsr $r0 ,$BPCID6
|
||||
mfsr $r0 ,$BPCID7
|
||||
mfsr $r0 ,$EDM_CFG
|
||||
mfsr $r0 ,$EDMSW
|
||||
mfsr $r0 ,$EDM_CTL
|
||||
mfsr $r0 ,$EDM_DTR
|
||||
mfsr $r0 ,$BPMTC
|
||||
mfsr $r0 ,$DIMBR
|
||||
mfsr $r0 ,$TECR0
|
||||
mfsr $r0 ,$TECR1
|
||||
|
||||
mfsr $r0 ,$PFMC0
|
||||
mfsr $r0 ,$PFMC1
|
||||
mfsr $r0 ,$PFMC2
|
||||
mfsr $r0 ,$PFM_CTL
|
||||
mfsr $r0 ,$PRUSR_ACC_CTL
|
||||
mfsr $r0 ,$FUCOP_CTL
|
||||
|
||||
mfsr $r0 ,$DMA_CFG
|
||||
mfsr $r0 ,$DMA_GCSW
|
||||
mfsr $r0 ,$DMA_CHNSEL
|
||||
mfsr $r0 ,$DMA_ACT
|
||||
mfsr $r0 ,$DMA_SETUP
|
||||
mfsr $r0 ,$DMA_ISADDR
|
||||
mfsr $r0 ,$DMA_ESADDR
|
||||
mfsr $r0 ,$DMA_TCNT
|
||||
mfsr $r0 ,$DMA_STATUS
|
||||
mfsr $r0 ,$DMA_2DSET
|
||||
mfsr $r0 ,$DMA_2DSCTL
|
29
gas/testsuite/gas/nds32/usr-spe-reg.d
Normal file
29
gas/testsuite/gas/nds32/usr-spe-reg.d
Normal file
@ -0,0 +1,29 @@
|
||||
#objdump: -d --prefix-addresses
|
||||
#name: nds32 usr-spe-reg instructions
|
||||
#as:
|
||||
|
||||
# Test user specail register instructions
|
||||
|
||||
.*: file format .*
|
||||
|
||||
Disassembly of section .text:
|
||||
0+0000 <[^>]*> mfusr \$r0, \$d0.lo
|
||||
0+0004 <[^>]*> mfusr \$r0, \$d0.hi
|
||||
0+0008 <[^>]*> mfusr \$r0, \$d1.lo
|
||||
0+000c <[^>]*> mfusr \$r0, \$d1.hi
|
||||
0+0010 <[^>]*> mfusr \$r0, \$pc
|
||||
0+0014 <[^>]*> mfusr \$r0, \$DMA_CFG
|
||||
0+0018 <[^>]*> mfusr \$r0, \$DMA_GCSW
|
||||
0+001c <[^>]*> mfusr \$r0, \$DMA_CHNSEL
|
||||
0+0020 <[^>]*> mfusr \$r0, \$DMA_ACT
|
||||
0+0024 <[^>]*> mfusr \$r0, \$DMA_SETUP
|
||||
0+0028 <[^>]*> mfusr \$r0, \$DMA_ISADDR
|
||||
0+002c <[^>]*> mfusr \$r0, \$DMA_ESADDR
|
||||
0+0030 <[^>]*> mfusr \$r0, \$DMA_TCNT
|
||||
0+0034 <[^>]*> mfusr \$r0, \$DMA_STATUS
|
||||
0+0038 <[^>]*> mfusr \$r0, \$DMA_2DSET
|
||||
0+003c <[^>]*> mfusr \$r0, \$DMA_2DSCTL
|
||||
0+0040 <[^>]*> mfusr \$r0, \$PFMC0
|
||||
0+0044 <[^>]*> mfusr \$r0, \$PFMC1
|
||||
0+0048 <[^>]*> mfusr \$r0, \$PFMC2
|
||||
0+004c <[^>]*> mfusr \$r0, \$PFM_CTL
|
21
gas/testsuite/gas/nds32/usr-spe-reg.s
Normal file
21
gas/testsuite/gas/nds32/usr-spe-reg.s
Normal file
@ -0,0 +1,21 @@
|
||||
foo:
|
||||
mfusr $r0, d0.lo
|
||||
mfusr $r0, d0.hi
|
||||
mfusr $r0, d1.lo
|
||||
mfusr $r0, d1.hi
|
||||
mfusr $r0, $pc
|
||||
mfusr $r0, $DMA_CFG
|
||||
mfusr $r0, $DMA_GCSW
|
||||
mfusr $r0, $DMA_CHNSEL
|
||||
mfusr $r0, $DMA_ACT
|
||||
mfusr $r0, $DMA_SETUP
|
||||
mfusr $r0, $DMA_ISADDR
|
||||
mfusr $r0, $DMA_ESADDR
|
||||
mfusr $r0, $DMA_TCNT
|
||||
mfusr $r0, $DMA_STATUS
|
||||
mfusr $r0, $DMA_2DSET
|
||||
mfusr $r0, $DMA_2DSCTL
|
||||
mfusr $r0, $PFMC0
|
||||
mfusr $r0, $PFMC1
|
||||
mfusr $r0, $PFMC2
|
||||
mfusr $r0, $PFM_CTL
|
@ -1,3 +1,9 @@
|
||||
2013-12-17 Kuan-Lin Chen <kuanlinchentw@gmail.com>
|
||||
|
||||
* nds32-dis.c (sr_map): Add system register table for disassembling.
|
||||
(usr_map): Fix typo.
|
||||
* nds32-asm.c (keyword_sr): Add embedded debug registers.
|
||||
|
||||
2013-12-17 Michael Zolotukhin <michael.v.zolotukhin@gmail.com>
|
||||
|
||||
* i386-dis.c (MOD_FF_REG_3): New.
|
||||
|
@ -858,6 +858,54 @@ static const keyword_t keyword_sr[] =
|
||||
{"prusr_acc_ctl", SRIDX (4, 4, 0), 0},
|
||||
{"fucpr", SRIDX (4, 5, 0), 0}, {"fucop_ctl", SRIDX (4, 5, 0), 0},
|
||||
|
||||
{"dr0", SRIDX (3, 0, 0), 0}, {"bpc0", SRIDX (3, 0, 0), 0},
|
||||
{"dr1", SRIDX (3, 0, 1), 0}, {"bpc1", SRIDX (3, 0, 1), 0},
|
||||
{"dr2", SRIDX (3, 0, 2), 0}, {"bpc2", SRIDX (3, 0, 2), 0},
|
||||
{"dr3", SRIDX (3, 0, 3), 0}, {"bpc3", SRIDX (3, 0, 3), 0},
|
||||
{"dr4", SRIDX (3, 0, 4), 0}, {"bpc4", SRIDX (3, 0, 4), 0},
|
||||
{"dr5", SRIDX (3, 0, 5), 0}, {"bpc5", SRIDX (3, 0, 5), 0},
|
||||
{"dr6", SRIDX (3, 0, 6), 0}, {"bpc6", SRIDX (3, 0, 6), 0},
|
||||
{"dr7", SRIDX (3, 0, 7), 0}, {"bpc7", SRIDX (3, 0, 7), 0},
|
||||
{"dr8", SRIDX (3, 1, 0), 0}, {"bpa0", SRIDX (3, 1, 0), 0},
|
||||
{"dr9", SRIDX (3, 1, 1), 0}, {"bpa1", SRIDX (3, 1, 1), 0},
|
||||
{"dr10", SRIDX (3, 1, 2), 0}, {"bpa2", SRIDX (3, 1, 2), 0},
|
||||
{"dr11", SRIDX (3, 1, 3), 0}, {"bpa3", SRIDX (3, 1, 3), 0},
|
||||
{"dr12", SRIDX (3, 1, 4), 0}, {"bpa4", SRIDX (3, 1, 4), 0},
|
||||
{"dr13", SRIDX (3, 1, 5), 0}, {"bpa5", SRIDX (3, 1, 5), 0},
|
||||
{"dr14", SRIDX (3, 1, 6), 0}, {"bpa6", SRIDX (3, 1, 6), 0},
|
||||
{"dr15", SRIDX (3, 1, 7), 0}, {"bpa7", SRIDX (3, 1, 7), 0},
|
||||
{"dr16", SRIDX (3, 2, 0), 0}, {"bpam0", SRIDX (3, 2, 0), 0},
|
||||
{"dr17", SRIDX (3, 2, 1), 0}, {"bpam1", SRIDX (3, 2, 1), 0},
|
||||
{"dr18", SRIDX (3, 2, 2), 0}, {"bpam2", SRIDX (3, 2, 2), 0},
|
||||
{"dr19", SRIDX (3, 2, 3), 0}, {"bpam3", SRIDX (3, 2, 3), 0},
|
||||
{"dr20", SRIDX (3, 2, 4), 0}, {"bpam4", SRIDX (3, 2, 4), 0},
|
||||
{"dr21", SRIDX (3, 2, 5), 0}, {"bpam5", SRIDX (3, 2, 5), 0},
|
||||
{"dr22", SRIDX (3, 2, 6), 0}, {"bpam6", SRIDX (3, 2, 6), 0},
|
||||
{"dr23", SRIDX (3, 2, 7), 0}, {"bpam7", SRIDX (3, 2, 7), 0},
|
||||
{"dr24", SRIDX (3, 3, 0), 0}, {"bpv0", SRIDX (3, 3, 0), 0},
|
||||
{"dr25", SRIDX (3, 3, 1), 0}, {"bpv1", SRIDX (3, 3, 1), 0},
|
||||
{"dr26", SRIDX (3, 3, 2), 0}, {"bpv2", SRIDX (3, 3, 2), 0},
|
||||
{"dr27", SRIDX (3, 3, 3), 0}, {"bpv3", SRIDX (3, 3, 3), 0},
|
||||
{"dr28", SRIDX (3, 3, 4), 0}, {"bpv4", SRIDX (3, 3, 4), 0},
|
||||
{"dr29", SRIDX (3, 3, 5), 0}, {"bpv5", SRIDX (3, 3, 5), 0},
|
||||
{"dr30", SRIDX (3, 3, 6), 0}, {"bpv6", SRIDX (3, 3, 6), 0},
|
||||
{"dr31", SRIDX (3, 3, 7), 0}, {"bpv7", SRIDX (3, 3, 7), 0},
|
||||
{"dr32", SRIDX (3, 4, 0), 0}, {"bpcid0", SRIDX (3, 4, 0), 0},
|
||||
{"dr33", SRIDX (3, 4, 1), 0}, {"bpcid1", SRIDX (3, 4, 1), 0},
|
||||
{"dr34", SRIDX (3, 4, 2), 0}, {"bpcid2", SRIDX (3, 4, 2), 0},
|
||||
{"dr35", SRIDX (3, 4, 3), 0}, {"bpcid3", SRIDX (3, 4, 3), 0},
|
||||
{"dr36", SRIDX (3, 4, 4), 0}, {"bpcid4", SRIDX (3, 4, 4), 0},
|
||||
{"dr37", SRIDX (3, 4, 5), 0}, {"bpcid5", SRIDX (3, 4, 5), 0},
|
||||
{"dr38", SRIDX (3, 4, 6), 0}, {"bpcid6", SRIDX (3, 4, 6), 0},
|
||||
{"dr39", SRIDX (3, 4, 7), 0}, {"bpcid7", SRIDX (3, 4, 7), 0},
|
||||
{"dr40", SRIDX (3, 5, 0), 0}, {"edm_cfg", SRIDX (3, 5, 0), 0},
|
||||
{"dr41", SRIDX (3, 6, 0), 0}, {"edmsw", SRIDX (3, 6, 0), 0},
|
||||
{"dr42", SRIDX (3, 7, 0), 0}, {"edm_ctl", SRIDX (3, 7, 0), 0},
|
||||
{"dr43", SRIDX (3, 8, 0), 0}, {"edm_dtr", SRIDX (3, 8, 0), 0},
|
||||
{"dr44", SRIDX (3, 9, 0), 0}, {"bpmtc", SRIDX (3, 9, 0), 0},
|
||||
{"dr45", SRIDX (3, 10, 0), 0}, {"dimbr", SRIDX (3, 10, 0), 0},
|
||||
{"dr46", SRIDX (3, 14, 0), 0}, {"tecr0", SRIDX (3, 14, 0), 0},
|
||||
{"dr47", SRIDX (3, 14, 1), 0}, {"tecr1", SRIDX (3, 14, 1), 0},
|
||||
{NULL,0 ,0}
|
||||
};
|
||||
|
||||
|
@ -167,6 +167,9 @@ static const char *mnemonic_fd2_cmp[] =
|
||||
"fcmpled", "fcmpled.e", "fcmpund", "fcmpund.e"
|
||||
};
|
||||
|
||||
/* Register name table. */
|
||||
/* General purpose register. */
|
||||
|
||||
static const char *gpr_map[] =
|
||||
{
|
||||
"$r0", "$r1", "$r2", "$r3", "$r4", "$r5", "$r6", "$r7",
|
||||
@ -175,10 +178,12 @@ static const char *gpr_map[] =
|
||||
"$r24", "$r25", "$r26", "$r27", "$fp", "$gp", "$lp", "$sp"
|
||||
};
|
||||
|
||||
/* User special register. */
|
||||
|
||||
static const char *usr_map[][32] =
|
||||
{
|
||||
{
|
||||
"d0,lo", "d0.hi", "d1,lo", "d1,hi", "4", "5", "6", "7",
|
||||
"d0.lo", "d0.hi", "d1.lo", "d1.hi", "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", "pc"
|
||||
@ -187,12 +192,94 @@ static const char *usr_map[][32] =
|
||||
"DMA_CFG", "DMA_GCSW", "DMA_CHNSEL", "DMA_ACT", "DMA_SETUP",
|
||||
"DMA_ISADDR", "DMA_ESADDR", "DMA_TCNT", "DMA_STATUS", "DMA_2DSET",
|
||||
"10", "11", "12", "13", "14",
|
||||
"15", "16,", "17", "18", "19",
|
||||
"20", "21", "22", "23", "24,",
|
||||
"15", "16", "17", "18", "19",
|
||||
"20", "21", "22", "23", "24",
|
||||
"DMA_2DSCTL"
|
||||
},
|
||||
{
|
||||
"PFMC0", "PFMC1", "PFMC2", "3", "PFMCTL"
|
||||
"PFMC0", "PFMC1", "PFMC2", "3", "PFM_CTL"
|
||||
}
|
||||
};
|
||||
|
||||
/* System register. */
|
||||
/* Major Minor Extension. */
|
||||
static const char *sr_map[8][16][8] =
|
||||
{
|
||||
{
|
||||
{"CPU_VER", "CORE_ID"},
|
||||
{"ICM_CFG"},
|
||||
{"DCM_CFG"},
|
||||
{"MMU_CFG"},
|
||||
{"MSC_CFG"}
|
||||
},
|
||||
{
|
||||
{"PSW", "IPSW", "P_IPSW"},
|
||||
{"0", "IVB", "INT_CTRL"},
|
||||
{"0", "EVA", "P_EVA"},
|
||||
{"0", "ITYPE", "P_ITYPE"},
|
||||
{"0", "MERR"},
|
||||
{"0", "IPC", "P_IPC", "OIPC"},
|
||||
{"0", "1", "P_P0"},
|
||||
{"0", "1", "P_P1"},
|
||||
{"INT_MASK", "INT_MASK2"},
|
||||
{"INT_PEND", "INT_PEND2", "2", "3", "INT_TRIGGER"},
|
||||
{"SP_USR", "SP_PRIV"},
|
||||
{"INT_PRI", "INT_PRI2"}
|
||||
},
|
||||
{
|
||||
{"MMU_CTL"},
|
||||
{"L1_PPTB"},
|
||||
{"TLB_VPN"},
|
||||
{"TLB_DATA"},
|
||||
{"TLB_MISC"},
|
||||
{"VLPT_IDX"},
|
||||
{"ILMB"},
|
||||
{"DLMB"},
|
||||
{"CACHE_CTL"},
|
||||
{"HSMP_SADDR", "HSMP_EADDR"},
|
||||
{"0"},
|
||||
{"0"},
|
||||
{"0"},
|
||||
{"0"},
|
||||
{"0"},
|
||||
{"SDZ_CTL", "MISC_CTL"}
|
||||
},
|
||||
{
|
||||
{"BPC0", "BPC1", "BPC2", "BPC3", "BPC4", "BPC5", "BPC6", "BPC7"},
|
||||
{"BPA0", "BPA1", "BPA2", "BPA3", "BPA4", "BPA5", "BPA6", "BPA7"},
|
||||
{"BPAM0", "BPAM1", "BPAM2", "BPAM3", "BPAM4", "BPAM5", "BPAM6", "BPAM7"},
|
||||
{"BPV0", "BPV1", "BPV2", "BPV3", "BPV4", "BPV5", "BPV6", "BPV7"},
|
||||
{"BPCID0", "BPCID1", "BPCID2", "BPCID3", "BPCID4", "BPCID5", "BPCID6", "BPCID7"},
|
||||
{"EDM_CFG"},
|
||||
{"EDMSW"},
|
||||
{"EDM_CTL"},
|
||||
{"EDM_DTR"},
|
||||
{"BPMTC"},
|
||||
{"DIMBR"},
|
||||
{"EDM_PROBE"},
|
||||
{"0"},
|
||||
{"0"},
|
||||
{"TECR0", "TECR1"}
|
||||
},
|
||||
{
|
||||
{"PFMC0", "PFMC1", "PFMC2"},
|
||||
{"PFM_CTL"},
|
||||
{"0"},
|
||||
{"0"},
|
||||
{"PRUSR_ACC_CTL"},
|
||||
{"FUCOP_CTL"}
|
||||
},
|
||||
{
|
||||
{"DMA_CFG"},
|
||||
{"DMA_GCSW"},
|
||||
{"DMA_CHNSEL"},
|
||||
{"DMA_ACT"},
|
||||
{"DMA_SETUP"},
|
||||
{"DMA_ISADDR"},
|
||||
{"DMA_ESADDR"},
|
||||
{"DMA_TCNT"},
|
||||
{"DMA_STATUS"},
|
||||
{"DMA_2DSET", "DMA_2DSCTL"}
|
||||
}
|
||||
};
|
||||
|
||||
@ -763,8 +850,8 @@ print_insn32_misc (bfd_vma pc ATTRIBUTE_UNUSED, disassemble_info *info,
|
||||
case 0x2: /* mfsr */
|
||||
case 0x3: /* mtsr */
|
||||
/* FIXME: setend, setgie. */
|
||||
id = __GF (insn, 10, 10);
|
||||
func (stream, "%s\t%s, %d", mnemonic_misc[op], gpr_map[rt], id);
|
||||
func (stream, "%s\t%s, $%s", mnemonic_misc[op], gpr_map[rt],
|
||||
sr_map[__GF(insn, 17, 3)][__GF(insn, 13, 4)][__GF(insn, 10, 3)]);
|
||||
return;
|
||||
case 0x6: /* teqz */
|
||||
case 0x7: /* tnez */
|
||||
|
Loading…
x
Reference in New Issue
Block a user