mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2024-12-24 11:34:50 +08:00
ca2e334232
Add IO memory emulation that uses callbacks for read/write to the allocated regions. The callbacks can be registered by the users using logic_iomem_alloc(). To use, an architecture must 'select LOGIC_IOMEM' in Kconfig and then include <asm-generic/logic_io.h> into asm/io.h to get the __raw_read*/__raw_write* functions. Optionally, an architecture may 'select LOGIC_IOMEM_FALLBACK' in which case non-emulated regions will 'fall back' to the various real_* functions that must then be provided. Cc: Arnd Bergmann <arnd@kernel.org> Signed-off-by: Johannes Berg <johannes.berg@intel.com> Signed-off-by: Richard Weinberger <richard@nod.at>
79 lines
2.3 KiB
C
79 lines
2.3 KiB
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
/*
|
|
* Copyright (C) 2021 Intel Corporation
|
|
* Author: johannes@sipsolutions.net
|
|
*/
|
|
#ifndef _LOGIC_IO_H
|
|
#define _LOGIC_IO_H
|
|
#include <linux/types.h>
|
|
|
|
/* include this file into asm/io.h */
|
|
|
|
#ifdef CONFIG_INDIRECT_IOMEM
|
|
|
|
#ifdef CONFIG_INDIRECT_IOMEM_FALLBACK
|
|
/*
|
|
* If you want emulated IO memory to fall back to 'normal' IO memory
|
|
* if a region wasn't registered as emulated, then you need to have
|
|
* all of the real_* functions implemented.
|
|
*/
|
|
#if !defined(real_ioremap) || !defined(real_iounmap) || \
|
|
!defined(real_raw_readb) || !defined(real_raw_writeb) || \
|
|
!defined(real_raw_readw) || !defined(real_raw_writew) || \
|
|
!defined(real_raw_readl) || !defined(real_raw_writel) || \
|
|
(defined(CONFIG_64BIT) && \
|
|
(!defined(real_raw_readq) || !defined(real_raw_writeq))) || \
|
|
!defined(real_memset_io) || \
|
|
!defined(real_memcpy_fromio) || \
|
|
!defined(real_memcpy_toio)
|
|
#error "Must provide fallbacks for real IO memory access"
|
|
#endif /* defined ... */
|
|
#endif /* CONFIG_INDIRECT_IOMEM_FALLBACK */
|
|
|
|
#define ioremap ioremap
|
|
void __iomem *ioremap(phys_addr_t offset, size_t size);
|
|
|
|
#define iounmap iounmap
|
|
void iounmap(void __iomem *addr);
|
|
|
|
#define __raw_readb __raw_readb
|
|
u8 __raw_readb(const volatile void __iomem *addr);
|
|
|
|
#define __raw_readw __raw_readw
|
|
u16 __raw_readw(const volatile void __iomem *addr);
|
|
|
|
#define __raw_readl __raw_readl
|
|
u32 __raw_readl(const volatile void __iomem *addr);
|
|
|
|
#ifdef CONFIG_64BIT
|
|
#define __raw_readq __raw_readq
|
|
u64 __raw_readq(const volatile void __iomem *addr);
|
|
#endif /* CONFIG_64BIT */
|
|
|
|
#define __raw_writeb __raw_writeb
|
|
void __raw_writeb(u8 value, volatile void __iomem *addr);
|
|
|
|
#define __raw_writew __raw_writew
|
|
void __raw_writew(u16 value, volatile void __iomem *addr);
|
|
|
|
#define __raw_writel __raw_writel
|
|
void __raw_writel(u32 value, volatile void __iomem *addr);
|
|
|
|
#ifdef CONFIG_64BIT
|
|
#define __raw_writeq __raw_writeq
|
|
void __raw_writeq(u64 value, volatile void __iomem *addr);
|
|
#endif /* CONFIG_64BIT */
|
|
|
|
#define memset_io memset_io
|
|
void memset_io(volatile void __iomem *addr, int value, size_t size);
|
|
|
|
#define memcpy_fromio memcpy_fromio
|
|
void memcpy_fromio(void *buffer, const volatile void __iomem *addr,
|
|
size_t size);
|
|
|
|
#define memcpy_toio memcpy_toio
|
|
void memcpy_toio(volatile void __iomem *addr, const void *buffer, size_t size);
|
|
|
|
#endif /* CONFIG_INDIRECT_IOMEM */
|
|
#endif /* _LOGIC_IO_H */
|