Girish Gowdra | ddf9a16 | 2020-01-27 12:56:27 +0530 | [diff] [blame] | 1 | /* |
| 2 | * Copyright 2018-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 | #ifndef OPENOLT_CORE_DATA_H_ |
| 17 | #define OPENOLT_CORE_DATA_H_ |
| 18 | |
| 19 | #include <bitset> |
| 20 | |
| 21 | #include "core.h" |
| 22 | #include "Queue.h" |
Girish Gowdra | 252f497 | 2020-09-07 21:24:01 -0700 | [diff] [blame] | 23 | #include "device.h" |
Girish Gowdra | ddf9a16 | 2020-01-27 12:56:27 +0530 | [diff] [blame] | 24 | |
Girish Gowdra | 1935e6a | 2020-10-31 21:48:22 -0700 | [diff] [blame] | 25 | // pcapplusplus packet decoder include files |
| 26 | #include "Packet.h" |
| 27 | #include "EthLayer.h" |
| 28 | #include "IPv4Layer.h" |
| 29 | #include "UdpLayer.h" |
| 30 | #include "VlanLayer.h" |
| 31 | |
| 32 | #include <time.h> |
| 33 | #include <arpa/inet.h> |
| 34 | |
Girish Gowdra | ddf9a16 | 2020-01-27 12:56:27 +0530 | [diff] [blame] | 35 | extern "C" |
| 36 | { |
| 37 | #include <bcmolt_api.h> |
| 38 | #include <bcmolt_api_model_supporting_enums.h> |
| 39 | |
| 40 | #include <bcmolt_api_conn_mgr.h> |
| 41 | //CLI header files |
| 42 | #include <bcmcli_session.h> |
| 43 | #include <bcmcli.h> |
| 44 | #include <bcm_api_cli.h> |
| 45 | |
| 46 | #include <bcmos_common.h> |
| 47 | #include <bcm_config.h> |
| 48 | // FIXME : dependency problem |
| 49 | // #include <bcm_common_gpon.h> |
| 50 | // #include <bcm_dev_log_task.h> |
| 51 | } |
| 52 | |
Girish Gowdra | 5057a3d | 2020-05-29 18:49:56 -0700 | [diff] [blame] | 53 | #define ALLOC_CFG_COMPLETE_WAIT_TIMEOUT 5000 // in milli-seconds |
Thiyagarajan Subramani | e976fcf | 2021-05-07 22:46:57 +0530 | [diff] [blame] | 54 | #define GEM_CFG_COMPLETE_WAIT_TIMEOUT 5000 // in milli-seconds |
| 55 | |
| 56 | // max retry count to find gem config key in gem_cfg_compltd_map |
| 57 | #define MAX_GEM_CFG_KEY_CHECK 5 |
Girish Gowdra | ddf9a16 | 2020-01-27 12:56:27 +0530 | [diff] [blame] | 58 | |
Girish Gowdra | 5057a3d | 2020-05-29 18:49:56 -0700 | [diff] [blame] | 59 | #define ONU_DEACTIVATE_COMPLETE_WAIT_TIMEOUT 5000 // in milli-seconds |
Girish Gowdra | 7a79dae | 2020-02-10 18:22:11 +0530 | [diff] [blame] | 60 | |
Girish Gowdra | ddf9a16 | 2020-01-27 12:56:27 +0530 | [diff] [blame] | 61 | |
| 62 | #define MAX_ACL_ID 33 |
Girish Gowdra | 1935e6a | 2020-10-31 21:48:22 -0700 | [diff] [blame] | 63 | #define MAX_ACL_WITH_VLAN_CLASSIFIER 10 |
| 64 | |
| 65 | #define ANY_VLAN 4095 |
Girish Gowdra | ddf9a16 | 2020-01-27 12:56:27 +0530 | [diff] [blame] | 66 | |
| 67 | // **************************************// |
| 68 | // Enums and structures used by the core // |
| 69 | // **************************************// |
| 70 | enum FLOW_CFG { |
| 71 | ONU_ID = 0, |
| 72 | FLOW_TYPE = 1, |
| 73 | SVC_PORT_ID = 2, |
| 74 | PRIORITY = 3, |
| 75 | COOKIE = 4, |
| 76 | INGRESS_INTF_TYPE= 5, |
| 77 | EGRESS_INTF_TYPE= 6, |
| 78 | INGRESS_INTF_ID = 7, |
| 79 | EGRESS_INTF_ID = 8, |
| 80 | CLASSIFIER_O_VID = 9, |
| 81 | CLASSIFIER_O_PBITS = 10, |
| 82 | CLASSIFIER_I_VID = 11, |
| 83 | CLASSIFIER_I_PBITS = 12, |
| 84 | CLASSIFIER_ETHER_TYPE = 13, |
| 85 | CLASSIFIER_IP_PROTO =14, |
| 86 | CLASSIFIER_SRC_PORT = 15, |
| 87 | CLASSIFIER_DST_PORT = 16, |
| 88 | CLASSIFIER_PKT_TAG_TYPE = 17, |
| 89 | EGRESS_QOS_TYPE = 18, |
| 90 | EGRESS_QOS_QUEUE_ID = 19, |
| 91 | EGRESS_QOS_TM_SCHED_ID = 20, |
| 92 | ACTION_CMDS_BITMASK = 21, |
| 93 | ACTION_O_VID = 22, |
| 94 | ACTION_O_PBITS = 23, |
| 95 | ACTION_I_VID = 24, |
| 96 | ACTION_I_PBITS = 25, |
| 97 | STATE = 26, |
| 98 | GROUP_ID = 27 |
| 99 | }; |
| 100 | |
| 101 | enum AllocCfgAction { |
| 102 | ALLOC_OBJECT_CREATE, |
| 103 | ALLOC_OBJECT_DELETE |
| 104 | }; |
| 105 | |
| 106 | enum AllocObjectState { |
| 107 | ALLOC_OBJECT_STATE_NOT_CONFIGURED, |
| 108 | ALLOC_OBJECT_STATE_INACTIVE, |
| 109 | ALLOC_OBJECT_STATE_PROCESSING, |
| 110 | ALLOC_OBJECT_STATE_ACTIVE |
| 111 | }; |
| 112 | |
| 113 | enum AllocCfgStatus { |
| 114 | ALLOC_CFG_STATUS_SUCCESS, |
| 115 | ALLOC_CFG_STATUS_FAIL |
| 116 | }; |
| 117 | |
| 118 | typedef struct { |
| 119 | uint32_t pon_intf_id; |
| 120 | uint32_t alloc_id; |
| 121 | AllocObjectState state; |
| 122 | AllocCfgStatus status; |
| 123 | } alloc_cfg_complete_result; |
| 124 | |
Thiyagarajan Subramani | e976fcf | 2021-05-07 22:46:57 +0530 | [diff] [blame] | 125 | enum GemCfgAction { |
| 126 | GEM_OBJECT_CREATE, |
| 127 | GEM_OBJECT_DELETE, |
| 128 | GEM_OBJECT_ENCRYPT |
| 129 | }; |
| 130 | |
| 131 | enum GemObjectState { |
| 132 | GEM_OBJECT_STATE_NOT_CONFIGURED, |
| 133 | GEM_OBJECT_STATE_INACTIVE, |
| 134 | GEM_OBJECT_STATE_PROCESSING, |
| 135 | GEM_OBJECT_STATE_ACTIVE |
| 136 | }; |
| 137 | |
| 138 | enum GemCfgStatus { |
| 139 | GEM_CFG_STATUS_SUCCESS, |
| 140 | GEM_CFG_STATUS_FAIL |
| 141 | }; |
| 142 | |
| 143 | typedef struct { |
| 144 | uint32_t pon_intf_id; |
| 145 | uint32_t gem_port_id; |
| 146 | GemObjectState state; |
| 147 | GemCfgStatus status; |
| 148 | } gem_cfg_complete_result; |
| 149 | |
Girish Gowdra | 7a79dae | 2020-02-10 18:22:11 +0530 | [diff] [blame] | 150 | typedef struct { |
| 151 | uint32_t pon_intf_id; |
| 152 | uint32_t onu_id; |
| 153 | bcmolt_result result; |
| 154 | bcmolt_deactivation_fail_reason reason; |
| 155 | } onu_deactivate_complete_result; |
| 156 | |
Girish Gowdra | ddf9a16 | 2020-01-27 12:56:27 +0530 | [diff] [blame] | 157 | // key for map used for tracking ITU PON Alloc Configuration results from BAL |
| 158 | typedef std::tuple<uint32_t, uint32_t> alloc_cfg_compltd_key; |
| 159 | |
Thiyagarajan Subramani | e976fcf | 2021-05-07 22:46:57 +0530 | [diff] [blame] | 160 | // key for map used for tracking ITU PON Gem Configuration results from BAL |
| 161 | typedef std::tuple<uint32_t, uint32_t> gem_cfg_compltd_key; |
| 162 | |
Girish Gowdra | 7a79dae | 2020-02-10 18:22:11 +0530 | [diff] [blame] | 163 | // key for map used for tracking Onu Deactivation Completed Indication |
| 164 | typedef std::tuple<uint32_t, uint32_t> onu_deact_compltd_key; |
| 165 | |
Girish Gowdra | ddf9a16 | 2020-01-27 12:56:27 +0530 | [diff] [blame] | 166 | // The elements in this acl_classifier_key structure constitute key to |
| 167 | // acl_classifier_to_acl_id_map. |
| 168 | // Fill invalid values in the acl_classifier_key structure to -1. |
| 169 | typedef struct acl_classifier_key { |
| 170 | int32_t ether_type; |
| 171 | int16_t ip_proto; |
| 172 | int32_t src_port; |
| 173 | int32_t dst_port; |
Girish Gowdra | 1935e6a | 2020-10-31 21:48:22 -0700 | [diff] [blame] | 174 | int16_t o_vid; |
Girish Gowdra | ddf9a16 | 2020-01-27 12:56:27 +0530 | [diff] [blame] | 175 | // Add more classifiers elements as needed here |
| 176 | // For now, ACLs will be classified only based on |
| 177 | // above elements. |
| 178 | } acl_classifier_key; |
| 179 | |
Girish Gowdra | 252f497 | 2020-09-07 21:24:01 -0700 | [diff] [blame] | 180 | typedef struct device_flow_params { |
| 181 | uint8_t pbit; // If pbit classifier is not present in flow, use 0xff to invalidate |
| 182 | uint32_t gemport_id; |
| 183 | uint16_t flow_id; |
| 184 | } device_flow_params; |
| 185 | |
| 186 | typedef struct device_flow { |
| 187 | bool is_flow_replicated; // If true number of replicated flows is to the NUMBER_OF_PBITS, else 1 |
Girish Gowdra | fc6c0bf | 2022-01-28 18:31:30 -0800 | [diff] [blame] | 188 | std::string flow_type; // upstream, downstream, multicast |
Girish Gowdra | 252f497 | 2020-09-07 21:24:01 -0700 | [diff] [blame] | 189 | device_flow_params params[NUMBER_OF_REPLICATED_FLOWS]; // A voltha-flow cannot be replicated more than the number of pbits |
| 190 | uint64_t voltha_flow_id; // This is corresponding voltha flow-id. |
| 191 | uint64_t symmetric_voltha_flow_id; // Is not applicable for trap-to-controller voltha flows. |
| 192 | // 0 value means invalid or not-applicable |
| 193 | // Applicable for bi-directional data path flows (one flow per direction) |
| 194 | // Symmetric flows should share the same device_flow_id. |
| 195 | |
| 196 | } device_flow; |
| 197 | |
Orhan Kupusoglu | ec57af0 | 2021-05-12 12:38:17 +0000 | [diff] [blame] | 198 | // key for map used for tracking Onu RSSI Measurement Completed Indication |
| 199 | typedef std::tuple<uint32_t, uint32_t> onu_rssi_compltd_key; |
| 200 | |
| 201 | typedef struct { |
| 202 | uint32_t pon_intf_id; |
| 203 | uint32_t onu_id; |
| 204 | std::string status; |
| 205 | bcmolt_rssi_measurement_fail_reason reason; |
| 206 | double rx_power_mean_dbm; |
| 207 | } onu_rssi_complete_result; |
| 208 | |
Girish Gowdra | eec0fc9 | 2021-05-12 15:37:55 -0700 | [diff] [blame] | 209 | // Key for map used for tracking symmetric datapath flows ==> <pon, onu, uni, tp_id, flow_type> |
| 210 | typedef std::tuple<int32_t, int32_t, int32_t, uint32_t, std::string> symmetric_datapath_flow_id_map_key; |
| 211 | |
| 212 | // Key and value for the pon_gem_to_onu_uni_map |
| 213 | typedef std::tuple<uint32_t, uint32_t> pon_gem; |
| 214 | typedef std::tuple<uint32_t, uint32_t> onu_uni; |
| 215 | |
Girish Gowdra | ddf9a16 | 2020-01-27 12:56:27 +0530 | [diff] [blame] | 216 | // *******************************************************// |
| 217 | // Extern Variable/Constant declarations used by the core // |
| 218 | // *******************************************************// |
| 219 | extern State state; |
| 220 | |
| 221 | extern dev_log_id openolt_log_id; |
| 222 | extern dev_log_id omci_log_id; |
| 223 | |
| 224 | extern unsigned int num_of_nni_ports; |
| 225 | extern unsigned int num_of_pon_ports; |
| 226 | |
| 227 | extern const uint32_t tm_upstream_sched_id_start; |
| 228 | extern const uint32_t tm_downstream_sched_id_start; |
| 229 | |
| 230 | extern const uint32_t queue_id_list[8]; |
| 231 | |
| 232 | extern const std::string upstream; |
| 233 | extern const std::string downstream; |
| 234 | extern const std::string multicast; |
| 235 | extern bcmolt_oltid dev_id; |
| 236 | |
| 237 | extern const uint32_t BAL_API_RETRY_TIME_IN_USECS; |
| 238 | extern const uint32_t MAX_BAL_API_RETRY_COUNT; |
| 239 | |
| 240 | extern const unsigned int OPENOLT_FIELD_LEN; |
| 241 | |
| 242 | /* Current session */ |
| 243 | extern bcmcli_session *current_session; |
| 244 | extern bcmcli_entry *api_parent_dir; |
| 245 | extern bcmos_bool status_bcm_cli_quit; |
| 246 | extern bcmos_task bal_cli_thread; |
| 247 | extern const char *bal_cli_thread_name; |
| 248 | extern uint16_t flow_id_counters; |
| 249 | |
| 250 | extern std::map<uint32_t, uint32_t> flowid_to_port; // For mapping upstream flows to logical ports |
| 251 | extern std::map<uint32_t, uint32_t> flowid_to_gemport; // For mapping downstream flows into gemports |
| 252 | extern std::map<uint32_t, std::set<uint32_t> > port_to_flows; // For mapping logical ports to downstream flows |
| 253 | |
| 254 | /* This represents the Key to 'sched_map' map. |
Burak Gurdag | 2f2618c | 2020-04-23 13:20:30 +0000 | [diff] [blame] | 255 | Represents (pon_intf_id, onu_id, uni_id, direction, tech_profile_id) */ |
| 256 | typedef std::tuple<uint32_t, uint32_t, uint32_t, std::string, uint32_t> sched_map_key_tuple; |
Girish Gowdra | ddf9a16 | 2020-01-27 12:56:27 +0530 | [diff] [blame] | 257 | /* 'sched_map' maps sched_map_key_tuple to DBA (Upstream) or |
| 258 | Subscriber (Downstream) Scheduler ID */ |
| 259 | extern std::map<sched_map_key_tuple, int> sched_map; |
| 260 | |
| 261 | /* Flow control is for flow_id and flow_type */ |
| 262 | typedef std::pair<uint16_t, uint16_t> flow_pair; |
| 263 | extern std::map<flow_pair, int32_t> flow_map; |
| 264 | |
| 265 | /* This represents the Key to 'qos_type_map' map. |
| 266 | Represents (pon_intf_id, onu_id, uni_id) */ |
| 267 | typedef std::tuple<uint32_t, uint32_t, uint32_t> qos_type_map_key_tuple; |
| 268 | /* 'qos_type_map' maps qos_type_map_key_tuple to qos_type*/ |
| 269 | extern std::map<qos_type_map_key_tuple, bcmolt_egress_qos_type> qos_type_map; |
| 270 | |
| 271 | /* This represents the Key to 'sched_qmp_id_map' map. |
| 272 | Represents (sched_id, pon_intf_id, onu_id, uni_id) */ |
| 273 | typedef std::tuple<uint32_t, uint32_t, uint32_t, uint32_t> sched_qmp_id_map_key_tuple; |
| 274 | /* 'sched_qmp_id_map' maps sched_qmp_id_map_key_tuple to TM Queue Mapping Profile ID */ |
| 275 | extern std::map<sched_qmp_id_map_key_tuple, int> sched_qmp_id_map; |
| 276 | /* 'qmp_id_to_qmp_map' maps TM Queue Mapping Profile ID to TM Queue Mapping Profile */ |
| 277 | extern std::map<int, std::vector < uint32_t > > qmp_id_to_qmp_map; |
| 278 | |
Girish Gowdra | ddf9a16 | 2020-01-27 12:56:27 +0530 | [diff] [blame] | 279 | // Map used to track response from BAL for ITU PON Alloc Configuration. |
| 280 | // The key is alloc_cfg_compltd_key and value is a concurrent thread-safe queue which is |
| 281 | // used for pushing (from BAL) and popping (at application) the results. |
| 282 | extern std::map<alloc_cfg_compltd_key, Queue<alloc_cfg_complete_result> *> alloc_cfg_compltd_map; |
Thiyagarajan Subramani | e976fcf | 2021-05-07 22:46:57 +0530 | [diff] [blame] | 283 | |
| 284 | // Map used to track response from BAL for ITU PON Gem Configuration. |
| 285 | // The key is gem_cfg_compltd_key and value is a concurrent thread-safe queue which is |
| 286 | // used for pushing (from BAL) and popping (at application) the results. |
| 287 | extern std::map<gem_cfg_compltd_key, Queue<gem_cfg_complete_result> *> gem_cfg_compltd_map; |
| 288 | |
| 289 | /* This represents the Key to 'gemport_status_map' map. |
| 290 | Represents (pon_intf_id, onu_id, uni_id, gemport_id) */ |
| 291 | typedef std::tuple<uint32_t, uint32_t, uint32_t, uint32_t> gemport_status_map_key_tuple; |
| 292 | /* 'gemport_status_map' maps gemport_status_map_key_tuple to boolean value */ |
| 293 | extern std::map<gemport_status_map_key_tuple, bool> gemport_status_map; |
| 294 | |
Girish Gowdra | 7a79dae | 2020-02-10 18:22:11 +0530 | [diff] [blame] | 295 | // Map used to track response from BAL for Onu Deactivation Completed Indication |
Thiyagarajan Subramani | e976fcf | 2021-05-07 22:46:57 +0530 | [diff] [blame] | 296 | // The key is onu_deact_compltd_key and value is a concurrent thread-safe queue which is |
Girish Gowdra | 7a79dae | 2020-02-10 18:22:11 +0530 | [diff] [blame] | 297 | // used for pushing (from BAL) and popping (at application) the results. |
| 298 | extern std::map<onu_deact_compltd_key, Queue<onu_deactivate_complete_result> *> onu_deact_compltd_map; |
| 299 | |
Girish Gowdra | ddf9a16 | 2020-01-27 12:56:27 +0530 | [diff] [blame] | 300 | // Lock to protect critical section data structure used for handling AllocObject configuration response. |
| 301 | extern bcmos_fastlock alloc_cfg_wait_lock; |
Thiyagarajan Subramani | e976fcf | 2021-05-07 22:46:57 +0530 | [diff] [blame] | 302 | // Lock to protect critical section data structure used for handling GemObject configuration response. |
| 303 | extern bcmos_fastlock gem_cfg_wait_lock; |
Girish Gowdra | 7a79dae | 2020-02-10 18:22:11 +0530 | [diff] [blame] | 304 | // Lock to protect critical section data structure used for handling Onu deactivation completed Indication |
| 305 | extern bcmos_fastlock onu_deactivate_wait_lock; |
Girish Gowdra | ddf9a16 | 2020-01-27 12:56:27 +0530 | [diff] [blame] | 306 | |
| 307 | |
| 308 | /*** ACL Handling related data start ***/ |
| 309 | |
| 310 | extern std::map<acl_classifier_key, uint16_t> acl_classifier_to_acl_id_map; |
| 311 | extern bool operator<(const acl_classifier_key& a1, const acl_classifier_key& a2); |
| 312 | |
Girish Gowdra | 252f497 | 2020-09-07 21:24:01 -0700 | [diff] [blame] | 313 | typedef std::tuple<uint64_t, std::string> flow_id_flow_direction; |
| 314 | typedef std::tuple<int16_t, int32_t> acl_id_intf_id; |
| 315 | extern std::map<flow_id_flow_direction, acl_id_intf_id> flow_to_acl_map; |
Girish Gowdra | ddf9a16 | 2020-01-27 12:56:27 +0530 | [diff] [blame] | 316 | |
| 317 | // Keeps a reference count of how many flows are referencing a given ACL ID. |
| 318 | // Key represents the ACL-ID and value is number of flows referencing the given ACL-ID. |
| 319 | // When there is at least one flow referencing the ACL-ID, the ACL should be installed. |
| 320 | // When there are no flows referencing the ACL-ID, the ACL should be removed. |
| 321 | extern std::map<uint16_t, uint16_t> acl_ref_cnt; |
| 322 | |
Girish Gowdra | ddf9a16 | 2020-01-27 12:56:27 +0530 | [diff] [blame] | 323 | // Needed to keep track of how many flows for a given acl_id, intf_id and intf_type are |
| 324 | // installed. When there is at least on flow for this key, we should have interface registered |
| 325 | // for the given ACL-ID. When there are no flows, the intf should unregister itself from |
| 326 | // the ACL-ID. |
| 327 | typedef std::tuple<uint16_t, uint8_t, std::string> acl_id_intf_id_intf_type; |
| 328 | extern std::map<acl_id_intf_id_intf_type, uint16_t> intf_acl_registration_ref_cnt; |
| 329 | |
Girish Gowdra | 1935e6a | 2020-10-31 21:48:22 -0700 | [diff] [blame] | 330 | // Data structures to work around ACL limits on BAL -- start -- |
| 331 | |
| 332 | enum trap_to_host_packet_type { |
| 333 | dhcpv4 = 0, |
| 334 | lldp = 1, |
| 335 | eap = 2, |
| 336 | igmpv4 = 3, |
Marcos Aurelio Carrero (Furukawa) | cfe3e0d | 2021-03-03 10:36:56 -0300 | [diff] [blame] | 337 | pppoed = 4, |
Girish Gowdra | 1935e6a | 2020-10-31 21:48:22 -0700 | [diff] [blame] | 338 | unsupported_trap_to_host_pkt_type = 0xff |
| 339 | }; |
| 340 | |
| 341 | // Constants useful during trap-to-host packet header field classification |
Marcos Aurelio Carrero (Furukawa) | cfe3e0d | 2021-03-03 10:36:56 -0300 | [diff] [blame] | 342 | #define EAP_ETH_TYPE 0x888e |
| 343 | #define LLDP_ETH_TYPE 0x88cc |
| 344 | #define IPV4_ETH_TYPE 0x0800 |
| 345 | #define VLAN_ETH_TYPE 0x8100 |
| 346 | #define PPPoED_ETH_TYPE 0x8863 |
Girish Gowdra | 1935e6a | 2020-10-31 21:48:22 -0700 | [diff] [blame] | 347 | |
| 348 | #define IGMPv4_PROTOCOL 2 |
| 349 | #define UDP_PROTOCOL 17 |
| 350 | |
| 351 | #define DHCP_SERVER_SRC_PORT 67 |
| 352 | #define DHCP_CLIENT_SRC_PORT 68 |
| 353 | |
| 354 | // This flag is set as soon as ACL count reaches MAX_ACL_WITH_VLAN_CLASSIFIER is hit. |
| 355 | // It is not reset when ACL count comes below MAX_ACL_WITH_VLAN_CLASSIFIER again |
| 356 | extern bool max_acls_with_vlan_classifiers_hit; |
| 357 | |
| 358 | // Tuple of -> {bcmolt_flow_interface_type, intf-id, trap_to_host_packet_type, gemport-id, c-vid} |
| 359 | typedef std::tuple<int32_t, uint32_t, int32_t, int32_t, uint16_t> trap_to_host_pkt_info_with_vlan; |
| 360 | |
| 361 | // Tuple of -> {bcmolt_flow_interface_type, intf-id, trap_to_host_packet_type, gemport-id} |
| 362 | typedef std::tuple<int32_t, uint32_t, int32_t, int32_t> trap_to_host_pkt_info; |
| 363 | |
| 364 | // Map of flow_id -> trap_to_host_pkt_info_with_vlan |
| 365 | extern std::map<uint64_t, trap_to_host_pkt_info_with_vlan> trap_to_host_pkt_info_with_vlan_for_flow_id; |
| 366 | |
| 367 | // Map of trap_to_host_pkt_info -> cvid_list |
| 368 | extern std::map<trap_to_host_pkt_info, std::list<uint16_t> > trap_to_host_vlan_ids_for_trap_to_host_pkt_info; |
| 369 | |
| 370 | // Data structures to work around ACL limits on BAL -- end -- |
| 371 | |
Girish Gowdra | ddf9a16 | 2020-01-27 12:56:27 +0530 | [diff] [blame] | 372 | extern std::bitset<MAX_ACL_ID> acl_id_bitset; |
Girish Gowdra | 252f497 | 2020-09-07 21:24:01 -0700 | [diff] [blame] | 373 | extern bcmos_fastlock acl_id_bitset_lock; |
Girish Gowdra | ddf9a16 | 2020-01-27 12:56:27 +0530 | [diff] [blame] | 374 | |
| 375 | /*** ACL Handling related data end ***/ |
| 376 | |
| 377 | extern std::bitset<MAX_TM_SCHED_ID> tm_sched_bitset; |
Girish Gowdra | 252f497 | 2020-09-07 21:24:01 -0700 | [diff] [blame] | 378 | extern bcmos_fastlock tm_sched_bitset_lock; |
| 379 | |
Girish Gowdra | ddf9a16 | 2020-01-27 12:56:27 +0530 | [diff] [blame] | 380 | extern std::bitset<MAX_TM_QMP_ID> tm_qmp_bitset; |
Girish Gowdra | 252f497 | 2020-09-07 21:24:01 -0700 | [diff] [blame] | 381 | extern bcmos_fastlock tm_qmp_bitset_lock; |
| 382 | |
| 383 | extern std::bitset<MAX_FLOW_ID> flow_id_bitset; |
| 384 | extern bcmos_fastlock flow_id_bitset_lock; |
| 385 | |
| 386 | extern std::map<uint64_t, device_flow> voltha_flow_to_device_flow; |
| 387 | extern bcmos_fastlock voltha_flow_to_device_flow_lock; |
Girish Gowdra | ddf9a16 | 2020-01-27 12:56:27 +0530 | [diff] [blame] | 388 | |
Girish Gowdra | eec0fc9 | 2021-05-12 15:37:55 -0700 | [diff] [blame] | 389 | extern std::map<symmetric_datapath_flow_id_map_key, uint64_t> symmetric_datapath_flow_id_map; |
| 390 | extern bcmos_fastlock symmetric_datapath_flow_id_lock; |
| 391 | |
| 392 | extern std::map<pon_gem, onu_uni> pon_gem_to_onu_uni_map; |
| 393 | extern bcmos_fastlock pon_gem_to_onu_uni_map_lock; |
| 394 | |
Girish Gowdra | 1935e6a | 2020-10-31 21:48:22 -0700 | [diff] [blame] | 395 | // Lock to protect critical section around handling data associated with ACL trap packet handling |
| 396 | extern bcmos_fastlock acl_packet_trap_handler_lock; |
| 397 | |
Girish Gowdra | ddf9a16 | 2020-01-27 12:56:27 +0530 | [diff] [blame] | 398 | extern Queue<openolt::Indication> oltIndQ; |
| 399 | |
Girish Gowdra | 252f497 | 2020-09-07 21:24:01 -0700 | [diff] [blame] | 400 | /*** ACL Handling related data end ***/ |
| 401 | |
Girish Gowdra | ddf9a16 | 2020-01-27 12:56:27 +0530 | [diff] [blame] | 402 | extern bcmos_fastlock data_lock; |
| 403 | |
Humera Kouser | 6143c9e | 2020-06-17 22:37:31 +0530 | [diff] [blame] | 404 | // Interface name on which grpc server is running on |
| 405 | // and this can be used to get the mac adress based on interface name. |
| 406 | extern char* grpc_server_interface_name; |
Orhan Kupusoglu | ec57af0 | 2021-05-12 12:38:17 +0000 | [diff] [blame] | 407 | |
| 408 | extern std::map<onu_rssi_compltd_key, Queue<onu_rssi_complete_result>*> onu_rssi_compltd_map; |
| 409 | extern bcmos_fastlock onu_rssi_wait_lock; |
Girish Gowdra | ddf9a16 | 2020-01-27 12:56:27 +0530 | [diff] [blame] | 410 | #endif // OPENOLT_CORE_DATA_H_ |