icrdma_hw.h 2.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  1. /* SPDX-License-Identifier: GPL-2.0 or Linux-OpenIB */
  2. /* Copyright (c) 2017 - 2021 Intel Corporation */
  3. #ifndef ICRDMA_HW_H
  4. #define ICRDMA_HW_H
  5. #include "irdma.h"
  6. #define VFPE_CQPTAIL1 0x0000a000
  7. #define VFPE_CQPDB1 0x0000bc00
  8. #define VFPE_CCQPSTATUS1 0x0000b800
  9. #define VFPE_CCQPHIGH1 0x00009800
  10. #define VFPE_CCQPLOW1 0x0000ac00
  11. #define VFPE_CQARM1 0x0000b400
  12. #define VFPE_CQARM1 0x0000b400
  13. #define VFPE_CQACK1 0x0000b000
  14. #define VFPE_AEQALLOC1 0x0000a400
  15. #define VFPE_CQPERRCODES1 0x00009c00
  16. #define VFPE_WQEALLOC1 0x0000c000
  17. #define VFINT_DYN_CTLN(_i) (0x00003800 + ((_i) * 4)) /* _i=0...63 */
  18. #define PFPE_CQPTAIL 0x00500880
  19. #define PFPE_CQPDB 0x00500800
  20. #define PFPE_CCQPSTATUS 0x0050a000
  21. #define PFPE_CCQPHIGH 0x0050a100
  22. #define PFPE_CCQPLOW 0x0050a080
  23. #define PFPE_CQARM 0x00502c00
  24. #define PFPE_CQACK 0x00502c80
  25. #define PFPE_AEQALLOC 0x00502d00
  26. #define GLINT_DYN_CTL(_INT) (0x00160000 + ((_INT) * 4)) /* _i=0...2047 */
  27. #define GLPCI_LBARCTRL 0x0009de74
  28. #define GLPE_CPUSTATUS0 0x0050ba5c
  29. #define GLPE_CPUSTATUS1 0x0050ba60
  30. #define GLPE_CPUSTATUS2 0x0050ba64
  31. #define PFINT_AEQCTL 0x0016cb00
  32. #define PFPE_CQPERRCODES 0x0050a200
  33. #define PFPE_WQEALLOC 0x00504400
  34. #define GLINT_CEQCTL(_INT) (0x0015c000 + ((_INT) * 4)) /* _i=0...2047 */
  35. #define VSIQF_PE_CTL1(_VSI) (0x00414000 + ((_VSI) * 4)) /* _i=0...767 */
  36. #define PFHMC_PDINV 0x00520300
  37. #define GLHMC_VFPDINV(_i) (0x00528300 + ((_i) * 4)) /* _i=0...31 */
  38. #define GLPE_CRITERR 0x00534000
  39. #define GLINT_RATE(_INT) (0x0015A000 + ((_INT) * 4)) /* _i=0...2047 */ /* Reset Source: CORER */
  40. #define ICRDMA_DB_ADDR_OFFSET (8 * 1024 * 1024 - 64 * 1024)
  41. #define ICRDMA_VF_DB_ADDR_OFFSET (64 * 1024)
  42. /* shifts/masks for FLD_[LS/RS]_64 macros used in device table */
  43. #define ICRDMA_CCQPSTATUS_CCQP_DONE_S 0
  44. #define ICRDMA_CCQPSTATUS_CCQP_DONE BIT_ULL(0)
  45. #define ICRDMA_CCQPSTATUS_CCQP_ERR_S 31
  46. #define ICRDMA_CCQPSTATUS_CCQP_ERR BIT_ULL(31)
  47. #define ICRDMA_CQPSQ_STAG_PDID_S 46
  48. #define ICRDMA_CQPSQ_STAG_PDID GENMASK_ULL(63, 46)
  49. #define ICRDMA_CQPSQ_CQ_CEQID_S 22
  50. #define ICRDMA_CQPSQ_CQ_CEQID GENMASK_ULL(31, 22)
  51. #define ICRDMA_CQPSQ_CQ_CQID_S 0
  52. #define ICRDMA_CQPSQ_CQ_CQID GENMASK_ULL(18, 0)
  53. #define ICRDMA_COMMIT_FPM_CQCNT_S 0
  54. #define ICRDMA_COMMIT_FPM_CQCNT GENMASK_ULL(19, 0)
  55. enum icrdma_device_caps_const {
  56. ICRDMA_MAX_STATS_COUNT = 128,
  57. ICRDMA_MAX_IRD_SIZE = 127,
  58. ICRDMA_MAX_ORD_SIZE = 255,
  59. };
  60. void icrdma_init_hw(struct irdma_sc_dev *dev);
  61. #endif /* ICRDMA_HW_H*/