mirror of
https://github.com/FEX-Emu/linux.git
synced 2025-01-20 00:26:28 +00:00
[AVR32] Use memcpy/memset in memcpy_{from,to}_io and memset_io
Using readb/writeb to implement these breaks NOR flash support. I can't see any reason why regular memcpy and memset shouldn't work. Signed-off-by: Haavard Skinnemoen <hskinnemoen@atmel.com>
This commit is contained in:
parent
d80e2bb126
commit
2c1a2a3441
@ -240,30 +240,19 @@ BUILDSTRING(l, u32)
|
||||
static inline void memcpy_fromio(void * to, const volatile void __iomem *from,
|
||||
unsigned long count)
|
||||
{
|
||||
char *p = to;
|
||||
volatile const char __iomem *addr = from;
|
||||
|
||||
while (count--)
|
||||
*p++ = readb(addr++);
|
||||
memcpy(to, (const void __force *)from, count);
|
||||
}
|
||||
|
||||
static inline void memcpy_toio(volatile void __iomem *to, const void * from,
|
||||
unsigned long count)
|
||||
{
|
||||
const char *p = from;
|
||||
volatile char __iomem *addr = to;
|
||||
|
||||
while (count--)
|
||||
writeb(*p++, addr++);
|
||||
memcpy((void __force *)to, from, count);
|
||||
}
|
||||
|
||||
static inline void memset_io(volatile void __iomem *addr, unsigned char val,
|
||||
unsigned long count)
|
||||
{
|
||||
volatile char __iomem *p = addr;
|
||||
|
||||
while (count--)
|
||||
writeb(val, p++);
|
||||
memset((void __force *)addr, val, count);
|
||||
}
|
||||
|
||||
#define IO_SPACE_LIMIT 0xffffffff
|
||||
|
Loading…
x
Reference in New Issue
Block a user