Commit fa6a1ecd authored by Yao Zhang's avatar Yao Zhang Committed by Minux Ma

cmd/internal/obj/mips: added support for GOARCH=mips64{,le}

MIPS64 has 32 general purpose 64-bit integer registers (R0-R31), 32
64-bit floating point registers (F0-F31). Instructions are fixed-width,
and are 32-bit wide. Instructions are all in standard 1-, 2-, 3-operand
forms.

MIPS64-specific relocations are added. For this reason, test data of
cmd/newlink are regenerated.

No other changes are made to portable structures.

Branch delay slots are current filled with NOP instructions. The function
for instruction scheduling (try to fill the delay slot with a useful
instruction) is implemented but disabled for now.

Change-Id: Ic364999c7a33245260c1381fc26a2fa8972d38b3
Reviewed-on: https://go-review.googlesource.com/14442Reviewed-by: default avatarMinux Ma <minux@golang.org>
parent a9bebd91
...@@ -411,12 +411,18 @@ const ( ...@@ -411,12 +411,18 @@ const (
// low 16 bits into that of the second instruction. // low 16 bits into that of the second instruction.
R_ADDRPOWER R_ADDRPOWER
R_ADDRARM64 R_ADDRARM64
// R_ADDRMIPS (only used on mips64) resolves to a 32-bit external address,
// by loading the address into a register with two instructions (lui, ori).
R_ADDRMIPS
R_SIZE R_SIZE
R_CALL R_CALL
R_CALLARM R_CALLARM
R_CALLARM64 R_CALLARM64
R_CALLIND R_CALLIND
R_CALLPOWER R_CALLPOWER
// R_CALLMIPS (only used on mips64) resolves to non-PC-relative target address
// of a CALL (JAL) instruction, by encoding the address into the instruction.
R_CALLMIPS
R_CONST R_CONST
R_PCREL R_PCREL
// R_TLS_LE, used on 386, amd64, and ARM, resolves to the offset of the // R_TLS_LE, used on 386, amd64, and ARM, resolves to the offset of the
...@@ -437,6 +443,10 @@ const ( ...@@ -437,6 +443,10 @@ const (
R_USEFIELD R_USEFIELD
R_POWER_TOC R_POWER_TOC
R_GOTPCREL R_GOTPCREL
// R_JMPMIPS (only used on mips64) resolves to non-PC-relative target address
// of a JMP instruction, by encoding the address into the instruction.
// The stack nosplit check ignores this since it is not a function call.
R_JMPMIPS
// Platform dependent relocations. Architectures with fixed width instructions // Platform dependent relocations. Architectures with fixed width instructions
// have the inherent issue that a 32-bit (or 64-bit!) displacement cannot be // have the inherent issue that a 32-bit (or 64-bit!) displacement cannot be
......
...@@ -27,14 +27,14 @@ ...@@ -27,14 +27,14 @@
// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
// THE SOFTWARE. // THE SOFTWARE.
package ppc64 package mips
import "cmd/internal/obj" import "cmd/internal/obj"
//go:generate go run ../stringer.go -i $GOFILE -o anames.go -p ppc64 //go:generate go run ../stringer.go -i $GOFILE -o anames.go -p mips
/* /*
* powerpc 64 * mips 64
*/ */
const ( const (
NSNAME = 8 NSNAME = 8
...@@ -44,7 +44,7 @@ const ( ...@@ -44,7 +44,7 @@ const (
) )
const ( const (
REG_R0 = obj.RBasePPC64 + iota REG_R0 = obj.RBaseMIPS64 + iota
REG_R1 REG_R1
REG_R2 REG_R2
REG_R3 REG_R3
...@@ -110,90 +110,128 @@ const ( ...@@ -110,90 +110,128 @@ const (
REG_F30 REG_F30
REG_F31 REG_F31
REG_CR0 REG_HI
REG_CR1 REG_LO
REG_CR2
REG_CR3
REG_CR4
REG_CR5
REG_CR6
REG_CR7
REG_MSR // co-processor 0 control registers
REG_FPSCR REG_M0 = obj.RBaseMIPS64 + 1024 + iota
REG_CR REG_M1
REG_M2
REG_M3
REG_M4
REG_M5
REG_M6
REG_M7
REG_M8
REG_M9
REG_M10
REG_M11
REG_M12
REG_M13
REG_M14
REG_M15
REG_M16
REG_M17
REG_M18
REG_M19
REG_M20
REG_M21
REG_M22
REG_M23
REG_M24
REG_M25
REG_M26
REG_M27
REG_M28
REG_M29
REG_M30
REG_M31
REG_SPECIAL = REG_CR0 // FPU control registers
REG_FCR0 = obj.RBaseMIPS64 + 2048 + iota
REG_FCR1
REG_FCR2
REG_FCR3
REG_FCR4
REG_FCR5
REG_FCR6
REG_FCR7
REG_FCR8
REG_FCR9
REG_FCR10
REG_FCR11
REG_FCR12
REG_FCR13
REG_FCR14
REG_FCR15
REG_FCR16
REG_FCR17
REG_FCR18
REG_FCR19
REG_FCR20
REG_FCR21
REG_FCR22
REG_FCR23
REG_FCR24
REG_FCR25
REG_FCR26
REG_FCR27
REG_FCR28
REG_FCR29
REG_FCR30
REG_FCR31
REG_SPR0 = obj.RBasePPC64 + 1024 // first of 1024 registers REG_SPECIAL = REG_M0
REG_DCR0 = obj.RBasePPC64 + 2048 // first of 1024 registers
REG_XER = REG_SPR0 + 1
REG_LR = REG_SPR0 + 8
REG_CTR = REG_SPR0 + 9
REGZERO = REG_R0 /* set to zero */ REGZERO = REG_R0 /* set to zero */
REGSP = REG_R1 REGSP = REG_R29
REGSB = REG_R2 REGSB = REG_R30
REGRET = REG_R3 REGLINK = REG_R31
REGRET = REG_R1
REGARG = -1 /* -1 disables passing the first argument in register */ REGARG = -1 /* -1 disables passing the first argument in register */
REGRT1 = REG_R3 /* reserved for runtime, duffzero and duffcopy */ REGRT1 = REG_R1 /* reserved for runtime, duffzero and duffcopy */
REGRT2 = REG_R4 /* reserved for runtime, duffcopy */ REGRT2 = REG_R2 /* reserved for runtime, duffcopy */
REGMIN = REG_R7 /* register variables allocated from here to REGMAX */ REGCTXT = REG_R22 /* context for closures */
REGCTXT = REG_R11 /* context for closures */
REGTLS = REG_R13 /* C ABI TLS base pointer */
REGMAX = REG_R27
REGEXT = REG_R30 /* external registers allocated from here down */
REGG = REG_R30 /* G */ REGG = REG_R30 /* G */
REGTMP = REG_R31 /* used by the linker */ REGTMP = REG_R28 /* used by the linker */
FREGRET = REG_F0 FREGRET = REG_F0
FREGMIN = REG_F17 /* first register variable */ FREGZERO = REG_F24 /* both float and double */
FREGMAX = REG_F26 /* last register variable for 9g only */ FREGHALF = REG_F26 /* double */
FREGEXT = REG_F26 /* first external register */ FREGONE = REG_F28 /* double */
FREGCVI = REG_F27 /* floating conversion constant */ FREGTWO = REG_F30 /* double */
FREGZERO = REG_F28 /* both float and double */
FREGHALF = REG_F29 /* double */
FREGONE = REG_F30 /* double */
FREGTWO = REG_F31 /* double */
) )
/*
* GENERAL:
*
* compiler allocates R3 up as temps
* compiler allocates register variables R7-R27
* compiler allocates external registers R30 down
*
* compiler allocates register variables F17-F26
* compiler allocates external registers F26 down
*/
const ( const (
BIG = 32768 - 8 BIG = 32766
) )
const ( const (
/* mark flags */ /* mark flags */
LABEL = 1 << 0 FOLL = 1 << 0
LEAF = 1 << 1 LABEL = 1 << 1
FLOAT = 1 << 2 LEAF = 1 << 2
BRANCH = 1 << 3 SYNC = 1 << 3
LOAD = 1 << 4 BRANCH = 1 << 4
FCMP = 1 << 5 LOAD = 1 << 5
SYNC = 1 << 6 FCMP = 1 << 6
LIST = 1 << 7 NOSCHED = 1 << 7
FOLL = 1 << 8
NOSCHED = 1 << 9 NSCHED = 20
) )
const ( const (
C_NONE = iota C_NONE = iota
C_REG C_REG
C_FREG C_FREG
C_CREG C_FCREG
C_SPR /* special processor register */ C_MREG /* special processor register */
C_HI
C_LO
C_ZCON C_ZCON
C_SCON /* 16 bit signed */ C_SCON /* 16 bit signed */
C_UCON /* 32 bit signed, low 16 bits 0 */ C_UCON /* 32 bit signed, low 16 bits 0 */
C_ADD0CON
C_AND0CON
C_ADDCON /* -0x8000 <= v < 0 */ C_ADDCON /* -0x8000 <= v < 0 */
C_ANDCON /* 0 < v <= 0xFFFF */ C_ANDCON /* 0 < v <= 0xFFFF */
C_LCON /* other 32 */ C_LCON /* other 32 */
...@@ -212,12 +250,6 @@ const ( ...@@ -212,12 +250,6 @@ const (
C_ZOREG C_ZOREG
C_SOREG C_SOREG
C_LOREG C_LOREG
C_FPSCR
C_MSR
C_XER
C_LR
C_CTR
C_ANY
C_GOK C_GOK
C_ADDR C_ADDR
C_TEXTSIZE C_TEXTSIZE
...@@ -226,313 +258,117 @@ const ( ...@@ -226,313 +258,117 @@ const (
) )
const ( const (
AADD = obj.ABasePPC64 + obj.A_ARCHSPECIFIC + iota AABSD = obj.ABaseMIPS64 + obj.A_ARCHSPECIFIC + iota
AADDCC AABSF
AADDV AABSW
AADDVCC AADD
AADDC AADDD
AADDCCC AADDF
AADDCV AADDU
AADDCVCC AADDW
AADDME
AADDMECC
AADDMEVCC
AADDMEV
AADDE
AADDECC
AADDEVCC
AADDEV
AADDZE
AADDZECC
AADDZEVCC
AADDZEV
AAND AAND
AANDCC
AANDN
AANDNCC
ABC
ABCL
ABEQ ABEQ
ABGE ABFPF
ABGT ABFPT
ABLE ABGEZ
ABLT ABGEZAL
ABGTZ
ABLEZ
ABLTZ
ABLTZAL
ABNE ABNE
ABVC ABREAK
ABVS ACMPEQD
ACMP ACMPEQF
ACMPU ACMPGED
ACNTLZW ACMPGEF
ACNTLZWCC ACMPGTD
ACRAND ACMPGTF
ACRANDN ADIV
ACREQV ADIVD
ACRNAND ADIVF
ACRNOR ADIVU
ACROR
ACRORN
ACRXOR
ADIVW ADIVW
ADIVWCC AGOK
ADIVWVCC
ADIVWV
ADIVWU
ADIVWUCC
ADIVWUVCC
ADIVWUV
AEQV
AEQVCC
AEXTSB
AEXTSBCC
AEXTSH
AEXTSHCC
AFABS
AFABSCC
AFADD
AFADDCC
AFADDS
AFADDSCC
AFCMPO
AFCMPU
AFCTIW
AFCTIWCC
AFCTIWZ
AFCTIWZCC
AFDIV
AFDIVCC
AFDIVS
AFDIVSCC
AFMADD
AFMADDCC
AFMADDS
AFMADDSCC
AFMOVD
AFMOVDCC
AFMOVDU
AFMOVS
AFMOVSU
AFMSUB
AFMSUBCC
AFMSUBS
AFMSUBSCC
AFMUL
AFMULCC
AFMULS
AFMULSCC
AFNABS
AFNABSCC
AFNEG
AFNEGCC
AFNMADD
AFNMADDCC
AFNMADDS
AFNMADDSCC
AFNMSUB
AFNMSUBCC
AFNMSUBS
AFNMSUBSCC
AFRSP
AFRSPCC
AFSUB
AFSUBCC
AFSUBS
AFSUBSCC
AMOVMW
ALSW
ALWAR
AMOVWBR
AMOVB AMOVB
AMOVBU AMOVBU
AMOVBZ AMOVD
AMOVBZU AMOVDF
AMOVDW
AMOVF
AMOVFD
AMOVFW
AMOVH AMOVH
AMOVHBR
AMOVHU AMOVHU
AMOVHZ
AMOVHZU
AMOVW AMOVW
AMOVWU AMOVWD
AMOVFL AMOVWF
AMOVCRFS AMOVWL
AMTFSB0 AMOVWR
AMTFSB0CC AMUL
AMTFSB1 AMULD
AMTFSB1CC AMULF
AMULHW AMULU
AMULHWCC AMULW
AMULHWU ANEGD
AMULHWUCC ANEGF
AMULLW ANEGW
AMULLWCC
AMULLWVCC
AMULLWV
ANAND
ANANDCC
ANEG
ANEGCC
ANEGVCC
ANEGV
ANOR ANOR
ANORCC
AOR AOR
AORCC
AORN
AORNCC
AREM AREM
AREMCC
AREMV
AREMVCC
AREMU AREMU
AREMUCC ARFE
AREMUV ASGT
AREMUVCC ASGTU
ARFI ASLL
ARLWMI ASRA
ARLWMICC ASRL
ARLWNM
ARLWNMCC
ASLW
ASLWCC
ASRW
ASRAW
ASRAWCC
ASRWCC
ASTSW
ASTWCCC
ASUB ASUB
ASUBCC ASUBD
ASUBVCC ASUBF
ASUBC ASUBU
ASUBCCC ASUBW
ASUBCV
ASUBCVCC
ASUBME
ASUBMECC
ASUBMEVCC
ASUBMEV
ASUBV
ASUBE
ASUBECC
ASUBEV
ASUBEVCC
ASUBZE
ASUBZECC
ASUBZEVCC
ASUBZEV
ASYNC
AXOR
AXORCC
ADCBF
ADCBI
ADCBST
ADCBT
ADCBTST
ADCBZ
AECIWX
AECOWX
AEIEIO
AICBI
AISYNC
APTESYNC
ATLBIE
ATLBIEL
ATLBSYNC
ATW
ASYSCALL ASYSCALL
ATLBP
ATLBR
ATLBWI
ATLBWR
AWORD AWORD
AXOR
ARFCI
/* optional on 32-bit */
AFRES
AFRESCC
AFRSQRTE
AFRSQRTECC
AFSEL
AFSELCC
AFSQRT
AFSQRTCC
AFSQRTS
AFSQRTSCC
/* 64-bit */ /* 64-bit */
AMOVV
AMOVVL
AMOVVR
ASLLV
ASRAV
ASRLV
ADIVV
ADIVVU
AREMV
AREMVU
AMULV
AMULVU
AADDV
AADDVU
ASUBV
ASUBVU
ACNTLZD /* 64-bit FP */
ACNTLZDCC ATRUNCFV
ACMPW /* CMP with L=0 */ ATRUNCDV
ACMPWU ATRUNCFW
ADIVD ATRUNCDW
ADIVDCC AMOVWU
ADIVDVCC AMOVFV
ADIVDV AMOVDV
ADIVDU AMOVVF
ADIVDUCC AMOVVD
ADIVDUVCC
ADIVDUV
AEXTSW
AEXTSWCC
/* AFCFIW; AFCFIWCC */
AFCFID
AFCFIDCC
AFCTID
AFCTIDCC
AFCTIDZ
AFCTIDZCC
ALDAR
AMOVD
AMOVDU
AMOVWZ
AMOVWZU
AMULHD
AMULHDCC
AMULHDU
AMULHDUCC
AMULLD
AMULLDCC
AMULLDVCC
AMULLDV
ARFID
ARLDMI
ARLDMICC
ARLDC
ARLDCCC
ARLDCR
ARLDCRCC
ARLDCL
ARLDCLCC
ASLBIA
ASLBIE
ASLBMFEE
ASLBMFEV
ASLBMTE
ASLD
ASLDCC
ASRD
ASRAD
ASRADCC
ASRDCC
ASTDCCC
ATD
/* 64-bit pseudo operation */
ADWORD
AREMD
AREMDCC
AREMDV
AREMDVCC
AREMDU
AREMDUCC
AREMDUV
AREMDUVCC
/* more 64-bit operations */
AHRFID
ALAST ALAST
// aliases // aliases
ABR = obj.AJMP AJMP = obj.AJMP
ABL = obj.ACALL AJAL = obj.ACALL
ARET = obj.ARET
) )
// Generated by stringer -i a.out.go -o anames.go -p ppc64 // Generated by stringer -i a.out.go -o anames.go -p mips
// Do not edit. // Do not edit.
package ppc64 package mips
import "cmd/internal/obj" import "cmd/internal/obj"
var Anames = []string{ var Anames = []string{
obj.A_ARCHSPECIFIC: "ADD", obj.A_ARCHSPECIFIC: "ABSD",
"ADDCC", "ABSF",
"ADDV", "ABSW",
"ADDVCC", "ADD",
"ADDC", "ADDD",
"ADDCCC", "ADDF",
"ADDCV", "ADDU",
"ADDCVCC", "ADDW",
"ADDME",
"ADDMECC",
"ADDMEVCC",
"ADDMEV",
"ADDE",
"ADDECC",
"ADDEVCC",
"ADDEV",
"ADDZE",
"ADDZECC",
"ADDZEVCC",
"ADDZEV",
"AND", "AND",
"ANDCC",
"ANDN",
"ANDNCC",
"BC",
"BCL",
"BEQ", "BEQ",
"BGE", "BFPF",
"BGT", "BFPT",
"BLE", "BGEZ",
"BLT", "BGEZAL",
"BGTZ",
"BLEZ",
"BLTZ",
"BLTZAL",
"BNE", "BNE",
"BVC", "BREAK",
"BVS", "CMPEQD",
"CMP", "CMPEQF",
"CMPU", "CMPGED",
"CNTLZW", "CMPGEF",
"CNTLZWCC", "CMPGTD",
"CRAND", "CMPGTF",
"CRANDN", "DIV",
"CREQV", "DIVD",
"CRNAND", "DIVF",
"CRNOR", "DIVU",
"CROR",
"CRORN",
"CRXOR",
"DIVW", "DIVW",
"DIVWCC", "GOK",
"DIVWVCC",
"DIVWV",
"DIVWU",
"DIVWUCC",
"DIVWUVCC",
"DIVWUV",
"EQV",
"EQVCC",
"EXTSB",
"EXTSBCC",
"EXTSH",
"EXTSHCC",
"FABS",
"FABSCC",
"FADD",
"FADDCC",
"FADDS",
"FADDSCC",
"FCMPO",
"FCMPU",
"FCTIW",
"FCTIWCC",
"FCTIWZ",
"FCTIWZCC",
"FDIV",
"FDIVCC",
"FDIVS",
"FDIVSCC",
"FMADD",
"FMADDCC",
"FMADDS",
"FMADDSCC",
"FMOVD",
"FMOVDCC",
"FMOVDU",
"FMOVS",
"FMOVSU",
"FMSUB",
"FMSUBCC",
"FMSUBS",
"FMSUBSCC",
"FMUL",
"FMULCC",
"FMULS",
"FMULSCC",
"FNABS",
"FNABSCC",
"FNEG",
"FNEGCC",
"FNMADD",
"FNMADDCC",
"FNMADDS",
"FNMADDSCC",
"FNMSUB",
"FNMSUBCC",
"FNMSUBS",
"FNMSUBSCC",
"FRSP",
"FRSPCC",
"FSUB",
"FSUBCC",
"FSUBS",
"FSUBSCC",
"MOVMW",
"LSW",
"LWAR",
"MOVWBR",
"MOVB", "MOVB",
"MOVBU", "MOVBU",
"MOVBZ", "MOVD",
"MOVBZU", "MOVDF",
"MOVDW",
"MOVF",
"MOVFD",
"MOVFW",
"MOVH", "MOVH",
"MOVHBR",
"MOVHU", "MOVHU",
"MOVHZ",
"MOVHZU",
"MOVW", "MOVW",
"MOVWU", "MOVWD",
"MOVFL", "MOVWF",
"MOVCRFS", "MOVWL",
"MTFSB0", "MOVWR",
"MTFSB0CC", "MUL",
"MTFSB1", "MULD",
"MTFSB1CC", "MULF",
"MULHW", "MULU",
"MULHWCC", "MULW",
"MULHWU", "NEGD",
"MULHWUCC", "NEGF",
"MULLW", "NEGW",
"MULLWCC",
"MULLWVCC",
"MULLWV",
"NAND",
"NANDCC",
"NEG",
"NEGCC",
"NEGVCC",
"NEGV",
"NOR", "NOR",
"NORCC",
"OR", "OR",
"ORCC",
"ORN",
"ORNCC",
"REM", "REM",
"REMCC",
"REMV",
"REMVCC",
"REMU", "REMU",
"REMUCC", "RFE",
"REMUV", "SGT",
"REMUVCC", "SGTU",
"RFI", "SLL",
"RLWMI", "SRA",
"RLWMICC", "SRL",
"RLWNM",
"RLWNMCC",
"SLW",
"SLWCC",
"SRW",
"SRAW",
"SRAWCC",
"SRWCC",
"STSW",
"STWCCC",
"SUB", "SUB",
"SUBCC", "SUBD",
"SUBVCC", "SUBF",
"SUBC", "SUBU",
"SUBCCC", "SUBW",
"SUBCV",
"SUBCVCC",
"SUBME",
"SUBMECC",
"SUBMEVCC",
"SUBMEV",
"SUBV",
"SUBE",
"SUBECC",
"SUBEV",
"SUBEVCC",
"SUBZE",
"SUBZECC",
"SUBZEVCC",
"SUBZEV",
"SYNC",
"XOR",
"XORCC",
"DCBF",
"DCBI",
"DCBST",
"DCBT",
"DCBTST",
"DCBZ",
"ECIWX",
"ECOWX",
"EIEIO",
"ICBI",
"ISYNC",
"PTESYNC",
"TLBIE",
"TLBIEL",
"TLBSYNC",
"TW",
"SYSCALL", "SYSCALL",
"TLBP",
"TLBR",
"TLBWI",
"TLBWR",
"WORD", "WORD",
"RFCI", "XOR",
"FRES", "MOVV",
"FRESCC", "MOVVL",
"FRSQRTE", "MOVVR",
"FRSQRTECC", "SLLV",
"FSEL", "SRAV",
"FSELCC", "SRLV",
"FSQRT", "DIVV",
"FSQRTCC", "DIVVU",
"FSQRTS", "REMV",
"FSQRTSCC", "REMVU",
"CNTLZD", "MULV",
"CNTLZDCC", "MULVU",
"CMPW", "ADDV",
"CMPWU", "ADDVU",
"DIVD", "SUBV",
"DIVDCC", "SUBVU",
"DIVDVCC", "TRUNCFV",
"DIVDV", "TRUNCDV",
"DIVDU", "TRUNCFW",
"DIVDUCC", "TRUNCDW",
"DIVDUVCC", "MOVWU",
"DIVDUV", "MOVFV",
"EXTSW", "MOVDV",
"EXTSWCC", "MOVVF",
"FCFID", "MOVVD",
"FCFIDCC",
"FCTID",
"FCTIDCC",
"FCTIDZ",
"FCTIDZCC",
"LDAR",
"MOVD",
"MOVDU",
"MOVWZ",
"MOVWZU",
"MULHD",
"MULHDCC",
"MULHDU",
"MULHDUCC",
"MULLD",
"MULLDCC",
"MULLDVCC",
"MULLDV",
"RFID",
"RLDMI",
"RLDMICC",
"RLDC",
"RLDCCC",
"RLDCR",
"RLDCRCC",
"RLDCL",
"RLDCLCC",
"SLBIA",
"SLBIE",
"SLBMFEE",
"SLBMFEV",
"SLBMTE",
"SLD",
"SLDCC",
"SRD",
"SRAD",
"SRADCC",
"SRDCC",
"STDCCC",
"TD",
"DWORD",
"REMD",
"REMDCC",
"REMDV",
"REMDVCC",
"REMDU",
"REMDUCC",
"REMDUV",
"REMDUVCC",
"HRFID",
"LAST", "LAST",
} }
package ppc64 package mips
var cnames9 = []string{ var cnames0 = []string{
"NONE", "NONE",
"REG", "REG",
"FREG", "FREG",
"CREG", "FCREG",
"SPR", "MREG",
"HI",
"LO",
"ZCON", "ZCON",
"SCON", "SCON",
"UCON", "UCON",
"ADD0CON",
"AND0CON",
"ADDCON", "ADDCON",
"ANDCON", "ANDCON",
"LCON", "LCON",
...@@ -27,12 +31,6 @@ var cnames9 = []string{ ...@@ -27,12 +31,6 @@ var cnames9 = []string{
"ZOREG", "ZOREG",
"SOREG", "SOREG",
"LOREG", "LOREG",
"FPSCR",
"MSR",
"XER",
"LR",
"CTR",
"ANY",
"GOK", "GOK",
"ADDR", "ADDR",
"TEXTSIZE", "TEXTSIZE",
......
This source diff could not be displayed because it is too large. You can view the blob instead.
...@@ -27,7 +27,7 @@ ...@@ -27,7 +27,7 @@
// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
// THE SOFTWARE. // THE SOFTWARE.
package ppc64 package mips
import ( import (
"cmd/internal/obj" "cmd/internal/obj"
...@@ -35,8 +35,8 @@ import ( ...@@ -35,8 +35,8 @@ import (
) )
func init() { func init() {
obj.RegisterRegister(obj.RBasePPC64, REG_DCR0+1024, Rconv) obj.RegisterRegister(obj.RBaseMIPS64, REG_FCR0+1024, Rconv)
obj.RegisterOpcode(obj.ABasePPC64, Anames) obj.RegisterOpcode(obj.ABaseMIPS64, Anames)
} }
func Rconv(r int) string { func Rconv(r int) string {
...@@ -53,44 +53,26 @@ func Rconv(r int) string { ...@@ -53,44 +53,26 @@ func Rconv(r int) string {
if REG_F0 <= r && r <= REG_F31 { if REG_F0 <= r && r <= REG_F31 {
return fmt.Sprintf("F%d", r-REG_F0) return fmt.Sprintf("F%d", r-REG_F0)
} }
if REG_CR0 <= r && r <= REG_CR7 { if REG_M0 <= r && r <= REG_M31 {
return fmt.Sprintf("CR%d", r-REG_CR0) return fmt.Sprintf("M%d", r-REG_M0)
} }
if r == REG_CR { if REG_FCR0 <= r && r <= REG_FCR31 {
return "CR" return fmt.Sprintf("FCR%d", r-REG_FCR0)
} }
if REG_SPR0 <= r && r <= REG_SPR0+1023 { if r == REG_HI {
switch r { return "HI"
case REG_XER:
return "XER"
case REG_LR:
return "LR"
case REG_CTR:
return "CTR"
}
return fmt.Sprintf("SPR(%d)", r-REG_SPR0)
}
if REG_DCR0 <= r && r <= REG_DCR0+1023 {
return fmt.Sprintf("DCR(%d)", r-REG_DCR0)
}
if r == REG_FPSCR {
return "FPSCR"
} }
if r == REG_MSR { if r == REG_LO {
return "MSR" return "LO"
} }
return fmt.Sprintf("Rgok(%d)", r-obj.RBasePPC64) return fmt.Sprintf("Rgok(%d)", r-obj.RBaseMIPS64)
} }
func DRconv(a int) string { func DRconv(a int) string {
s := "C_??" s := "C_??"
if a >= C_NONE && a <= C_NCLASS { if a >= C_NONE && a <= C_NCLASS {
s = cnames9[a] s = cnames0[a]
} }
var fp string var fp string
fp += s fp += s
......
This diff is collapsed.
...@@ -524,11 +524,12 @@ var regSpace []regSet ...@@ -524,11 +524,12 @@ var regSpace []regSet
const ( const (
// Because of masking operations in the encodings, each register // Because of masking operations in the encodings, each register
// space should start at 0 modulo some power of 2. // space should start at 0 modulo some power of 2.
RBase386 = 1 * 1024 RBase386 = 1 * 1024
RBaseAMD64 = 2 * 1024 RBaseAMD64 = 2 * 1024
RBaseARM = 3 * 1024 RBaseARM = 3 * 1024
RBasePPC64 = 4 * 1024 // range [4k, 8k) RBasePPC64 = 4 * 1024 // range [4k, 8k)
RBaseARM64 = 8 * 1024 // range [8k, 12k) RBaseARM64 = 8 * 1024 // range [8k, 13k)
RBaseMIPS64 = 13 * 1024 // range [13k, 16k)
) )
// RegisterRegister binds a pretty-printer (Rconv) for register // RegisterRegister binds a pretty-printer (Rconv) for register
...@@ -588,6 +589,7 @@ const ( ...@@ -588,6 +589,7 @@ const (
ABaseAMD64 ABaseAMD64
ABasePPC64 ABasePPC64
ABaseARM64 ABaseARM64
ABaseMIPS64
AMask = 1<<12 - 1 // AND with this to use the opcode as an array index. AMask = 1<<12 - 1 // AND with this to use the opcode as an array index.
) )
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment