123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156 |
- #ifndef _MSM_RMNET_H_
- #define _MSM_RMNET_H_
- /* Bitmap macros for RmNET driver operation mode. */
- #define RMNET_MODE_NONE (0x00)
- #define RMNET_MODE_LLP_ETH (0x01)
- #define RMNET_MODE_LLP_IP (0x02)
- #define RMNET_MODE_QOS (0x04)
- #define RMNET_MODE_MASK (RMNET_MODE_LLP_ETH | \
- RMNET_MODE_LLP_IP | \
- RMNET_MODE_QOS)
- #define RMNET_IS_MODE_QOS(mode) \
- ((mode & RMNET_MODE_QOS) == RMNET_MODE_QOS)
- #define RMNET_IS_MODE_IP(mode) \
- ((mode & RMNET_MODE_LLP_IP) == RMNET_MODE_LLP_IP)
- /* IOCTL command enum
- * Values chosen to not conflict with other drivers in the ecosystem */
- enum rmnet_ioctl_cmds_e {
- RMNET_IOCTL_SET_LLP_ETHERNET = 0x000089F1, /* Set Ethernet protocol */
- RMNET_IOCTL_SET_LLP_IP = 0x000089F2, /* Set RAWIP protocol */
- RMNET_IOCTL_GET_LLP = 0x000089F3, /* Get link protocol */
- RMNET_IOCTL_SET_QOS_ENABLE = 0x000089F4, /* Set QoS header enabled */
- RMNET_IOCTL_SET_QOS_DISABLE = 0x000089F5, /* Set QoS header disabled*/
- RMNET_IOCTL_GET_QOS = 0x000089F6, /* Get QoS header state */
- RMNET_IOCTL_GET_OPMODE = 0x000089F7, /* Get operation mode */
- RMNET_IOCTL_OPEN = 0x000089F8, /* Open transport port */
- RMNET_IOCTL_CLOSE = 0x000089F9, /* Close transport port */
- RMNET_IOCTL_FLOW_ENABLE = 0x000089FA, /* Flow enable */
- RMNET_IOCTL_FLOW_DISABLE = 0x000089FB, /* Flow disable */
- RMNET_IOCTL_FLOW_SET_HNDL = 0x000089FC, /* Set flow handle */
- RMNET_IOCTL_EXTENDED = 0x000089FD, /* Extended IOCTLs */
- RMNET_IOCTL_MAX
- };
- enum rmnet_ioctl_extended_cmds_e {
- /* RmNet Data Required IOCTLs */
- RMNET_IOCTL_GET_SUPPORTED_FEATURES = 0x0000, /* Get features */
- RMNET_IOCTL_SET_MRU = 0x0001, /* Set MRU */
- RMNET_IOCTL_GET_MRU = 0x0002, /* Get MRU */
- RMNET_IOCTL_GET_EPID = 0x0003, /* Get endpoint ID */
- RMNET_IOCTL_GET_DRIVER_NAME = 0x0004, /* Get driver name */
- RMNET_IOCTL_ADD_MUX_CHANNEL = 0x0005, /* Add MUX ID */
- RMNET_IOCTL_SET_EGRESS_DATA_FORMAT = 0x0006, /* Set EDF */
- RMNET_IOCTL_SET_INGRESS_DATA_FORMAT = 0x0007, /* Set IDF */
- RMNET_IOCTL_SET_AGGREGATION_COUNT = 0x0008, /* Set agg count */
- RMNET_IOCTL_GET_AGGREGATION_COUNT = 0x0009, /* Get agg count */
- RMNET_IOCTL_SET_AGGREGATION_SIZE = 0x000A, /* Set agg size */
- RMNET_IOCTL_GET_AGGREGATION_SIZE = 0x000B, /* Get agg size */
- RMNET_IOCTL_FLOW_CONTROL = 0x000C, /* Do flow control */
- RMNET_IOCTL_GET_DFLT_CONTROL_CHANNEL = 0x000D, /* For legacy use */
- RMNET_IOCTL_GET_HWSW_MAP = 0x000E, /* Get HW/SW map */
- RMNET_IOCTL_SET_RX_HEADROOM = 0x000F, /* RX Headroom */
- RMNET_IOCTL_GET_EP_PAIR = 0x0010, /* Endpoint pair */
- RMNET_IOCTL_SET_QOS_VERSION = 0x0011, /* 8/6 byte QoS hdr*/
- RMNET_IOCTL_GET_QOS_VERSION = 0x0012, /* 8/6 byte QoS hdr*/
- RMNET_IOCTL_GET_SUPPORTED_QOS_MODES = 0x0013, /* Get QoS modes */
- RMNET_IOCTL_SET_SLEEP_STATE = 0x0014, /* Set sleep state */
- RMNET_IOCTL_SET_XLAT_DEV_INFO = 0x0015, /* xlat dev name */
- RMNET_IOCTL_DEREGISTER_DEV = 0x0016, /* Dereg a net dev */
- RMNET_IOCTL_EXTENDED_MAX = 0x0017
- };
- /* Return values for the RMNET_IOCTL_GET_SUPPORTED_FEATURES IOCTL */
- #define RMNET_IOCTL_FEAT_NOTIFY_MUX_CHANNEL (1<<0)
- #define RMNET_IOCTL_FEAT_SET_EGRESS_DATA_FORMAT (1<<1)
- #define RMNET_IOCTL_FEAT_SET_INGRESS_DATA_FORMAT (1<<2)
- #define RMNET_IOCTL_FEAT_SET_AGGREGATION_COUNT (1<<3)
- #define RMNET_IOCTL_FEAT_GET_AGGREGATION_COUNT (1<<4)
- #define RMNET_IOCTL_FEAT_SET_AGGREGATION_SIZE (1<<5)
- #define RMNET_IOCTL_FEAT_GET_AGGREGATION_SIZE (1<<6)
- #define RMNET_IOCTL_FEAT_FLOW_CONTROL (1<<7)
- #define RMNET_IOCTL_FEAT_GET_DFLT_CONTROL_CHANNEL (1<<8)
- #define RMNET_IOCTL_FEAT_GET_HWSW_MAP (1<<9)
- /* Input values for the RMNET_IOCTL_SET_EGRESS_DATA_FORMAT IOCTL */
- #define RMNET_IOCTL_EGRESS_FORMAT_MAP (1<<1)
- #define RMNET_IOCTL_EGRESS_FORMAT_AGGREGATION (1<<2)
- #define RMNET_IOCTL_EGRESS_FORMAT_MUXING (1<<3)
- #define RMNET_IOCTL_EGRESS_FORMAT_CHECKSUM (1<<4)
- /* Input values for the RMNET_IOCTL_SET_INGRESS_DATA_FORMAT IOCTL */
- #define RMNET_IOCTL_INGRESS_FORMAT_MAP (1<<1)
- #define RMNET_IOCTL_INGRESS_FORMAT_DEAGGREGATION (1<<2)
- #define RMNET_IOCTL_INGRESS_FORMAT_DEMUXING (1<<3)
- #define RMNET_IOCTL_INGRESS_FORMAT_CHECKSUM (1<<4)
- #define RMNET_IOCTL_INGRESS_FORMAT_AGG_DATA (1<<5)
- /* User space may not have this defined. */
- #ifndef IFNAMSIZ
- #define IFNAMSIZ 16
- #endif
- struct rmnet_ioctl_extended_s {
- uint32_t extended_ioctl;
- union {
- uint32_t data; /* Generic data field for most extended IOCTLs */
- /* Return values for
- * RMNET_IOCTL_GET_DRIVER_NAME
- * RMNET_IOCTL_GET_DFLT_CONTROL_CHANNEL */
- int8_t if_name[IFNAMSIZ];
- /* Input values for the RMNET_IOCTL_ADD_MUX_CHANNEL IOCTL */
- struct {
- uint32_t mux_id;
- int8_t vchannel_name[IFNAMSIZ];
- } rmnet_mux_val;
- /* Input values for the RMNET_IOCTL_FLOW_CONTROL IOCTL */
- struct {
- uint8_t flow_mode;
- uint8_t mux_id;
- } flow_control_prop;
- /* Return values for RMNET_IOCTL_GET_EP_PAIR */
- struct {
- uint32_t consumer_pipe_num;
- uint32_t producer_pipe_num;
- } ipa_ep_pair;
- struct {
- uint32_t __data; /* Placeholder for legacy data*/
- uint32_t agg_size;
- uint32_t agg_count;
- } ingress_format;
- } u;
- };
- struct rmnet_ioctl_data_s {
- union {
- uint32_t operation_mode;
- uint32_t tcm_handle;
- } u;
- };
- #define RMNET_IOCTL_QOS_MODE_6 (1<<0)
- #define RMNET_IOCTL_QOS_MODE_8 (1<<1)
- /* QMI QoS header definition */
- #define QMI_QOS_HDR_S __attribute((__packed__)) qmi_qos_hdr_s
- struct QMI_QOS_HDR_S {
- unsigned char version;
- unsigned char flags;
- unsigned long flow_id;
- };
- /* QMI QoS 8-byte header. */
- struct qmi_qos_hdr8_s {
- struct QMI_QOS_HDR_S hdr;
- uint8_t reserved[2];
- } __attribute((__packed__));
- #endif /* _MSM_RMNET_H_ */
|