islpci_mgt.h 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140
  1. /*
  2. * Copyright (C) 2002 Intersil Americas Inc.
  3. * Copyright (C) 2003 Luis R. Rodriguez <mcgrof@ruslug.rutgers.edu>
  4. *
  5. * This program is free software; you can redistribute it and/or modify
  6. * it under the terms of the GNU General Public License as published by
  7. * the Free Software Foundation; either version 2 of the License
  8. *
  9. * This program is distributed in the hope that it will be useful,
  10. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  11. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  12. * GNU General Public License for more details.
  13. *
  14. * You should have received a copy of the GNU General Public License
  15. * along with this program; if not, write to the Free Software
  16. * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
  17. *
  18. */
  19. #ifndef _ISLPCI_MGT_H
  20. #define _ISLPCI_MGT_H
  21. #include <linux/wireless.h>
  22. #include <linux/skbuff.h>
  23. #include <linux/slab.h>
  24. /*
  25. * Function definitions
  26. */
  27. #define K_DEBUG(f, m, args...) do { if(f & m) printk(KERN_DEBUG args); } while(0)
  28. #define DEBUG(f, args...) K_DEBUG(f, pc_debug, args)
  29. extern int pc_debug;
  30. #define init_wds 0 /* help compiler optimize away dead code */
  31. /* General driver definitions */
  32. #define PCIDEVICE_LATENCY_TIMER_MIN 0x40
  33. #define PCIDEVICE_LATENCY_TIMER_VAL 0x50
  34. /* Debugging verbose definitions */
  35. #define SHOW_NOTHING 0x00 /* overrules everything */
  36. #define SHOW_ANYTHING 0xFF
  37. #define SHOW_ERROR_MESSAGES 0x01
  38. #define SHOW_TRAPS 0x02
  39. #define SHOW_FUNCTION_CALLS 0x04
  40. #define SHOW_TRACING 0x08
  41. #define SHOW_QUEUE_INDEXES 0x10
  42. #define SHOW_PIMFOR_FRAMES 0x20
  43. #define SHOW_BUFFER_CONTENTS 0x40
  44. #define VERBOSE 0x01
  45. /* Default card definitions */
  46. #define CARD_DEFAULT_CHANNEL 6
  47. #define CARD_DEFAULT_MODE INL_MODE_CLIENT
  48. #define CARD_DEFAULT_IW_MODE IW_MODE_INFRA
  49. #define CARD_DEFAULT_BSSTYPE DOT11_BSSTYPE_INFRA
  50. #define CARD_DEFAULT_CLIENT_SSID ""
  51. #define CARD_DEFAULT_AP_SSID "default"
  52. #define CARD_DEFAULT_KEY1 "default_key_1"
  53. #define CARD_DEFAULT_KEY2 "default_key_2"
  54. #define CARD_DEFAULT_KEY3 "default_key_3"
  55. #define CARD_DEFAULT_KEY4 "default_key_4"
  56. #define CARD_DEFAULT_WEP 0
  57. #define CARD_DEFAULT_FILTER 0
  58. #define CARD_DEFAULT_WDS 0
  59. #define CARD_DEFAULT_AUTHEN DOT11_AUTH_OS
  60. #define CARD_DEFAULT_DOT1X 0
  61. #define CARD_DEFAULT_MLME_MODE DOT11_MLME_AUTO
  62. #define CARD_DEFAULT_CONFORMANCE OID_INL_CONFORMANCE_NONE
  63. #define CARD_DEFAULT_PROFILE DOT11_PROFILE_MIXED_G_WIFI
  64. #define CARD_DEFAULT_MAXFRAMEBURST DOT11_MAXFRAMEBURST_MIXED_SAFE
  65. /* PIMFOR package definitions */
  66. #define PIMFOR_ETHERTYPE 0x8828
  67. #define PIMFOR_HEADER_SIZE 12
  68. #define PIMFOR_VERSION 1
  69. #define PIMFOR_OP_GET 0
  70. #define PIMFOR_OP_SET 1
  71. #define PIMFOR_OP_RESPONSE 2
  72. #define PIMFOR_OP_ERROR 3
  73. #define PIMFOR_OP_TRAP 4
  74. #define PIMFOR_OP_RESERVED 5 /* till 255 */
  75. #define PIMFOR_DEV_ID_MHLI_MIB 0
  76. #define PIMFOR_FLAG_APPLIC_ORIGIN 0x01
  77. #define PIMFOR_FLAG_LITTLE_ENDIAN 0x02
  78. void display_buffer(char *, int);
  79. /*
  80. * Type definition section
  81. *
  82. * the structure defines only the header allowing copyless
  83. * frame handling
  84. */
  85. typedef struct {
  86. u8 version;
  87. u8 operation;
  88. u32 oid;
  89. u8 device_id;
  90. u8 flags;
  91. u32 length;
  92. } __packed
  93. pimfor_header_t;
  94. /* A received and interrupt-processed management frame, either for
  95. * schedule_work(prism54_process_trap) or for priv->mgmt_received,
  96. * processed by islpci_mgt_transaction(). */
  97. struct islpci_mgmtframe {
  98. struct net_device *ndev; /* pointer to network device */
  99. pimfor_header_t *header; /* payload header, points into buf */
  100. void *data; /* payload ex header, points into buf */
  101. struct work_struct ws; /* argument for schedule_work() */
  102. char buf[0]; /* fragment buffer */
  103. };
  104. int
  105. islpci_mgt_receive(struct net_device *ndev);
  106. int
  107. islpci_mgmt_rx_fill(struct net_device *ndev);
  108. void
  109. islpci_mgt_cleanup_transmit(struct net_device *ndev);
  110. int
  111. islpci_mgt_transaction(struct net_device *ndev,
  112. int operation, unsigned long oid,
  113. void *senddata, int sendlen,
  114. struct islpci_mgmtframe **recvframe);
  115. static inline void
  116. islpci_mgt_release(struct islpci_mgmtframe *frame)
  117. {
  118. kfree(frame);
  119. }
  120. #endif /* _ISLPCI_MGT_H */