/* SPDX-License-Identifier: GPL-2.0 */
/*
* __clear_user_page, __clear_user, clear_page implementation of SuperH
*
* Copyright (C) 2001 Kaz Kojima
* Copyright (C) 2001, 2002 Niibe Yutaka
* Copyright (C) 2006 Paul Mundt
*/
#include <linux/linkage.h>
#include <asm/page.h>
ENTRY(__clear_user)
!
mov #0 , r0
mov #0 xffffffe0, r1
!
! r4..(r4+31)&~32 -------- not aligned [ Area 0 ]
! (r4+31)&~32..(r4+r5)&~32 -------- aligned [ Area 1 ]
! (r4+r5)&~32..r4+r5 -------- not aligned [ Area 2 ]
!
! Clear area 0
mov r4, r2
!
tst r1, r5 ! length < 32
bt .Larea2 ! skip to remainder
!
add #31 , r2
and r1, r2
cmp/eq r4, r2
bt .Larea1
mov r2, r3
sub r4, r3
mov r3, r7
mov r4, r2
!
.L0: dt r3
0 : mov.b r0, @r2
bf/s .L0
add #1 , r2
!
sub r7, r5
mov r2, r4
.Larea1:
mov r4, r3
add r5, r3
and r1, r3
cmp/hi r2, r3
bf .Larea2
!
! Clear area 1
#if defined(CONFIG_CPU_SH4)
1 : movca.l r0, @r2
#else
1 : mov.l r0, @r2
#endif
add #4 , r2
2 : mov.l r0, @r2
add #4 , r2
3 : mov.l r0, @r2
add #4 , r2
4 : mov.l r0, @r2
add #4 , r2
5 : mov.l r0, @r2
add #4 , r2
6 : mov.l r0, @r2
add #4 , r2
7 : mov.l r0, @r2
add #4 , r2
8 : mov.l r0, @r2
add #4 , r2
cmp/hi r2, r3
bt/s 1 b
nop
!
! Clear area 2
.Larea2:
mov r4, r3
add r5, r3
cmp/hs r3, r2
bt/s .Ldone
sub r2, r3
.L2: dt r3
9 : mov.b r0, @r2
bf/s .L2
add #1 , r2
!
.Ldone: rts
mov #0 , r0 ! return 0 as normal return
! return the number of bytes remained
.Lbad_clear_user:
mov r4, r0
add r5, r0
rts
sub r2, r0
.section __ex_table,"a"
.align 2
.long 0 b, .Lbad_clear_user
.long 1 b, .Lbad_clear_user
.long 2 b, .Lbad_clear_user
.long 3 b, .Lbad_clear_user
.long 4 b, .Lbad_clear_user
.long 5 b, .Lbad_clear_user
.long 6 b, .Lbad_clear_user
.long 7 b, .Lbad_clear_user
.long 8 b, .Lbad_clear_user
.long 9 b, .Lbad_clear_user
.previous
Messung V0.5 in Prozent C=98 H=97 G=97
¤ Dauer der Verarbeitung: 0.9 Sekunden
(vorverarbeitet am 2026-06-08)
¤
*© Formatika GbR, Deutschland