regs.h 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384
  1. /*******************************************************************************
  2. Intel 82599 Virtual Function driver
  3. Copyright(c) 1999 - 2015 Intel Corporation.
  4. This program is free software; you can redistribute it and/or modify it
  5. under the terms and conditions of the GNU General Public License,
  6. version 2, as published by the Free Software Foundation.
  7. This program is distributed in the hope it will be useful, but WITHOUT
  8. ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
  9. FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  10. more details.
  11. You should have received a copy of the GNU General Public License along with
  12. this program; if not, see <http://www.gnu.org/licenses/>.
  13. The full GNU General Public License is included in this distribution in
  14. the file called "COPYING".
  15. Contact Information:
  16. e1000-devel Mailing List <e1000-devel@lists.sourceforge.net>
  17. Intel Corporation, 5200 N.E. Elam Young Parkway, Hillsboro, OR 97124-6497
  18. *******************************************************************************/
  19. #ifndef _IXGBEVF_REGS_H_
  20. #define _IXGBEVF_REGS_H_
  21. #define IXGBE_VFCTRL 0x00000
  22. #define IXGBE_VFSTATUS 0x00008
  23. #define IXGBE_VFLINKS 0x00010
  24. #define IXGBE_VFFRTIMER 0x00048
  25. #define IXGBE_VFRXMEMWRAP 0x03190
  26. #define IXGBE_VTEICR 0x00100
  27. #define IXGBE_VTEICS 0x00104
  28. #define IXGBE_VTEIMS 0x00108
  29. #define IXGBE_VTEIMC 0x0010C
  30. #define IXGBE_VTEIAC 0x00110
  31. #define IXGBE_VTEIAM 0x00114
  32. #define IXGBE_VTEITR(x) (0x00820 + (4 * (x)))
  33. #define IXGBE_VTIVAR(x) (0x00120 + (4 * (x)))
  34. #define IXGBE_VTIVAR_MISC 0x00140
  35. #define IXGBE_VTRSCINT(x) (0x00180 + (4 * (x)))
  36. #define IXGBE_VFRDBAL(x) (0x01000 + (0x40 * (x)))
  37. #define IXGBE_VFRDBAH(x) (0x01004 + (0x40 * (x)))
  38. #define IXGBE_VFRDLEN(x) (0x01008 + (0x40 * (x)))
  39. #define IXGBE_VFRDH(x) (0x01010 + (0x40 * (x)))
  40. #define IXGBE_VFRDT(x) (0x01018 + (0x40 * (x)))
  41. #define IXGBE_VFRXDCTL(x) (0x01028 + (0x40 * (x)))
  42. #define IXGBE_VFSRRCTL(x) (0x01014 + (0x40 * (x)))
  43. #define IXGBE_VFRSCCTL(x) (0x0102C + (0x40 * (x)))
  44. #define IXGBE_VFPSRTYPE 0x00300
  45. #define IXGBE_VFTDBAL(x) (0x02000 + (0x40 * (x)))
  46. #define IXGBE_VFTDBAH(x) (0x02004 + (0x40 * (x)))
  47. #define IXGBE_VFTDLEN(x) (0x02008 + (0x40 * (x)))
  48. #define IXGBE_VFTDH(x) (0x02010 + (0x40 * (x)))
  49. #define IXGBE_VFTDT(x) (0x02018 + (0x40 * (x)))
  50. #define IXGBE_VFTXDCTL(x) (0x02028 + (0x40 * (x)))
  51. #define IXGBE_VFTDWBAL(x) (0x02038 + (0x40 * (x)))
  52. #define IXGBE_VFTDWBAH(x) (0x0203C + (0x40 * (x)))
  53. #define IXGBE_VFDCA_RXCTRL(x) (0x0100C + (0x40 * (x)))
  54. #define IXGBE_VFDCA_TXCTRL(x) (0x0200c + (0x40 * (x)))
  55. #define IXGBE_VFGPRC 0x0101C
  56. #define IXGBE_VFGPTC 0x0201C
  57. #define IXGBE_VFGORC_LSB 0x01020
  58. #define IXGBE_VFGORC_MSB 0x01024
  59. #define IXGBE_VFGOTC_LSB 0x02020
  60. #define IXGBE_VFGOTC_MSB 0x02024
  61. #define IXGBE_VFMPRC 0x01034
  62. #define IXGBE_VFMRQC 0x3000
  63. #define IXGBE_VFRSSRK(x) (0x3100 + ((x) * 4))
  64. #define IXGBE_VFRETA(x) (0x3200 + ((x) * 4))
  65. /* VFMRQC bits */
  66. #define IXGBE_VFMRQC_RSSEN 0x00000001 /* RSS Enable */
  67. #define IXGBE_VFMRQC_RSS_FIELD_IPV4_TCP 0x00010000
  68. #define IXGBE_VFMRQC_RSS_FIELD_IPV4 0x00020000
  69. #define IXGBE_VFMRQC_RSS_FIELD_IPV6 0x00100000
  70. #define IXGBE_VFMRQC_RSS_FIELD_IPV6_TCP 0x00200000
  71. #define IXGBE_WRITE_FLUSH(a) (IXGBE_READ_REG(a, IXGBE_VFSTATUS))
  72. #endif /* _IXGBEVF_REGS_H_ */