Yi Tseng | be34205 | 2017-11-03 10:21:23 -0700 | [diff] [blame] | 1 | /* |
| 2 | * Copyright 2017-present Open Networking Foundation |
| 3 | * |
| 4 | * Licensed under the Apache License, Version 2.0 (the "License"); |
| 5 | * you may not use this file except in compliance with the License. |
| 6 | * You may obtain a copy of the License at |
| 7 | * |
| 8 | * http://www.apache.org/licenses/LICENSE-2.0 |
| 9 | * |
| 10 | * Unless required by applicable law or agreed to in writing, software |
| 11 | * distributed under the License is distributed on an "AS IS" BASIS, |
| 12 | * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| 13 | * See the License for the specific language governing permissions and |
| 14 | * limitations under the License. |
| 15 | */ |
| 16 | |
| 17 | #ifndef __DEFINE__ |
| 18 | #define __DEFINE__ |
| 19 | |
| 20 | #define MAX_PORTS 511 |
| 21 | |
Carmelo Cascone | 79a3a31 | 2018-08-16 17:14:43 -0700 | [diff] [blame] | 22 | #if defined(WITH_INT_SOURCE) || defined(WITH_INT_TRANSIT) || defined(WITH_INT_SINK) |
| 23 | #define WITH_INT |
| 24 | #endif |
| 25 | |
Carmelo Cascone | b5324e7 | 2018-11-25 02:26:32 -0800 | [diff] [blame] | 26 | #ifndef WITHOUT_XCONNECT |
| 27 | #define WITH_XCONNECT |
| 28 | #endif |
| 29 | |
| 30 | #if ! defined(WITH_SIMPLE_NEXT) |
| 31 | #define WITH_HASHED_NEXT |
| 32 | #endif |
| 33 | |
Carmelo Cascone | 35d9b33 | 2018-06-15 16:27:22 +0200 | [diff] [blame] | 34 | #ifndef _BOOL |
| 35 | #define _BOOL bool |
| 36 | #endif |
| 37 | #ifndef _TRUE |
| 38 | #define _TRUE true |
| 39 | #endif |
| 40 | #ifndef _FALSE |
Yi Tseng | 34af316 | 2018-06-17 18:02:21 +0800 | [diff] [blame] | 41 | #define _FALSE false |
Carmelo Cascone | 35d9b33 | 2018-06-15 16:27:22 +0200 | [diff] [blame] | 42 | #endif |
| 43 | |
| 44 | #ifndef _PKT_OUT_HDR_ANNOT |
| 45 | #define _PKT_OUT_HDR_ANNOT |
| 46 | #endif |
| 47 | |
Carmelo Cascone | fa42158 | 2018-09-13 10:05:57 -0700 | [diff] [blame] | 48 | #ifndef _PRE_INGRESS |
| 49 | #define _PRE_INGRESS |
| 50 | #endif |
| 51 | |
| 52 | #ifndef _PRE_EGRESS |
| 53 | #define _PRE_EGRESS |
| 54 | #endif |
| 55 | |
Carmelo Cascone | 35d9b33 | 2018-06-15 16:27:22 +0200 | [diff] [blame] | 56 | #ifndef IP_VER_LENGTH |
| 57 | #define IP_VER_LENGTH 4 |
| 58 | #endif |
| 59 | #ifndef IP_VERSION_4 |
| 60 | #define IP_VERSION_4 4 |
| 61 | #endif |
| 62 | #ifndef IP_VERSION_6 |
| 63 | #define IP_VERSION_6 6 |
| 64 | #endif |
| 65 | |
| 66 | #define ETH_HDR_SIZE 14 |
| 67 | #define IPV4_HDR_SIZE 20 |
| 68 | #define UDP_HDR_SIZE 8 |
| 69 | #define GTP_HDR_SIZE 8 |
| 70 | |
| 71 | #define UDP_PORT_GTPU 2152 |
| 72 | #define GTP_GPDU 0xff |
| 73 | #define GTPU_VERSION 0x01 |
| 74 | #define GTP_PROTOCOL_TYPE_GTP 0x01 |
| 75 | |
Jonghwan Hyun | ed478dc | 2018-08-06 15:35:18 +0900 | [diff] [blame] | 76 | #define PKT_INSTANCE_TYPE_NORMAL 0 |
| 77 | #define PKT_INSTANCE_TYPE_INGRESS_CLONE 1 |
| 78 | #define PKT_INSTANCE_TYPE_EGRESS_CLONE 2 |
| 79 | #define PKT_INSTANCE_TYPE_COALESCED 3 |
| 80 | #define PKT_INSTANCE_TYPE_INGRESS_RECIRC 4 |
| 81 | #define PKT_INSTANCE_TYPE_REPLICATION 5 |
| 82 | #define PKT_INSTANCE_TYPE_RESUBMIT 6 |
| 83 | |
Yi Tseng | be34205 | 2017-11-03 10:21:23 -0700 | [diff] [blame] | 84 | typedef bit<3> fwd_type_t; |
Yi Tseng | 1b154bd | 2017-11-20 17:48:19 -0800 | [diff] [blame] | 85 | typedef bit<32> next_id_t; |
Yi Tseng | be34205 | 2017-11-03 10:21:23 -0700 | [diff] [blame] | 86 | typedef bit<20> mpls_label_t; |
| 87 | typedef bit<9> port_num_t; |
| 88 | typedef bit<48> mac_addr_t; |
Carmelo Cascone | b5324e7 | 2018-11-25 02:26:32 -0800 | [diff] [blame] | 89 | typedef bit<16> mcast_group_id_t; |
Yi Tseng | be34205 | 2017-11-03 10:21:23 -0700 | [diff] [blame] | 90 | typedef bit<12> vlan_id_t; |
Carmelo Cascone | 9b0171b | 2018-08-14 01:43:57 -0700 | [diff] [blame] | 91 | typedef bit<32> ipv4_addr_t; |
| 92 | typedef bit<16> l4_port_t; |
| 93 | |
| 94 | // SPGW types |
| 95 | typedef bit<2> direction_t; |
| 96 | typedef bit pcc_gate_status_t; |
| 97 | typedef bit<32> sdf_rule_id_t; |
| 98 | typedef bit<32> pcc_rule_id_t; |
| 99 | |
| 100 | // spgw.p4 expects uplink packets with IP dst on this subnet |
| 101 | // 140.0.0.0/8 |
| 102 | const ipv4_addr_t S1U_SGW_PREFIX = 2348810240; |
| 103 | #define S1U_SGW_PREFIX_LEN 8 |
Yi Tseng | be34205 | 2017-11-03 10:21:23 -0700 | [diff] [blame] | 104 | |
| 105 | const bit<16> ETHERTYPE_QINQ = 0x88A8; |
| 106 | const bit<16> ETHERTYPE_QINQ_NON_STD = 0x9100; |
| 107 | const bit<16> ETHERTYPE_VLAN = 0x8100; |
| 108 | const bit<16> ETHERTYPE_MPLS = 0x8847; |
| 109 | const bit<16> ETHERTYPE_MPLS_MULTICAST =0x8848; |
| 110 | const bit<16> ETHERTYPE_IPV4 = 0x0800; |
| 111 | const bit<16> ETHERTYPE_IPV6 = 0x86dd; |
| 112 | const bit<16> ETHERTYPE_ARP = 0x0806; |
| 113 | |
Yi Tseng | be34205 | 2017-11-03 10:21:23 -0700 | [diff] [blame] | 114 | const bit<8> PROTO_ICMP = 1; |
| 115 | const bit<8> PROTO_TCP = 6; |
| 116 | const bit<8> PROTO_UDP = 17; |
| 117 | const bit<8> PROTO_ICMPV6 = 58; |
| 118 | |
Carmelo Cascone | b81f4be | 2018-01-16 23:24:01 -0800 | [diff] [blame] | 119 | const bit<4> IPV4_MIN_IHL = 5; |
| 120 | |
Yi Tseng | be34205 | 2017-11-03 10:21:23 -0700 | [diff] [blame] | 121 | const fwd_type_t FWD_BRIDGING = 0; |
| 122 | const fwd_type_t FWD_MPLS = 1; |
| 123 | const fwd_type_t FWD_IPV4_UNICAST = 2; |
| 124 | const fwd_type_t FWD_IPV4_MULTICAST = 3; |
| 125 | const fwd_type_t FWD_IPV6_UNICAST = 4; |
| 126 | const fwd_type_t FWD_IPV6_MULTICAST = 5; |
Carmelo Cascone | 8a715f8 | 2018-08-20 23:16:27 -0700 | [diff] [blame] | 127 | const fwd_type_t FWD_UNKNOWN = 7; |
| 128 | |
| 129 | const vlan_id_t DEFAULT_VLAN_ID = 12w4094; |
Yi Tseng | be34205 | 2017-11-03 10:21:23 -0700 | [diff] [blame] | 130 | |
Yi Tseng | 1b154bd | 2017-11-20 17:48:19 -0800 | [diff] [blame] | 131 | const bit<8> DEFAULT_MPLS_TTL = 64; |
Carmelo Cascone | b81f4be | 2018-01-16 23:24:01 -0800 | [diff] [blame] | 132 | const bit<8> DEFAULT_IPV4_TTL = 64; |
| 133 | |
Carmelo Cascone | b81f4be | 2018-01-16 23:24:01 -0800 | [diff] [blame] | 134 | const sdf_rule_id_t DEFAULT_SDF_RULE_ID = 0; |
| 135 | const pcc_rule_id_t DEFAULT_PCC_RULE_ID = 0; |
Carmelo Cascone | 9b0171b | 2018-08-14 01:43:57 -0700 | [diff] [blame] | 136 | const direction_t SPGW_DIR_UNKNOWN = 2w0; |
| 137 | const direction_t SPGW_DIR_UPLINK = 2w1; |
| 138 | const direction_t SPGW_DIR_DOWNLINK = 2w2; |
Carmelo Cascone | b81f4be | 2018-01-16 23:24:01 -0800 | [diff] [blame] | 139 | const pcc_gate_status_t PCC_GATE_OPEN = 1w0; |
| 140 | const pcc_gate_status_t PCC_GATE_CLOSED = 1w1; |
Yi Tseng | 1b154bd | 2017-11-20 17:48:19 -0800 | [diff] [blame] | 141 | |
Jonghwan Hyun | ed478dc | 2018-08-06 15:35:18 +0900 | [diff] [blame] | 142 | /* indicate INT at LSB of DSCP */ |
| 143 | const bit<6> INT_DSCP = 0x1; |
| 144 | |
Carmelo Cascone | 79a3a31 | 2018-08-16 17:14:43 -0700 | [diff] [blame] | 145 | // Length of the whole INT header, |
| 146 | // including shim and tail, excluding metadata stack. |
| 147 | const bit<8> INT_HEADER_LEN_WORDS = 4; |
| 148 | const bit<16> INT_HEADER_LEN_BYTES = 16; |
Jonghwan Hyun | ed478dc | 2018-08-06 15:35:18 +0900 | [diff] [blame] | 149 | |
| 150 | const bit<8> CPU_MIRROR_SESSION_ID = 250; |
| 151 | const bit<32> REPORT_MIRROR_SESSION_ID = 500; |
| 152 | |
| 153 | const bit<4> NPROTO_ETHERNET = 0; |
| 154 | const bit<4> NPROTO_TELEMETRY_DROP_HEADER = 1; |
| 155 | const bit<4> NPROTO_TELEMETRY_SWITCH_LOCAL_HEADER = 2; |
| 156 | |
| 157 | const bit<6> HW_ID = 1; |
| 158 | const bit<8> REPORT_FIXED_HEADER_LEN = 12; |
| 159 | const bit<8> DROP_REPORT_HEADER_LEN = 12; |
| 160 | const bit<8> LOCAL_REPORT_HEADER_LEN = 16; |
| 161 | const bit<8> ETH_HEADER_LEN = 14; |
| 162 | const bit<8> IPV4_MIN_HEAD_LEN = 20; |
| 163 | const bit<8> UDP_HEADER_LEN = 8; |
| 164 | |
Carmelo Cascone | b5324e7 | 2018-11-25 02:26:32 -0800 | [diff] [blame] | 165 | action nop() { |
| 166 | NoAction(); |
| 167 | } |
| 168 | |
Yi Tseng | be34205 | 2017-11-03 10:21:23 -0700 | [diff] [blame] | 169 | #endif |