mirror of https://github.com/golang/go.git
cmd/internal/obj/arm64: add error report for invalid base register
The current assembler accepts the non-integer register as the base register, which should be an illegal combination. Add the test cases. Change-Id: Ia21596bbb5b1e212e34bd3a170748ae788860422 Reviewed-on: https://go-review.googlesource.com/134575 Reviewed-by: Cherry Zhang <cherryyz@google.com> Run-TryBot: Cherry Zhang <cherryyz@google.com> TryBot-Result: Gobot Gobot <gobot@golang.org>
This commit is contained in:
parent
d5377c2026
commit
e7f5f3eca4
|
|
@ -110,4 +110,6 @@ TEXT errors(SB),$0
|
|||
FLDPD (R1), (F2, F2) // ERROR "constrained unpredictable behavior"
|
||||
FLDPS (R2), (F3, F3) // ERROR "constrained unpredictable behavior"
|
||||
FSTPD (R1, R2), (R0) // ERROR "invalid register pair"
|
||||
FMOVS (F2), F0 // ERROR "illegal combination"
|
||||
FMOVD F0, (F1) // ERROR "illegal combination"
|
||||
RET
|
||||
|
|
|
|||
|
|
@ -1426,6 +1426,10 @@ func (c *ctxt7) aclass(a *obj.Addr) int {
|
|||
return C_LIST
|
||||
|
||||
case obj.TYPE_MEM:
|
||||
// The base register should be an integer register.
|
||||
if int16(REG_F0) <= a.Reg && a.Reg <= int16(REG_V31) {
|
||||
break
|
||||
}
|
||||
switch a.Name {
|
||||
case obj.NAME_EXTERN, obj.NAME_STATIC:
|
||||
if a.Sym == nil {
|
||||
|
|
@ -2968,7 +2972,7 @@ func (c *ctxt7) asmout(p *obj.Prog, o *Optab, out []uint32) {
|
|||
}
|
||||
|
||||
case 22: /* movT (R)O!,R; movT O(R)!, R -> ldrT */
|
||||
if p.As != AFMOVS && p.As != AFMOVD && p.From.Reg != REGSP && p.From.Reg == p.To.Reg {
|
||||
if p.From.Reg != REGSP && p.From.Reg == p.To.Reg {
|
||||
c.ctxt.Diag("constrained unpredictable behavior: %v", p)
|
||||
}
|
||||
|
||||
|
|
@ -2986,7 +2990,7 @@ func (c *ctxt7) asmout(p *obj.Prog, o *Optab, out []uint32) {
|
|||
o1 |= ((uint32(v) & 0x1FF) << 12) | (uint32(p.From.Reg&31) << 5) | uint32(p.To.Reg&31)
|
||||
|
||||
case 23: /* movT R,(R)O!; movT O(R)!, R -> strT */
|
||||
if p.As != AFMOVS && p.As != AFMOVD && p.To.Reg != REGSP && p.From.Reg == p.To.Reg {
|
||||
if p.To.Reg != REGSP && p.From.Reg == p.To.Reg {
|
||||
c.ctxt.Diag("constrained unpredictable behavior: %v", p)
|
||||
}
|
||||
|
||||
|
|
|
|||
Loading…
Reference in New Issue