123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271 |
- /* SPDX-License-Identifier: GPL-2.0 */
- #ifndef __LINUX_HTE_H
- #define __LINUX_HTE_H
- #include <linux/errno.h>
- struct hte_chip;
- struct hte_device;
- struct of_phandle_args;
- /**
- * enum hte_edge - HTE line edge flags.
- *
- * @HTE_EDGE_NO_SETUP: No edge setup. In this case consumer will setup edges,
- * for example during request irq call.
- * @HTE_RISING_EDGE_TS: Rising edge.
- * @HTE_FALLING_EDGE_TS: Falling edge.
- *
- */
- enum hte_edge {
- HTE_EDGE_NO_SETUP = 1U << 0,
- HTE_RISING_EDGE_TS = 1U << 1,
- HTE_FALLING_EDGE_TS = 1U << 2,
- };
- /**
- * enum hte_return - HTE subsystem return values used during callback.
- *
- * @HTE_CB_HANDLED: The consumer handled the data.
- * @HTE_RUN_SECOND_CB: The consumer needs further processing, in that case
- * HTE subsystem calls secondary callback provided by the consumer where it
- * is allowed to sleep.
- */
- enum hte_return {
- HTE_CB_HANDLED,
- HTE_RUN_SECOND_CB,
- };
- /**
- * struct hte_ts_data - HTE timestamp data.
- *
- * @tsc: Timestamp value.
- * @seq: Sequence counter of the timestamps.
- * @raw_level: Level of the line at the timestamp if provider supports it,
- * -1 otherwise.
- */
- struct hte_ts_data {
- u64 tsc;
- u64 seq;
- int raw_level;
- };
- /**
- * struct hte_clk_info - Clock source info that HTE provider uses to timestamp.
- *
- * @hz: Supported clock rate in HZ, for example 1KHz clock = 1000.
- * @type: Supported clock type.
- */
- struct hte_clk_info {
- u64 hz;
- clockid_t type;
- };
- /**
- * typedef hte_ts_cb_t - HTE timestamp data processing primary callback.
- *
- * The callback is used to push timestamp data to the client and it is
- * not allowed to sleep.
- *
- * @ts: HW timestamp data.
- * @data: Client supplied data.
- */
- typedef enum hte_return (*hte_ts_cb_t)(struct hte_ts_data *ts, void *data);
- /**
- * typedef hte_ts_sec_cb_t - HTE timestamp data processing secondary callback.
- *
- * This is used when the client needs further processing where it is
- * allowed to sleep.
- *
- * @data: Client supplied data.
- *
- */
- typedef enum hte_return (*hte_ts_sec_cb_t)(void *data);
- /**
- * struct hte_line_attr - Line attributes.
- *
- * @line_id: The logical ID understood by the consumers and providers.
- * @line_data: Line data related to line_id.
- * @edge_flags: Edge setup flags.
- * @name: Descriptive name of the entity that is being monitored for the
- * hardware timestamping. If null, HTE core will construct the name.
- *
- */
- struct hte_line_attr {
- u32 line_id;
- void *line_data;
- unsigned long edge_flags;
- const char *name;
- };
- /**
- * struct hte_ts_desc - HTE timestamp descriptor.
- *
- * This structure is a communication token between consumers to subsystem
- * and subsystem to providers.
- *
- * @attr: The line attributes.
- * @hte_data: Subsystem's private data, set by HTE subsystem.
- */
- struct hte_ts_desc {
- struct hte_line_attr attr;
- void *hte_data;
- };
- /**
- * struct hte_ops - HTE operations set by providers.
- *
- * @request: Hook for requesting a HTE timestamp. Returns 0 on success,
- * non-zero for failures.
- * @release: Hook for releasing a HTE timestamp. Returns 0 on success,
- * non-zero for failures.
- * @enable: Hook to enable the specified timestamp. Returns 0 on success,
- * non-zero for failures.
- * @disable: Hook to disable specified timestamp. Returns 0 on success,
- * non-zero for failures.
- * @get_clk_src_info: Hook to get the clock information the provider uses
- * to timestamp. Returns 0 for success and negative error code for failure. On
- * success HTE subsystem fills up provided struct hte_clk_info.
- *
- * xlated_id parameter is used to communicate between HTE subsystem and the
- * providers and is translated by the provider.
- */
- struct hte_ops {
- int (*request)(struct hte_chip *chip, struct hte_ts_desc *desc,
- u32 xlated_id);
- int (*release)(struct hte_chip *chip, struct hte_ts_desc *desc,
- u32 xlated_id);
- int (*enable)(struct hte_chip *chip, u32 xlated_id);
- int (*disable)(struct hte_chip *chip, u32 xlated_id);
- int (*get_clk_src_info)(struct hte_chip *chip,
- struct hte_clk_info *ci);
- };
- /**
- * struct hte_chip - Abstract HTE chip.
- *
- * @name: functional name of the HTE IP block.
- * @dev: device providing the HTE.
- * @ops: callbacks for this HTE.
- * @nlines: number of lines/signals supported by this chip.
- * @xlate_of: Callback which translates consumer supplied logical ids to
- * physical ids, return 0 for the success and negative for the failures.
- * It stores (between 0 to @nlines) in xlated_id parameter for the success.
- * @xlate_plat: Same as above but for the consumers with no DT node.
- * @match_from_linedata: Match HTE device using the line_data.
- * @of_hte_n_cells: Number of cells used to form the HTE specifier.
- * @gdev: HTE subsystem abstract device, internal to the HTE subsystem.
- * @data: chip specific private data.
- */
- struct hte_chip {
- const char *name;
- struct device *dev;
- const struct hte_ops *ops;
- u32 nlines;
- int (*xlate_of)(struct hte_chip *gc,
- const struct of_phandle_args *args,
- struct hte_ts_desc *desc, u32 *xlated_id);
- int (*xlate_plat)(struct hte_chip *gc, struct hte_ts_desc *desc,
- u32 *xlated_id);
- bool (*match_from_linedata)(const struct hte_chip *chip,
- const struct hte_ts_desc *hdesc);
- u8 of_hte_n_cells;
- struct hte_device *gdev;
- void *data;
- };
- #if IS_ENABLED(CONFIG_HTE)
- /* HTE APIs for the providers */
- int devm_hte_register_chip(struct hte_chip *chip);
- int hte_push_ts_ns(const struct hte_chip *chip, u32 xlated_id,
- struct hte_ts_data *data);
- /* HTE APIs for the consumers */
- int hte_init_line_attr(struct hte_ts_desc *desc, u32 line_id,
- unsigned long edge_flags, const char *name,
- void *data);
- int hte_ts_get(struct device *dev, struct hte_ts_desc *desc, int index);
- int hte_ts_put(struct hte_ts_desc *desc);
- int hte_request_ts_ns(struct hte_ts_desc *desc, hte_ts_cb_t cb,
- hte_ts_sec_cb_t tcb, void *data);
- int devm_hte_request_ts_ns(struct device *dev, struct hte_ts_desc *desc,
- hte_ts_cb_t cb, hte_ts_sec_cb_t tcb, void *data);
- int of_hte_req_count(struct device *dev);
- int hte_enable_ts(struct hte_ts_desc *desc);
- int hte_disable_ts(struct hte_ts_desc *desc);
- int hte_get_clk_src_info(const struct hte_ts_desc *desc,
- struct hte_clk_info *ci);
- #else /* !CONFIG_HTE */
- static inline int devm_hte_register_chip(struct hte_chip *chip)
- {
- return -EOPNOTSUPP;
- }
- static inline int hte_push_ts_ns(const struct hte_chip *chip,
- u32 xlated_id,
- const struct hte_ts_data *data)
- {
- return -EOPNOTSUPP;
- }
- static inline int hte_init_line_attr(struct hte_ts_desc *desc, u32 line_id,
- unsigned long edge_flags,
- const char *name, void *data)
- {
- return -EOPNOTSUPP;
- }
- static inline int hte_ts_get(struct device *dev, struct hte_ts_desc *desc,
- int index)
- {
- return -EOPNOTSUPP;
- }
- static inline int hte_ts_put(struct hte_ts_desc *desc)
- {
- return -EOPNOTSUPP;
- }
- static inline int hte_request_ts_ns(struct hte_ts_desc *desc, hte_ts_cb_t cb,
- hte_ts_sec_cb_t tcb, void *data)
- {
- return -EOPNOTSUPP;
- }
- static inline int devm_hte_request_ts_ns(struct device *dev,
- struct hte_ts_desc *desc,
- hte_ts_cb_t cb,
- hte_ts_sec_cb_t tcb,
- void *data)
- {
- return -EOPNOTSUPP;
- }
- static inline int of_hte_req_count(struct device *dev)
- {
- return -EOPNOTSUPP;
- }
- static inline int hte_enable_ts(struct hte_ts_desc *desc)
- {
- return -EOPNOTSUPP;
- }
- static inline int hte_disable_ts(struct hte_ts_desc *desc)
- {
- return -EOPNOTSUPP;
- }
- static inline int hte_get_clk_src_info(const struct hte_ts_desc *desc,
- struct hte_clk_info *ci)
- {
- return -EOPNOTSUPP;
- }
- #endif /* !CONFIG_HTE */
- #endif
|