mtk_ppe.h 8.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358
  1. // SPDX-License-Identifier: GPL-2.0-only
  2. /* Copyright (C) 2020 Felix Fietkau <[email protected]> */
  3. #ifndef __MTK_PPE_H
  4. #define __MTK_PPE_H
  5. #include <linux/kernel.h>
  6. #include <linux/bitfield.h>
  7. #include <linux/rhashtable.h>
  8. #define MTK_PPE_ENTRIES_SHIFT 3
  9. #define MTK_PPE_ENTRIES (1024 << MTK_PPE_ENTRIES_SHIFT)
  10. #define MTK_PPE_HASH_MASK (MTK_PPE_ENTRIES - 1)
  11. #define MTK_PPE_WAIT_TIMEOUT_US 1000000
  12. #define MTK_FOE_IB1_UNBIND_TIMESTAMP GENMASK(7, 0)
  13. #define MTK_FOE_IB1_UNBIND_PACKETS GENMASK(23, 8)
  14. #define MTK_FOE_IB1_UNBIND_PREBIND BIT(24)
  15. #define MTK_FOE_IB1_BIND_TIMESTAMP GENMASK(14, 0)
  16. #define MTK_FOE_IB1_BIND_KEEPALIVE BIT(15)
  17. #define MTK_FOE_IB1_BIND_VLAN_LAYER GENMASK(18, 16)
  18. #define MTK_FOE_IB1_BIND_PPPOE BIT(19)
  19. #define MTK_FOE_IB1_BIND_VLAN_TAG BIT(20)
  20. #define MTK_FOE_IB1_BIND_PKT_SAMPLE BIT(21)
  21. #define MTK_FOE_IB1_BIND_CACHE BIT(22)
  22. #define MTK_FOE_IB1_BIND_TUNNEL_DECAP BIT(23)
  23. #define MTK_FOE_IB1_BIND_TTL BIT(24)
  24. #define MTK_FOE_IB1_PACKET_TYPE GENMASK(27, 25)
  25. #define MTK_FOE_IB1_STATE GENMASK(29, 28)
  26. #define MTK_FOE_IB1_UDP BIT(30)
  27. #define MTK_FOE_IB1_STATIC BIT(31)
  28. /* CONFIG_MEDIATEK_NETSYS_V2 */
  29. #define MTK_FOE_IB1_BIND_TIMESTAMP_V2 GENMASK(7, 0)
  30. #define MTK_FOE_IB1_BIND_VLAN_LAYER_V2 GENMASK(16, 14)
  31. #define MTK_FOE_IB1_BIND_PPPOE_V2 BIT(17)
  32. #define MTK_FOE_IB1_BIND_VLAN_TAG_V2 BIT(18)
  33. #define MTK_FOE_IB1_BIND_CACHE_V2 BIT(20)
  34. #define MTK_FOE_IB1_BIND_TTL_V2 BIT(22)
  35. #define MTK_FOE_IB1_PACKET_TYPE_V2 GENMASK(27, 23)
  36. enum {
  37. MTK_PPE_PKT_TYPE_IPV4_HNAPT = 0,
  38. MTK_PPE_PKT_TYPE_IPV4_ROUTE = 1,
  39. MTK_PPE_PKT_TYPE_BRIDGE = 2,
  40. MTK_PPE_PKT_TYPE_IPV4_DSLITE = 3,
  41. MTK_PPE_PKT_TYPE_IPV6_ROUTE_3T = 4,
  42. MTK_PPE_PKT_TYPE_IPV6_ROUTE_5T = 5,
  43. MTK_PPE_PKT_TYPE_IPV6_6RD = 7,
  44. };
  45. #define MTK_FOE_IB2_QID GENMASK(3, 0)
  46. #define MTK_FOE_IB2_PSE_QOS BIT(4)
  47. #define MTK_FOE_IB2_DEST_PORT GENMASK(7, 5)
  48. #define MTK_FOE_IB2_MULTICAST BIT(8)
  49. #define MTK_FOE_IB2_WDMA_QID2 GENMASK(13, 12)
  50. #define MTK_FOE_IB2_WDMA_DEVIDX BIT(16)
  51. #define MTK_FOE_IB2_WDMA_WINFO BIT(17)
  52. #define MTK_FOE_IB2_PORT_MG GENMASK(17, 12)
  53. #define MTK_FOE_IB2_RX_IDX GENMASK(18, 17)
  54. #define MTK_FOE_IB2_PORT_AG GENMASK(23, 18)
  55. #define MTK_FOE_IB2_DSCP GENMASK(31, 24)
  56. /* CONFIG_MEDIATEK_NETSYS_V2 */
  57. #define MTK_FOE_IB2_PORT_MG_V2 BIT(7)
  58. #define MTK_FOE_IB2_DEST_PORT_V2 GENMASK(12, 9)
  59. #define MTK_FOE_IB2_MULTICAST_V2 BIT(13)
  60. #define MTK_FOE_IB2_WDMA_WINFO_V2 BIT(19)
  61. #define MTK_FOE_IB2_PORT_AG_V2 GENMASK(23, 20)
  62. #define MTK_FOE_VLAN2_WINFO_BSS GENMASK(5, 0)
  63. #define MTK_FOE_VLAN2_WINFO_WCID GENMASK(13, 6)
  64. #define MTK_FOE_VLAN2_WINFO_RING GENMASK(15, 14)
  65. #define MTK_FOE_WINFO_BSS GENMASK(5, 0)
  66. #define MTK_FOE_WINFO_WCID GENMASK(15, 6)
  67. enum {
  68. MTK_FOE_STATE_INVALID,
  69. MTK_FOE_STATE_UNBIND,
  70. MTK_FOE_STATE_BIND,
  71. MTK_FOE_STATE_FIN
  72. };
  73. struct mtk_foe_mac_info {
  74. u16 vlan1;
  75. u16 etype;
  76. u32 dest_mac_hi;
  77. u16 vlan2;
  78. u16 dest_mac_lo;
  79. u32 src_mac_hi;
  80. u16 pppoe_id;
  81. u16 src_mac_lo;
  82. u16 minfo;
  83. u16 winfo;
  84. };
  85. /* software-only entry type */
  86. struct mtk_foe_bridge {
  87. u8 dest_mac[ETH_ALEN];
  88. u8 src_mac[ETH_ALEN];
  89. u16 vlan;
  90. struct {} key_end;
  91. u32 ib2;
  92. struct mtk_foe_mac_info l2;
  93. };
  94. struct mtk_ipv4_tuple {
  95. u32 src_ip;
  96. u32 dest_ip;
  97. union {
  98. struct {
  99. u16 dest_port;
  100. u16 src_port;
  101. };
  102. struct {
  103. u8 protocol;
  104. u8 _pad[3]; /* fill with 0xa5a5a5 */
  105. };
  106. u32 ports;
  107. };
  108. };
  109. struct mtk_foe_ipv4 {
  110. struct mtk_ipv4_tuple orig;
  111. u32 ib2;
  112. struct mtk_ipv4_tuple new;
  113. u16 timestamp;
  114. u16 _rsv0[3];
  115. u32 udf_tsid;
  116. struct mtk_foe_mac_info l2;
  117. };
  118. struct mtk_foe_ipv4_dslite {
  119. struct mtk_ipv4_tuple ip4;
  120. u32 tunnel_src_ip[4];
  121. u32 tunnel_dest_ip[4];
  122. u8 flow_label[3];
  123. u8 priority;
  124. u32 udf_tsid;
  125. u32 ib2;
  126. struct mtk_foe_mac_info l2;
  127. };
  128. struct mtk_foe_ipv6 {
  129. u32 src_ip[4];
  130. u32 dest_ip[4];
  131. union {
  132. struct {
  133. u8 protocol;
  134. u8 _pad[3]; /* fill with 0xa5a5a5 */
  135. }; /* 3-tuple */
  136. struct {
  137. u16 dest_port;
  138. u16 src_port;
  139. }; /* 5-tuple */
  140. u32 ports;
  141. };
  142. u32 _rsv[3];
  143. u32 udf;
  144. u32 ib2;
  145. struct mtk_foe_mac_info l2;
  146. };
  147. struct mtk_foe_ipv6_6rd {
  148. u32 src_ip[4];
  149. u32 dest_ip[4];
  150. u16 dest_port;
  151. u16 src_port;
  152. u32 tunnel_src_ip;
  153. u32 tunnel_dest_ip;
  154. u16 hdr_csum;
  155. u8 dscp;
  156. u8 ttl;
  157. u8 flag;
  158. u8 pad;
  159. u8 per_flow_6rd_id;
  160. u8 pad2;
  161. u32 ib2;
  162. struct mtk_foe_mac_info l2;
  163. };
  164. struct mtk_foe_entry {
  165. u32 ib1;
  166. union {
  167. struct mtk_foe_bridge bridge;
  168. struct mtk_foe_ipv4 ipv4;
  169. struct mtk_foe_ipv4_dslite dslite;
  170. struct mtk_foe_ipv6 ipv6;
  171. struct mtk_foe_ipv6_6rd ipv6_6rd;
  172. u32 data[23];
  173. };
  174. };
  175. enum {
  176. MTK_PPE_CPU_REASON_TTL_EXCEEDED = 0x02,
  177. MTK_PPE_CPU_REASON_OPTION_HEADER = 0x03,
  178. MTK_PPE_CPU_REASON_NO_FLOW = 0x07,
  179. MTK_PPE_CPU_REASON_IPV4_FRAG = 0x08,
  180. MTK_PPE_CPU_REASON_IPV4_DSLITE_FRAG = 0x09,
  181. MTK_PPE_CPU_REASON_IPV4_DSLITE_NO_TCP_UDP = 0x0a,
  182. MTK_PPE_CPU_REASON_IPV6_6RD_NO_TCP_UDP = 0x0b,
  183. MTK_PPE_CPU_REASON_TCP_FIN_SYN_RST = 0x0c,
  184. MTK_PPE_CPU_REASON_UN_HIT = 0x0d,
  185. MTK_PPE_CPU_REASON_HIT_UNBIND = 0x0e,
  186. MTK_PPE_CPU_REASON_HIT_UNBIND_RATE_REACHED = 0x0f,
  187. MTK_PPE_CPU_REASON_HIT_BIND_TCP_FIN = 0x10,
  188. MTK_PPE_CPU_REASON_HIT_TTL_1 = 0x11,
  189. MTK_PPE_CPU_REASON_HIT_BIND_VLAN_VIOLATION = 0x12,
  190. MTK_PPE_CPU_REASON_KEEPALIVE_UC_OLD_HDR = 0x13,
  191. MTK_PPE_CPU_REASON_KEEPALIVE_MC_NEW_HDR = 0x14,
  192. MTK_PPE_CPU_REASON_KEEPALIVE_DUP_OLD_HDR = 0x15,
  193. MTK_PPE_CPU_REASON_HIT_BIND_FORCE_CPU = 0x16,
  194. MTK_PPE_CPU_REASON_TUNNEL_OPTION_HEADER = 0x17,
  195. MTK_PPE_CPU_REASON_MULTICAST_TO_CPU = 0x18,
  196. MTK_PPE_CPU_REASON_MULTICAST_TO_GMAC1_CPU = 0x19,
  197. MTK_PPE_CPU_REASON_HIT_PRE_BIND = 0x1a,
  198. MTK_PPE_CPU_REASON_PACKET_SAMPLING = 0x1b,
  199. MTK_PPE_CPU_REASON_EXCEED_MTU = 0x1c,
  200. MTK_PPE_CPU_REASON_PPE_BYPASS = 0x1e,
  201. MTK_PPE_CPU_REASON_INVALID = 0x1f,
  202. };
  203. enum {
  204. MTK_FLOW_TYPE_L4,
  205. MTK_FLOW_TYPE_L2,
  206. MTK_FLOW_TYPE_L2_SUBFLOW,
  207. };
  208. struct mtk_flow_entry {
  209. union {
  210. struct hlist_node list;
  211. struct {
  212. struct rhash_head l2_node;
  213. struct hlist_head l2_flows;
  214. };
  215. };
  216. u8 type;
  217. s8 wed_index;
  218. u8 ppe_index;
  219. u16 hash;
  220. union {
  221. struct mtk_foe_entry data;
  222. struct {
  223. struct mtk_flow_entry *base_flow;
  224. struct hlist_node list;
  225. } l2_data;
  226. };
  227. struct rhash_head node;
  228. unsigned long cookie;
  229. };
  230. struct mtk_ppe {
  231. struct mtk_eth *eth;
  232. struct device *dev;
  233. void __iomem *base;
  234. int version;
  235. char dirname[5];
  236. void *foe_table;
  237. dma_addr_t foe_phys;
  238. u16 foe_check_time[MTK_PPE_ENTRIES];
  239. struct hlist_head *foe_flow;
  240. struct rhashtable l2_flows;
  241. void *acct_table;
  242. };
  243. struct mtk_ppe *mtk_ppe_init(struct mtk_eth *eth, void __iomem *base,
  244. int version, int index);
  245. void mtk_ppe_deinit(struct mtk_eth *eth);
  246. void mtk_ppe_start(struct mtk_ppe *ppe);
  247. int mtk_ppe_stop(struct mtk_ppe *ppe);
  248. void __mtk_ppe_check_skb(struct mtk_ppe *ppe, struct sk_buff *skb, u16 hash);
  249. static inline void
  250. mtk_ppe_check_skb(struct mtk_ppe *ppe, struct sk_buff *skb, u16 hash)
  251. {
  252. u16 now, diff;
  253. if (!ppe)
  254. return;
  255. if (hash > MTK_PPE_HASH_MASK)
  256. return;
  257. now = (u16)jiffies;
  258. diff = now - ppe->foe_check_time[hash];
  259. if (diff < HZ / 10)
  260. return;
  261. ppe->foe_check_time[hash] = now;
  262. __mtk_ppe_check_skb(ppe, skb, hash);
  263. }
  264. int mtk_foe_entry_prepare(struct mtk_eth *eth, struct mtk_foe_entry *entry,
  265. int type, int l4proto, u8 pse_port, u8 *src_mac,
  266. u8 *dest_mac);
  267. int mtk_foe_entry_set_pse_port(struct mtk_eth *eth,
  268. struct mtk_foe_entry *entry, u8 port);
  269. int mtk_foe_entry_set_ipv4_tuple(struct mtk_eth *eth,
  270. struct mtk_foe_entry *entry, bool orig,
  271. __be32 src_addr, __be16 src_port,
  272. __be32 dest_addr, __be16 dest_port);
  273. int mtk_foe_entry_set_ipv6_tuple(struct mtk_eth *eth,
  274. struct mtk_foe_entry *entry,
  275. __be32 *src_addr, __be16 src_port,
  276. __be32 *dest_addr, __be16 dest_port);
  277. int mtk_foe_entry_set_dsa(struct mtk_eth *eth, struct mtk_foe_entry *entry,
  278. int port);
  279. int mtk_foe_entry_set_vlan(struct mtk_eth *eth, struct mtk_foe_entry *entry,
  280. int vid);
  281. int mtk_foe_entry_set_pppoe(struct mtk_eth *eth, struct mtk_foe_entry *entry,
  282. int sid);
  283. int mtk_foe_entry_set_wdma(struct mtk_eth *eth, struct mtk_foe_entry *entry,
  284. int wdma_idx, int txq, int bss, int wcid);
  285. int mtk_foe_entry_commit(struct mtk_ppe *ppe, struct mtk_flow_entry *entry);
  286. void mtk_foe_entry_clear(struct mtk_ppe *ppe, struct mtk_flow_entry *entry);
  287. int mtk_foe_entry_idle_time(struct mtk_ppe *ppe, struct mtk_flow_entry *entry);
  288. int mtk_ppe_debugfs_init(struct mtk_ppe *ppe, int index);
  289. #endif