[PATCH v3] MIPS: add virt_to_phys() and phys_to_virt()
Oleksij Rempel
linux at rempel-privat.de
Fri Aug 11 07:26:10 PDT 2017
From: Antony Pavlov <antonynpavlov at gmail.com>
Signed-off-by: Antony Pavlov <antonynpavlov at gmail.com>
Signed-off-by: Peter Mamonov <pmamonov at gmail.com>
Signed-off-by: Oleksij Rempel <linux at rempel-privat.de>
---
changes.
v3:
- remove some comments.
v2:
- make use of use CPHYSADDR and CKSEG0ADDR
arch/mips/include/asm/io.h | 25 +++++++++++++++++++++++++
1 file changed, 25 insertions(+)
diff --git a/arch/mips/include/asm/io.h b/arch/mips/include/asm/io.h
index 4bee5913a..5a4cbf564 100644
--- a/arch/mips/include/asm/io.h
+++ b/arch/mips/include/asm/io.h
@@ -12,11 +12,36 @@
#include <linux/compiler.h>
#include <asm/types.h>
+#include <asm/addrspace.h>
#include <asm/byteorder.h>
void dma_flush_range(unsigned long, unsigned long);
void dma_inv_range(unsigned long, unsigned long);
+/*
+ * virt_to_phys - map virtual addresses to physical
+ * @address: address to remap
+ *
+ * The returned physical address is the physical (CPU) mapping for
+ * the memory address given.
+ */
+static inline unsigned long virt_to_phys(const void *address)
+{
+ return (unsigned long)CPHYSADDR(address);
+}
+
+/*
+ * phys_to_virt - map physical address to virtual
+ * @address: address to remap
+ *
+ * The returned virtual address is a current CPU mapping for
+ * the memory address given.
+ */
+static inline void *phys_to_virt(unsigned long address)
+{
+ return (void *)CKSEG0ADDR(address);
+}
+
#define IO_SPACE_LIMIT 0
/*****************************************************************************/
--
2.11.0
More information about the barebox
mailing list