forked from ~ljy/RK356X_SDK_RELEASE

hc
2023-12-09 95099d4622f8cb224d94e314c7a8e0df60b13f87
kernel/arch/microblaze/include/asm/highmem.h
....@@ -25,8 +25,6 @@
2525 #include <linux/uaccess.h>
2626 #include <asm/fixmap.h>
2727
28
-extern pte_t *kmap_pte;
29
-extern pgprot_t kmap_prot;
3028 extern pte_t *pkmap_page_table;
3129
3230 /*
....@@ -51,34 +49,13 @@
5149 #define PKMAP_NR(virt) ((virt - PKMAP_BASE) >> PAGE_SHIFT)
5250 #define PKMAP_ADDR(nr) (PKMAP_BASE + ((nr) << PAGE_SHIFT))
5351
54
-extern void *kmap_high(struct page *page);
55
-extern void kunmap_high(struct page *page);
56
-extern void *kmap_atomic_prot(struct page *page, pgprot_t prot);
57
-extern void __kunmap_atomic(void *kvaddr);
58
-
59
-static inline void *kmap(struct page *page)
60
-{
61
- might_sleep();
62
- if (!PageHighMem(page))
63
- return page_address(page);
64
- return kmap_high(page);
65
-}
66
-
67
-static inline void kunmap(struct page *page)
68
-{
69
- BUG_ON(in_interrupt());
70
- if (!PageHighMem(page))
71
- return;
72
- kunmap_high(page);
73
-}
74
-
75
-static inline void *kmap_atomic(struct page *page)
76
-{
77
- return kmap_atomic_prot(page, kmap_prot);
78
-}
79
-
8052 #define flush_cache_kmaps() { flush_icache(); flush_dcache(); }
8153
54
+#define arch_kmap_local_post_map(vaddr, pteval) \
55
+ local_flush_tlb_page(NULL, vaddr);
56
+#define arch_kmap_local_post_unmap(vaddr) \
57
+ local_flush_tlb_page(NULL, vaddr);
58
+
8259 #endif /* __KERNEL__ */
8360
8461 #endif /* _ASM_HIGHMEM_H */