/* SPDX-License-Identifier: GPL-2.0-only */ /* * linux/arch/arm/lib/delay.S * * Copyright (C) 1995, 1996 Russell King */ #include #include #include #include #ifdef CONFIG_ARCH_RPC .arch armv4 #endif .text .LC0: .word loops_per_jiffy .LC1: .word UDELAY_MULT /* * loops = r0 * HZ * loops_per_jiffy / 1000000 * * r0 <= 2000 * HZ <= 1000 */ SYM_TYPED_FUNC_START(__loop_udelay) ldr r2, .LC1 mul r0, r2, r0 @ r0 = delay_us * UDELAY_MULT b __loop_const_udelay SYM_FUNC_END(__loop_udelay) SYM_TYPED_FUNC_START(__loop_const_udelay) @ 0 <= r0 <= 0xfffffaf0 ldr r2, .LC0 ldr r2, [r2] umull r1, r0, r2, r0 @ r0-r1 = r0 * loops_per_jiffy adds r1, r1, #0xffffffff @ rounding up ... adcs r0, r0, r0 @ and right shift by 31 reteq lr b __loop_delay SYM_FUNC_END(__loop_const_udelay) .align 3 @ Delay routine SYM_TYPED_FUNC_START(__loop_delay) subs r0, r0, #1 #if 0 retls lr subs r0, r0, #1 retls lr subs r0, r0, #1 retls lr subs r0, r0, #1 retls lr subs r0, r0, #1 retls lr subs r0, r0, #1 retls lr subs r0, r0, #1 retls lr subs r0, r0, #1 #endif bhi __loop_delay ret lr SYM_FUNC_END(__loop_delay)