12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152 |
- /*
- * linux/arch/unicore32/lib/delay.S
- *
- * Code specific to PKUnity SoC and UniCore ISA
- *
- * Copyright (C) 2001-2010 GUAN Xue-tao
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License version 2 as
- * published by the Free Software Foundation.
- */
- #include <linux/linkage.h>
- #include <asm/assembler.h>
- #include <asm/param.h>
- .text
- .LC0: .word loops_per_jiffy
- .LC1: .word (2199023*HZ)>>11
- /*
- * r0 <= 2000
- * lpj <= 0x01ffffff (max. 3355 bogomips)
- * HZ <= 1000
- */
- ENTRY(__udelay)
- ldw r2, .LC1
- mul r0, r2, r0
- ENTRY(__const_udelay) @ 0 <= r0 <= 0x7fffff06
- ldw r2, .LC0
- ldw r2, [r2] @ max = 0x01ffffff
- mov r0, r0 >> #14 @ max = 0x0001ffff
- mov r2, r2 >> #10 @ max = 0x00007fff
- mul r0, r2, r0 @ max = 2^32-1
- mov.a r0, r0 >> #6
- cmoveq pc, lr
- /*
- * loops = r0 * HZ * loops_per_jiffy / 1000000
- *
- * Oh, if only we had a cycle counter...
- */
- @ Delay routine
- ENTRY(__delay)
- sub.a r0, r0, #2
- bua __delay
- mov pc, lr
- ENDPROC(__udelay)
- ENDPROC(__const_udelay)
- ENDPROC(__delay)
|