2009-11-28 22:34:48 +00:00
|
|
|
|
2009-10-09 17:50:31 +00:00
|
|
|
#include <grub/symbol.h>
|
|
|
|
|
2010-09-21 08:14:08 +00:00
|
|
|
.set noreorder
|
2010-09-21 09:22:52 +00:00
|
|
|
.set nomacro
|
2010-09-21 08:14:08 +00:00
|
|
|
|
2009-10-17 22:23:00 +00:00
|
|
|
FUNCTION (grub_arch_sync_caches)
|
2009-11-28 22:34:48 +00:00
|
|
|
#include "cache_flush.S"
|
2009-11-22 23:16:49 +00:00
|
|
|
j $ra
|
2011-05-13 18:56:50 +00:00
|
|
|
|
|
|
|
FUNCTION (grub_arch_sync_dma_caches)
|
|
|
|
move $t2, $a0
|
|
|
|
addu $t3, $a0, $a1
|
|
|
|
srl $t2, $t2, 5
|
|
|
|
sll $t2, $t2, 5
|
|
|
|
addu $t3, $t3, 0x1f
|
|
|
|
srl $t3, $t3, 5
|
|
|
|
sll $t3, $t3, 5
|
|
|
|
move $t0, $t2
|
|
|
|
subu $t1, $t3, $t2
|
|
|
|
1:
|
2013-11-22 03:36:53 +00:00
|
|
|
cache_op 1, 0($t0)
|
2012-06-22 21:36:33 +00:00
|
|
|
#ifdef GRUB_MACHINE_MIPS_LOONGSON
|
2013-11-22 03:36:53 +00:00
|
|
|
cache_op 1, 1($t0)
|
|
|
|
cache_op 1, 2($t0)
|
|
|
|
cache_op 1, 3($t0)
|
2012-06-22 21:36:33 +00:00
|
|
|
|
|
|
|
addiu $t1, $t1, -0x20
|
|
|
|
bne $t1, $zero, 1b
|
|
|
|
addiu $t0, $t0, 0x20
|
|
|
|
#else
|
|
|
|
addiu $t1, $t1, -4
|
2011-05-13 18:56:50 +00:00
|
|
|
bne $t1, $zero, 1b
|
2012-06-22 21:36:33 +00:00
|
|
|
addiu $t0, $t0, 0x4
|
|
|
|
#endif
|
2013-11-22 03:36:53 +00:00
|
|
|
sync_op
|
2011-05-13 18:56:50 +00:00
|
|
|
move $t0, $t2
|
|
|
|
subu $t1, $t3, $t2
|
|
|
|
2:
|
2012-06-22 21:36:33 +00:00
|
|
|
#ifdef GRUB_MACHINE_MIPS_LOONGSON
|
2013-11-22 03:36:53 +00:00
|
|
|
cache_op 0, 0($t0)
|
2012-06-22 21:36:33 +00:00
|
|
|
addiu $t1, $t1, -0x20
|
|
|
|
bne $t1, $zero, 2b
|
|
|
|
addiu $t0, $t0, 0x20
|
|
|
|
#else
|
2013-11-22 03:36:53 +00:00
|
|
|
cache_op 0, 0($t0)
|
2012-06-22 21:36:33 +00:00
|
|
|
addiu $t1, $t1, -4
|
2011-05-13 18:56:50 +00:00
|
|
|
bne $t1, $zero, 2b
|
2012-06-22 21:36:33 +00:00
|
|
|
addiu $t0, $t0, 0x4
|
|
|
|
#endif
|
2013-11-22 03:36:53 +00:00
|
|
|
sync_op
|
2011-05-13 18:56:50 +00:00
|
|
|
move $t0, $t2
|
|
|
|
subu $t1, $t3, $t2
|
|
|
|
2:
|
2012-06-22 21:36:33 +00:00
|
|
|
#ifdef GRUB_MACHINE_MIPS_LOONGSON
|
2013-11-22 03:36:53 +00:00
|
|
|
cache_op 23, 0($t0)
|
2012-06-22 21:36:33 +00:00
|
|
|
addiu $t1, $t1, -0x20
|
|
|
|
bne $t1, $zero, 2b
|
|
|
|
addiu $t0, $t0, 0x20
|
|
|
|
#else
|
2013-11-22 03:36:53 +00:00
|
|
|
cache_op 23, 0($t0)
|
2012-06-22 21:36:33 +00:00
|
|
|
addiu $t1, $t1, -0x4
|
2011-05-13 18:56:50 +00:00
|
|
|
bne $t1, $zero, 2b
|
2012-06-22 21:36:33 +00:00
|
|
|
addiu $t0, $t0, 0x4
|
|
|
|
#endif
|
2013-11-22 03:36:53 +00:00
|
|
|
sync_op
|
2011-05-13 18:56:50 +00:00
|
|
|
|
2015-02-23 21:33:28 +00:00
|
|
|
jr $ra
|