2021-03-05 12:19:52 +00:00
|
|
|
/* 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
|
2021-09-20 21:32:49 +00:00
|
|
|
void iounmap(void volatile __iomem *addr);
|
2021-03-05 12:19:52 +00:00
|
|
|
|
|
|
|
#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 */
|