2019-05-27 06:55:21 +00:00
|
|
|
/* SPDX-License-Identifier: GPL-2.0-only */
|
2017-02-01 16:53:41 +00:00
|
|
|
/* FSI device & driver interfaces
|
|
|
|
*
|
|
|
|
* Copyright (C) IBM Corporation 2016
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef LINUX_FSI_H
|
|
|
|
#define LINUX_FSI_H
|
|
|
|
|
|
|
|
#include <linux/device.h>
|
|
|
|
|
2017-02-01 16:53:42 +00:00
|
|
|
struct fsi_device {
|
2017-02-01 16:53:43 +00:00
|
|
|
struct device dev;
|
|
|
|
u8 engine_type;
|
|
|
|
u8 version;
|
2017-06-06 21:08:44 +00:00
|
|
|
u8 unit;
|
|
|
|
struct fsi_slave *slave;
|
|
|
|
uint32_t addr;
|
|
|
|
uint32_t size;
|
2017-02-01 16:53:42 +00:00
|
|
|
};
|
|
|
|
|
2017-06-06 21:08:45 +00:00
|
|
|
extern int fsi_device_read(struct fsi_device *dev, uint32_t addr,
|
|
|
|
void *val, size_t size);
|
|
|
|
extern int fsi_device_write(struct fsi_device *dev, uint32_t addr,
|
|
|
|
const void *val, size_t size);
|
|
|
|
extern int fsi_device_peek(struct fsi_device *dev, void *val);
|
|
|
|
|
2017-02-01 16:53:43 +00:00
|
|
|
struct fsi_device_id {
|
|
|
|
u8 engine_type;
|
|
|
|
u8 version;
|
|
|
|
};
|
|
|
|
|
|
|
|
#define FSI_VERSION_ANY 0
|
|
|
|
|
|
|
|
#define FSI_DEVICE(t) \
|
|
|
|
.engine_type = (t), .version = FSI_VERSION_ANY,
|
|
|
|
|
|
|
|
#define FSI_DEVICE_VERSIONED(t, v) \
|
|
|
|
.engine_type = (t), .version = (v),
|
|
|
|
|
2017-02-01 16:53:42 +00:00
|
|
|
struct fsi_driver {
|
2017-02-01 16:53:43 +00:00
|
|
|
struct device_driver drv;
|
|
|
|
const struct fsi_device_id *id_table;
|
2017-02-01 16:53:42 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
#define to_fsi_dev(devp) container_of(devp, struct fsi_device, dev)
|
|
|
|
#define to_fsi_drv(drvp) container_of(drvp, struct fsi_driver, drv)
|
|
|
|
|
2017-06-06 21:08:48 +00:00
|
|
|
extern int fsi_driver_register(struct fsi_driver *fsi_drv);
|
|
|
|
extern void fsi_driver_unregister(struct fsi_driver *fsi_drv);
|
|
|
|
|
|
|
|
/* module_fsi_driver() - Helper macro for drivers that don't do
|
|
|
|
* anything special in module init/exit. This eliminates a lot of
|
|
|
|
* boilerplate. Each module may only use this macro once, and
|
|
|
|
* calling it replaces module_init() and module_exit()
|
|
|
|
*/
|
|
|
|
#define module_fsi_driver(__fsi_driver) \
|
|
|
|
module_driver(__fsi_driver, fsi_driver_register, \
|
|
|
|
fsi_driver_unregister)
|
|
|
|
|
2017-06-06 21:08:50 +00:00
|
|
|
/* direct slave API */
|
|
|
|
extern int fsi_slave_claim_range(struct fsi_slave *slave,
|
|
|
|
uint32_t addr, uint32_t size);
|
|
|
|
extern void fsi_slave_release_range(struct fsi_slave *slave,
|
|
|
|
uint32_t addr, uint32_t size);
|
|
|
|
extern int fsi_slave_read(struct fsi_slave *slave, uint32_t addr,
|
|
|
|
void *val, size_t size);
|
|
|
|
extern int fsi_slave_write(struct fsi_slave *slave, uint32_t addr,
|
|
|
|
const void *val, size_t size);
|
|
|
|
|
2018-06-20 05:22:52 +00:00
|
|
|
extern struct bus_type fsi_bus_type;
|
|
|
|
extern const struct device_type fsi_cdev_type;
|
2017-06-06 21:08:50 +00:00
|
|
|
|
2018-06-20 05:22:52 +00:00
|
|
|
enum fsi_dev_type {
|
|
|
|
fsi_dev_cfam,
|
|
|
|
fsi_dev_sbefifo,
|
|
|
|
fsi_dev_scom,
|
|
|
|
fsi_dev_occ
|
|
|
|
};
|
2017-06-06 21:08:50 +00:00
|
|
|
|
2018-06-20 05:22:52 +00:00
|
|
|
extern int fsi_get_new_minor(struct fsi_device *fdev, enum fsi_dev_type type,
|
|
|
|
dev_t *out_dev, int *out_index);
|
|
|
|
extern void fsi_free_minor(dev_t dev);
|
2017-02-01 16:53:41 +00:00
|
|
|
|
|
|
|
#endif /* LINUX_FSI_H */
|