msvcrt: Disable floating point instructions for the soft-float ARM build.

Signed-off-by: Alexandre Julliard <julliard@winehq.org>
This commit is contained in:
Alexandre Julliard 2017-12-08 13:03:28 +01:00
parent 5c50ec0c74
commit 702da12d04
1 changed files with 4 additions and 0 deletions

View File

@ -151,6 +151,7 @@ __ASM_GLOBAL_FUNC(MSVCRT__setjmpex,
"str r11, [r0, #0x20]\n\t" /* jmp_buf->R11 */ "str r11, [r0, #0x20]\n\t" /* jmp_buf->R11 */
"str sp, [r0, #0x24]\n\t" /* jmp_buf->Sp */ "str sp, [r0, #0x24]\n\t" /* jmp_buf->Sp */
"str lr, [r0, #0x28]\n\t" /* jmp_buf->Pc */ "str lr, [r0, #0x28]\n\t" /* jmp_buf->Pc */
#ifndef __SOFTFP__
"vmrs r2, fpscr\n\t" "vmrs r2, fpscr\n\t"
"str r2, [r0, #0x2c]\n\t" /* jmp_buf->Fpscr */ "str r2, [r0, #0x2c]\n\t" /* jmp_buf->Fpscr */
"vstr d8, [r0, #0x30]\n\t" /* jmp_buf->D[0] */ "vstr d8, [r0, #0x30]\n\t" /* jmp_buf->D[0] */
@ -161,6 +162,7 @@ __ASM_GLOBAL_FUNC(MSVCRT__setjmpex,
"vstr d13, [r0, #0x58]\n\t" /* jmp_buf->D[5] */ "vstr d13, [r0, #0x58]\n\t" /* jmp_buf->D[5] */
"vstr d14, [r0, #0x60]\n\t" /* jmp_buf->D[6] */ "vstr d14, [r0, #0x60]\n\t" /* jmp_buf->D[6] */
"vstr d15, [r0, #0x68]\n\t" /* jmp_buf->D[7] */ "vstr d15, [r0, #0x68]\n\t" /* jmp_buf->D[7] */
#endif
"mov r0, #0\n\t" "mov r0, #0\n\t"
"bx lr"); "bx lr");
@ -177,6 +179,7 @@ __ASM_GLOBAL_FUNC(longjmp_set_regs,
"ldr r11, [r0, #0x20]\n\t" /* jmp_buf->R11 */ "ldr r11, [r0, #0x20]\n\t" /* jmp_buf->R11 */
"ldr sp, [r0, #0x24]\n\t" /* jmp_buf->Sp */ "ldr sp, [r0, #0x24]\n\t" /* jmp_buf->Sp */
"ldr r2, [r0, #0x28]\n\t" /* jmp_buf->Pc */ "ldr r2, [r0, #0x28]\n\t" /* jmp_buf->Pc */
#ifndef __SOFTFP__
"ldr r3, [r0, #0x2c]\n\t" /* jmp_buf->Fpscr */ "ldr r3, [r0, #0x2c]\n\t" /* jmp_buf->Fpscr */
"vmsr fpscr, r3\n\t" "vmsr fpscr, r3\n\t"
"vldr d8, [r0, #0x30]\n\t" /* jmp_buf->D[0] */ "vldr d8, [r0, #0x30]\n\t" /* jmp_buf->D[0] */
@ -187,6 +190,7 @@ __ASM_GLOBAL_FUNC(longjmp_set_regs,
"vldr d13, [r0, #0x58]\n\t" /* jmp_buf->D[5] */ "vldr d13, [r0, #0x58]\n\t" /* jmp_buf->D[5] */
"vldr d14, [r0, #0x60]\n\t" /* jmp_buf->D[6] */ "vldr d14, [r0, #0x60]\n\t" /* jmp_buf->D[6] */
"vldr d15, [r0, #0x68]\n\t" /* jmp_buf->D[7] */ "vldr d15, [r0, #0x68]\n\t" /* jmp_buf->D[7] */
#endif
"mov r0, r1\n\t" /* retval */ "mov r0, r1\n\t" /* retval */
"bx r2"); "bx r2");