| 1 | /* SPDX-License-Identifier: GPL-2.0-or-later */ |
| 2 | /* |
| 3 | * QMC management |
| 4 | * |
| 5 | * Copyright 2022 CS GROUP France |
| 6 | * |
| 7 | * Author: Herve Codina <herve.codina@bootlin.com> |
| 8 | */ |
| 9 | #ifndef __SOC_FSL_QMC_H__ |
| 10 | #define __SOC_FSL_QMC_H__ |
| 11 | |
| 12 | #include <linux/bits.h> |
| 13 | #include <linux/types.h> |
| 14 | |
| 15 | struct device_node; |
| 16 | struct device; |
| 17 | struct qmc_chan; |
| 18 | |
| 19 | int qmc_chan_count_phandles(struct device_node *np, const char *phandles_name); |
| 20 | |
| 21 | struct qmc_chan *qmc_chan_get_byphandles_index(struct device_node *np, |
| 22 | const char *phandles_name, |
| 23 | int index); |
| 24 | struct qmc_chan *devm_qmc_chan_get_byphandles_index(struct device *dev, |
| 25 | struct device_node *np, |
| 26 | const char *phandles_name, |
| 27 | int index); |
| 28 | |
| 29 | static inline struct qmc_chan *qmc_chan_get_byphandle(struct device_node *np, |
| 30 | const char *phandle_name) |
| 31 | { |
| 32 | return qmc_chan_get_byphandles_index(np, phandles_name: phandle_name, index: 0); |
| 33 | } |
| 34 | |
| 35 | static inline struct qmc_chan *devm_qmc_chan_get_byphandle(struct device *dev, |
| 36 | struct device_node *np, |
| 37 | const char *phandle_name) |
| 38 | { |
| 39 | return devm_qmc_chan_get_byphandles_index(dev, np, phandles_name: phandle_name, index: 0); |
| 40 | } |
| 41 | |
| 42 | struct qmc_chan *qmc_chan_get_bychild(struct device_node *np); |
| 43 | void qmc_chan_put(struct qmc_chan *chan); |
| 44 | |
| 45 | struct qmc_chan *devm_qmc_chan_get_bychild(struct device *dev, struct device_node *np); |
| 46 | |
| 47 | enum qmc_mode { |
| 48 | QMC_TRANSPARENT, |
| 49 | QMC_HDLC, |
| 50 | }; |
| 51 | |
| 52 | struct qmc_chan_info { |
| 53 | enum qmc_mode mode; |
| 54 | unsigned long rx_fs_rate; |
| 55 | unsigned long rx_bit_rate; |
| 56 | u8 nb_rx_ts; |
| 57 | unsigned long tx_fs_rate; |
| 58 | unsigned long tx_bit_rate; |
| 59 | u8 nb_tx_ts; |
| 60 | }; |
| 61 | |
| 62 | int qmc_chan_get_info(struct qmc_chan *chan, struct qmc_chan_info *info); |
| 63 | |
| 64 | struct qmc_chan_ts_info { |
| 65 | u64 rx_ts_mask_avail; |
| 66 | u64 tx_ts_mask_avail; |
| 67 | u64 rx_ts_mask; |
| 68 | u64 tx_ts_mask; |
| 69 | }; |
| 70 | |
| 71 | int qmc_chan_get_ts_info(struct qmc_chan *chan, struct qmc_chan_ts_info *ts_info); |
| 72 | int qmc_chan_set_ts_info(struct qmc_chan *chan, const struct qmc_chan_ts_info *ts_info); |
| 73 | |
| 74 | struct qmc_chan_param { |
| 75 | enum qmc_mode mode; |
| 76 | union { |
| 77 | struct { |
| 78 | u16 max_rx_buf_size; |
| 79 | u16 max_rx_frame_size; |
| 80 | bool is_crc32; |
| 81 | } hdlc; |
| 82 | struct { |
| 83 | u16 max_rx_buf_size; |
| 84 | } transp; |
| 85 | }; |
| 86 | }; |
| 87 | |
| 88 | int qmc_chan_set_param(struct qmc_chan *chan, const struct qmc_chan_param *param); |
| 89 | |
| 90 | int qmc_chan_write_submit(struct qmc_chan *chan, dma_addr_t addr, size_t length, |
| 91 | void (*complete)(void *context), void *context); |
| 92 | |
| 93 | /* Flags available (ORed) for read complete() flags parameter in HDLC mode. |
| 94 | * No flags are available in transparent mode and the read complete() flags |
| 95 | * parameter has no meaning in transparent mode. |
| 96 | */ |
| 97 | #define QMC_RX_FLAG_HDLC_LAST BIT(11) /* Last in frame */ |
| 98 | #define QMC_RX_FLAG_HDLC_FIRST BIT(10) /* First in frame */ |
| 99 | #define QMC_RX_FLAG_HDLC_OVF BIT(5) /* Data overflow */ |
| 100 | #define QMC_RX_FLAG_HDLC_UNA BIT(4) /* Unaligned (ie. bits received not multiple of 8) */ |
| 101 | #define QMC_RX_FLAG_HDLC_ABORT BIT(3) /* Received an abort sequence (seven consecutive ones) */ |
| 102 | #define QMC_RX_FLAG_HDLC_CRC BIT(2) /* CRC error */ |
| 103 | |
| 104 | int qmc_chan_read_submit(struct qmc_chan *chan, dma_addr_t addr, size_t length, |
| 105 | void (*complete)(void *context, size_t length, |
| 106 | unsigned int flags), |
| 107 | void *context); |
| 108 | |
| 109 | #define QMC_CHAN_READ (1<<0) |
| 110 | #define QMC_CHAN_WRITE (1<<1) |
| 111 | #define QMC_CHAN_ALL (QMC_CHAN_READ | QMC_CHAN_WRITE) |
| 112 | |
| 113 | int qmc_chan_start(struct qmc_chan *chan, int direction); |
| 114 | int qmc_chan_stop(struct qmc_chan *chan, int direction); |
| 115 | int qmc_chan_reset(struct qmc_chan *chan, int direction); |
| 116 | |
| 117 | #endif /* __SOC_FSL_QMC_H__ */ |
| 118 | |