bcmcdc.h 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123
  1. /*
  2. * CDC network driver ioctl/indication encoding
  3. * Broadcom 802.11abg Networking Device Driver
  4. *
  5. * Definitions subject to change without notice.
  6. *
  7. * Portions of this code are copyright (c) 2020 Cypress Semiconductor Corporation
  8. *
  9. * Copyright (C) 1999-2020, Broadcom Corporation
  10. *
  11. * Unless you and Broadcom execute a separate written software license
  12. * agreement governing use of this software, this software is licensed to you
  13. * under the terms of the GNU General Public License version 2 (the "GPL"),
  14. * available at http://www.broadcom.com/licenses/GPLv2.php, with the
  15. * following added to such license:
  16. *
  17. * As a special exception, the copyright holders of this software give you
  18. * permission to link this software with independent modules, and to copy and
  19. * distribute the resulting executable under terms of your choice, provided that
  20. * you also meet, for each linked independent module, the terms and conditions of
  21. * the license of that module. An independent module is a module which is not
  22. * derived from this software. The special exception does not apply to any
  23. * modifications of the software.
  24. *
  25. * Notwithstanding the above, under no circumstances may you combine this
  26. * software in any way with any other Broadcom software provided under a license
  27. * other than the GPL, without Broadcom's express prior written consent.
  28. *
  29. *
  30. * <<Broadcom-WL-IPTag/Open:>>
  31. *
  32. * $Id: bcmcdc.h 681862 2018-01-03 12:34:14Z $
  33. */
  34. #ifndef _bcmcdc_h_
  35. #define _bcmcdc_h_
  36. #include <ethernet.h>
  37. typedef struct cdc_ioctl {
  38. uint32 cmd; /* ioctl command value */
  39. uint32 len; /* lower 16: output buflen; upper 16: input buflen (excludes header) */
  40. uint32 flags; /* flag defns given below */
  41. uint32 status; /* status code returned from the device */
  42. } cdc_ioctl_t;
  43. /* Max valid buffer size that can be sent to the dongle */
  44. #define CDC_MAX_MSG_SIZE ETHER_MAX_LEN
  45. /* len field is divided into input and output buffer lengths */
  46. #define CDCL_IOC_OUTLEN_MASK 0x0000FFFF /* maximum or expected response length, */
  47. /* excluding IOCTL header */
  48. #define CDCL_IOC_OUTLEN_SHIFT 0
  49. #define CDCL_IOC_INLEN_MASK 0xFFFF0000 /* input buffer length, excluding IOCTL header */
  50. #define CDCL_IOC_INLEN_SHIFT 16
  51. /* CDC flag definitions */
  52. #define CDCF_IOC_ERROR 0x01 /* 0=success, 1=ioctl cmd failed */
  53. #define CDCF_IOC_SET 0x02 /* 0=get, 1=set cmd */
  54. #define CDCF_IOC_OVL_IDX_MASK 0x3c /* overlay region index mask */
  55. #define CDCF_IOC_OVL_RSV 0x40 /* 1=reserve this overlay region */
  56. #define CDCF_IOC_OVL 0x80 /* 1=this ioctl corresponds to an overlay */
  57. #define CDCF_IOC_ACTION_MASK 0xfe /* SET/GET, OVL_IDX, OVL_RSV, OVL mask */
  58. #define CDCF_IOC_ACTION_SHIFT 1 /* SET/GET, OVL_IDX, OVL_RSV, OVL shift */
  59. #define CDCF_IOC_IF_MASK 0xF000 /* I/F index */
  60. #define CDCF_IOC_IF_SHIFT 12
  61. #define CDCF_IOC_ID_MASK 0xFFFF0000 /* used to uniquely id an ioctl req/resp pairing */
  62. #define CDCF_IOC_ID_SHIFT 16 /* # of bits of shift for ID Mask */
  63. #define CDC_IOC_IF_IDX(flags) (((flags) & CDCF_IOC_IF_MASK) >> CDCF_IOC_IF_SHIFT)
  64. #define CDC_IOC_ID(flags) (((flags) & CDCF_IOC_ID_MASK) >> CDCF_IOC_ID_SHIFT)
  65. #define CDC_GET_IF_IDX(hdr) \
  66. ((int)((((hdr)->flags) & CDCF_IOC_IF_MASK) >> CDCF_IOC_IF_SHIFT))
  67. #define CDC_SET_IF_IDX(hdr, idx) \
  68. ((hdr)->flags = (((hdr)->flags & ~CDCF_IOC_IF_MASK) | ((idx) << CDCF_IOC_IF_SHIFT)))
  69. /*
  70. * BDC header
  71. *
  72. * The BDC header is used on data packets to convey priority across USB.
  73. */
  74. struct bdc_header {
  75. uint8 flags; /* Flags */
  76. uint8 priority; /* 802.1d Priority 0:2 bits, 4:7 USB flow control info */
  77. uint8 flags2;
  78. uint8 dataOffset; /* Offset from end of BDC header to packet data, in
  79. * 4-byte words. Leaves room for optional headers.
  80. */
  81. };
  82. #define BDC_HEADER_LEN 4
  83. /* flags field bitmap */
  84. #define BDC_FLAG_EXEMPT 0x03 /* EXT_STA: encryption exemption (host -> dongle?) */
  85. #define BDC_FLAG_80211_PKT 0x01 /* Packet is in 802.11 format (dongle -> host) */
  86. #define BDC_FLAG_SUM_GOOD 0x04 /* Dongle has verified good RX checksums */
  87. #define BDC_FLAG_SUM_NEEDED 0x08 /* Dongle needs to do TX checksums: host->device */
  88. #define BDC_FLAG_EVENT_MSG 0x08 /* Payload contains an event msg: device->host */
  89. #define BDC_FLAG_VER_MASK 0xf0 /* Protocol version mask */
  90. #define BDC_FLAG_VER_SHIFT 4 /* Protocol version shift */
  91. /* priority field bitmap */
  92. #define BDC_PRIORITY_MASK 0x07
  93. #define BDC_PRIORITY_FC_MASK 0xf0 /* flow control info mask */
  94. #define BDC_PRIORITY_FC_SHIFT 4 /* flow control info shift */
  95. /* flags2 field bitmap */
  96. #define BDC_FLAG2_IF_MASK 0x0f /* interface index (host <-> dongle) */
  97. #define BDC_FLAG2_IF_SHIFT 0
  98. #define BDC_FLAG2_FC_FLAG 0x10 /* flag to indicate if pkt contains */
  99. /* FLOW CONTROL info only */
  100. /* version numbers */
  101. #define BDC_PROTO_VER_1 1 /* Old Protocol version */
  102. #define BDC_PROTO_VER 2 /* Protocol version */
  103. /* flags2.if field access macros */
  104. #define BDC_GET_IF_IDX(hdr) \
  105. ((int)((((hdr)->flags2) & BDC_FLAG2_IF_MASK) >> BDC_FLAG2_IF_SHIFT))
  106. #define BDC_SET_IF_IDX(hdr, idx) \
  107. ((hdr)->flags2 = (((hdr)->flags2 & ~BDC_FLAG2_IF_MASK) | ((idx) << BDC_FLAG2_IF_SHIFT)))
  108. #endif /* _bcmcdc_h_ */