]> Cypherpunks repositories - gostls13.git/commitdiff
cmd/internal/obj/arm64: add error report for invalid base register
authorfanzha02 <fannie.zhang@arm.com>
Mon, 10 Sep 2018 02:22:48 +0000 (02:22 +0000)
committerCherry Zhang <cherryyz@google.com>
Wed, 12 Sep 2018 15:45:13 +0000 (15:45 +0000)
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>

src/cmd/asm/internal/asm/testdata/arm64error.s
src/cmd/internal/obj/arm64/asm7.go

index bbdce479c517be7c7b3c03355cb4e3abbec9acb8..357db80222d8d2bbb38bd449abae01ac202d24de 100644 (file)
@@ -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
index 09ffc5dccf72e2dc219ad3010543732ee8bdff53..46fdcdcf7dff55a127c37748eb4b9195d6e00b98 100644 (file)
@@ -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)
                }