1
0
mirror of https://github.com/golang/go synced 2024-11-15 06:30:32 -07:00
go/src/runtime/preempt_arm.s
Ludi Rehak ee6b34797b all: add floating point option for ARM targets
This change introduces new options to set the floating point
mode on ARM targets. The GOARM version number can optionally be
followed by ',hardfloat' or ',softfloat' to select whether to
use hardware instructions or software emulation for floating
point computations, respectively. For example,
GOARM=7,softfloat.

Previously, software floating point support was limited to
GOARM=5. With these options, software floating point is now
extended to all ARM versions, including GOARM=6 and 7. This
change also extends hardware floating point to GOARM=5.

GOARM=5 defaults to softfloat and GOARM=6 and 7 default to
hardfloat.

For #61588

Change-Id: I23dc86fbd0733b262004a2ed001e1032cf371e94
Reviewed-on: https://go-review.googlesource.com/c/go/+/514907
Run-TryBot: Michael Knyszek <mknyszek@google.com>
Reviewed-by: Michael Knyszek <mknyszek@google.com>
Reviewed-by: Keith Randall <khr@golang.org>
TryBot-Result: Gopher Robot <gobot@golang.org>
Reviewed-by: Keith Randall <khr@google.com>
Auto-Submit: Michael Knyszek <mknyszek@google.com>
2023-11-20 17:19:36 +00:00

84 lines
1.5 KiB
ArmAsm

// Code generated by mkpreempt.go; DO NOT EDIT.
#include "go_asm.h"
#include "textflag.h"
TEXT ·asyncPreempt(SB),NOSPLIT|NOFRAME,$0-0
MOVW.W R14, -188(R13)
MOVW R0, 4(R13)
MOVW R1, 8(R13)
MOVW R2, 12(R13)
MOVW R3, 16(R13)
MOVW R4, 20(R13)
MOVW R5, 24(R13)
MOVW R6, 28(R13)
MOVW R7, 32(R13)
MOVW R8, 36(R13)
MOVW R9, 40(R13)
MOVW R11, 44(R13)
MOVW R12, 48(R13)
MOVW CPSR, R0
MOVW R0, 52(R13)
MOVB ·goarmsoftfp(SB), R0
CMP $0, R0
BNE nofp
MOVW FPCR, R0
MOVW R0, 56(R13)
MOVD F0, 60(R13)
MOVD F1, 68(R13)
MOVD F2, 76(R13)
MOVD F3, 84(R13)
MOVD F4, 92(R13)
MOVD F5, 100(R13)
MOVD F6, 108(R13)
MOVD F7, 116(R13)
MOVD F8, 124(R13)
MOVD F9, 132(R13)
MOVD F10, 140(R13)
MOVD F11, 148(R13)
MOVD F12, 156(R13)
MOVD F13, 164(R13)
MOVD F14, 172(R13)
MOVD F15, 180(R13)
nofp:
CALL ·asyncPreempt2(SB)
MOVB ·goarmsoftfp(SB), R0
CMP $0, R0
BNE nofp2
MOVD 180(R13), F15
MOVD 172(R13), F14
MOVD 164(R13), F13
MOVD 156(R13), F12
MOVD 148(R13), F11
MOVD 140(R13), F10
MOVD 132(R13), F9
MOVD 124(R13), F8
MOVD 116(R13), F7
MOVD 108(R13), F6
MOVD 100(R13), F5
MOVD 92(R13), F4
MOVD 84(R13), F3
MOVD 76(R13), F2
MOVD 68(R13), F1
MOVD 60(R13), F0
MOVW 56(R13), R0
MOVW R0, FPCR
nofp2:
MOVW 52(R13), R0
MOVW R0, CPSR
MOVW 48(R13), R12
MOVW 44(R13), R11
MOVW 40(R13), R9
MOVW 36(R13), R8
MOVW 32(R13), R7
MOVW 28(R13), R6
MOVW 24(R13), R5
MOVW 20(R13), R4
MOVW 16(R13), R3
MOVW 12(R13), R2
MOVW 8(R13), R1
MOVW 4(R13), R0
MOVW 188(R13), R14
MOVW.P 192(R13), R15
UNDEF