mirror of
https://github.com/Atmosphere-NX/Atmosphere
synced 2025-01-09 22:36:18 +00:00
thermosphere: add common asm macros
This commit is contained in:
parent
84a2dc4ad9
commit
3e7e658594
7 changed files with 101 additions and 121 deletions
|
@ -14,6 +14,8 @@
|
||||||
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#include "asm_macros.s"
|
||||||
|
|
||||||
/* The following functions are taken/adapted from https://github.com/u-boot/u-boot/blob/master/arch/arm/cpu/armv8/cache.S */
|
/* The following functions are taken/adapted from https://github.com/u-boot/u-boot/blob/master/arch/arm/cpu/armv8/cache.S */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -117,27 +119,15 @@ skip:
|
||||||
finished:
|
finished:
|
||||||
ret
|
ret
|
||||||
|
|
||||||
.section .text.flush_dcache_all, "ax", %progbits
|
FUNCTION flush_dcache_all
|
||||||
.global flush_dcache_all
|
|
||||||
.type flush_dcache_all, %function
|
|
||||||
.func flush_dcache_all
|
|
||||||
.cfi_startproc
|
|
||||||
flush_dcache_all:
|
|
||||||
mov x0, #0
|
mov x0, #0
|
||||||
b __asm_dcache_all
|
b __asm_dcache_all
|
||||||
.endfunc
|
END_FUNCTION
|
||||||
.cfi_endproc
|
|
||||||
|
|
||||||
.section .text.invalidate_dcache_all, "ax", %progbits
|
FUNCTION invalidate_dcache_all
|
||||||
.global invalidate_dcache_all
|
|
||||||
.type invalidate_dcache_all, %function
|
|
||||||
.func invalidate_dcache_all
|
|
||||||
.cfi_startproc
|
|
||||||
invalidate_dcache_all:
|
|
||||||
mov x0, #1
|
mov x0, #1
|
||||||
b __asm_dcache_all
|
b __asm_dcache_all
|
||||||
.endfunc
|
END_FUNCTION
|
||||||
.cfi_endproc
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* void __asm_flush_dcache_range(start, end) (renamed -> flush_dcache_range)
|
* void __asm_flush_dcache_range(start, end) (renamed -> flush_dcache_range)
|
||||||
|
@ -147,12 +137,8 @@ invalidate_dcache_all:
|
||||||
* x0: start address
|
* x0: start address
|
||||||
* x1: end address
|
* x1: end address
|
||||||
*/
|
*/
|
||||||
.section .text.flush_dcache_range, "ax", %progbits
|
|
||||||
.global flush_dcache_range
|
FUNCTION flush_dcache_range
|
||||||
.type flush_dcache_range, %function
|
|
||||||
.func flush_dcache_range
|
|
||||||
.cfi_startproc
|
|
||||||
flush_dcache_range:
|
|
||||||
mrs x3, ctr_el0
|
mrs x3, ctr_el0
|
||||||
lsr x3, x3, #16
|
lsr x3, x3, #16
|
||||||
and x3, x3, #0xf
|
and x3, x3, #0xf
|
||||||
|
@ -168,8 +154,7 @@ flush_dcache_range:
|
||||||
b.lo 1b
|
b.lo 1b
|
||||||
dsb sy
|
dsb sy
|
||||||
ret
|
ret
|
||||||
.endfunc
|
END_FUNCTION
|
||||||
.cfi_endproc
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* void __asm_invalidate_dcache_range(start, end) (-> invalidate_dcache_range)
|
* void __asm_invalidate_dcache_range(start, end) (-> invalidate_dcache_range)
|
||||||
|
@ -179,12 +164,7 @@ flush_dcache_range:
|
||||||
* x0: start address
|
* x0: start address
|
||||||
* x1: end address
|
* x1: end address
|
||||||
*/
|
*/
|
||||||
.section .text.invalidate_dcache_range, "ax", %progbits
|
FUNCTION invalidate_dcache_range
|
||||||
.global invalidate_dcache_range
|
|
||||||
.type invalidate_dcache_range, %function
|
|
||||||
.func invalidate_dcache_range
|
|
||||||
.cfi_startproc
|
|
||||||
invalidate_dcache_range:
|
|
||||||
mrs x3, ctr_el0
|
mrs x3, ctr_el0
|
||||||
ubfm x3, x3, #16, #19
|
ubfm x3, x3, #16, #19
|
||||||
mov x2, #4
|
mov x2, #4
|
||||||
|
@ -199,50 +179,32 @@ invalidate_dcache_range:
|
||||||
b.lo 1b
|
b.lo 1b
|
||||||
dsb sy
|
dsb sy
|
||||||
ret
|
ret
|
||||||
.endfunc
|
END_FUNCTION
|
||||||
.cfi_endproc
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* void __asm_invalidate_icache_all(void) (-> invalidate_icache_inner_shareable)
|
* void __asm_invalidate_icache_all(void) (-> invalidate_icache_inner_shareable)
|
||||||
*
|
*
|
||||||
* invalidate all icache entries.
|
* invalidate all icache entries.
|
||||||
*/
|
*/
|
||||||
.section .text.invalidate_icache_all_inner_shareable, "ax", %progbits
|
FUNCTION invalidate_icache_all_inner_shareable
|
||||||
.global invalidate_icache_all_inner_shareable
|
|
||||||
.type invalidate_icache_all_inner_shareable, %function
|
|
||||||
.func invalidate_icache_all_inner_shareable
|
|
||||||
.cfi_startproc
|
|
||||||
invalidate_icache_all_inner_shareable:
|
|
||||||
dsb ish
|
dsb ish
|
||||||
isb
|
isb
|
||||||
ic ialluis
|
ic ialluis
|
||||||
dsb ish
|
dsb ish
|
||||||
isb
|
isb
|
||||||
ret
|
ret
|
||||||
.endfunc
|
END_FUNCTION
|
||||||
.cfi_endproc
|
|
||||||
|
|
||||||
.section .text.invalidate_icache_all, "ax", %progbits
|
FUNCTION invalidate_icache_all
|
||||||
.global invalidate_icache_all
|
|
||||||
.type invalidate_icache_all, %function
|
|
||||||
.func invalidate_icache_all
|
|
||||||
.cfi_startproc
|
|
||||||
invalidate_icache_all:
|
|
||||||
dsb sy
|
dsb sy
|
||||||
isb
|
isb
|
||||||
ic iallu
|
ic iallu
|
||||||
dsb sy
|
dsb sy
|
||||||
isb
|
isb
|
||||||
ret
|
ret
|
||||||
.endfunc
|
END_FUNCTION
|
||||||
.cfi_endproc
|
|
||||||
|
|
||||||
.section .text.set_memory_registers_enable_mmu, "ax", %progbits
|
FUNCTION set_memory_registers_enable_mmu
|
||||||
.global set_memory_registers_enable_mmu
|
|
||||||
.type set_memory_registers_enable_mmu, %function
|
|
||||||
.func set_memory_registers_enable_mmu
|
|
||||||
.cfi_startproc
|
|
||||||
set_memory_registers_enable_mmu:
|
|
||||||
msr ttbr0_el2, x0
|
msr ttbr0_el2, x0
|
||||||
msr tcr_el2, x1
|
msr tcr_el2, x1
|
||||||
msr mair_el2, x2
|
msr mair_el2, x2
|
||||||
|
@ -264,15 +226,9 @@ set_memory_registers_enable_mmu:
|
||||||
isb
|
isb
|
||||||
|
|
||||||
ret
|
ret
|
||||||
.endfunc
|
END_FUNCTION
|
||||||
.cfi_endproc
|
|
||||||
|
|
||||||
.section .text.set_memory_registers_enable_stage2, "ax", %progbits
|
FUNCTION set_memory_registers_enable_stage2
|
||||||
.global set_memory_registers_enable_stage2
|
|
||||||
.type set_memory_registers_enable_stage2, %function
|
|
||||||
.func set_memory_registers_enable_stage2
|
|
||||||
.cfi_startproc
|
|
||||||
set_memory_registers_enable_stage2:
|
|
||||||
msr vttbr_el2, x0
|
msr vttbr_el2, x0
|
||||||
msr vtcr_el2, x1
|
msr vtcr_el2, x1
|
||||||
|
|
||||||
|
@ -292,5 +248,4 @@ set_memory_registers_enable_stage2:
|
||||||
isb
|
isb
|
||||||
|
|
||||||
ret
|
ret
|
||||||
.endfunc
|
END_FUNCTION
|
||||||
.cfi_endproc
|
|
||||||
|
|
36
thermosphere/src/asm_macros.s
Normal file
36
thermosphere/src/asm_macros.s
Normal file
|
@ -0,0 +1,36 @@
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2018-2019 Atmosphère-NX
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms and conditions of the GNU General Public License,
|
||||||
|
* version 2, as published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
||||||
|
* more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#define EXCEP_STACK_FRAME_SIZE 0x140
|
||||||
|
|
||||||
|
#define CORECTX_USER_FRAME_OFFSET 0x000
|
||||||
|
#define CORECTX_SCRATCH_OFFSET 0x008
|
||||||
|
#define CORECTX_CRASH_STACK_OFFSET 0x010
|
||||||
|
|
||||||
|
.macro FUNCTION name
|
||||||
|
.section .text.\name, "ax", %progbits
|
||||||
|
.global \name
|
||||||
|
.type \name, %function
|
||||||
|
.func \name
|
||||||
|
.cfi_sections .debug_frame
|
||||||
|
.cfi_startproc
|
||||||
|
\name:
|
||||||
|
.endm
|
||||||
|
|
||||||
|
.macro END_FUNCTION
|
||||||
|
.cfi_endproc
|
||||||
|
.endfunc
|
||||||
|
.endm
|
|
@ -14,14 +14,10 @@
|
||||||
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#include "asm_macros.s"
|
||||||
|
|
||||||
// Precondition: x1 <= 16
|
// Precondition: x1 <= 16
|
||||||
.section .text.loadBreakpointRegs, "ax", %progbits
|
FUNCTION loadBreakpointRegs
|
||||||
.global loadBreakpointRegs
|
|
||||||
.type loadBreakpointRegs, %function
|
|
||||||
.func loadBreakpointRegs
|
|
||||||
.cfi_startproc
|
|
||||||
loadBreakpointRegs:
|
|
||||||
// x1 = number
|
// x1 = number
|
||||||
dmb sy
|
dmb sy
|
||||||
|
|
||||||
|
@ -42,16 +38,10 @@ loadBreakpointRegs:
|
||||||
dsb sy
|
dsb sy
|
||||||
isb
|
isb
|
||||||
ret
|
ret
|
||||||
.endfunc
|
END_FUNCTION
|
||||||
.cfi_endproc
|
|
||||||
|
|
||||||
// Precondition: x1 <= 16
|
// Precondition: x1 <= 16
|
||||||
.section .text.loadWatchpointRegs, "ax", %progbits
|
FUNCTION loadWatchpointRegs
|
||||||
.global loadWatchpointRegs
|
|
||||||
.type loadWatchpointRegs, %function
|
|
||||||
.func loadWatchpointRegs
|
|
||||||
.cfi_startproc
|
|
||||||
loadWatchpointRegs:
|
|
||||||
// x1 = number
|
// x1 = number
|
||||||
dmb sy
|
dmb sy
|
||||||
|
|
||||||
|
@ -72,5 +62,4 @@ loadWatchpointRegs:
|
||||||
dsb sy
|
dsb sy
|
||||||
isb
|
isb
|
||||||
ret
|
ret
|
||||||
.endfunc
|
END_FUNCTION
|
||||||
.cfi_endproc
|
|
||||||
|
|
|
@ -1,3 +1,21 @@
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2018-2019 Atmosphère-NX
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms and conditions of the GNU General Public License,
|
||||||
|
* version 2, as published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
||||||
|
* more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "asm_macros.s"
|
||||||
|
|
||||||
/* Some macros taken from https://github.com/ARM-software/arm-trusted-firmware/blob/master/include/common/aarch64/asm_macros.S */
|
/* Some macros taken from https://github.com/ARM-software/arm-trusted-firmware/blob/master/include/common/aarch64/asm_macros.S */
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2013-2017, ARM Limited and Contributors. All rights reserved.
|
* Copyright (c) 2013-2017, ARM Limited and Contributors. All rights reserved.
|
||||||
|
@ -5,9 +23,6 @@
|
||||||
* SPDX-License-Identifier: BSD-3-Clause
|
* SPDX-License-Identifier: BSD-3-Clause
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
#define STACK_FRAME_SIZE 0x140
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Declare the exception vector table, enforcing it is aligned on a
|
* Declare the exception vector table, enforcing it is aligned on a
|
||||||
* 2KB boundary, as required by the ARMv8 architecture.
|
* 2KB boundary, as required by the ARMv8 architecture.
|
||||||
|
@ -53,7 +68,7 @@
|
||||||
.endm
|
.endm
|
||||||
|
|
||||||
.macro SAVE_MOST_REGISTERS
|
.macro SAVE_MOST_REGISTERS
|
||||||
sub sp, sp, #STACK_FRAME_SIZE
|
sub sp, sp, #EXCEP_STACK_FRAME_SIZE
|
||||||
|
|
||||||
stp x28, x29, [sp, #-0x20]
|
stp x28, x29, [sp, #-0x20]
|
||||||
stp x30, xzr, [sp, #-0x10]
|
stp x30, xzr, [sp, #-0x10]
|
||||||
|
@ -65,12 +80,12 @@
|
||||||
.macro PIVOT_STACK_FOR_CRASH
|
.macro PIVOT_STACK_FOR_CRASH
|
||||||
// Note: x18 assumed uncorrupted
|
// Note: x18 assumed uncorrupted
|
||||||
// Note: replace sp_el0 with crashing sp
|
// Note: replace sp_el0 with crashing sp
|
||||||
str x16, [x18, #8] // currentCoreCtx->scratch = x16
|
str x16, [x18, #CORECTX_SCRATCH_OFFSET]
|
||||||
mov x16, sp
|
mov x16, sp
|
||||||
msr sp_el0, x16
|
msr sp_el0, x16
|
||||||
ldr x16, [x18, #0x10] // currentCoreCtx->crashStack
|
ldr x16, [x18, #CORECTX_CRASH_STACK_OFFSET]
|
||||||
mov sp, x16
|
mov sp, x16
|
||||||
ldr x16, [x18, #8]
|
ldr x16, [x18, #CORECTX_SCRATCH_OFFSET]
|
||||||
.endm
|
.endm
|
||||||
|
|
||||||
.equ EXCEPTION_TYPE_HOST, 0
|
.equ EXCEPTION_TYPE_HOST, 0
|
||||||
|
@ -88,8 +103,8 @@ vector_entry \name
|
||||||
mov x0, sp
|
mov x0, sp
|
||||||
|
|
||||||
.if \type == EXCEPTION_TYPE_GUEST
|
.if \type == EXCEPTION_TYPE_GUEST
|
||||||
ldp x18, xzr, [sp, #STACK_FRAME_SIZE]
|
ldp x18, xzr, [sp, #EXCEP_STACK_FRAME_SIZE]
|
||||||
str x0, [x18] // currentCoreCtx->userFrame
|
str x0, [x18, #CORECTX_USER_FRAME_OFFSET]
|
||||||
mov w1, #1
|
mov w1, #1
|
||||||
.else
|
.else
|
||||||
mov w1, #0
|
mov w1, #0
|
||||||
|
@ -202,7 +217,7 @@ _restoreAllRegisters:
|
||||||
ldp x26, x27, [sp, #0xD0]
|
ldp x26, x27, [sp, #0xD0]
|
||||||
ldp x28, x29, [sp, #0xE0]
|
ldp x28, x29, [sp, #0xE0]
|
||||||
|
|
||||||
add sp, sp, #STACK_FRAME_SIZE
|
add sp, sp, #EXCEP_STACK_FRAME_SIZE
|
||||||
eret
|
eret
|
||||||
|
|
||||||
UNKNOWN_EXCEPTION _serrorSp0
|
UNKNOWN_EXCEPTION _serrorSp0
|
||||||
|
|
|
@ -14,6 +14,8 @@
|
||||||
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#include "asm_macros.s"
|
||||||
|
|
||||||
.macro LDSTORE_QREGS, op
|
.macro LDSTORE_QREGS, op
|
||||||
\op q0, q1, [x0], 0x20
|
\op q0, q1, [x0], 0x20
|
||||||
\op q2, q3, [x0], 0x20
|
\op q2, q3, [x0], 0x20
|
||||||
|
@ -33,12 +35,7 @@
|
||||||
\op q30, q31, [x0], 0x20
|
\op q30, q31, [x0], 0x20
|
||||||
.endm
|
.endm
|
||||||
|
|
||||||
.section .text.fpuLoadRegistersFromStorage, "ax", %progbits
|
FUNCTION fpuLoadRegistersFromStorage
|
||||||
.global fpuLoadRegistersFromStorage
|
|
||||||
.type fpuLoadRegistersFromStorage, %function
|
|
||||||
.func fpuLoadRegistersFromStorage
|
|
||||||
.cfi_startproc
|
|
||||||
fpuLoadRegistersFromStorage:
|
|
||||||
dmb sy
|
dmb sy
|
||||||
LDSTORE_QREGS ldp
|
LDSTORE_QREGS ldp
|
||||||
ldp x1, x2, [x0]
|
ldp x1, x2, [x0]
|
||||||
|
@ -47,14 +44,9 @@ fpuLoadRegistersFromStorage:
|
||||||
dsb sy
|
dsb sy
|
||||||
isb sy
|
isb sy
|
||||||
ret
|
ret
|
||||||
.cfi_endproc
|
END_FUNCTION
|
||||||
.endfunc
|
|
||||||
|
|
||||||
.section .text.fpuStoreRegistersToStorage, "ax", %progbits
|
FUNCTION fpuStoreRegistersToStorage
|
||||||
.global fpuStoreRegistersToStorage
|
|
||||||
.type fpuStoreRegistersToStorage, %function
|
|
||||||
.func fpuStoreRegistersToStorage
|
|
||||||
.cfi_startproc
|
|
||||||
dsb sy
|
dsb sy
|
||||||
isb sy
|
isb sy
|
||||||
LDSTORE_QREGS stp
|
LDSTORE_QREGS stp
|
||||||
|
@ -63,5 +55,4 @@ fpuLoadRegistersFromStorage:
|
||||||
stp x1, x2, [x0]
|
stp x1, x2, [x0]
|
||||||
dmb sy
|
dmb sy
|
||||||
ret
|
ret
|
||||||
.cfi_endproc
|
END_FUNCTION
|
||||||
.endfunc
|
|
||||||
|
|
|
@ -14,6 +14,8 @@
|
||||||
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#include "asm_macros.s"
|
||||||
|
|
||||||
// From Arm TF
|
// From Arm TF
|
||||||
|
|
||||||
|
|
||||||
|
@ -23,11 +25,7 @@
|
||||||
* SPDX-License-Identifier: BSD-3-Clause
|
* SPDX-License-Identifier: BSD-3-Clause
|
||||||
*/
|
*/
|
||||||
|
|
||||||
.global spinlockLock
|
FUNCTION spinlockLock
|
||||||
.type spinlockLock, %function
|
|
||||||
.func spinlockLock
|
|
||||||
.cfi_startproc
|
|
||||||
spinlockLock:
|
|
||||||
mov w2, #1
|
mov w2, #1
|
||||||
sevl
|
sevl
|
||||||
l1:
|
l1:
|
||||||
|
@ -38,16 +36,10 @@ spinlockLock:
|
||||||
stxr w1, w2, [x0]
|
stxr w1, w2, [x0]
|
||||||
cbnz w1, l2
|
cbnz w1, l2
|
||||||
ret
|
ret
|
||||||
.endfunc
|
END_FUNCTION
|
||||||
.cfi_endproc
|
|
||||||
|
|
||||||
.global spinlockUnlock
|
FUNCTION spinlockUnlock
|
||||||
.type spinlockUnlock, %function
|
|
||||||
.func spinlockUnlock
|
|
||||||
.cfi_startproc
|
|
||||||
spinlockUnlock:
|
|
||||||
stlr wzr, [x0]
|
stlr wzr, [x0]
|
||||||
sev
|
sev
|
||||||
ret
|
ret
|
||||||
.endfunc
|
END_FUNCTION
|
||||||
.cfi_endproc
|
|
||||||
|
|
|
@ -14,6 +14,8 @@
|
||||||
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#include "asm_macros.s"
|
||||||
|
|
||||||
.section .crt0, "ax", %progbits
|
.section .crt0, "ax", %progbits
|
||||||
.align 3
|
.align 3
|
||||||
.global _start
|
.global _start
|
||||||
|
@ -71,7 +73,7 @@ _startCommon:
|
||||||
|
|
||||||
// Save x18, reserve space for exception frame
|
// Save x18, reserve space for exception frame
|
||||||
stp x18, xzr, [sp, #-0x10]!
|
stp x18, xzr, [sp, #-0x10]!
|
||||||
sub sp, sp, #0x140
|
sub sp, sp, #EXCEP_STACK_FRAME_SIZE
|
||||||
|
|
||||||
dsb sy
|
dsb sy
|
||||||
isb
|
isb
|
||||||
|
|
Loading…
Reference in a new issue