1
2
3
4
5
6
7
8
9#ifndef __ASM_OUTERCACHE_H
10#define __ASM_OUTERCACHE_H
11
12#include <linux/types.h>
13
14struct l2x0_regs;
15
16struct outer_cache_fns {
17 void (*inv_range)(unsigned long, unsigned long);
18 void (*clean_range)(unsigned long, unsigned long);
19 void (*flush_range)(unsigned long, unsigned long);
20 void (*flush_all)(void);
21 void (*disable)(void);
22#ifdef CONFIG_OUTER_CACHE_SYNC
23 void (*sync)(void);
24#endif
25 void (*resume)(void);
26
27
28 void (*write_sec)(unsigned long, unsigned);
29 void (*configure)(const struct l2x0_regs *);
30};
31
32extern struct outer_cache_fns outer_cache;
33
34#ifdef CONFIG_OUTER_CACHE
35
36
37
38
39
40static inline void outer_inv_range(phys_addr_t start, phys_addr_t end)
41{
42 if (outer_cache.inv_range)
43 outer_cache.inv_range(start, end);
44}
45
46
47
48
49
50
51static inline void outer_clean_range(phys_addr_t start, phys_addr_t end)
52{
53 if (outer_cache.clean_range)
54 outer_cache.clean_range(start, end);
55}
56
57
58
59
60
61
62static inline void outer_flush_range(phys_addr_t start, phys_addr_t end)
63{
64 if (outer_cache.flush_range)
65 outer_cache.flush_range(start, end);
66}
67
68
69
70
71
72
73
74
75
76
77
78
79static inline void outer_flush_all(void)
80{
81 if (outer_cache.flush_all)
82 outer_cache.flush_all();
83}
84
85
86
87
88
89
90
91
92extern void outer_disable(void);
93
94
95
96
97
98
99
100static inline void outer_resume(void)
101{
102 if (outer_cache.resume)
103 outer_cache.resume();
104}
105
106#else
107
108static inline void outer_inv_range(phys_addr_t start, phys_addr_t end)
109{ }
110static inline void outer_clean_range(phys_addr_t start, phys_addr_t end)
111{ }
112static inline void outer_flush_range(phys_addr_t start, phys_addr_t end)
113{ }
114static inline void outer_flush_all(void) { }
115static inline void outer_disable(void) { }
116static inline void outer_resume(void) { }
117
118#endif
119
120#endif
121