cfg_ipa.h 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210
  1. /*
  2. * Copyright (c) 2012-2019 The Linux Foundation. All rights reserved.
  3. *
  4. * Permission to use, copy, modify, and/or distribute this software for
  5. * any purpose with or without fee is hereby granted, provided that the
  6. * above copyright notice and this permission notice appear in all
  7. * copies.
  8. *
  9. * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL
  10. * WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED
  11. * WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE
  12. * AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL
  13. * DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR
  14. * PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER
  15. * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
  16. * PERFORMANCE OF THIS SOFTWARE.
  17. */
  18. /**
  19. * DOC: This file contains definitions of Data Path configuration.
  20. */
  21. #ifndef _CFG_IPA_H_
  22. #define _CFG_IPA_H_
  23. #include "cfg_define.h"
  24. /* DP INI Declerations */
  25. /*
  26. * IPA Offload configuration - Each bit enables a feature
  27. * bit0 - IPA Enable
  28. * bit1 - IPA Pre filter enable
  29. * bit2 - IPv6 enable
  30. * bit3 - IPA Resource Manager (RM) enable
  31. * bit4 - IPA Clock scaling enable
  32. */
  33. /*
  34. * <ini>
  35. * gIPAConfig - IPA configuration
  36. * @Min: 0
  37. * @Max: 0xFFFFFFFF
  38. * @Default: 0
  39. *
  40. * This ini specifies the IPA configuration
  41. *
  42. * Related: N/A
  43. *
  44. * Supported Feature: IPA
  45. *
  46. * Usage: Internal
  47. *
  48. * </ini>
  49. */
  50. #define CFG_DP_IPA_OFFLOAD_CONFIG \
  51. CFG_INI_UINT("gIPAConfig", \
  52. 0, \
  53. 0xFFFFFFFF, \
  54. 0, \
  55. CFG_VALUE_OR_DEFAULT, "IPA offload configuration")
  56. /*
  57. * <ini>
  58. * gIPADescSize - IPA descriptor size
  59. * @Min: 800
  60. * @Max: 8000
  61. * @Default: 800
  62. *
  63. * This ini specifies the IPA descriptor size
  64. *
  65. * Related: N/A
  66. *
  67. * Supported Feature: IPA
  68. *
  69. * Usage: Internal
  70. *
  71. * </ini>
  72. */
  73. #define CFG_DP_IPA_DESC_SIZE \
  74. CFG_INI_UINT("gIPADescSize", \
  75. 800, \
  76. 8000, \
  77. 800, \
  78. CFG_VALUE_OR_DEFAULT, "IPA DESC SIZE")
  79. /*
  80. * <ini>
  81. * gIPAHighBandwidthMbps - IPA high bw threshold
  82. * @Min: 200
  83. * @Max: 1000
  84. * @Default: 400
  85. *
  86. * This ini specifies the IPA high bw threshold
  87. *
  88. * Related: N/A
  89. *
  90. * Supported Feature: IPA
  91. *
  92. * Usage: Internal
  93. *
  94. * </ini>
  95. */
  96. #define CFG_DP_IPA_HIGH_BANDWIDTH_MBPS \
  97. CFG_INI_UINT("gIPAHighBandwidthMbps", \
  98. 200, \
  99. 1000, \
  100. 400, \
  101. CFG_VALUE_OR_DEFAULT, "IPA high bw threshold")
  102. /*
  103. * <ini>
  104. * gIPAMediumBandwidthMbps - IPA medium bw threshold
  105. * @Min: 100
  106. * @Max: 400
  107. * @Default: 200
  108. *
  109. * This ini specifies the IPA medium bw threshold
  110. *
  111. * Related: N/A
  112. *
  113. * Supported Feature: IPA
  114. *
  115. * Usage: Internal
  116. *
  117. * </ini>
  118. */
  119. #define CFG_DP_IPA_MEDIUM_BANDWIDTH_MBPS \
  120. CFG_INI_UINT("gIPAMediumBandwidthMbps", \
  121. 100, \
  122. 400, \
  123. 200, \
  124. CFG_VALUE_OR_DEFAULT, "IPA medium bw threshold")
  125. /*
  126. * <ini>
  127. * gIPALowBandwidthMbps - IPA low bw threshold
  128. * @Min: 0
  129. * @Max: 100
  130. * @Default: 100
  131. *
  132. * This ini specifies the IPA low bw threshold
  133. *
  134. * Related: N/A
  135. *
  136. * Supported Feature: IPA
  137. *
  138. * Usage: Internal
  139. *
  140. * </ini>
  141. */
  142. #define CFG_DP_IPA_LOW_BANDWIDTH_MBPS \
  143. CFG_INI_UINT("gIPALowBandwidthMbps", \
  144. 0, \
  145. 100, \
  146. 100, \
  147. CFG_VALUE_OR_DEFAULT, "IPA low bw threshold")
  148. /*
  149. * <ini>
  150. * gIPAForceVotingEnable - IPA force voting enable
  151. * @Default: false
  152. *
  153. * This ini specifies to enable IPA force voting
  154. *
  155. * Related: N/A
  156. *
  157. * Supported Feature: IPA
  158. *
  159. * Usage: Internal
  160. *
  161. * </ini>
  162. */
  163. #define CFG_DP_IPA_ENABLE_FORCE_VOTING \
  164. CFG_INI_BOOL("gIPAForceVotingEnable", \
  165. false, "Ctrl to enable force voting")
  166. /*
  167. * <ini>
  168. * IpaUcTxBufCount - IPA tx buffer count
  169. * @Min: 0
  170. * @Max: 2048
  171. * @Default: 512
  172. *
  173. * This ini specifies the IPA tx buffer count
  174. *
  175. * Related: N/A
  176. *
  177. * Supported Feature: IPA
  178. *
  179. * Usage: Internal
  180. *
  181. * </ini>
  182. */
  183. #define CFG_DP_IPA_UC_TX_BUF_COUNT \
  184. CFG_INI_UINT("IpaUcTxBufCount", \
  185. 0, \
  186. 2048, \
  187. 512, \
  188. CFG_VALUE_OR_DEFAULT, "IPA tx buffer count")
  189. #define CFG_IPA \
  190. CFG(CFG_DP_IPA_OFFLOAD_CONFIG) \
  191. CFG(CFG_DP_IPA_DESC_SIZE) \
  192. CFG(CFG_DP_IPA_HIGH_BANDWIDTH_MBPS) \
  193. CFG(CFG_DP_IPA_MEDIUM_BANDWIDTH_MBPS) \
  194. CFG(CFG_DP_IPA_LOW_BANDWIDTH_MBPS) \
  195. CFG(CFG_DP_IPA_ENABLE_FORCE_VOTING) \
  196. CFG(CFG_DP_IPA_UC_TX_BUF_COUNT)
  197. #endif /* _CFG_IPA_H_ */