blob: 96bbe06367073ec9dcc2616b39d7ad8b0527a3e9 [file] [log] [blame]
developerfd40db22021-04-29 10:08:25 +08001/* This program is free software; you can redistribute it and/or modify
2 * it under the terms of the GNU General Public License as published by
3 * the Free Software Foundation; version 2 of the License
4 *
5 * This program is distributed in the hope that it will be useful,
6 * but WITHOUT ANY WARRANTY; without even the implied warranty of
7 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
8 * GNU General Public License for more details.
9 *
10 * Copyright (C) 2014-2016 Sean Wang <sean.wang@mediatek.com>
11 * Copyright (C) 2016-2017 John Crispin <blogic@openwrt.org>
12 */
13
14#ifndef NF_HNAT_MTK_H
15#define NF_HNAT_MTK_H
16
17#include <linux/dma-mapping.h>
18#include <linux/netdevice.h>
19#include "../mtk_eth_soc.h"
20
21#define HNAT_SKB_CB2(__skb) ((struct hnat_skb_cb2 *)&((__skb)->cb[44]))
22struct hnat_skb_cb2 {
23 __u32 magic;
24};
25
developera2bdbd52021-05-31 19:10:17 +080026#if defined(CONFIG_MEDIATEK_NETSYS_V2)
developerfd40db22021-04-29 10:08:25 +080027struct hnat_desc {
28 u32 entry : 15;
developerfdfe1572021-09-13 16:56:33 +080029 u32 filled : 3;
developerfd40db22021-04-29 10:08:25 +080030 u32 crsn : 5;
31 u32 resv1 : 3;
32 u32 sport : 4;
33 u32 resv2 : 1;
34 u32 alg : 1;
developere567ad32021-05-25 17:16:17 +080035 u32 iface : 8;
developerfd40db22021-04-29 10:08:25 +080036 u32 wdmaid : 2;
37 u32 rxid : 2;
38 u32 wcid : 10;
39 u32 bssid : 6;
developere567ad32021-05-25 17:16:17 +080040 u32 resv5 : 20;
41 u32 magic_tag_protect : 16;
developerfd40db22021-04-29 10:08:25 +080042} __packed;
43#else
44struct hnat_desc {
45 u32 entry : 14;
46 u32 crsn : 5;
47 u32 sport : 4;
48 u32 alg : 1;
49 u32 iface : 4;
developerfdfe1572021-09-13 16:56:33 +080050 u32 filled : 3;
51 u32 resv : 1;
developerfd40db22021-04-29 10:08:25 +080052 u32 magic_tag_protect : 16;
53 u32 wdmaid : 8;
54 u32 rxid : 2;
55 u32 wcid : 8;
56 u32 bssid : 6;
57} __packed;
58#endif
59
developerfd40db22021-04-29 10:08:25 +080060#define HQOS_MAGIC_TAG 0x5678
developer24948202021-11-24 17:38:27 +080061#define HAS_HQOS_MAGIC_TAG(skb) (qos_toggle && skb->protocol == HQOS_MAGIC_TAG)
developerfd40db22021-04-29 10:08:25 +080062
63#define HNAT_MAGIC_TAG 0x6789
developerfdfe1572021-09-13 16:56:33 +080064#define HNAT_INFO_FILLED 0x7
developerfd40db22021-04-29 10:08:25 +080065#define WIFI_INFO_LEN 3
66#define FOE_INFO_LEN (10 + WIFI_INFO_LEN)
67#define IS_SPACE_AVAILABLE_HEAD(skb) \
68 ((((skb_headroom(skb) >= FOE_INFO_LEN) ? 1 : 0)))
69
70#define skb_hnat_info(skb) ((struct hnat_desc *)(skb->head))
71#define skb_hnat_magic(skb) (((struct hnat_desc *)(skb->head))->magic)
72#define skb_hnat_reason(skb) (((struct hnat_desc *)(skb->head))->crsn)
73#define skb_hnat_entry(skb) (((struct hnat_desc *)(skb->head))->entry)
74#define skb_hnat_sport(skb) (((struct hnat_desc *)(skb->head))->sport)
75#define skb_hnat_alg(skb) (((struct hnat_desc *)(skb->head))->alg)
76#define skb_hnat_iface(skb) (((struct hnat_desc *)(skb->head))->iface)
developerfdfe1572021-09-13 16:56:33 +080077#define skb_hnat_filled(skb) (((struct hnat_desc *)(skb->head))->filled)
developerfd40db22021-04-29 10:08:25 +080078#define skb_hnat_magic_tag(skb) (((struct hnat_desc *)((skb)->head))->magic_tag_protect)
79#define skb_hnat_wdma_id(skb) (((struct hnat_desc *)((skb)->head))->wdmaid)
80#define skb_hnat_rx_id(skb) (((struct hnat_desc *)((skb)->head))->rxid)
81#define skb_hnat_wc_id(skb) (((struct hnat_desc *)((skb)->head))->wcid)
82#define skb_hnat_bss_id(skb) (((struct hnat_desc *)((skb)->head))->bssid)
developer471f6562021-05-10 20:48:34 +080083#define skb_hnat_ppe(skb) \
84 ((skb_hnat_iface(skb) == FOE_MAGIC_WED1 && CFG_PPE_NUM > 1) ? 1 : 0)
developere567ad32021-05-25 17:16:17 +080085#define do_ext2ge_fast_try(dev, skb) \
86 ((skb_hnat_iface(skb) == FOE_MAGIC_EXT) && !is_from_extge(skb))
developerfd40db22021-04-29 10:08:25 +080087#define set_from_extge(skb) (HNAT_SKB_CB2(skb)->magic = 0x78786688)
88#define clr_from_extge(skb) (HNAT_SKB_CB2(skb)->magic = 0x0)
89#define set_to_ppe(skb) (HNAT_SKB_CB2(skb)->magic = 0x78681415)
90#define is_from_extge(skb) (HNAT_SKB_CB2(skb)->magic == 0x78786688)
developerfdfe1572021-09-13 16:56:33 +080091#define is_hnat_info_filled(skb) (skb_hnat_filled(skb) == HNAT_INFO_FILLED)
developerfd40db22021-04-29 10:08:25 +080092#define is_magic_tag_valid(skb) (skb_hnat_magic_tag(skb) == HNAT_MAGIC_TAG)
93#define set_from_mape(skb) (HNAT_SKB_CB2(skb)->magic = 0x78787788)
94#define is_from_mape(skb) (HNAT_SKB_CB2(skb)->magic == 0x78787788)
95#define is_unreserved_port(hdr) \
96 ((ntohs(hdr->source) > 1023) && (ntohs(hdr->dest) > 1023))
97
98#define TTL_0 0x02
99#define HAS_OPTION_HEADER 0x03
100#define NO_FLOW_IS_ASSIGNED 0x07
101#define IPV4_WITH_FRAGMENT 0x08
102#define IPV4_HNAPT_DSLITE_WITH_FRAGMENT 0x09
103#define IPV4_HNAPT_DSLITE_WITHOUT_TCP_UDP 0x0A
104#define IPV6_5T_6RD_WITHOUT_TCP_UDP 0x0B
105#define TCP_FIN_SYN_RST \
106 0x0C /* Ingress packet is TCP fin/syn/rst (for IPv4 NAPT/DS-Lite or IPv6 5T-route/6RD) */
107#define UN_HIT 0x0D /* FOE Un-hit */
108#define HIT_UNBIND 0x0E /* FOE Hit unbind */
109#define HIT_UNBIND_RATE_REACH 0x0F
110#define HIT_BIND_TCP_FIN 0x10
111#define HIT_BIND_TTL_1 0x11
112#define HIT_BIND_WITH_VLAN_VIOLATION 0x12
113#define HIT_BIND_KEEPALIVE_UC_OLD_HDR 0x13
114#define HIT_BIND_KEEPALIVE_MC_NEW_HDR 0x14
115#define HIT_BIND_KEEPALIVE_DUP_OLD_HDR 0x15
116#define HIT_BIND_FORCE_TO_CPU 0x16
117#define HIT_BIND_WITH_OPTION_HEADER 0x17
118#define HIT_BIND_MULTICAST_TO_CPU 0x18
119#define HIT_BIND_MULTICAST_TO_GMAC_CPU 0x19
120#define HIT_PRE_BIND 0x1A
121#define HIT_BIND_PACKET_SAMPLING 0x1B
122#define HIT_BIND_EXCEED_MTU 0x1C
123
124u32 hnat_tx(struct sk_buff *skb);
125u32 hnat_set_skb_info(struct sk_buff *skb, u32 *rxd);
126u32 hnat_reg(struct net_device *, void __iomem *);
127u32 hnat_unreg(void);
128
129#endif