diff options
| author | Charles Perry <[email protected]> | 2024-03-21 22:04:33 +0000 |
|---|---|---|
| committer | Xu Yilun <[email protected]> | 2024-03-31 14:41:26 +0000 |
| commit | a52e3a9dba347134ee53ebfe68b7b22548a387b0 (patch) | |
| tree | d8d2554f154286613efaf604d205c351273c58ff /drivers/fpga/xilinx-core.h | |
| parent | fpga: bridge: add owner module and take its refcount (diff) | |
| download | kernel-a52e3a9dba347134ee53ebfe68b7b22548a387b0.tar.gz kernel-a52e3a9dba347134ee53ebfe68b7b22548a387b0.zip | |
fpga: xilinx-spi: extract a common driver core
Factor out the gpio handshaking (using PROGRAM_B, INIT_B and DONE)
protocol in xilinx-core so that it can be reused for another driver.
This commit does not change anything functionally to xilinx-spi.
xilinx-core expects drivers to provide a write(const char* buf,
size_t count) function that performs the actual write to the device,
as well as a struct device* for resource management.
Signed-off-by: Charles Perry <[email protected]>
Acked-by: Xu Yilun <[email protected]>
Link: https://lore.kernel.org/r/[email protected]
Signed-off-by: Xu Yilun <[email protected]>
Diffstat (limited to 'drivers/fpga/xilinx-core.h')
| -rw-r--r-- | drivers/fpga/xilinx-core.h | 27 |
1 files changed, 27 insertions, 0 deletions
diff --git a/drivers/fpga/xilinx-core.h b/drivers/fpga/xilinx-core.h new file mode 100644 index 000000000000..f02ac67fce7b --- /dev/null +++ b/drivers/fpga/xilinx-core.h @@ -0,0 +1,27 @@ +/* SPDX-License-Identifier: GPL-2.0-only */ + +#ifndef __XILINX_CORE_H +#define __XILINX_CORE_H + +#include <linux/device.h> + +/** + * struct xilinx_fpga_core - interface between the driver and the core manager + * of Xilinx 7 Series FPGA manager + * @dev: device node + * @write: write callback of the driver + */ +struct xilinx_fpga_core { +/* public: */ + struct device *dev; + int (*write)(struct xilinx_fpga_core *core, const char *buf, + size_t count); +/* private: handled by xilinx-core */ + struct gpio_desc *prog_b; + struct gpio_desc *init_b; + struct gpio_desc *done; +}; + +int xilinx_core_probe(struct xilinx_fpga_core *core); + +#endif /* __XILINX_CORE_H */ |
