| /* SPDX-License-Identifier: GPL-2.0 */ |
| /* |
| * System Trace Module (STM) infrastructure |
| * Copyright (c) 2014, Intel Corporation. |
| * |
| * STM class implements generic infrastructure for System Trace Module devices |
| * as defined in MIPI STPv2 specification. |
| */ |
| |
| #ifndef _STM_STM_H_ |
| #define _STM_STM_H_ |
| |
| #include <linux/configfs.h> |
| |
| struct stp_policy; |
| struct stp_policy_node; |
| struct stm_protocol_driver; |
| |
| int stp_configfs_init(void); |
| void stp_configfs_exit(void); |
| |
| void *stp_policy_node_priv(struct stp_policy_node *pn); |
| |
| struct stp_master { |
| unsigned int nr_free; |
| unsigned long chan_map[]; |
| }; |
| |
| struct stm_device { |
| struct device dev; |
| struct module *owner; |
| struct stp_policy *policy; |
| struct mutex policy_mutex; |
| int major; |
| unsigned int sw_nmasters; |
| struct stm_data *data; |
| struct mutex link_mutex; |
| spinlock_t link_lock; |
| struct list_head link_list; |
| /* framing protocol in use */ |
| const struct stm_protocol_driver *pdrv; |
| const struct config_item_type *pdrv_node_type; |
| /* master allocation */ |
| spinlock_t mc_lock; |
| struct stp_master *masters[]; |
| }; |
| |
| #define to_stm_device(_d) \ |
| container_of((_d), struct stm_device, dev) |
| |
| struct stp_policy_node * |
| stp_policy_node_lookup(struct stm_device *stm, char *s); |
| void stp_policy_node_put(struct stp_policy_node *policy_node); |
| void stp_policy_unbind(struct stp_policy *policy); |
| |
| void stp_policy_node_get_ranges(struct stp_policy_node *policy_node, |
| unsigned int *mstart, unsigned int *mend, |
| unsigned int *cstart, unsigned int *cend); |
| |
| const struct config_item_type * |
| get_policy_node_type(struct configfs_attribute **attrs); |
| |
| struct stm_output { |
| spinlock_t lock; |
| unsigned int master; |
| unsigned int channel; |
| unsigned int nr_chans; |
| void *pdrv_private; |
| }; |
| |
| struct stm_file { |
| struct stm_device *stm; |
| struct stm_output output; |
| }; |
| |
| struct stm_device *stm_find_device(const char *name); |
| void stm_put_device(struct stm_device *stm); |
| |
| struct stm_source_device { |
| struct device dev; |
| struct stm_source_data *data; |
| spinlock_t link_lock; |
| struct stm_device __rcu *link; |
| struct list_head link_entry; |
| /* one output per stm_source device */ |
| struct stm_output output; |
| }; |
| |
| #define to_stm_source_device(_d) \ |
| container_of((_d), struct stm_source_device, dev) |
| |
| void *to_pdrv_policy_node(struct config_item *item); |
| |
| struct stm_protocol_driver { |
| struct module *owner; |
| const char *name; |
| ssize_t (*write)(struct stm_data *data, |
| struct stm_output *output, unsigned int chan, |
| const char *buf, size_t count); |
| void (*policy_node_init)(void *arg); |
| int (*output_open)(void *priv, struct stm_output *output); |
| void (*output_close)(struct stm_output *output); |
| ssize_t priv_sz; |
| struct configfs_attribute **policy_attr; |
| }; |
| |
| int stm_register_protocol(const struct stm_protocol_driver *pdrv); |
| void stm_unregister_protocol(const struct stm_protocol_driver *pdrv); |
| int stm_lookup_protocol(const char *name, |
| const struct stm_protocol_driver **pdrv, |
| const struct config_item_type **type); |
| void stm_put_protocol(const struct stm_protocol_driver *pdrv); |
| ssize_t stm_data_write(struct stm_data *data, unsigned int m, |
| unsigned int c, bool ts_first, const void *buf, |
| size_t count); |
| |
| #endif /* _STM_STM_H_ */ |