mmc.h 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130
  1. /* SPDX-License-Identifier: GPL-2.0-only */
  2. /*******************************************************************************
  3. MMC Header file
  4. Copyright (C) 2011 STMicroelectronics Ltd
  5. Author: Giuseppe Cavallaro <[email protected]>
  6. *******************************************************************************/
  7. #ifndef __MMC_H__
  8. #define __MMC_H__
  9. /* MMC control register */
  10. /* When set, all counter are reset */
  11. #define MMC_CNTRL_COUNTER_RESET 0x1
  12. /* When set, do not roll over zero after reaching the max value*/
  13. #define MMC_CNTRL_COUNTER_STOP_ROLLOVER 0x2
  14. #define MMC_CNTRL_RESET_ON_READ 0x4 /* Reset after reading */
  15. #define MMC_CNTRL_COUNTER_FREEZER 0x8 /* Freeze counter values to the
  16. * current value.*/
  17. #define MMC_CNTRL_PRESET 0x10
  18. #define MMC_CNTRL_FULL_HALF_PRESET 0x20
  19. #define MMC_GMAC4_OFFSET 0x700
  20. #define MMC_GMAC3_X_OFFSET 0x100
  21. #define MMC_XGMAC_OFFSET 0x800
  22. struct stmmac_counters {
  23. unsigned int mmc_tx_octetcount_gb;
  24. unsigned int mmc_tx_framecount_gb;
  25. unsigned int mmc_tx_broadcastframe_g;
  26. unsigned int mmc_tx_multicastframe_g;
  27. unsigned int mmc_tx_64_octets_gb;
  28. unsigned int mmc_tx_65_to_127_octets_gb;
  29. unsigned int mmc_tx_128_to_255_octets_gb;
  30. unsigned int mmc_tx_256_to_511_octets_gb;
  31. unsigned int mmc_tx_512_to_1023_octets_gb;
  32. unsigned int mmc_tx_1024_to_max_octets_gb;
  33. unsigned int mmc_tx_unicast_gb;
  34. unsigned int mmc_tx_multicast_gb;
  35. unsigned int mmc_tx_broadcast_gb;
  36. unsigned int mmc_tx_underflow_error;
  37. unsigned int mmc_tx_singlecol_g;
  38. unsigned int mmc_tx_multicol_g;
  39. unsigned int mmc_tx_deferred;
  40. unsigned int mmc_tx_latecol;
  41. unsigned int mmc_tx_exesscol;
  42. unsigned int mmc_tx_carrier_error;
  43. unsigned int mmc_tx_octetcount_g;
  44. unsigned int mmc_tx_framecount_g;
  45. unsigned int mmc_tx_excessdef;
  46. unsigned int mmc_tx_pause_frame;
  47. unsigned int mmc_tx_vlan_frame_g;
  48. /* MMC RX counter registers */
  49. unsigned int mmc_rx_framecount_gb;
  50. unsigned int mmc_rx_octetcount_gb;
  51. unsigned int mmc_rx_octetcount_g;
  52. unsigned int mmc_rx_broadcastframe_g;
  53. unsigned int mmc_rx_multicastframe_g;
  54. unsigned int mmc_rx_crc_error;
  55. unsigned int mmc_rx_align_error;
  56. unsigned int mmc_rx_run_error;
  57. unsigned int mmc_rx_jabber_error;
  58. unsigned int mmc_rx_undersize_g;
  59. unsigned int mmc_rx_oversize_g;
  60. unsigned int mmc_rx_64_octets_gb;
  61. unsigned int mmc_rx_65_to_127_octets_gb;
  62. unsigned int mmc_rx_128_to_255_octets_gb;
  63. unsigned int mmc_rx_256_to_511_octets_gb;
  64. unsigned int mmc_rx_512_to_1023_octets_gb;
  65. unsigned int mmc_rx_1024_to_max_octets_gb;
  66. unsigned int mmc_rx_unicast_g;
  67. unsigned int mmc_rx_length_error;
  68. unsigned int mmc_rx_autofrangetype;
  69. unsigned int mmc_rx_pause_frames;
  70. unsigned int mmc_rx_fifo_overflow;
  71. unsigned int mmc_rx_vlan_frames_gb;
  72. unsigned int mmc_rx_watchdog_error;
  73. /* IPC */
  74. unsigned int mmc_rx_ipc_intr_mask;
  75. unsigned int mmc_rx_ipc_intr;
  76. /* IPv4 */
  77. unsigned int mmc_rx_ipv4_gd;
  78. unsigned int mmc_rx_ipv4_hderr;
  79. unsigned int mmc_rx_ipv4_nopay;
  80. unsigned int mmc_rx_ipv4_frag;
  81. unsigned int mmc_rx_ipv4_udsbl;
  82. unsigned int mmc_rx_ipv4_gd_octets;
  83. unsigned int mmc_rx_ipv4_hderr_octets;
  84. unsigned int mmc_rx_ipv4_nopay_octets;
  85. unsigned int mmc_rx_ipv4_frag_octets;
  86. unsigned int mmc_rx_ipv4_udsbl_octets;
  87. /* IPV6 */
  88. unsigned int mmc_rx_ipv6_gd_octets;
  89. unsigned int mmc_rx_ipv6_hderr_octets;
  90. unsigned int mmc_rx_ipv6_nopay_octets;
  91. unsigned int mmc_rx_ipv6_gd;
  92. unsigned int mmc_rx_ipv6_hderr;
  93. unsigned int mmc_rx_ipv6_nopay;
  94. /* Protocols */
  95. unsigned int mmc_rx_udp_gd;
  96. unsigned int mmc_rx_udp_err;
  97. unsigned int mmc_rx_tcp_gd;
  98. unsigned int mmc_rx_tcp_err;
  99. unsigned int mmc_rx_icmp_gd;
  100. unsigned int mmc_rx_icmp_err;
  101. unsigned int mmc_rx_udp_gd_octets;
  102. unsigned int mmc_rx_udp_err_octets;
  103. unsigned int mmc_rx_tcp_gd_octets;
  104. unsigned int mmc_rx_tcp_err_octets;
  105. unsigned int mmc_rx_icmp_gd_octets;
  106. unsigned int mmc_rx_icmp_err_octets;
  107. /* FPE */
  108. unsigned int mmc_tx_fpe_fragment_cntr;
  109. unsigned int mmc_tx_hold_req_cntr;
  110. unsigned int mmc_rx_packet_assembly_err_cntr;
  111. unsigned int mmc_rx_packet_smd_err_cntr;
  112. unsigned int mmc_rx_packet_assembly_ok_cntr;
  113. unsigned int mmc_rx_fpe_fragment_cntr;
  114. };
  115. #endif /* __MMC_H__ */