/drivers/net/wireless/bcmdhd_29/include/dhdioctl.h

https://bitbucket.org/cyanogenmod/android_kernel_asus_tf300t · C Header · 131 lines · 69 code · 20 blank · 42 comment · 0 complexity · 81e96786aa0b8a6d481430d6378fc1a1 MD5 · raw file

  1. /*
  2. * Definitions for ioctls to access DHD iovars.
  3. * Based on wlioctl.h (for Broadcom 802.11abg driver).
  4. * (Moves towards generic ioctls for BCM drivers/iovars.)
  5. *
  6. * Definitions subject to change without notice.
  7. *
  8. * Copyright (C) 1999-2011, Broadcom Corporation
  9. *
  10. * Unless you and Broadcom execute a separate written software license
  11. * agreement governing use of this software, this software is licensed to you
  12. * under the terms of the GNU General Public License version 2 (the "GPL"),
  13. * available at http://www.broadcom.com/licenses/GPLv2.php, with the
  14. * following added to such license:
  15. *
  16. * As a special exception, the copyright holders of this software give you
  17. * permission to link this software with independent modules, and to copy and
  18. * distribute the resulting executable under terms of your choice, provided that
  19. * you also meet, for each linked independent module, the terms and conditions of
  20. * the license of that module. An independent module is a module which is not
  21. * derived from this software. The special exception does not apply to any
  22. * modifications of the software.
  23. *
  24. * Notwithstanding the above, under no circumstances may you combine this
  25. * software in any way with any other Broadcom software provided under a license
  26. * other than the GPL, without Broadcom's express prior written consent.
  27. *
  28. * $Id: dhdioctl.h 323572 2012-03-26 06:28:14Z $
  29. */
  30. #ifndef _dhdioctl_h_
  31. #define _dhdioctl_h_
  32. #include <typedefs.h>
  33. /* require default structure packing */
  34. #define BWL_DEFAULT_PACKING
  35. #include <packed_section_start.h>
  36. /* Linux network driver ioctl encoding */
  37. typedef struct dhd_ioctl {
  38. uint cmd; /* common ioctl definition */
  39. void *buf; /* pointer to user buffer */
  40. uint len; /* length of user buffer */
  41. bool set; /* get or set request (optional) */
  42. uint used; /* bytes read or written (optional) */
  43. uint needed; /* bytes needed (optional) */
  44. uint driver; /* to identify target driver */
  45. } dhd_ioctl_t;
  46. /* Underlying BUS definition */
  47. enum {
  48. BUS_TYPE_USB = 0, /* for USB dongles */
  49. BUS_TYPE_SDIO /* for SDIO dongles */
  50. };
  51. /* per-driver magic numbers */
  52. #define DHD_IOCTL_MAGIC 0x00444944
  53. /* bump this number if you change the ioctl interface */
  54. #define DHD_IOCTL_VERSION 1
  55. #define DHD_IOCTL_MAXLEN 8192 /* max length ioctl buffer required */
  56. #define DHD_IOCTL_SMLEN 256 /* "small" length ioctl buffer required */
  57. /* common ioctl definitions */
  58. #define DHD_GET_MAGIC 0
  59. #define DHD_GET_VERSION 1
  60. #define DHD_GET_VAR 2
  61. #define DHD_SET_VAR 3
  62. /* message levels */
  63. #define DHD_ERROR_VAL 0x0001
  64. #define DHD_TRACE_VAL 0x0002
  65. #define DHD_INFO_VAL 0x0004
  66. #define DHD_DATA_VAL 0x0008
  67. #define DHD_CTL_VAL 0x0010
  68. #define DHD_TIMER_VAL 0x0020
  69. #define DHD_HDRS_VAL 0x0040
  70. #define DHD_BYTES_VAL 0x0080
  71. #define DHD_INTR_VAL 0x0100
  72. #define DHD_LOG_VAL 0x0200
  73. #define DHD_GLOM_VAL 0x0400
  74. #define DHD_EVENT_VAL 0x0800
  75. #define DHD_BTA_VAL 0x1000
  76. #define DHD_ISCAN_VAL 0x2000
  77. #define DHD_ARPOE_VAL 0x4000
  78. #define DHD_REORDER_VAL 0x8000
  79. #define DHD_WL_VAL 0x10000
  80. #ifdef SDTEST
  81. /* For pktgen iovar */
  82. typedef struct dhd_pktgen {
  83. uint version; /* To allow structure change tracking */
  84. uint freq; /* Max ticks between tx/rx attempts */
  85. uint count; /* Test packets to send/rcv each attempt */
  86. uint print; /* Print counts every <print> attempts */
  87. uint total; /* Total packets (or bursts) */
  88. uint minlen; /* Minimum length of packets to send */
  89. uint maxlen; /* Maximum length of packets to send */
  90. uint numsent; /* Count of test packets sent */
  91. uint numrcvd; /* Count of test packets received */
  92. uint numfail; /* Count of test send failures */
  93. uint mode; /* Test mode (type of test packets) */
  94. uint stop; /* Stop after this many tx failures */
  95. } dhd_pktgen_t;
  96. /* Version in case structure changes */
  97. #define DHD_PKTGEN_VERSION 2
  98. /* Type of test packets to use */
  99. #define DHD_PKTGEN_ECHO 1 /* Send echo requests */
  100. #define DHD_PKTGEN_SEND 2 /* Send discard packets */
  101. #define DHD_PKTGEN_RXBURST 3 /* Request dongle send N packets */
  102. #define DHD_PKTGEN_RECV 4 /* Continuous rx from continuous tx dongle */
  103. #endif /* SDTEST */
  104. /* Enter idle immediately (no timeout) */
  105. #define DHD_IDLE_IMMEDIATE (-1)
  106. /* Values for idleclock iovar: other values are the sd_divisor to use when idle */
  107. #define DHD_IDLE_ACTIVE 0 /* Do not request any SD clock change when idle */
  108. #define DHD_IDLE_STOP (-1) /* Request SD clock be stopped (and use SD1 mode) */
  109. /* require default structure packing */
  110. #include <packed_section_end.h>
  111. #endif /* _dhdioctl_h_ */