]> git.sesse.net Git - ffmpeg/commitdiff
Merge commit '71a0472114574993df7035f4de9aa007e03817b8'
authorClément Bœsch <u@pkh.me>
Tue, 24 Jan 2017 18:17:38 +0000 (19:17 +0100)
committerClément Bœsch <u@pkh.me>
Tue, 24 Jan 2017 18:21:29 +0000 (19:21 +0100)
* commit '71a0472114574993df7035f4de9aa007e03817b8':
  checkasm: arm: report the first clobbered register in checkasm_checked_call

Also includes 446353ea1859aeed93e4, and 37961044c6 to avoid breaking
too much stuff.

Merged-by: Clément Bœsch <u@pkh.me>
1  2 
tests/checkasm/arm/checkasm.S

index 62a91c19abb3d21085e5ac9a402197c2f7cd1c1d,989f6136561cebe1da9359e85808c8a2d9a30a59..0cbf32e57ff27eae2626dad20706d1945fe91b23
  
  #include "libavutil/arm/asm.S"
  
++/* override fpu so that NEON instructions are rejected */
++#if HAVE_VFP
++.fpu            vfp
++ELF     .eabi_attribute 10, 0           @ suppress Tag_FP_arch
++#endif
++
  const register_init, align=3
      .quad 0x21f86d66c8ca00ce
      .quad 0x75b6ba21077c48ad
      .quad 0x249214109d5d1c88
  endconst
  
- const error_message
-     .asciz "failed to preserve register"
+ const error_message_fpscr
 -    .asciz "failed to preserve register FPSCR"
 -const error_message_gpr
++    .asciz "failed to preserve register FPSCR, changed bits: %x"
++error_message_gpr:
+     .asciz "failed to preserve register r%d"
 -const error_message_vfp
++error_message_vfp:
+     .asciz "failed to preserve register d%d"
  endconst
  
  @ max number of args used by any asm function.
@@@ -79,39 -83,42 +89,45 @@@ function checkasm_checked_call_\variant
  
      push        {r0, r1}
      movrel      r12, register_init
-     mov         r3,  #0
  .ifc \variant, vfp
- .macro check_reg_vfp, dreg, inc=8
-     ldrd        r0,  r1,  [r12], #\inc
-     vmov        r2,  lr,  \dreg
-     eor         r0,  r0,  r2
-     eor         r1,  r1,  lr
-     orr         r3,  r3,  r0
-     orr         r3,  r3,  r1
+ .macro check_reg_vfp, dreg, offset
 -    vldr        d0,  [r12, #8 * (\offset)]
 -    veor        d0,  d0,  \dreg
 -    vmov        r2,  r3,  d0
++    ldrd        r2,  r3,  [r12, #8 * (\offset)]
++    vmov        r0,  lr,  \dreg
++    eor         r2,  r2,  r0
++    eor         r3,  r3,  lr
+     orrs        r2,  r2,  r3
+     bne         4f
  .endm
  
- .irp n, 8, 9, 10, 11, 12, 13, 14
-     check_reg_vfp d\n
+ .irp n, 8, 9, 10, 11, 12, 13, 14, 15
+     @ keep track of the checked double/SIMD register
+     mov         r1,  #\n
+     check_reg_vfp d\n, \n-8
  .endr
-     check_reg_vfp d15, -56
  .purgem check_reg_vfp
  
--    fmrx        r0,  FPSCR
-     ldr         r1,  [sp, #8]
-     eor         r0,  r0,  r1
++    fmrx        r1,  FPSCR
+     ldr         r3,  [sp, #8]
 -    eor         r0,  r0,  r3
++    eor         r1,  r1,  r3
++    @ Ignore changes in bits 0-4 and 7
++    bic         r1,  r1,  #0x9f
      @ Ignore changes in the topmost 5 bits
-     lsl         r0,  r0,  #5
-     orr         r3,  r3,  r0
 -    lsls        r0,  r0,  #5
++    bics        r1,  r1,  #0xf8000000
+     bne         3f
  .endif
  
+     @ keep track of the checked GPR
+     mov         r1,  #4
  .macro check_reg reg1, reg2=
-     ldrd        r0,  r1,  [r12], #8
-     eor         r0,  r0,  \reg1
-     orrs        r3,  r3,  r0
+     ldrd        r2,  r3,  [r12], #8
+     eors        r2,  r2,  \reg1
+     bne         2f
+     add         r1,  r1,  #1
  .ifnb \reg2
-     eor         r1,  r1,  \reg2
-     orrs        r3,  r3,  r1
+     eors        r3,  r3,  \reg2
+     bne         2f
  .endif
+     add         r1,  r1,  #1
  .endm
      check_reg   r4,  r5
      check_reg   r6,  r7