/* SPDX-License-Identifier: GPL-2.0-or-later */
/*
* This file contains low-level assembler routines for managing
* the PowerPC 603 tlb invalidation.
*/
#include <asm/page.h>
#include <asm/ppc_asm.h>
#include <asm/asm-offsets.h>
/*
* Flush an entry from the TLB
*/
#ifdef CONFIG_SMP
_GLOBAL (_tlbie)
lwz r8,TASK_CPU(r2)
oris r8,r8,11
mfmsr r10
rlwinm r0,r10,0 ,17 ,15 /* clear bit 16 (MSR_EE) */
rlwinm r0,r0,0 ,28 ,26 /* clear DR */
mtmsr r0
isync
lis r9,mmu_hash_lock@h
ori r9,r9,mmu_hash_lock@l
tophys(r9,r9)
10 : lwarx r7,0 ,r9
cmpwi 0 ,r7,0
bne- 10 b
stwcx. r8,0 ,r9
bne- 10 b
eieio
tlbie r3
sync
TLBSYNC
li r0,0
stw r0,0 (r9) /* clear mmu_hash_lock */
mtmsr r10
isync
blr
_ASM_NOKPROBE_SYMBOL(_tlbie)
#endif /* CONFIG_SMP */
/*
* Flush the entire TLB. 603/603e only
*/
_GLOBAL (_tlbia)
#if defined(CONFIG_SMP)
lwz r8,TASK_CPU(r2)
oris r8,r8,10
mfmsr r10
rlwinm r0,r10,0 ,17 ,15 /* clear bit 16 (MSR_EE) */
rlwinm r0,r0,0 ,28 ,26 /* clear DR */
mtmsr r0
isync
lis r9,mmu_hash_lock@h
ori r9,r9,mmu_hash_lock@l
tophys(r9,r9)
10 : lwarx r7,0 ,r9
cmpwi 0 ,r7,0
bne- 10 b
stwcx. r8,0 ,r9
bne- 10 b
#endif /* CONFIG_SMP */
li r5, 32
lis r4, KERNELBASE@h
mtctr r5
sync
0 : tlbie r4
addi r4, r4, 0 x1000
bdnz 0 b
sync
#ifdef CONFIG_SMP
TLBSYNC
li r0,0
stw r0,0 (r9) /* clear mmu_hash_lock */
mtmsr r10
isync
#endif /* CONFIG_SMP */
blr
_ASM_NOKPROBE_SYMBOL(_tlbia)
Messung V0.5 in Prozent C=95 H=94 G=94
¤ Dauer der Verarbeitung: 0.10 Sekunden
(vorverarbeitet am 2026-06-08)
¤
*© Formatika GbR, Deutschland