123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156 |
- #ifndef ZEPHYR_INCLUDE_DRIVERS_FPGA_H_
- #define ZEPHYR_INCLUDE_DRIVERS_FPGA_H_
- #include <zephyr/types.h>
- #include <sys/util.h>
- #include <device.h>
- #ifdef __cplusplus
- extern "C" {
- #endif
- enum FPGA_status {
-
- FPGA_STATUS_INACTIVE,
-
- FPGA_STATUS_ACTIVE
- };
- typedef enum FPGA_status (*fpga_api_get_status)(const struct device *dev);
- typedef int (*fpga_api_load)(const struct device *dev, uint32_t *image_ptr,
- uint32_t img_size);
- typedef int (*fpga_api_reset)(const struct device *dev);
- typedef int (*fpga_api_on)(const struct device *dev);
- typedef int (*fpga_api_off)(const struct device *dev);
- typedef const char *(*fpga_api_get_info)(const struct device *dev);
- __subsystem struct fpga_driver_api {
- fpga_api_get_status get_status;
- fpga_api_reset reset;
- fpga_api_load load;
- fpga_api_on on;
- fpga_api_off off;
- fpga_api_get_info get_info;
- };
- static inline enum FPGA_status fpga_get_status(const struct device *dev)
- {
- const struct fpga_driver_api *api =
- (const struct fpga_driver_api *)dev->api;
- return api->get_status(dev);
- }
- static inline int fpga_reset(const struct device *dev)
- {
- const struct fpga_driver_api *api =
- (const struct fpga_driver_api *)dev->api;
- return api->reset(dev);
- }
- static inline int fpga_load(const struct device *dev, uint32_t *image_ptr,
- uint32_t img_size)
- {
- const struct fpga_driver_api *api =
- (const struct fpga_driver_api *)dev->api;
- return api->load(dev, image_ptr, img_size);
- }
- static inline int fpga_on(const struct device *dev)
- {
- const struct fpga_driver_api *api =
- (const struct fpga_driver_api *)dev->api;
- if (api->on == NULL) {
- return -ENOTSUP;
- }
- return api->on(dev);
- }
- static inline const char *fpga_get_info(const struct device *dev)
- {
- const struct fpga_driver_api *api =
- (const struct fpga_driver_api *)dev->api;
- return api->get_info(dev);
- }
- static inline int fpga_off(const struct device *dev)
- {
- const struct fpga_driver_api *api =
- (const struct fpga_driver_api *)dev->api;
- if (api->off == NULL) {
- return -ENOTSUP;
- }
- return api->off(dev);
- }
- #ifdef __cplusplus
- }
- #endif
- #endif
|