404

[ Avaa Bypassed ]




Upload:

Command:

botdev@18.217.142.228: ~ $
/* SPDX-License-Identifier: GPL-2.0 */
#ifndef _ASM_SCORE_ASMMACRO_H
#define _ASM_SCORE_ASMMACRO_H

#include <asm/asm-offsets.h>

#ifdef __ASSEMBLY__

.macro	SAVE_ALL
	mfcr	r30, cr0
	mv	r31, r0
	nop
	/* if UMs == 1, change stack. */
	slli.c	r30, r30, 28
	bpl	1f
	la	r31, kernelsp
	lw	r31, [r31]
1:
	mv	r30, r0
	addri	r0, r31, -PT_SIZE

	sw	r30, [r0, PT_R0]
	.set	r1
	sw	r1, [r0, PT_R1]
	.set	nor1
	sw	r2, [r0, PT_R2]
	sw	r3, [r0, PT_R3]
	sw	r4, [r0, PT_R4]
	sw	r5, [r0, PT_R5]
	sw	r6, [r0, PT_R6]
	sw	r7, [r0, PT_R7]

	sw	r8, [r0, PT_R8]
	sw	r9, [r0, PT_R9]
	sw	r10, [r0, PT_R10]
	sw	r11, [r0, PT_R11]
	sw	r12, [r0, PT_R12]
	sw	r13, [r0, PT_R13]
	sw	r14, [r0, PT_R14]
	sw	r15, [r0, PT_R15]

	sw	r16, [r0, PT_R16]
	sw	r17, [r0, PT_R17]
	sw	r18, [r0, PT_R18]
	sw	r19, [r0, PT_R19]
	sw	r20, [r0, PT_R20]
	sw	r21, [r0, PT_R21]
	sw	r22, [r0, PT_R22]
	sw	r23, [r0, PT_R23]

	sw	r24, [r0, PT_R24]
	sw	r25, [r0, PT_R25]
	sw	r25, [r0, PT_R25]
	sw	r26, [r0, PT_R26]
	sw	r27, [r0, PT_R27]

	sw	r28, [r0, PT_R28]
	sw	r29, [r0, PT_R29]
	orri	r28, r0, 0x1fff
	li	r31, 0x00001fff
	xor	r28, r28, r31

	mfcehl	r30, r31
	sw	r30, [r0, PT_CEH]
	sw	r31, [r0, PT_CEL]

	mfcr	r31, cr0
	sw	r31, [r0, PT_PSR]

	mfcr	r31, cr1
	sw	r31, [r0, PT_CONDITION]

	mfcr	r31, cr2
	sw	r31, [r0, PT_ECR]
	
	mfcr	r31, cr5
	srli	r31, r31, 1
	slli	r31, r31, 1
	sw	r31, [r0, PT_EPC]
.endm

.macro	RESTORE_ALL_AND_RET
	mfcr	r30, cr0
	srli	r30, r30, 1
	slli	r30, r30, 1
	mtcr	r30, cr0
	nop
	nop
	nop
	nop
	nop

	.set	r1
	ldis	r1, 0x00ff
	and	r30, r30, r1
	not	r1, r1
	lw	r31, [r0, PT_PSR]
	and	r31, r31, r1
	.set	nor1
	or	r31, r31, r30
	mtcr	r31, cr0
	nop
	nop
	nop
	nop
	nop

	lw	r30, [r0, PT_CONDITION]
	mtcr	r30, cr1
	nop
	nop
	nop
	nop
	nop

	lw	r30, [r0, PT_CEH]
	lw	r31, [r0, PT_CEL]
	mtcehl	r30, r31

	.set	r1
	lw	r1, [r0, PT_R1]
	.set	nor1
	lw	r2, [r0, PT_R2]
	lw	r3, [r0, PT_R3]
	lw	r4, [r0, PT_R4]
	lw	r5, [r0, PT_R5]
	lw	r6, [r0, PT_R6]
	lw	r7, [r0, PT_R7]

	lw	r8, [r0, PT_R8]
	lw	r9, [r0, PT_R9]
	lw	r10, [r0, PT_R10]
	lw	r11, [r0, PT_R11]
	lw	r12, [r0, PT_R12]
	lw	r13, [r0, PT_R13]
	lw	r14, [r0, PT_R14]
	lw	r15, [r0, PT_R15]

	lw	r16, [r0, PT_R16]
	lw	r17, [r0, PT_R17]
	lw	r18, [r0, PT_R18]
	lw	r19, [r0, PT_R19]
	lw	r20, [r0, PT_R20]
	lw	r21, [r0, PT_R21]
	lw	r22, [r0, PT_R22]
	lw	r23, [r0, PT_R23]

	lw	r24, [r0, PT_R24]
	lw	r25, [r0, PT_R25]
	lw	r26, [r0, PT_R26]
	lw	r27, [r0, PT_R27]
	lw	r28, [r0, PT_R28]
	lw	r29, [r0, PT_R29]

	lw	r30, [r0, PT_EPC]
	lw	r0, [r0, PT_R0]
	mtcr	r30, cr5
	rte
.endm

#endif /* __ASSEMBLY__ */
#endif /* _ASM_SCORE_ASMMACRO_H */

Filemanager

Name Type Size Permission Actions
Kbuild File 340 B 0644
asm-offsets.h File 35 B 0644
asmmacro.h File 2.48 KB 0644
atomic.h File 187 B 0644
bitops.h File 266 B 0644
bug.h File 578 B 0644
bugs.h File 154 B 0644
cache.h File 199 B 0644
cacheflush.h File 1.63 KB 0644
checksum.h File 5.61 KB 0644
cmpxchg.h File 1.02 KB 0644
delay.h File 567 B 0644
device.h File 162 B 0644
div64.h File 158 B 0644
dma.h File 171 B 0644
elf.h File 2.84 KB 0644
emergency-restart.h File 206 B 0644
exec.h File 181 B 0644
fixmap.h File 2.38 KB 0644
ftrace.h File 90 B 0644
futex.h File 158 B 0644
hardirq.h File 166 B 0644
hw_irq.h File 90 B 0644
io.h File 212 B 0644
irq.h File 794 B 0644
irq_regs.h File 258 B 0644
irqflags.h File 1.9 KB 0644
kdebug.h File 162 B 0644
kmap_types.h File 178 B 0644
linkage.h File 189 B 0644
local.h File 158 B 0644
local64.h File 33 B 0644
mmu.h File 157 B 0644
mmu_context.h File 2.68 KB 0644
module.h File 949 B 0644
page.h File 2.84 KB 0644
pci.h File 81 B 0644
percpu.h File 162 B 0644
pgalloc.h File 1.81 KB 0644
pgtable-bits.h File 990 B 0644
pgtable.h File 7.29 KB 0644
processor.h File 2.39 KB 0644
ptrace.h File 749 B 0644
scoreregs.h File 1.4 KB 0644
segment.h File 513 B 0644
setup.h File 1.01 KB 0644
shmparam.h File 170 B 0644
string.h File 327 B 0644
switch_to.h File 323 B 0644
syscalls.h File 229 B 0644
thread_info.h File 2.55 KB 0644
timex.h File 216 B 0644
tlb.h File 538 B 0644
tlbflush.h File 3.02 KB 0644
topology.h File 170 B 0644
uaccess.h File 10.78 KB 0644
ucontext.h File 34 B 0644
unaligned.h File 174 B 0644
user.h File 437 B 0644