Revert "xtensa: cache inquiry and unaligned cache handling functions"
Drop unaligned dcache management functions as they are no longer used.
This reverts commit bd974240c9
("xtensa: cache inquiry and
unaligned cache handling functions").
Signed-off-by: Max Filippov <jcmvbkbc@gmail.com>
This commit is contained in:
Родитель
0d848afe11
Коммит
e2b31f7540
|
@ -174,99 +174,4 @@ extern void copy_from_user_page(struct vm_area_struct*, struct page*,
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#define XTENSA_CACHEBLK_LOG2 29
|
|
||||||
#define XTENSA_CACHEBLK_SIZE (1 << XTENSA_CACHEBLK_LOG2)
|
|
||||||
#define XTENSA_CACHEBLK_MASK (7 << XTENSA_CACHEBLK_LOG2)
|
|
||||||
|
|
||||||
#if XCHAL_HAVE_CACHEATTR
|
|
||||||
static inline u32 xtensa_get_cacheattr(void)
|
|
||||||
{
|
|
||||||
u32 r;
|
|
||||||
asm volatile(" rsr %0, cacheattr" : "=a"(r));
|
|
||||||
return r;
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline u32 xtensa_get_dtlb1(u32 addr)
|
|
||||||
{
|
|
||||||
u32 r = addr & XTENSA_CACHEBLK_MASK;
|
|
||||||
return r | ((xtensa_get_cacheattr() >> (r >> (XTENSA_CACHEBLK_LOG2-2)))
|
|
||||||
& 0xF);
|
|
||||||
}
|
|
||||||
#else
|
|
||||||
static inline u32 xtensa_get_dtlb1(u32 addr)
|
|
||||||
{
|
|
||||||
u32 r;
|
|
||||||
asm volatile(" rdtlb1 %0, %1" : "=a"(r) : "a"(addr));
|
|
||||||
asm volatile(" dsync");
|
|
||||||
return r;
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline u32 xtensa_get_cacheattr(void)
|
|
||||||
{
|
|
||||||
u32 r = 0;
|
|
||||||
u32 a = 0;
|
|
||||||
do {
|
|
||||||
a -= XTENSA_CACHEBLK_SIZE;
|
|
||||||
r = (r << 4) | (xtensa_get_dtlb1(a) & 0xF);
|
|
||||||
} while (a);
|
|
||||||
return r;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
static inline int xtensa_need_flush_dma_source(u32 addr)
|
|
||||||
{
|
|
||||||
return (xtensa_get_dtlb1(addr) & ((1 << XCHAL_CA_BITS) - 1)) >= 4;
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline int xtensa_need_invalidate_dma_destination(u32 addr)
|
|
||||||
{
|
|
||||||
return (xtensa_get_dtlb1(addr) & ((1 << XCHAL_CA_BITS) - 1)) != 2;
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline void flush_dcache_unaligned(u32 addr, u32 size)
|
|
||||||
{
|
|
||||||
u32 cnt;
|
|
||||||
if (size) {
|
|
||||||
cnt = (size + ((XCHAL_DCACHE_LINESIZE - 1) & addr)
|
|
||||||
+ XCHAL_DCACHE_LINESIZE - 1) / XCHAL_DCACHE_LINESIZE;
|
|
||||||
while (cnt--) {
|
|
||||||
asm volatile(" dhwb %0, 0" : : "a"(addr));
|
|
||||||
addr += XCHAL_DCACHE_LINESIZE;
|
|
||||||
}
|
|
||||||
asm volatile(" dsync");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline void invalidate_dcache_unaligned(u32 addr, u32 size)
|
|
||||||
{
|
|
||||||
int cnt;
|
|
||||||
if (size) {
|
|
||||||
asm volatile(" dhwbi %0, 0 ;" : : "a"(addr));
|
|
||||||
cnt = (size + ((XCHAL_DCACHE_LINESIZE - 1) & addr)
|
|
||||||
- XCHAL_DCACHE_LINESIZE - 1) / XCHAL_DCACHE_LINESIZE;
|
|
||||||
while (cnt-- > 0) {
|
|
||||||
asm volatile(" dhi %0, %1" : : "a"(addr),
|
|
||||||
"n"(XCHAL_DCACHE_LINESIZE));
|
|
||||||
addr += XCHAL_DCACHE_LINESIZE;
|
|
||||||
}
|
|
||||||
asm volatile(" dhwbi %0, %1" : : "a"(addr),
|
|
||||||
"n"(XCHAL_DCACHE_LINESIZE));
|
|
||||||
asm volatile(" dsync");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline void flush_invalidate_dcache_unaligned(u32 addr, u32 size)
|
|
||||||
{
|
|
||||||
u32 cnt;
|
|
||||||
if (size) {
|
|
||||||
cnt = (size + ((XCHAL_DCACHE_LINESIZE - 1) & addr)
|
|
||||||
+ XCHAL_DCACHE_LINESIZE - 1) / XCHAL_DCACHE_LINESIZE;
|
|
||||||
while (cnt--) {
|
|
||||||
asm volatile(" dhwbi %0, 0" : : "a"(addr));
|
|
||||||
addr += XCHAL_DCACHE_LINESIZE;
|
|
||||||
}
|
|
||||||
asm volatile(" dsync");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif /* _XTENSA_CACHEFLUSH_H */
|
#endif /* _XTENSA_CACHEFLUSH_H */
|
||||||
|
|
Загрузка…
Ссылка в новой задаче