summaryrefslogtreecommitdiffstats
path: root/grub-core/kern/mips/cache.S
blob: fa331eca1bede6828e1929252a662275f7fa6ef4 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
#include <grub/symbol.h>

	.set noreorder
	.set nomacro

FUNCTION (grub_arch_sync_caches)
#include "cache_flush.S"
	j $ra
	 nop

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:
	cache_op 1, 0($t0)
#ifdef GRUB_MACHINE_MIPS_LOONGSON
	cache_op 1, 1($t0)
	cache_op 1, 2($t0)
	cache_op 1, 3($t0)

	addiu $t1, $t1, -0x20
	bne $t1, $zero, 1b
	 addiu $t0, $t0, 0x20
#else
	addiu $t1, $t1, -4
	bne $t1, $zero, 1b
	 addiu $t0, $t0, 0x4
#endif
	sync_op
	move $t0, $t2
	subu $t1, $t3, $t2
2:
#ifdef GRUB_MACHINE_MIPS_LOONGSON
	cache_op 0, 0($t0)
	addiu $t1, $t1, -0x20
	bne $t1, $zero, 2b
	 addiu $t0, $t0, 0x20
#else
	cache_op 0, 0($t0)
	addiu $t1, $t1, -4
	bne $t1, $zero, 2b
	 addiu $t0, $t0, 0x4
#endif
	sync_op
	move $t0, $t2
	subu $t1, $t3, $t2
2:
#ifdef GRUB_MACHINE_MIPS_LOONGSON
	cache_op 23, 0($t0)
	addiu $t1, $t1, -0x20
	bne $t1, $zero, 2b
	 addiu $t0, $t0, 0x20
#else
	cache_op 23, 0($t0)
	addiu $t1, $t1, -0x4
	bne $t1, $zero, 2b
	 addiu $t0, $t0, 0x4
#endif
	sync_op

	jr $ra
	 nop