Commit 4f3cbd79 authored by Michal Simek's avatar Michal Simek

microblaze: Define readq and writeq IO helper function

Some drivers check if readq/writeq functions are defined.
If not internal driver functions are used which cause
compilation failures.
Signed-off-by: default avatarMichal Simek <michal.simek@xilinx.com>
parent ac1566ec
...@@ -89,6 +89,11 @@ static inline unsigned int readl(const volatile void __iomem *addr) ...@@ -89,6 +89,11 @@ static inline unsigned int readl(const volatile void __iomem *addr)
{ {
return le32_to_cpu(*(volatile unsigned int __force *)addr); return le32_to_cpu(*(volatile unsigned int __force *)addr);
} }
#define readq readq
static inline u64 readq(const volatile void __iomem *addr)
{
return le64_to_cpu(__raw_readq(addr));
}
static inline void writeb(unsigned char v, volatile void __iomem *addr) static inline void writeb(unsigned char v, volatile void __iomem *addr)
{ {
*(volatile unsigned char __force *)addr = v; *(volatile unsigned char __force *)addr = v;
...@@ -101,6 +106,7 @@ static inline void writel(unsigned int v, volatile void __iomem *addr) ...@@ -101,6 +106,7 @@ static inline void writel(unsigned int v, volatile void __iomem *addr)
{ {
*(volatile unsigned int __force *)addr = cpu_to_le32(v); *(volatile unsigned int __force *)addr = cpu_to_le32(v);
} }
#define writeq(b, addr) __raw_writeq(cpu_to_le64(b), addr)
/* ioread and iowrite variants. thease are for now same as __raw_ /* ioread and iowrite variants. thease are for now same as __raw_
* variants of accessors. we might check for endianess in the feature * variants of accessors. we might check for endianess in the feature
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment