|
@@ -88,10 +88,10 @@
|
|
|
*/
|
|
|
#define __virt_to_phys(x) ({ \
|
|
|
phys_addr_t __x = (phys_addr_t)(x); \
|
|
|
- __x >= PAGE_OFFSET ? (__x - PAGE_OFFSET + PHYS_OFFSET) : \
|
|
|
- (__x - kimage_voffset); })
|
|
|
+ __x & BIT(VA_BITS - 1) ? (__x & ~PAGE_OFFSET) + PHYS_OFFSET : \
|
|
|
+ (__x - kimage_voffset); })
|
|
|
|
|
|
-#define __phys_to_virt(x) ((unsigned long)((x) - PHYS_OFFSET + PAGE_OFFSET))
|
|
|
+#define __phys_to_virt(x) ((unsigned long)((x) - PHYS_OFFSET) | PAGE_OFFSET)
|
|
|
#define __phys_to_kimg(x) ((unsigned long)((x) + kimage_voffset))
|
|
|
|
|
|
/*
|
|
@@ -132,6 +132,7 @@
|
|
|
|
|
|
#ifndef __ASSEMBLY__
|
|
|
|
|
|
+#include <linux/bitops.h>
|
|
|
#include <linux/mmdebug.h>
|
|
|
|
|
|
extern phys_addr_t memstart_addr;
|