| /* SPDX-License-Identifier: GPL-2.0 */ |
| /* |
| * Copyright (C) 2021 Intel Corporation |
| * Author: johannes@sipsolutions.net |
| */ |
| #ifndef __LOGIC_IOMEM_H |
| #define __LOGIC_IOMEM_H |
| #include <linux/types.h> |
| #include <linux/ioport.h> |
| |
| /** |
| * struct logic_iomem_ops - emulated IO memory ops |
| * @read: read an 8, 16, 32 or 64 bit quantity from the given offset, |
| * size is given in bytes (1, 2, 4 or 8) |
| * (64-bit only necessary if CONFIG_64BIT is set) |
| * @write: write an 8, 16 32 or 64 bit quantity to the given offset, |
| * size is given in bytes (1, 2, 4 or 8) |
| * (64-bit only necessary if CONFIG_64BIT is set) |
| * @set: optional, for memset_io() |
| * @copy_from: optional, for memcpy_fromio() |
| * @copy_to: optional, for memcpy_toio() |
| * @unmap: optional, this region is getting unmapped |
| */ |
| struct logic_iomem_ops { |
| unsigned long (*read)(void *priv, unsigned int offset, int size); |
| void (*write)(void *priv, unsigned int offset, int size, |
| unsigned long val); |
| |
| void (*set)(void *priv, unsigned int offset, u8 value, int size); |
| void (*copy_from)(void *priv, void *buffer, unsigned int offset, |
| int size); |
| void (*copy_to)(void *priv, unsigned int offset, const void *buffer, |
| int size); |
| |
| void (*unmap)(void *priv); |
| }; |
| |
| /** |
| * struct logic_iomem_region_ops - ops for an IO memory handler |
| * @map: map a range in the registered IO memory region, must |
| * fill *ops with the ops and may fill *priv to be passed |
| * to the ops. The offset is given as the offset into the |
| * registered resource region. |
| * The return value is negative for errors, or >= 0 for |
| * success. On success, the return value is added to the |
| * offset for later ops, to allow for partial mappings. |
| */ |
| struct logic_iomem_region_ops { |
| long (*map)(unsigned long offset, size_t size, |
| const struct logic_iomem_ops **ops, |
| void **priv); |
| }; |
| |
| /** |
| * logic_iomem_add_region - register an IO memory region |
| * @resource: the resource description for this region |
| * @ops: the IO memory mapping ops for this resource |
| */ |
| int logic_iomem_add_region(struct resource *resource, |
| const struct logic_iomem_region_ops *ops); |
| |
| #endif /* __LOGIC_IOMEM_H */ |