ref: 9d790238f28647de47d7dadebe48a1f567729dc2
parent: 1c0427e6dd9da96e6e20410f205a95b30c2ae770
author: cinap_lenrek <cinap_lenrek@felloff.net>
date: Thu May 9 07:11:45 EDT 2019
bcm64: use MOVP instruction for saving and restoring registers
--- a/sys/src/9/bcm64/fns.h
+++ b/sys/src/9/bcm64/fns.h
@@ -17,7 +17,6 @@
extern void returnto(void*);
extern void fpsaveregs(void*);
extern void fploadregs(void*);
-extern void magic(void);
extern void setttbr(uintptr pa);
extern uintptr getfar(void);
--- a/sys/src/9/bcm64/l.s
+++ b/sys/src/9/bcm64/l.s
@@ -334,17 +334,6 @@
B cacheiinv(SB)
-TEXT magic(SB), 1, $-4
- DSB $SY
- ISB $SY
- DSB $SY
- ISB $SY
- DSB $SY
- ISB $SY
- DSB $SY
- ISB $SY
- RETURN
-
/*
* TLB maintenance operations.
* these broadcast to all cpu's in the cluser
@@ -421,10 +410,8 @@
CMPW $0x15, R17 // SVC trap?
BNE _itsatrap // nope.
- MOV R26, 224(RSP) // special
- MOV R27, 232(RSP) // special
- MOV R28, 240(RSP) // sb
- MOV R29, 248(RSP) // special
+ MOVP R26, R27, 224(RSP)
+ MOVP R28, R29, 240(RSP)
MRS SP_EL0, R1
MRS ELR_EL1, R2
@@ -456,10 +443,8 @@
MSR R2, ELR_EL1
MSR R3, SPSR_EL1
- MOV 224(RSP), R26 // special
- MOV 232(RSP), R27 // special
- MOV 240(RSP), R28 // sb
- MOV 248(RSP), R29 // special
+ MOVP 224(RSP), R26, R27
+ MOVP 240(RSP), R28, R29
MOV 256(RSP), R30 // link
@@ -468,38 +453,24 @@
TEXT itsatrap<>(SB), 1, $-4
_itsatrap:
- MOV R1, 24(RSP)
- MOV R2, 32(RSP)
- MOV R3, 40(RSP)
- MOV R4, 48(RSP)
- MOV R5, 56(RSP)
- MOV R6, 64(RSP)
- MOV R7, 72(RSP)
- MOV R8, 80(RSP)
- MOV R9, 88(RSP)
- MOV R10, 96(RSP)
- MOV R11, 104(RSP)
- MOV R12, 112(RSP)
- MOV R13, 120(RSP)
- MOV R14, 128(RSP)
- MOV R15, 136(RSP)
- MOV R16, 144(RSP)
+ MOVP R1, R2, 24(RSP)
+ MOVP R3, R4, 40(RSP)
+ MOVP R5, R6, 56(RSP)
+ MOVP R7, R8, 72(RSP)
+ MOVP R9, R10, 88(RSP)
+ MOVP R11, R12, 104(RSP)
+ MOVP R13, R14, 120(RSP)
+ MOVP R15, R16, 136(RSP)
- MOV R18, 160(RSP)
- MOV R19, 168(RSP)
- MOV R20, 176(RSP)
- MOV R21, 184(RSP)
- MOV R22, 192(RSP)
- MOV R23, 200(RSP)
- MOV R24, 208(RSP)
- MOV R25, 216(RSP)
+ MOVP R18, R19, 160(RSP)
+ MOVP R20, R21, 176(RSP)
+ MOVP R22, R23, 192(RSP)
+ MOVP R24, R25, 208(RSP)
// trap/irq/fiq/serr from EL0
TEXT vtrap0(SB), 1, $-4
- MOV R26, 224(RSP) // special
- MOV R27, 232(RSP) // special
- MOV R28, 240(RSP) // sb
- MOV R29, 248(RSP) // special
+ MOVP R26, R27, 224(RSP)
+ MOVP R28, R29, 240(RSP)
MRS SP_EL0, R1
MRS ELR_EL1, R2
@@ -530,38 +501,23 @@
MSR R2, ELR_EL1
MSR R3, SPSR_EL1
- MOV 224(RSP), R26 // special
- MOV 232(RSP), R27 // special
- MOV 240(RSP), R28 // sb
- MOV 248(RSP), R29 // special
+ MOVP 224(RSP), R26, R27
+ MOVP 240(RSP), R28, R29
_intrreturn:
- MOV 16(RSP), R0
- MOV 24(RSP), R1
- MOV 32(RSP), R2
- MOV 40(RSP), R3
- MOV 48(RSP), R4
- MOV 56(RSP), R5
- MOV 64(RSP), R6
- MOV 72(RSP), R7
- MOV 80(RSP), R8
- MOV 88(RSP), R9
- MOV 96(RSP), R10
- MOV 104(RSP), R11
- MOV 112(RSP), R12
- MOV 120(RSP), R13
- MOV 128(RSP), R14
- MOV 136(RSP), R15
- MOV 144(RSP), R16
- MOV 152(RSP), R17
- MOV 160(RSP), R18
- MOV 168(RSP), R19
- MOV 176(RSP), R20
- MOV 184(RSP), R21
- MOV 192(RSP), R22
- MOV 200(RSP), R23
- MOV 208(RSP), R24
- MOV 216(RSP), R25
+ MOVP 16(RSP), R0, R1
+ MOVP 32(RSP), R2, R3
+ MOVP 48(RSP), R4, R5
+ MOVP 64(RSP), R6, R7
+ MOVP 80(RSP), R8, R9
+ MOVP 96(RSP), R10, R11
+ MOVP 112(RSP), R12, R13
+ MOVP 128(RSP), R14, R15
+ MOVP 144(RSP), R16, R17
+ MOVP 160(RSP), R18, R19
+ MOVP 176(RSP), R20, R21
+ MOVP 192(RSP), R22, R23
+ MOVP 208(RSP), R24, R25
MOV 256(RSP), R30 // link
@@ -612,32 +568,19 @@
TEXT vtrap(SB), 1, $-4
SUB $TRAPFRAMESIZE, RSP
- MOV R0, 16(RSP)
- MOV R1, 24(RSP)
- MOV R2, 32(RSP)
- MOV R3, 40(RSP)
- MOV R4, 48(RSP)
- MOV R5, 56(RSP)
- MOV R6, 64(RSP)
- MOV R7, 72(RSP)
- MOV R8, 80(RSP)
- MOV R9, 88(RSP)
- MOV R10, 96(RSP)
- MOV R11, 104(RSP)
- MOV R12, 112(RSP)
- MOV R13, 120(RSP)
- MOV R14, 128(RSP)
- MOV R15, 136(RSP)
- MOV R16, 144(RSP)
- MOV R17, 152(RSP)
- MOV R18, 160(RSP)
- MOV R19, 168(RSP)
- MOV R20, 176(RSP)
- MOV R21, 184(RSP)
- MOV R22, 192(RSP)
- MOV R23, 200(RSP)
- MOV R24, 208(RSP)
- MOV R25, 216(RSP)
+ MOVP R0, R1, 16(RSP)
+ MOVP R2, R3, 32(RSP)
+ MOVP R4, R5, 48(RSP)
+ MOVP R6, R7, 64(RSP)
+ MOVP R8, R9, 80(RSP)
+ MOVP R10, R11, 96(RSP)
+ MOVP R12, R13, 112(RSP)
+ MOVP R14, R15, 128(RSP)
+ MOVP R16, R17, 144(RSP)
+ MOVP R18, R19, 160(RSP)
+ MOVP R20, R21, 176(RSP)
+ MOVP R22, R23, 192(RSP)
+ MOVP R24, R25, 208(RSP)
MOV R30, 256(RSP) // link
@@ -649,32 +592,19 @@
TEXT virq(SB), 1, $-4
SUB $TRAPFRAMESIZE, RSP
- MOV R0, 16(RSP)
- MOV R1, 24(RSP)
- MOV R2, 32(RSP)
- MOV R3, 40(RSP)
- MOV R4, 48(RSP)
- MOV R5, 56(RSP)
- MOV R6, 64(RSP)
- MOV R7, 72(RSP)
- MOV R8, 80(RSP)
- MOV R9, 88(RSP)
- MOV R10, 96(RSP)
- MOV R11, 104(RSP)
- MOV R12, 112(RSP)
- MOV R13, 120(RSP)
- MOV R14, 128(RSP)
- MOV R15, 136(RSP)
- MOV R16, 144(RSP)
- MOV R17, 152(RSP)
- MOV R18, 160(RSP)
- MOV R19, 168(RSP)
- MOV R20, 176(RSP)
- MOV R21, 184(RSP)
- MOV R22, 192(RSP)
- MOV R23, 200(RSP)
- MOV R24, 208(RSP)
- MOV R25, 216(RSP)
+ MOVP R0, R1, 16(RSP)
+ MOVP R2, R3, 32(RSP)
+ MOVP R4, R5, 48(RSP)
+ MOVP R6, R7, 64(RSP)
+ MOVP R8, R9, 80(RSP)
+ MOVP R10, R11, 96(RSP)
+ MOVP R12, R13, 112(RSP)
+ MOVP R14, R15, 128(RSP)
+ MOVP R16, R17, 144(RSP)
+ MOVP R18, R19, 160(RSP)
+ MOVP R20, R21, 176(RSP)
+ MOVP R22, R23, 192(RSP)
+ MOVP R24, R25, 208(RSP)
MOV R30, 256(RSP) // link
@@ -686,32 +616,19 @@
TEXT vfiq(SB), 1, $-4
SUB $TRAPFRAMESIZE, RSP
- MOV R0, 16(RSP)
- MOV R1, 24(RSP)
- MOV R2, 32(RSP)
- MOV R3, 40(RSP)
- MOV R4, 48(RSP)
- MOV R5, 56(RSP)
- MOV R6, 64(RSP)
- MOV R7, 72(RSP)
- MOV R8, 80(RSP)
- MOV R9, 88(RSP)
- MOV R10, 96(RSP)
- MOV R11, 104(RSP)
- MOV R12, 112(RSP)
- MOV R13, 120(RSP)
- MOV R14, 128(RSP)
- MOV R15, 136(RSP)
- MOV R16, 144(RSP)
- MOV R17, 152(RSP)
- MOV R18, 160(RSP)
- MOV R19, 168(RSP)
- MOV R20, 176(RSP)
- MOV R21, 184(RSP)
- MOV R22, 192(RSP)
- MOV R23, 200(RSP)
- MOV R24, 208(RSP)
- MOV R25, 216(RSP)
+ MOVP R0, R1, 16(RSP)
+ MOVP R2, R3, 32(RSP)
+ MOVP R4, R5, 48(RSP)
+ MOVP R6, R7, 64(RSP)
+ MOVP R8, R9, 80(RSP)
+ MOVP R10, R11, 96(RSP)
+ MOVP R12, R13, 112(RSP)
+ MOVP R14, R15, 128(RSP)
+ MOVP R16, R17, 144(RSP)
+ MOVP R18, R19, 160(RSP)
+ MOVP R20, R21, 176(RSP)
+ MOVP R22, R23, 192(RSP)
+ MOVP R24, R25, 208(RSP)
MOV R30, 256(RSP) // link
MOV $(2<<32), R0 // type fiq
@@ -722,32 +639,19 @@
TEXT vserr(SB), 1, $-4
SUB $TRAPFRAMESIZE, RSP
- MOV R0, 16(RSP)
- MOV R1, 24(RSP)
- MOV R2, 32(RSP)
- MOV R3, 40(RSP)
- MOV R4, 48(RSP)
- MOV R5, 56(RSP)
- MOV R6, 64(RSP)
- MOV R7, 72(RSP)
- MOV R8, 80(RSP)
- MOV R9, 88(RSP)
- MOV R10, 96(RSP)
- MOV R11, 104(RSP)
- MOV R12, 112(RSP)
- MOV R13, 120(RSP)
- MOV R14, 128(RSP)
- MOV R15, 136(RSP)
- MOV R16, 144(RSP)
- MOV R17, 152(RSP)
- MOV R18, 160(RSP)
- MOV R19, 168(RSP)
- MOV R20, 176(RSP)
- MOV R21, 184(RSP)
- MOV R22, 192(RSP)
- MOV R23, 200(RSP)
- MOV R24, 208(RSP)
- MOV R25, 216(RSP)
+ MOVP R0, R1, 16(RSP)
+ MOVP R2, R3, 32(RSP)
+ MOVP R4, R5, 48(RSP)
+ MOVP R6, R7, 64(RSP)
+ MOVP R8, R9, 80(RSP)
+ MOVP R10, R11, 96(RSP)
+ MOVP R12, R13, 112(RSP)
+ MOVP R14, R15, 128(RSP)
+ MOVP R16, R17, 144(RSP)
+ MOVP R18, R19, 160(RSP)
+ MOVP R20, R21, 176(RSP)
+ MOVP R22, R23, 192(RSP)
+ MOVP R24, R25, 208(RSP)
MOV R30, 256(RSP) // link