desc.h 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  1. /*
  2. * Copyright (c) 1996, 2003 VIA Networking Technologies, Inc.
  3. * All rights reserved.
  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, or
  8. * (at your option) any later version.
  9. *
  10. * This program is distributed in the hope that it will be useful,
  11. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  12. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  13. * GNU General Public License for more details.
  14. *
  15. *
  16. * File: desc.h
  17. *
  18. * Purpose:The header file of descriptor
  19. *
  20. * Revision History:
  21. *
  22. * Author: Tevin Chen
  23. *
  24. * Date: May 21, 1996
  25. *
  26. */
  27. #ifndef __DESC_H__
  28. #define __DESC_H__
  29. #include <linux/types.h>
  30. #include <linux/mm.h>
  31. /* max transmit or receive buffer size */
  32. #define CB_MAX_BUF_SIZE 2900U /* NOTE: must be multiple of 4 */
  33. #define MAX_TOTAL_SIZE_WITH_ALL_HEADERS CB_MAX_BUF_SIZE
  34. #define MAX_INTERRUPT_SIZE 32
  35. #define CB_MAX_RX_DESC 128 /* max # of descriptors */
  36. #define CB_MIN_RX_DESC 16 /* min # of RX descriptors */
  37. #define CB_MAX_TX_DESC 128 /* max # of descriptors */
  38. #define CB_MIN_TX_DESC 16 /* min # of TX descriptors */
  39. /*
  40. * bits in the RSR register
  41. */
  42. #define RSR_ADDRBROAD 0x80
  43. #define RSR_ADDRMULTI 0x40
  44. #define RSR_ADDRUNI 0x00
  45. #define RSR_IVLDTYP 0x20 /* invalid packet type */
  46. #define RSR_IVLDLEN 0x10 /* invalid len (> 2312 byte) */
  47. #define RSR_BSSIDOK 0x08
  48. #define RSR_CRCOK 0x04
  49. #define RSR_BCNSSIDOK 0x02
  50. #define RSR_ADDROK 0x01
  51. /*
  52. * bits in the new RSR register
  53. */
  54. #define NEWRSR_DECRYPTOK 0x10
  55. #define NEWRSR_CFPIND 0x08
  56. #define NEWRSR_HWUTSF 0x04
  57. #define NEWRSR_BCNHITAID 0x02
  58. #define NEWRSR_BCNHITAID0 0x01
  59. /*
  60. * bits in the TSR register
  61. */
  62. #define TSR_RETRYTMO 0x08
  63. #define TSR_TMO 0x04
  64. #define TSR_ACKDATA 0x02
  65. #define TSR_VALID 0x01
  66. #define FIFOCTL_AUTO_FB_1 0x1000
  67. #define FIFOCTL_AUTO_FB_0 0x0800
  68. #define FIFOCTL_GRPACK 0x0400
  69. #define FIFOCTL_11GA 0x0300
  70. #define FIFOCTL_11GB 0x0200
  71. #define FIFOCTL_11B 0x0100
  72. #define FIFOCTL_11A 0x0000
  73. #define FIFOCTL_RTS 0x0080
  74. #define FIFOCTL_ISDMA0 0x0040
  75. #define FIFOCTL_GENINT 0x0020
  76. #define FIFOCTL_TMOEN 0x0010
  77. #define FIFOCTL_LRETRY 0x0008
  78. #define FIFOCTL_CRCDIS 0x0004
  79. #define FIFOCTL_NEEDACK 0x0002
  80. #define FIFOCTL_LHEAD 0x0001
  81. /* WMAC definition Frag Control */
  82. #define FRAGCTL_AES 0x0300
  83. #define FRAGCTL_TKIP 0x0200
  84. #define FRAGCTL_LEGACY 0x0100
  85. #define FRAGCTL_NONENCRYPT 0x0000
  86. #define FRAGCTL_ENDFRAG 0x0003
  87. #define FRAGCTL_MIDFRAG 0x0002
  88. #define FRAGCTL_STAFRAG 0x0001
  89. #define FRAGCTL_NONFRAG 0x0000
  90. #endif /* __DESC_H__ */