blob: fdd9bf30f0cc64ae84efb5e60817e0b95f311616 [file] [log] [blame]
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301/*
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#include "bal_indications_hdlr.h"
VoLTHA753536e2017-11-02 20:15:09 +053018#include "bal_indications_queue.h"
19
20/*global variables*/
21
22/*extern variables*/
23
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +053024
25/*static bcmos_mutex bal_ind_lock; - Need to define bcm independent mutex*/
26/********************************************************************\
Rajeswara Raoa3efbca2017-09-08 18:01:16 +053027 * Function : bal_acc_term_indication_cb *
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +053028 * Description : This function will handle the indications for *
29 * Access Terminal Indication *
30 * *
31 ********************************************************************/
32bcmos_errno bal_acc_term_indication_cb(bcmbal_obj *obj)
33{
34 bcmos_errno result = BCM_ERR_OK;
35
Rajeswara Raoa3efbca2017-09-08 18:01:16 +053036 if(BCMBAL_OBJ_ID_ACCESS_TERMINAL != obj->obj_type ||
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +053037 bcmbal_access_terminal_auto_id_ind != obj->subgroup)
38 {
Kim Kempfafa1ab42017-11-13 09:31:47 -080039 ASFVOLT_LOG(ASFVOLT_ERROR, "Processing BAL API '%s' IND callback (status is %s)",
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +053040 bcmbal_objtype_str(obj->obj_type), bcmos_strerror(obj->status));
41 result = BCM_ERR_INTERNAL;
42 }
43 else
44 {
Kim Kempfafa1ab42017-11-13 09:31:47 -080045 ASFVOLT_LOG(ASFVOLT_DEBUG, "Processing BAL API '%s' IND callback (status is %s)",
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +053046 bcmbal_objtype_str(obj->obj_type), bcmos_strerror(obj->status));
VoLTHA753536e2017-11-02 20:15:09 +053047 BalIndications *balIndCfg;
48 balIndCfg = malloc(sizeof(BalIndications));
49 memset(balIndCfg, 0, sizeof(BalIndications));
50 bal_indications__init(balIndCfg);
51 balIndCfg->u_case = BAL_INDICATIONS__U_ACCESS_TERM_IND;
52 balIndCfg->has_objtype = BAL_GRPC_PRES;
53 balIndCfg->objtype = obj->obj_type;
54 balIndCfg->has_sub_group = BAL_GRPC_PRES;
55 balIndCfg->sub_group = obj->subgroup;
56 balIndCfg->device_id = voltha_device_id;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +053057
58 bcmbal_access_terminal_ind *acc_term_ind = (bcmbal_access_terminal_ind *)obj;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +053059
VoLTHA753536e2017-11-02 20:15:09 +053060 balIndCfg->access_term_ind = malloc(sizeof(BalAccessTerminalInd));
61 memset(balIndCfg->access_term_ind, 0, sizeof(BalAccessTerminalInd));
62 bal_access_terminal_ind__init(balIndCfg->access_term_ind);
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +053063
VoLTHA753536e2017-11-02 20:15:09 +053064 BalObj *hdr;
65 hdr = malloc(sizeof(BalObj));
66 memset(hdr, 0, sizeof(BalObj));
67 bal_obj__init(hdr);
68 balIndCfg->access_term_ind->hdr = hdr;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +053069
VoLTHA753536e2017-11-02 20:15:09 +053070 BalAccessTerminalKey *accessTermkey;
71 accessTermkey = malloc(sizeof(BalAccessTerminalKey));
72 memset(accessTermkey, 0, sizeof(BalAccessTerminalKey));
73 bal_access_terminal_key__init(accessTermkey);
74 balIndCfg->access_term_ind->key = accessTermkey;
75 balIndCfg->access_term_ind->key->has_access_term_id = BAL_GRPC_PRES;
76 balIndCfg->access_term_ind->key->access_term_id = acc_term_ind->key.access_term_id;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +053077
VoLTHA753536e2017-11-02 20:15:09 +053078 BalAccessTerminalIndData *accessTermIndData;
79 accessTermIndData = malloc(sizeof(BalAccessTerminalIndData));
80 memset(accessTermIndData, 0, sizeof(BalAccessTerminalIndData));
81 bal_access_terminal_ind_data__init(accessTermIndData);
82 balIndCfg->access_term_ind->data = accessTermIndData;
83 balIndCfg->access_term_ind->data->has_admin_state = BAL_GRPC_PRES;
84 balIndCfg->access_term_ind->data->admin_state = acc_term_ind->data.admin_state;
85 balIndCfg->access_term_ind->data->has_oper_status = BAL_GRPC_PRES;
86 balIndCfg->access_term_ind->data->oper_status = acc_term_ind->data.oper_status;
87 balIndCfg->access_term_ind->data->has_iwf_mode = BAL_GRPC_PRES;
88 balIndCfg->access_term_ind->data->iwf_mode = acc_term_ind->data.iwf_mode;
Rajeswara Raoa3efbca2017-09-08 18:01:16 +053089
VoLTHA753536e2017-11-02 20:15:09 +053090 BalTopology *balTop;
91 balTop = malloc(sizeof(BalTopology));
92 memset(balTop, 0, sizeof(BalTopology));
93 bal_topology__init(balTop);
94 balIndCfg->access_term_ind->data->topology = balTop;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +053095
VoLTHA753536e2017-11-02 20:15:09 +053096 balIndCfg->access_term_ind->data->topology->has_num_of_nni_ports = BAL_GRPC_PRES;
97 balIndCfg->access_term_ind->data->topology->num_of_nni_ports =
Rajeswara Raoa3efbca2017-09-08 18:01:16 +053098 acc_term_ind->data.topology.num_of_nni_ports;
VoLTHA753536e2017-11-02 20:15:09 +053099 balIndCfg->access_term_ind->data->topology->has_num_of_pon_ports = BAL_GRPC_PRES;
100 balIndCfg->access_term_ind->data->topology->num_of_pon_ports =
Rajeswara Raoa3efbca2017-09-08 18:01:16 +0530101 acc_term_ind->data.topology.num_of_pon_ports;
VoLTHA753536e2017-11-02 20:15:09 +0530102 balIndCfg->access_term_ind->data->topology->has_num_of_mac_devs = BAL_GRPC_PRES;
103 balIndCfg->access_term_ind->data->topology->num_of_mac_devs =
Rajeswara Raoa3efbca2017-09-08 18:01:16 +0530104 acc_term_ind->data.topology.num_of_mac_devs;
VoLTHA753536e2017-11-02 20:15:09 +0530105 balIndCfg->access_term_ind->data->topology->has_num_of_pons_per_mac_dev = BAL_GRPC_PRES;
106 balIndCfg->access_term_ind->data->topology->num_of_pons_per_mac_dev =
Rajeswara Raoa3efbca2017-09-08 18:01:16 +0530107 acc_term_ind->data.topology.num_of_pons_per_mac_dev;
VoLTHA753536e2017-11-02 20:15:09 +0530108 balIndCfg->access_term_ind->data->topology->has_pon_family = BAL_GRPC_PRES;
109 balIndCfg->access_term_ind->data->topology->pon_family =
Rajeswara Raoa3efbca2017-09-08 18:01:16 +0530110 acc_term_ind->data.topology.pon_family;
VoLTHA753536e2017-11-02 20:15:09 +0530111 balIndCfg->access_term_ind->data->topology->has_pon_sub_family = BAL_GRPC_PRES;
112 balIndCfg->access_term_ind->data->topology->pon_sub_family =
Rajeswara Raoa3efbca2017-09-08 18:01:16 +0530113 acc_term_ind->data.topology.pon_sub_family;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530114
VoLTHA753536e2017-11-02 20:15:09 +0530115 BalSwVersion *balsv;
116 balsv = malloc(sizeof(BalSwVersion));
117 memset(balsv, 0, sizeof(BalSwVersion));
118 bal_sw_version__init(balsv);
119 balIndCfg->access_term_ind->data->sw_version = balsv;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530120
VoLTHA753536e2017-11-02 20:15:09 +0530121 balIndCfg->access_term_ind->data->sw_version->has_version_type = BAL_GRPC_PRES;
122 balIndCfg->access_term_ind->data->sw_version->version_type =
Rajeswara Raoa3efbca2017-09-08 18:01:16 +0530123 acc_term_ind->data.sw_version.version_type;
VoLTHA753536e2017-11-02 20:15:09 +0530124 balIndCfg->access_term_ind->data->sw_version->has_major_rev = BAL_GRPC_PRES;
125 balIndCfg->access_term_ind->data->sw_version->major_rev =
Rajeswara Raoa3efbca2017-09-08 18:01:16 +0530126 acc_term_ind->data.sw_version.major_rev;
VoLTHA753536e2017-11-02 20:15:09 +0530127 balIndCfg->access_term_ind->data->sw_version->has_minor_rev = BAL_GRPC_PRES;
128 balIndCfg->access_term_ind->data->sw_version->minor_rev =
Rajeswara Raob2e441c2017-09-20 16:40:21 +0530129 acc_term_ind->data.sw_version.minor_rev;
VoLTHA753536e2017-11-02 20:15:09 +0530130 balIndCfg->access_term_ind->data->sw_version->has_patch_rev = BAL_GRPC_PRES;
131 balIndCfg->access_term_ind->data->sw_version->patch_rev =
Rajeswara Raob2e441c2017-09-20 16:40:21 +0530132 acc_term_ind->data.sw_version.patch_rev;
VoLTHA753536e2017-11-02 20:15:09 +0530133 balIndCfg->access_term_ind->data->sw_version->has_om_version = BAL_GRPC_PRES;
134 balIndCfg->access_term_ind->data->sw_version->om_version =
Rajeswara Raob2e441c2017-09-20 16:40:21 +0530135 acc_term_ind->data.sw_version.om_version;
VoLTHA753536e2017-11-02 20:15:09 +0530136 balIndCfg->access_term_ind->data->sw_version->has_dev_point = BAL_GRPC_PRES;
137 balIndCfg->access_term_ind->data->sw_version->dev_point =
Rajeswara Raob2e441c2017-09-20 16:40:21 +0530138 acc_term_ind->data.sw_version.dev_point;
139
140 bal_register_indication_cbs();
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530141
VoLTHA753536e2017-11-02 20:15:09 +0530142 list_node *bal_indication_node = malloc(sizeof(list_node));
143 bal_indication_node->bal_indication = balIndCfg;
root2ca2cc02017-11-03 19:51:57 +0530144
VoLTHA753536e2017-11-02 20:15:09 +0530145 pthread_mutex_lock(&bal_ind_queue_lock);
146 add_bal_indication_node(bal_indication_node);
147 pthread_mutex_unlock(&bal_ind_queue_lock);
148
Rajeswara Rao9f1cea12017-10-10 18:25:29 +0530149 is_reboot = BAL_REBOOT_STATUS__BAL_OLT_UP_AFTER_ACTIVATION;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530150 }
151
152 return result;
153}
154
155/********************************************************************\
Rajeswara Raob2e441c2017-09-20 16:40:21 +0530156 * Function : bal_acc_term_osc_indication_cb *
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530157 * Description : This function will handle the indications for *
158 * Access Terminal Operational State Change *
159 * *
160 ********************************************************************/
161bcmos_errno bal_acc_term_osc_indication_cb(bcmbal_obj *obj)
162{
163 bcmos_errno result = BCM_ERR_OK;
164
Rajeswara Raob2e441c2017-09-20 16:40:21 +0530165 if(BCMBAL_OBJ_ID_ACCESS_TERMINAL != obj->obj_type ||
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530166 bcmbal_access_terminal_auto_id_oper_status_change != obj->subgroup)
167 {
Kim Kempfafa1ab42017-11-13 09:31:47 -0800168 ASFVOLT_LOG(ASFVOLT_ERROR, "Processing BAL API '%s' IND callback (status is %s)",
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530169 bcmbal_objtype_str(obj->obj_type), bcmos_strerror(obj->status));
170 result = BCM_ERR_INTERNAL;
171 }
172 else
173 {
VoLTHA753536e2017-11-02 20:15:09 +0530174 BalIndications *balIndCfg;
175 balIndCfg = malloc(sizeof(BalIndications));
176 memset(balIndCfg, 0, sizeof(BalIndications));
177 bal_indications__init(balIndCfg);
178 balIndCfg->has_objtype = BAL_GRPC_PRES;
179 balIndCfg->objtype = obj->obj_type;
180 balIndCfg->has_sub_group = BAL_GRPC_PRES;
181 balIndCfg->sub_group = obj->subgroup;
182 balIndCfg->u_case = BAL_INDICATIONS__U_ACCESS_TERM_IND_OP_STATE;
183 balIndCfg->device_id = voltha_device_id;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530184
Rajeswara Raob2e441c2017-09-20 16:40:21 +0530185 bcmbal_access_terminal_oper_status_change *acc_term_osc =
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530186 (bcmbal_access_terminal_oper_status_change *)obj;
187
VoLTHA753536e2017-11-02 20:15:09 +0530188 BalAccessTerminalOperStatusChange *acessTermOSC;
189 acessTermOSC = malloc(sizeof(BalAccessTerminalOperStatusChange));
190 memset(acessTermOSC, 0, sizeof(BalAccessTerminalOperStatusChange));
191 bal_access_terminal_oper_status_change__init(acessTermOSC);
192 balIndCfg->access_term_ind_op_state = acessTermOSC;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530193
VoLTHA753536e2017-11-02 20:15:09 +0530194 BalObj *hdr;
195 hdr = malloc(sizeof(BalObj));
196 memset(hdr, 0, sizeof(BalObj));
197 bal_obj__init(hdr);
198 balIndCfg->access_term_ind_op_state->hdr = hdr;
Rajeswara Raob2e441c2017-09-20 16:40:21 +0530199
VoLTHA753536e2017-11-02 20:15:09 +0530200 BalAccessTerminalKey *accessTermkey;
201 accessTermkey = malloc(sizeof(BalAccessTerminalKey));
202 memset(accessTermkey, 0, sizeof(BalAccessTerminalKey));
203 bal_access_terminal_key__init(accessTermkey);
204 balIndCfg->access_term_ind_op_state->key = accessTermkey;
205 balIndCfg->access_term_ind_op_state->key->has_access_term_id = BAL_GRPC_PRES;
206 balIndCfg->access_term_ind_op_state->key->access_term_id =
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530207 acc_term_osc->key.access_term_id;
Rajeswara Raob2e441c2017-09-20 16:40:21 +0530208
VoLTHA753536e2017-11-02 20:15:09 +0530209 BalAccessTerminalOperStatusChangeData *accessTermOscData;
210 accessTermOscData = malloc(sizeof(BalAccessTerminalOperStatusChangeData));
211 memset(accessTermOscData, 0, sizeof(BalAccessTerminalOperStatusChangeData));
212 bal_access_terminal_oper_status_change_data__init(accessTermOscData);
213 balIndCfg->access_term_ind_op_state->data = accessTermOscData;
214 balIndCfg->access_term_ind_op_state->data->has_new_oper_status = BAL_GRPC_PRES;
215 balIndCfg->access_term_ind_op_state->data->new_oper_status =
Rajeswara Raob2e441c2017-09-20 16:40:21 +0530216 acc_term_osc->data.new_oper_status;
VoLTHA753536e2017-11-02 20:15:09 +0530217 balIndCfg->access_term_ind_op_state->data->has_old_oper_status = BAL_GRPC_PRES;
218 balIndCfg->access_term_ind_op_state->data->old_oper_status =
Rajeswara Raob2e441c2017-09-20 16:40:21 +0530219 acc_term_osc->data.old_oper_status;
VoLTHA753536e2017-11-02 20:15:09 +0530220 balIndCfg->access_term_ind_op_state->data->has_admin_state = BAL_GRPC_PRES;
221 balIndCfg->access_term_ind_op_state->data->admin_state =
Rajeswara Raob2e441c2017-09-20 16:40:21 +0530222 acc_term_osc->data.admin_state;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530223
VoLTHA753536e2017-11-02 20:15:09 +0530224 list_node *bal_indication_node = malloc(sizeof(list_node));
225 bal_indication_node->bal_indication = balIndCfg;
226
227 pthread_mutex_lock(&bal_ind_queue_lock);
228 add_bal_indication_node(bal_indication_node);
229 pthread_mutex_unlock(&bal_ind_queue_lock);
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530230 }
231
232 return result;
233}
234
235/********************************************************************\
Rajeswara Raob2e441c2017-09-20 16:40:21 +0530236 * Function : bal_flow_osc_indication_cb *
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530237 * Description : This function will handle the indications for *
238 * Flow Operational State Change *
239 * *
240 ********************************************************************/
241bcmos_errno bal_flow_osc_indication_cb(bcmbal_obj *obj)
242{
243 bcmos_errno result = BCM_ERR_OK;
244
Rajeswara Raob2e441c2017-09-20 16:40:21 +0530245 if(BCMBAL_OBJ_ID_FLOW != obj->obj_type ||
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530246 bcmbal_flow_auto_id_oper_status_change != obj->subgroup)
247 {
Kim Kempfafa1ab42017-11-13 09:31:47 -0800248 ASFVOLT_LOG(ASFVOLT_ERROR, "Processing BAL API '%s' IND callback (status is %s)",
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530249 bcmbal_objtype_str(obj->obj_type), bcmos_strerror(obj->status));
250 result = BCM_ERR_INTERNAL;
251 }
252 else
253 {
VoLTHA753536e2017-11-02 20:15:09 +0530254 BalIndications *balIndCfg;
255 balIndCfg = malloc(sizeof(BalIndications));
256 memset(balIndCfg, 0, sizeof(BalIndications));
257 bal_indications__init(balIndCfg);
258 balIndCfg->u_case = BAL_INDICATIONS__U_FLOW_OP_STATE;
259 balIndCfg->has_objtype = BAL_GRPC_PRES;
260 balIndCfg->objtype = obj->obj_type;
261 balIndCfg->has_sub_group = BAL_GRPC_PRES;
262 balIndCfg->sub_group = obj->subgroup;
263 balIndCfg->device_id = voltha_device_id;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530264
265 bcmbal_flow_oper_status_change *flow_osc = (bcmbal_flow_oper_status_change *)obj;
266
VoLTHA753536e2017-11-02 20:15:09 +0530267 BalFlowOperStatusChange *flowOscInd;
268 flowOscInd = malloc(sizeof(BalFlowOperStatusChange));
269 memset(flowOscInd, 0, sizeof(BalFlowOperStatusChange));
270 bal_flow_oper_status_change__init(flowOscInd);
271 balIndCfg->flow_op_state = flowOscInd;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530272
VoLTHA753536e2017-11-02 20:15:09 +0530273 BalObj *hdr;
274 hdr = malloc(sizeof(BalObj));
275 memset(hdr, 0, sizeof(BalObj));
276 bal_obj__init(hdr);
277 balIndCfg->flow_op_state->hdr = hdr;
Rajeswara Raob2e441c2017-09-20 16:40:21 +0530278
VoLTHA753536e2017-11-02 20:15:09 +0530279 BalFlowKey *flowkey;
280 flowkey = malloc(sizeof(BalFlowKey));
281 memset(flowkey, 0, sizeof(BalFlowKey));
282 bal_flow_key__init(flowkey);
283 balIndCfg->flow_op_state->key = flowkey;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530284
VoLTHA753536e2017-11-02 20:15:09 +0530285 balIndCfg->flow_op_state->key->has_flow_id = BAL_GRPC_PRES;
286 balIndCfg->flow_op_state->key->flow_id = flow_osc->key.flow_id;
287 balIndCfg->flow_op_state->key->has_flow_type = BAL_GRPC_PRES;
288 balIndCfg->flow_op_state->key->flow_type = flow_osc->key.flow_type;
Rajeswara Raob2e441c2017-09-20 16:40:21 +0530289
VoLTHA753536e2017-11-02 20:15:09 +0530290 BalFlowOperStatusChangeData *flowOscIndData;
291 flowOscIndData = malloc(sizeof(BalFlowOperStatusChangeData));
292 memset(flowOscIndData, 0, sizeof(BalFlowOperStatusChangeData));
293 bal_flow_oper_status_change_data__init(flowOscIndData);
294 balIndCfg->flow_op_state->data = flowOscIndData;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530295
VoLTHA753536e2017-11-02 20:15:09 +0530296 balIndCfg->flow_op_state->data->has_new_oper_status = BAL_GRPC_PRES;
297 balIndCfg->flow_op_state->data->new_oper_status = flow_osc->data.new_oper_status;
298 balIndCfg->flow_op_state->data->has_old_oper_status = BAL_GRPC_PRES;
299 balIndCfg->flow_op_state->data->old_oper_status = flow_osc->data.old_oper_status;
300 balIndCfg->flow_op_state->data->has_admin_state = BAL_GRPC_PRES;
301 balIndCfg->flow_op_state->data->admin_state = flow_osc->data.admin_state;
302 balIndCfg->flow_op_state->data->has_svc_port_id = BAL_GRPC_PRES;
303 balIndCfg->flow_op_state->data->svc_port_id = flow_osc->data.svc_port_id;
304 balIndCfg->flow_op_state->data->has_dba_tm_sched_id = BAL_GRPC_PRES;
305 balIndCfg->flow_op_state->data->dba_tm_sched_id = flow_osc->data.dba_tm_sched_id;
306 balIndCfg->flow_op_state->data->has_cookie = BAL_GRPC_PRES;
307 balIndCfg->flow_op_state->data->cookie = flow_osc->data.cookie;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530308
VoLTHA753536e2017-11-02 20:15:09 +0530309 list_node *bal_indication_node = malloc(sizeof(list_node));
310 bal_indication_node->bal_indication = balIndCfg;
311
312 pthread_mutex_lock(&bal_ind_queue_lock);
313 add_bal_indication_node(bal_indication_node);
314 pthread_mutex_unlock(&bal_ind_queue_lock);
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530315 }
316
317 return result;
318}
319
320/********************************************************************\
Rajeswara Raob2e441c2017-09-20 16:40:21 +0530321 * Function : bal_flow_indication_cb *
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530322 * Description : This function will handle the indications for *
323 * Flow Indication *
324 * *
325 ********************************************************************/
326bcmos_errno bal_flow_indication_cb(bcmbal_obj *obj)
327{
328 bcmos_errno result = BCM_ERR_OK;
329
Rajeswara Raob2e441c2017-09-20 16:40:21 +0530330 if(BCMBAL_OBJ_ID_FLOW != obj->obj_type ||
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530331 bcmbal_flow_auto_id_ind != obj->subgroup)
332 {
Kim Kempfafa1ab42017-11-13 09:31:47 -0800333 ASFVOLT_LOG(ASFVOLT_ERROR, "Processing BAL API '%s' IND callback (status is %s)",
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530334 bcmbal_objtype_str(obj->obj_type), bcmos_strerror(obj->status));
335 result = BCM_ERR_INTERNAL;
336 }
337 else
338 {
VoLTHA753536e2017-11-02 20:15:09 +0530339 BalIndications *balIndCfg;
340 balIndCfg = malloc(sizeof(BalIndications));
341 memset(balIndCfg, 0, sizeof(BalIndications));
342 bal_indications__init(balIndCfg);
343 balIndCfg->u_case = BAL_INDICATIONS__U_FLOW_IND;
344 balIndCfg->has_objtype = BAL_GRPC_PRES;
345 balIndCfg->objtype = obj->obj_type;
346 balIndCfg->has_sub_group = BAL_GRPC_PRES;
347 balIndCfg->sub_group = obj->subgroup;
348 balIndCfg->device_id = voltha_device_id;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530349
350 bcmbal_flow_ind *flow_ind = (bcmbal_flow_ind *)obj;
351
VoLTHA753536e2017-11-02 20:15:09 +0530352 BalFlowInd *flowInd;
353 flowInd = malloc(sizeof(BalFlowInd));
354 memset(flowInd, 0, sizeof(BalFlowInd));
355 bal_flow_ind__init(flowInd);
356 balIndCfg->flow_ind = flowInd;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530357
VoLTHA753536e2017-11-02 20:15:09 +0530358 BalObj *hdr;
359 hdr = malloc(sizeof(BalObj));
360 memset(hdr, 0, sizeof(BalObj));
361 bal_obj__init(hdr);
362 balIndCfg->flow_ind->hdr = hdr;
Rajeswara Raob2e441c2017-09-20 16:40:21 +0530363
VoLTHA753536e2017-11-02 20:15:09 +0530364 BalFlowKey *flowkey;
365 flowkey = malloc(sizeof(BalFlowKey));
366 memset(flowkey, 0, sizeof(BalFlowKey));
367 bal_flow_key__init(flowkey);
368 balIndCfg->flow_ind->key = flowkey;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530369
VoLTHA753536e2017-11-02 20:15:09 +0530370 balIndCfg->flow_ind->key->has_flow_id = BAL_GRPC_PRES;
371 balIndCfg->flow_ind->key->flow_id = flow_ind->key.flow_id;
372 balIndCfg->flow_ind->key->has_flow_type = BAL_GRPC_PRES;
373 balIndCfg->flow_ind->key->flow_type = flow_ind->key.flow_type;
Rajeswara Raob2e441c2017-09-20 16:40:21 +0530374
VoLTHA753536e2017-11-02 20:15:09 +0530375 BalFlowIndData *flowIndData;
376 flowIndData = malloc(sizeof(BalFlowIndData));
377 memset(flowIndData, 0, sizeof(BalFlowIndData));
378 bal_flow_ind_data__init(flowIndData);
379 balIndCfg->flow_ind->data = flowIndData;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530380
VoLTHA753536e2017-11-02 20:15:09 +0530381 balIndCfg->flow_ind->data->has_admin_state = BAL_GRPC_PRES;
382 balIndCfg->flow_ind->data->admin_state = flow_ind->data.admin_state;
383 balIndCfg->flow_ind->data->has_oper_status= BAL_GRPC_PRES;
384 balIndCfg->flow_ind->data->oper_status= flow_ind->data.oper_status;
385 balIndCfg->flow_ind->data->has_access_int_id = BAL_GRPC_PRES;
386 balIndCfg->flow_ind->data->access_int_id = flow_ind->data.access_int_id;
387 balIndCfg->flow_ind->data->has_network_int_id = BAL_GRPC_PRES;
388 balIndCfg->flow_ind->data->network_int_id = flow_ind->data.network_int_id;
389 balIndCfg->flow_ind->data->has_sub_term_id = BAL_GRPC_PRES;
390 balIndCfg->flow_ind->data->sub_term_id = flow_ind->data.sub_term_id;
391 balIndCfg->flow_ind->data->has_sub_term_uni_idx = BAL_GRPC_PRES;
392 balIndCfg->flow_ind->data->sub_term_uni_idx = flow_ind->data.sub_term_uni_idx;
393 balIndCfg->flow_ind->data->has_svc_port_id = BAL_GRPC_PRES;
394 balIndCfg->flow_ind->data->svc_port_id = flow_ind->data.svc_port_id;
395 balIndCfg->flow_ind->data->has_resolve_mac = BAL_GRPC_PRES;
396 balIndCfg->flow_ind->data->resolve_mac = flow_ind->data.resolve_mac;
397 balIndCfg->flow_ind->data->has_cookie = BAL_GRPC_PRES;
398 balIndCfg->flow_ind->data->cookie = flow_ind->data.cookie;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530399
VoLTHA753536e2017-11-02 20:15:09 +0530400 BalClassifier *balClassifier;
401 balClassifier = malloc(sizeof(BalClassifier));
402 memset(balClassifier, 0, sizeof(BalClassifier));
403 bal_classifier__init(balClassifier);
404 balIndCfg->flow_ind->data->classifier = balClassifier;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530405
VoLTHA753536e2017-11-02 20:15:09 +0530406 balIndCfg->flow_ind->data->classifier->has_presence_mask = BAL_GRPC_PRES;
407 balIndCfg->flow_ind->data->classifier->presence_mask = flow_ind->data.classifier.presence_mask;
408 balIndCfg->flow_ind->data->classifier->has_o_tpid = BAL_GRPC_PRES;
409 balIndCfg->flow_ind->data->classifier->o_tpid = flow_ind->data.classifier.o_tpid;
410 balIndCfg->flow_ind->data->classifier->has_o_vid = BAL_GRPC_PRES;
411 balIndCfg->flow_ind->data->classifier->o_vid = flow_ind->data.classifier.o_vid;
412 balIndCfg->flow_ind->data->classifier->has_i_tpid = BAL_GRPC_PRES;
413 balIndCfg->flow_ind->data->classifier->i_tpid = flow_ind->data.classifier.i_tpid;
414 balIndCfg->flow_ind->data->classifier->has_i_vid = BAL_GRPC_PRES;
415 balIndCfg->flow_ind->data->classifier->i_vid = flow_ind->data.classifier.i_vid;
416 balIndCfg->flow_ind->data->classifier->has_o_pbits = BAL_GRPC_PRES;
417 balIndCfg->flow_ind->data->classifier->o_pbits = flow_ind->data.classifier.o_pbits;
418 balIndCfg->flow_ind->data->classifier->has_i_pbits = BAL_GRPC_PRES;
419 balIndCfg->flow_ind->data->classifier->i_pbits = flow_ind->data.classifier.i_pbits;
420 balIndCfg->flow_ind->data->classifier->has_ether_type = BAL_GRPC_PRES;
421 balIndCfg->flow_ind->data->classifier->ether_type = flow_ind->data.classifier.ether_type;
422 balIndCfg->flow_ind->data->classifier->has_dst_mac = BAL_GRPC_PRES;
423 balIndCfg->flow_ind->data->classifier->dst_mac.len =
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530424 (BCMOS_ETH_ALEN)*sizeof(flow_ind->data.classifier.dst_mac.u8);
VoLTHA753536e2017-11-02 20:15:09 +0530425 balIndCfg->flow_ind->data->classifier->dst_mac.data =
426 (uint8_t *)malloc((balIndCfg->flow_ind->data->classifier->dst_mac.len)*sizeof(uint8_t));
427 memcpy(balIndCfg->flow_ind->data->classifier->dst_mac.data,
Rajeswara Raob2e441c2017-09-20 16:40:21 +0530428 flow_ind->data.classifier.dst_mac.u8,
VoLTHA753536e2017-11-02 20:15:09 +0530429 balIndCfg->flow_ind->data->classifier->dst_mac.len);
430 balIndCfg->flow_ind->data->classifier->has_src_mac = BAL_GRPC_PRES;
431 balIndCfg->flow_ind->data->classifier->src_mac.len =
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530432 (BCMOS_ETH_ALEN)*sizeof(flow_ind->data.classifier.src_mac.u8);
VoLTHA753536e2017-11-02 20:15:09 +0530433 balIndCfg->flow_ind->data->classifier->src_mac.data =
434 (uint8_t *)malloc((balIndCfg->flow_ind->data->classifier->src_mac.len)*sizeof(uint8_t));
435 memcpy(balIndCfg->flow_ind->data->classifier->src_mac.data,
Rajeswara Raob2e441c2017-09-20 16:40:21 +0530436 flow_ind->data.classifier.src_mac.u8,
VoLTHA753536e2017-11-02 20:15:09 +0530437 balIndCfg->flow_ind->data->classifier->src_mac.len);
438 balIndCfg->flow_ind->data->classifier->has_ip_proto = BAL_GRPC_PRES;
439 balIndCfg->flow_ind->data->classifier->ip_proto = flow_ind->data.classifier.ip_proto;
440 balIndCfg->flow_ind->data->classifier->has_dst_ip = BAL_GRPC_PRES;
441 balIndCfg->flow_ind->data->classifier->dst_ip = flow_ind->data.classifier.dst_ip.u32;
442 balIndCfg->flow_ind->data->classifier->has_src_ip = BAL_GRPC_PRES;
443 balIndCfg->flow_ind->data->classifier->src_ip = flow_ind->data.classifier.src_ip.u32;
444 balIndCfg->flow_ind->data->classifier->has_src_port = BAL_GRPC_PRES;
445 balIndCfg->flow_ind->data->classifier->src_port = flow_ind->data.classifier.src_port;
446 balIndCfg->flow_ind->data->classifier->has_dst_port = BAL_GRPC_PRES;
447 balIndCfg->flow_ind->data->classifier->dst_port = flow_ind->data.classifier.dst_port;
448 balIndCfg->flow_ind->data->classifier->has_pkt_tag_type = BAL_GRPC_PRES;
449 balIndCfg->flow_ind->data->classifier->pkt_tag_type = flow_ind->data.classifier.pkt_tag_type;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530450
VoLTHA753536e2017-11-02 20:15:09 +0530451 BalAction *balAction;
452 balAction = malloc(sizeof(BalAction));
453 memset(balAction, 0, sizeof(BalAction));
454 bal_action__init(balAction);
455 balIndCfg->flow_ind->data->action = balAction;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530456
VoLTHA753536e2017-11-02 20:15:09 +0530457 balIndCfg->flow_ind->data->action->has_presence_mask = BAL_GRPC_PRES;
458 balIndCfg->flow_ind->data->action->presence_mask = flow_ind->data.action.presence_mask;
459 balIndCfg->flow_ind->data->action->has_cmds_bitmask = BAL_GRPC_PRES;
460 balIndCfg->flow_ind->data->action->cmds_bitmask = flow_ind->data.action.cmds_bitmask;
461 balIndCfg->flow_ind->data->action->has_o_vid = BAL_GRPC_PRES;
462 balIndCfg->flow_ind->data->action->o_vid = flow_ind->data.action.o_vid;
463 balIndCfg->flow_ind->data->action->has_o_pbits = BAL_GRPC_PRES;
464 balIndCfg->flow_ind->data->action->o_pbits = flow_ind->data.action.o_pbits;
465 balIndCfg->flow_ind->data->action->has_o_tpid = BAL_GRPC_PRES;
466 balIndCfg->flow_ind->data->action->o_tpid = flow_ind->data.action.o_tpid;
467 balIndCfg->flow_ind->data->action->has_i_vid = BAL_GRPC_PRES;
468 balIndCfg->flow_ind->data->action->i_vid = flow_ind->data.action.i_vid;
469 balIndCfg->flow_ind->data->action->has_i_pbits = BAL_GRPC_PRES;
470 balIndCfg->flow_ind->data->action->i_pbits = flow_ind->data.action.i_pbits;
471 balIndCfg->flow_ind->data->action->has_i_tpid = BAL_GRPC_PRES;
472 balIndCfg->flow_ind->data->action->i_tpid = flow_ind->data.action.i_tpid;
473
474 list_node *bal_indication_node = malloc(sizeof(list_node));
475 bal_indication_node->bal_indication = balIndCfg;
476
477 pthread_mutex_lock(&bal_ind_queue_lock);
478 add_bal_indication_node(bal_indication_node);
479 pthread_mutex_unlock(&bal_ind_queue_lock);
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530480 }
481
482 return result;
483}
484
485/********************************************************************\
Rajeswara Raob2e441c2017-09-20 16:40:21 +0530486 * Function : bal_group_indication_cb *
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530487 * Description : This function will handle the indications for *
488 * Group Indication *
489 * *
490 ********************************************************************/
491bcmos_errno bal_group_indication_cb(bcmbal_obj *obj)
492{
493 bcmos_errno result = BCM_ERR_OK;
root2ca2cc02017-11-03 19:51:57 +0530494 unsigned int i = 0;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530495
Rajeswara Raob2e441c2017-09-20 16:40:21 +0530496 if(BCMBAL_OBJ_ID_GROUP != obj->obj_type ||
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530497 bcmbal_group_auto_id_ind != obj->subgroup)
498 {
Kim Kempfafa1ab42017-11-13 09:31:47 -0800499 ASFVOLT_LOG(ASFVOLT_ERROR, "Processing BAL API '%s' IND callback (status is %s)",
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530500 bcmbal_objtype_str(obj->obj_type), bcmos_strerror(obj->status));
501 result = BCM_ERR_INTERNAL;
502 }
503 else
504 {
VoLTHA753536e2017-11-02 20:15:09 +0530505 BalIndications *balIndCfg;
506 balIndCfg = malloc(sizeof(BalIndications));
507 memset(balIndCfg, 0, sizeof(BalIndications));
508 bal_indications__init(balIndCfg);
509 balIndCfg->u_case = BAL_INDICATIONS__U_GROUP_IND;
510 balIndCfg->has_objtype = BAL_GRPC_PRES;
511 balIndCfg->objtype = obj->obj_type;
512 balIndCfg->has_sub_group = BAL_GRPC_PRES;
513 balIndCfg->sub_group = obj->subgroup;
514 balIndCfg->device_id = voltha_device_id;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530515
516 bcmbal_group_ind *group_ind = (bcmbal_group_ind *)obj;
517
VoLTHA753536e2017-11-02 20:15:09 +0530518 BalGroupInd *groupInd;
519 groupInd = malloc(sizeof(BalGroupInd));
520 memset(groupInd, 0, sizeof(BalGroupInd));
521 bal_group_ind__init(groupInd);
522 balIndCfg->group_ind = groupInd;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530523
VoLTHA753536e2017-11-02 20:15:09 +0530524 BalObj *hdr;
525 hdr = malloc(sizeof(BalObj));
526 memset(hdr, 0, sizeof(BalObj));
527 bal_obj__init(hdr);
528 balIndCfg->group_ind->hdr = hdr;
Rajeswara Raob2e441c2017-09-20 16:40:21 +0530529
VoLTHA753536e2017-11-02 20:15:09 +0530530 BalGroupKey *groupkey;
531 groupkey = malloc(sizeof(BalGroupKey));
532 memset(groupkey, 0, sizeof(BalGroupKey));
533 bal_group_key__init(groupkey);
534 balIndCfg->group_ind->key = groupkey;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530535
VoLTHA753536e2017-11-02 20:15:09 +0530536 balIndCfg->group_ind->key->has_group_id = BAL_GRPC_PRES;
537 balIndCfg->group_ind->key->group_id = group_ind->key.group_id;
Rajeswara Raob2e441c2017-09-20 16:40:21 +0530538
VoLTHA753536e2017-11-02 20:15:09 +0530539 BalGroupIndData *groupIndData;
540 groupIndData = malloc(sizeof(BalGroupIndData));
541 memset(groupIndData, 0, sizeof(BalGroupIndData));
542 bal_group_ind_data__init(groupIndData);
543 balIndCfg->group_ind->data = groupIndData;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530544
VoLTHA753536e2017-11-02 20:15:09 +0530545 balIndCfg->group_ind->data->has_members_cmd = BAL_GRPC_PRES;
546 balIndCfg->group_ind->data->members_cmd = group_ind->data.members_cmd;
547 balIndCfg->group_ind->data->has_cookie = BAL_GRPC_PRES;
548 balIndCfg->group_ind->data->cookie = group_ind->data.cookie;
549 balIndCfg->group_ind->data->has_owner = BAL_GRPC_PRES;
550 balIndCfg->group_ind->data->owner = group_ind->data.owner;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530551
VoLTHA753536e2017-11-02 20:15:09 +0530552 BalGroupMemberInfoList *balMembers;
553 balMembers = malloc(sizeof(BalGroupMemberInfoList));
554 memset(balMembers, 0, sizeof(BalGroupMemberInfoList));
555 bal_group_member_info_list__init(balMembers);
556 balIndCfg->group_ind->data->members = balMembers;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530557
VoLTHA753536e2017-11-02 20:15:09 +0530558 balIndCfg->group_ind->data->members->n_val = group_ind->data.members.len;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530559
560 BalGroupMemberInfo *balMemberInfo;
VoLTHA753536e2017-11-02 20:15:09 +0530561 BalAction *balAction;
VoLTHA753536e2017-11-02 20:15:09 +0530562 BalTmQueueRef *balQueue;
root2ca2cc02017-11-03 19:51:57 +0530563 for (i = 0; i < balIndCfg->group_ind->data->members->n_val; i++)
564 {
565 balMemberInfo = malloc(sizeof(BalGroupMemberInfo));
566 memset(balMemberInfo, 0, sizeof(BalGroupMemberInfo));
567 bal_group_member_info__init(balMemberInfo);
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530568
root2ca2cc02017-11-03 19:51:57 +0530569 balMemberInfo->has_intf_id = BAL_GRPC_PRES;
570 balMemberInfo->intf_id = group_ind->data.members.val->intf_id;
571 balMemberInfo->has_svc_port_id = BAL_GRPC_PRES;
572 balMemberInfo->svc_port_id = group_ind->data.members.val->svc_port_id;
573
574 balAction = malloc(sizeof(BalAction));
575 memset(balAction, 0, sizeof(BalAction));
576 bal_action__init(balAction);
577 balMemberInfo->action = balAction;
578
579 balMemberInfo->action->has_presence_mask = BAL_GRPC_PRES;
580 balMemberInfo->action->presence_mask = group_ind->data.members.val->action.presence_mask;
581 balMemberInfo->action->has_cmds_bitmask = BAL_GRPC_PRES;
582 balMemberInfo->action->cmds_bitmask = group_ind->data.members.val->action.cmds_bitmask;
583 balMemberInfo->action->has_o_vid = BAL_GRPC_PRES;
584 balMemberInfo->action->o_vid = group_ind->data.members.val->action.o_vid;
585 balMemberInfo->action->has_o_pbits = BAL_GRPC_PRES;
586 balMemberInfo->action->o_pbits = group_ind->data.members.val->action.o_pbits;
587 balMemberInfo->action->has_o_tpid = BAL_GRPC_PRES;
588 balMemberInfo->action->o_tpid = group_ind->data.members.val->action.o_tpid;
589 balMemberInfo->action->has_i_vid = BAL_GRPC_PRES;
590 balMemberInfo->action->i_vid = group_ind->data.members.val->action.i_vid;
591 balMemberInfo->action->has_i_pbits = BAL_GRPC_PRES;
592 balMemberInfo->action->i_pbits = group_ind->data.members.val->action.i_pbits;
593 balMemberInfo->action->has_i_tpid = BAL_GRPC_PRES;
594 balMemberInfo->action->i_tpid = group_ind->data.members.val->action.i_tpid;
595
596 balQueue = malloc(sizeof(BalTmQueueRef));
597 memset(balQueue, 0, sizeof(BalTmQueueRef));
598 bal_tm_queue_ref__init(balQueue);
599 balMemberInfo->queue = balQueue;
600
601 balMemberInfo->queue->has_sched_id = BAL_GRPC_PRES;
602 balMemberInfo->queue->sched_id = group_ind->data.members.val->queue.sched_id;
603 balMemberInfo->queue->has_queue_id = BAL_GRPC_PRES;
604 balMemberInfo->queue->queue_id = group_ind->data.members.val->queue.queue_id;
605
606 balIndCfg->group_ind->data->members->val[i] = balMemberInfo;
607 }
608
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530609
VoLTHA753536e2017-11-02 20:15:09 +0530610 BalIdList *balFlows;
611 balFlows = malloc(sizeof(BalIdList));
612 memset(balFlows, 0, sizeof(BalIdList));
613 bal_id_list__init(balFlows);
614 balIndCfg->group_ind->data->flows = balFlows;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530615
VoLTHA753536e2017-11-02 20:15:09 +0530616 balIndCfg->group_ind->data->flows->n_val = group_ind->data.flows.len;
617 balIndCfg->group_ind->data->flows->val =
618 (uint32_t *)malloc((balIndCfg->group_ind->data->flows->n_val)*sizeof(uint32_t));
619 memcpy(balIndCfg->group_ind->data->flows->val, group_ind->data.flows.val,
620 balIndCfg->group_ind->data->flows->n_val);
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530621
VoLTHA753536e2017-11-02 20:15:09 +0530622 list_node *bal_indication_node = malloc(sizeof(list_node));
623 bal_indication_node->bal_indication = balIndCfg;
624
625 pthread_mutex_lock(&bal_ind_queue_lock);
626 add_bal_indication_node(bal_indication_node);
627 pthread_mutex_unlock(&bal_ind_queue_lock);
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530628 }
629
630 return result;
631}
632
633/********************************************************************\
Rajeswara Raob2e441c2017-09-20 16:40:21 +0530634 * Function : bal_interface_osc_indication_cb *
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530635 * Description : This function will handle the indications for *
636 * Interface Operational State Change *
637 * *
638 ********************************************************************/
639bcmos_errno bal_interface_osc_indication_cb(bcmbal_obj *obj)
640{
641 bcmos_errno result = BCM_ERR_OK;
642
Rajeswara Raob2e441c2017-09-20 16:40:21 +0530643 if(BCMBAL_OBJ_ID_INTERFACE != obj->obj_type ||
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530644 bcmbal_interface_auto_id_oper_status_change != obj->subgroup)
645 {
Kim Kempfafa1ab42017-11-13 09:31:47 -0800646 ASFVOLT_LOG(ASFVOLT_ERROR, "Processing BAL API '%s' IND callback (status is %s)",
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530647 bcmbal_objtype_str(obj->obj_type), bcmos_strerror(obj->status));
648 result = BCM_ERR_INTERNAL;
649 }
650 else
651 {
VoLTHA753536e2017-11-02 20:15:09 +0530652 BalIndications *balIndCfg;
653 balIndCfg = malloc(sizeof(BalIndications));
654 memset(balIndCfg, 0, sizeof(BalIndications));
655 bal_indications__init(balIndCfg);
656 balIndCfg->u_case = BAL_INDICATIONS__U_INTERFACE_OP_STATE;
657 balIndCfg->has_objtype = BAL_GRPC_PRES;
658 balIndCfg->objtype = obj->obj_type;
659 balIndCfg->has_sub_group = BAL_GRPC_PRES;
660 balIndCfg->sub_group = obj->subgroup;
661 balIndCfg->device_id = voltha_device_id;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530662
Rajeswara Raob2e441c2017-09-20 16:40:21 +0530663 bcmbal_interface_oper_status_change *int_osc_ind =
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530664 (bcmbal_interface_oper_status_change *)obj;
665
VoLTHA753536e2017-11-02 20:15:09 +0530666 BalInterfaceOperStatusChange *ifOsc;
667 ifOsc = malloc(sizeof(BalInterfaceOperStatusChange));
668 memset(ifOsc, 0, sizeof(BalInterfaceOperStatusChange));
669 bal_interface_oper_status_change__init(ifOsc);
670 balIndCfg->interface_op_state = ifOsc;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530671
VoLTHA753536e2017-11-02 20:15:09 +0530672 BalObj *hdr;
673 hdr = malloc(sizeof(BalObj));
674 memset(hdr, 0, sizeof(BalObj));
675 bal_obj__init(hdr);
676 balIndCfg->interface_op_state->hdr = hdr;
Rajeswara Raob2e441c2017-09-20 16:40:21 +0530677
VoLTHA753536e2017-11-02 20:15:09 +0530678 BalInterfaceKey *ifkey;
679 ifkey = malloc(sizeof(BalInterfaceKey));
680 memset(ifkey, 0, sizeof(BalInterfaceKey));
681 bal_interface_key__init(ifkey);
682 balIndCfg->interface_op_state->key = ifkey;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530683
VoLTHA753536e2017-11-02 20:15:09 +0530684 balIndCfg->interface_op_state->key->has_intf_id = BAL_GRPC_PRES;
685 balIndCfg->interface_op_state->key->intf_id = int_osc_ind->key.intf_id;
686 balIndCfg->interface_op_state->key->has_intf_type = BAL_GRPC_PRES;
687 balIndCfg->interface_op_state->key->intf_type = int_osc_ind->key.intf_type;
Rajeswara Raob2e441c2017-09-20 16:40:21 +0530688
VoLTHA753536e2017-11-02 20:15:09 +0530689 BalInterfaceOperStatusChangeData *ifOscIndData;
690 ifOscIndData = malloc(sizeof(BalInterfaceOperStatusChangeData));
691 memset(ifOscIndData, 0, sizeof(BalInterfaceOperStatusChangeData));
692 bal_interface_oper_status_change_data__init(ifOscIndData);
693 balIndCfg->interface_op_state->data = ifOscIndData;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530694
VoLTHA753536e2017-11-02 20:15:09 +0530695 balIndCfg->interface_op_state->data->has_new_oper_status = BAL_GRPC_PRES;
696 balIndCfg->interface_op_state->data->new_oper_status = int_osc_ind->data.new_oper_status;
697 balIndCfg->interface_op_state->data->has_old_oper_status = BAL_GRPC_PRES;
698 balIndCfg->interface_op_state->data->old_oper_status = int_osc_ind->data.old_oper_status;
699 balIndCfg->interface_op_state->data->has_admin_state = BAL_GRPC_PRES;
700 balIndCfg->interface_op_state->data->admin_state = int_osc_ind->data.admin_state;
Rajeswara Raob2e441c2017-09-20 16:40:21 +0530701
VoLTHA753536e2017-11-02 20:15:09 +0530702 list_node *bal_indication_node = malloc(sizeof(list_node));
703 bal_indication_node->bal_indication = balIndCfg;
704
705 pthread_mutex_lock(&bal_ind_queue_lock);
706 add_bal_indication_node(bal_indication_node);
707 pthread_mutex_unlock(&bal_ind_queue_lock);
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530708 }
709
710 return result;
711}
712
713/********************************************************************\
Rajeswara Raob2e441c2017-09-20 16:40:21 +0530714 * Function : bal_interface_los_indication_cb *
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530715 * Description : This function will handle the indications for *
716 * Interface los Indication *
717 * *
718 ********************************************************************/
719bcmos_errno bal_interface_los_indication_cb(bcmbal_obj *obj)
720{
721 bcmos_errno result = BCM_ERR_OK;
722
Rajeswara Raob2e441c2017-09-20 16:40:21 +0530723 if(BCMBAL_OBJ_ID_INTERFACE != obj->obj_type ||
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530724 bcmbal_interface_auto_id_los != obj->subgroup)
725 {
Kim Kempfafa1ab42017-11-13 09:31:47 -0800726 ASFVOLT_LOG(ASFVOLT_ERROR, "Processing BAL API '%s' IND callback (status is %s)",
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530727 bcmbal_objtype_str(obj->obj_type), bcmos_strerror(obj->status));
728 result = BCM_ERR_INTERNAL;
729 }
730 else
731 {
VoLTHA753536e2017-11-02 20:15:09 +0530732 BalIndications *balIndCfg;
733 balIndCfg = malloc(sizeof(BalIndications));
734 memset(balIndCfg, 0, sizeof(BalIndications));
735 bal_indications__init(balIndCfg);
736 balIndCfg->u_case = BAL_INDICATIONS__U_INTERFACE_LOS;
737 balIndCfg->has_objtype = BAL_GRPC_PRES;
738 balIndCfg->objtype = obj->obj_type;
739 balIndCfg->has_sub_group = BAL_GRPC_PRES;
740 balIndCfg->sub_group = obj->subgroup;
741 balIndCfg->device_id = voltha_device_id;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530742
Rajeswara Raob2e441c2017-09-20 16:40:21 +0530743 bcmbal_interface_los *int_los_ind =
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530744 (bcmbal_interface_los *)obj;
745
VoLTHA753536e2017-11-02 20:15:09 +0530746 BalInterfaceLos *ifLos;
747 ifLos = malloc(sizeof(BalInterfaceLos));
748 memset(ifLos, 0, sizeof(BalInterfaceLos));
749 bal_interface_los__init(ifLos);
750 balIndCfg->interface_los = ifLos;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530751
VoLTHA753536e2017-11-02 20:15:09 +0530752 BalObj *hdr;
753 hdr = malloc(sizeof(BalObj));
754 memset(hdr, 0, sizeof(BalObj));
755 bal_obj__init(hdr);
756 balIndCfg->interface_los->hdr = hdr;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530757
VoLTHA753536e2017-11-02 20:15:09 +0530758 BalInterfaceKey *ifkey;
759 ifkey = malloc(sizeof(BalInterfaceKey));
760 memset(ifkey, 0, sizeof(BalInterfaceKey));
761 bal_interface_key__init(ifkey);
762 balIndCfg->interface_los->key = ifkey;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530763
VoLTHA753536e2017-11-02 20:15:09 +0530764 balIndCfg->interface_los->key->has_intf_id = BAL_GRPC_PRES;
765 balIndCfg->interface_los->key->intf_id = int_los_ind->key.intf_id;
766 balIndCfg->interface_los->key->has_intf_type = BAL_GRPC_PRES;
767 balIndCfg->interface_los->key->intf_type = int_los_ind->key.intf_type;
Rajeswara Raob2e441c2017-09-20 16:40:21 +0530768
VoLTHA753536e2017-11-02 20:15:09 +0530769 BalInterfaceLosData *ifLosIndData;
770 ifLosIndData = malloc(sizeof(BalInterfaceLosData));
771 memset(ifLosIndData, 0, sizeof(BalInterfaceLosData));
772 bal_interface_los_data__init(ifLosIndData);
773 balIndCfg->interface_los->data = ifLosIndData;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530774
VoLTHA753536e2017-11-02 20:15:09 +0530775 balIndCfg->interface_los->data->has_status = BAL_GRPC_PRES;
776 balIndCfg->interface_los->data->status = int_los_ind->data.status;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530777
VoLTHA753536e2017-11-02 20:15:09 +0530778 list_node *bal_indication_node = malloc(sizeof(list_node));
779 bal_indication_node->bal_indication = balIndCfg;
780
781 pthread_mutex_lock(&bal_ind_queue_lock);
782 add_bal_indication_node(bal_indication_node);
783 pthread_mutex_unlock(&bal_ind_queue_lock);
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530784 }
785
786 return result;
787}
788
789/********************************************************************\
Rajeswara Raob2e441c2017-09-20 16:40:21 +0530790 * Function : bal_interface_indication_cb *
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530791 * Description : This function will handle the indications for *
792 * Interface Indication *
793 * *
794 ********************************************************************/
795bcmos_errno bal_interface_indication_cb(bcmbal_obj *obj)
796{
797 bcmos_errno result = BCM_ERR_OK;
798
Rajeswara Raob2e441c2017-09-20 16:40:21 +0530799 if(BCMBAL_OBJ_ID_INTERFACE != obj->obj_type ||
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530800 bcmbal_interface_auto_id_ind != obj->subgroup)
801 {
Kim Kempfafa1ab42017-11-13 09:31:47 -0800802 ASFVOLT_LOG(ASFVOLT_ERROR, "Processing BAL API '%s' IND callback (status is %s)",
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530803 bcmbal_objtype_str(obj->obj_type), bcmos_strerror(obj->status));
804 result = BCM_ERR_INTERNAL;
805 }
806 else
807 {
VoLTHA753536e2017-11-02 20:15:09 +0530808 BalIndications *balIndCfg;
809 balIndCfg = malloc(sizeof(BalIndications));
810 memset(balIndCfg, 0, sizeof(BalIndications));
811 bal_indications__init(balIndCfg);
812 balIndCfg->u_case = BAL_INDICATIONS__U_INTERFACE_IND;
813 balIndCfg->has_objtype = BAL_GRPC_PRES;
814 balIndCfg->objtype = obj->obj_type;
815 balIndCfg->has_sub_group = BAL_GRPC_PRES;
816 balIndCfg->sub_group = obj->subgroup;
817 balIndCfg->device_id = voltha_device_id;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530818
819 bcmbal_interface_ind *interface_ind = (bcmbal_interface_ind *)obj;
820
VoLTHA753536e2017-11-02 20:15:09 +0530821 BalInterfaceInd *ifInd;
822 ifInd = malloc(sizeof(BalInterfaceInd));
823 memset(ifInd, 0, sizeof(BalInterfaceInd));
824 bal_interface_ind__init(ifInd);
825 balIndCfg->interface_ind = ifInd;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530826
VoLTHA753536e2017-11-02 20:15:09 +0530827 BalObj *hdr;
828 hdr = malloc(sizeof(BalObj));
829 memset(hdr, 0, sizeof(BalObj));
830 bal_obj__init(hdr);
831 balIndCfg->interface_ind->hdr = hdr;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530832
VoLTHA753536e2017-11-02 20:15:09 +0530833 BalInterfaceKey *ifkey;
834 ifkey = malloc(sizeof(BalInterfaceKey));
835 memset(ifkey, 0, sizeof(BalInterfaceKey));
836 bal_interface_key__init(ifkey);
837 balIndCfg->interface_ind->key = ifkey;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530838
VoLTHA753536e2017-11-02 20:15:09 +0530839 balIndCfg->interface_ind->key->has_intf_id = BAL_GRPC_PRES;
840 balIndCfg->interface_ind->key->intf_id = interface_ind->key.intf_id;
841 balIndCfg->interface_ind->key->has_intf_type = BAL_GRPC_PRES;
842 balIndCfg->interface_ind->key->intf_type = interface_ind->key.intf_type;
Rajeswara Raob2e441c2017-09-20 16:40:21 +0530843
VoLTHA753536e2017-11-02 20:15:09 +0530844 BalInterfaceIndData *ifIndData;
845 ifIndData = malloc(sizeof(BalInterfaceIndData));
846 memset(ifIndData, 0, sizeof(BalInterfaceIndData));
847 bal_interface_ind_data__init(ifIndData);
848 balIndCfg->interface_ind->data = ifIndData;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530849
VoLTHA753536e2017-11-02 20:15:09 +0530850 balIndCfg->interface_ind->data->has_admin_state = BAL_GRPC_PRES;
851 balIndCfg->interface_ind->data->admin_state = interface_ind->data.admin_state;
852 balIndCfg->interface_ind->data->has_oper_status = BAL_GRPC_PRES;
853 balIndCfg->interface_ind->data->oper_status = interface_ind->data.oper_status;
854 balIndCfg->interface_ind->data->has_min_data_agg_port_id = BAL_GRPC_PRES;
855 balIndCfg->interface_ind->data->min_data_agg_port_id = interface_ind->data.min_data_agg_port_id;
856 balIndCfg->interface_ind->data->has_min_data_svc_port_id = BAL_GRPC_PRES;
857 balIndCfg->interface_ind->data->min_data_svc_port_id = interface_ind->data.min_data_svc_port_id;
858 balIndCfg->interface_ind->data->has_transceiver_type = BAL_GRPC_PRES;
859 balIndCfg->interface_ind->data->transceiver_type = interface_ind->data.transceiver_type;
860 balIndCfg->interface_ind->data->has_ds_miss_mode = BAL_GRPC_PRES;
861 balIndCfg->interface_ind->data->ds_miss_mode = interface_ind->data.ds_miss_mode;
862 balIndCfg->interface_ind->data->has_mtu = BAL_GRPC_PRES;
863 balIndCfg->interface_ind->data->mtu = interface_ind->data.mtu;
864 balIndCfg->interface_ind->data->has_flow_control = BAL_GRPC_PRES;
865 balIndCfg->interface_ind->data->flow_control = interface_ind->data.flow_control;
866 balIndCfg->interface_ind->data->has_ds_tm = BAL_GRPC_PRES;
867 balIndCfg->interface_ind->data->ds_tm = interface_ind->data.ds_tm;
868 balIndCfg->interface_ind->data->has_us_tm = BAL_GRPC_PRES;
869 balIndCfg->interface_ind->data->us_tm = interface_ind->data.us_tm;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530870
VoLTHA753536e2017-11-02 20:15:09 +0530871 BalIdList *balFlows;
872 balFlows = malloc(sizeof(BalIdList));
873 memset(balFlows, 0, sizeof(BalIdList));
874 bal_id_list__init(balFlows);
875 balIndCfg->interface_ind->data->sub_term_id_list = balFlows;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530876
VoLTHA753536e2017-11-02 20:15:09 +0530877 balIndCfg->interface_ind->data->sub_term_id_list->n_val = interface_ind->data.sub_term_id_list.len;
878 balIndCfg->interface_ind->data->sub_term_id_list->val =
879 (uint32_t *)malloc((balIndCfg->interface_ind->data->sub_term_id_list->n_val)*sizeof(uint32_t));
880 memcpy(balIndCfg->interface_ind->data->sub_term_id_list->val, interface_ind->data.sub_term_id_list.val,
881 balIndCfg->interface_ind->data->sub_term_id_list->n_val);
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530882
VoLTHA753536e2017-11-02 20:15:09 +0530883 list_node *bal_indication_node = malloc(sizeof(list_node));
884 bal_indication_node->bal_indication = balIndCfg;
885
886 pthread_mutex_lock(&bal_ind_queue_lock);
887 add_bal_indication_node(bal_indication_node);
888 pthread_mutex_unlock(&bal_ind_queue_lock);
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530889 }
890
891 return result;
892}
893
894/********************************************************************\
Rajeswara Raob2e441c2017-09-20 16:40:21 +0530895 * Function : bal_sub_term_osc_indication_cb *
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530896 * Description : This function will handle the indications for *
897 * Subscriber term Operational State Change *
898 * *
899 ********************************************************************/
900bcmos_errno bal_sub_term_osc_indication_cb(bcmbal_obj *obj)
901{
902 bcmos_errno result = BCM_ERR_OK;
903
Rajeswara Raob2e441c2017-09-20 16:40:21 +0530904 if(BCMBAL_OBJ_ID_SUBSCRIBER_TERMINAL != obj->obj_type ||
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530905 bcmbal_subscriber_terminal_auto_id_oper_status_change != obj->subgroup)
906 {
Kim Kempfafa1ab42017-11-13 09:31:47 -0800907 ASFVOLT_LOG(ASFVOLT_ERROR, "Processing BAL API '%s' IND callback (status is %s)",
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530908 bcmbal_objtype_str(obj->obj_type), bcmos_strerror(obj->status));
909 result = BCM_ERR_INTERNAL;
910 }
911 else
912 {
VoLTHA753536e2017-11-02 20:15:09 +0530913 BalIndications *balIndCfg;
914 balIndCfg = malloc(sizeof(BalIndications));
915 memset(balIndCfg, 0, sizeof(BalIndications));
916 bal_indications__init(balIndCfg);
917 balIndCfg->u_case = BAL_INDICATIONS__U_TERMINAL_OP_STATE;
918 balIndCfg->has_objtype = BAL_GRPC_PRES;
919 balIndCfg->objtype = obj->obj_type;
920 balIndCfg->has_sub_group = BAL_GRPC_PRES;
921 balIndCfg->sub_group = obj->subgroup;
922 balIndCfg->device_id = voltha_device_id;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530923
Rajeswara Raob2e441c2017-09-20 16:40:21 +0530924 bcmbal_subscriber_terminal_oper_status_change *sub_osc_ind =
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530925 (bcmbal_subscriber_terminal_oper_status_change *)obj;
926
VoLTHA753536e2017-11-02 20:15:09 +0530927 BalSubscriberTerminalOperStatusChange *subOscInd;
928 subOscInd = malloc(sizeof(BalSubscriberTerminalOperStatusChange));
929 memset(subOscInd, 0, sizeof(BalSubscriberTerminalOperStatusChange));
930 bal_subscriber_terminal_oper_status_change__init(subOscInd);
931 balIndCfg->terminal_op_state = subOscInd;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530932
VoLTHA753536e2017-11-02 20:15:09 +0530933 BalObj *hdr;
934 hdr = malloc(sizeof(BalObj));
935 memset(hdr, 0, sizeof(BalObj));
936 bal_obj__init(hdr);
937 balIndCfg->terminal_op_state->hdr = hdr;
Rajeswara Raob2e441c2017-09-20 16:40:21 +0530938
VoLTHA753536e2017-11-02 20:15:09 +0530939 BalSubscriberTerminalKey *subkey;
940 subkey = malloc(sizeof(BalSubscriberTerminalKey));
941 memset(subkey, 0, sizeof(BalSubscriberTerminalKey));
942 bal_subscriber_terminal_key__init(subkey);
943 balIndCfg->terminal_op_state->key = subkey;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530944
VoLTHA753536e2017-11-02 20:15:09 +0530945 balIndCfg->terminal_op_state->key->has_intf_id = BAL_GRPC_PRES;
946 balIndCfg->terminal_op_state->key->intf_id = sub_osc_ind->key.intf_id;
947 balIndCfg->terminal_op_state->key->has_sub_term_id = BAL_GRPC_PRES;
948 balIndCfg->terminal_op_state->key->sub_term_id = sub_osc_ind->key.sub_term_id;
Rajeswara Raob2e441c2017-09-20 16:40:21 +0530949
VoLTHA753536e2017-11-02 20:15:09 +0530950 BalSubscriberTerminalOperStatusChangeData *subOscIndData;
951 subOscIndData = malloc(sizeof(BalSubscriberTerminalOperStatusChangeData));
952 memset(subOscIndData, 0, sizeof(BalSubscriberTerminalOperStatusChangeData));
953 bal_subscriber_terminal_oper_status_change_data__init(subOscIndData);
954 balIndCfg->terminal_op_state->data = subOscIndData;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530955
VoLTHA753536e2017-11-02 20:15:09 +0530956 balIndCfg->terminal_op_state->data->has_new_oper_status = BAL_GRPC_PRES;
957 balIndCfg->terminal_op_state->data->new_oper_status =
Rajeswara Raob2e441c2017-09-20 16:40:21 +0530958 sub_osc_ind->data.new_oper_status;
VoLTHA753536e2017-11-02 20:15:09 +0530959 balIndCfg->terminal_op_state->data->has_old_oper_status = BAL_GRPC_PRES;
960 balIndCfg->terminal_op_state->data->old_oper_status =
Rajeswara Raob2e441c2017-09-20 16:40:21 +0530961 sub_osc_ind->data.old_oper_status;
VoLTHA753536e2017-11-02 20:15:09 +0530962 balIndCfg->terminal_op_state->data->has_admin_state = BAL_GRPC_PRES;
963 balIndCfg->terminal_op_state->data->admin_state =
Rajeswara Raob2e441c2017-09-20 16:40:21 +0530964 sub_osc_ind->data.admin_state;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530965
VoLTHA753536e2017-11-02 20:15:09 +0530966 list_node *bal_indication_node = malloc(sizeof(list_node));
967 bal_indication_node->bal_indication = balIndCfg;
968
969 pthread_mutex_lock(&bal_ind_queue_lock);
970 add_bal_indication_node(bal_indication_node);
971 pthread_mutex_unlock(&bal_ind_queue_lock);
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530972 }
973
974 return result;
975}
976
977/********************************************************************\
Rajeswara Raob2e441c2017-09-20 16:40:21 +0530978 * Function : bal_sub_term_disc_indication_cb *
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530979 * Description : This function will handle the indications for *
980 * Subscriber term disc indication *
981 * *
982 ********************************************************************/
983bcmos_errno bal_sub_term_disc_indication_cb(bcmbal_obj *obj)
984{
985 bcmos_errno result = BCM_ERR_OK;
986
Rajeswara Raob2e441c2017-09-20 16:40:21 +0530987 if(BCMBAL_OBJ_ID_SUBSCRIBER_TERMINAL != obj->obj_type ||
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530988 bcmbal_subscriber_terminal_auto_id_sub_term_disc != obj->subgroup)
989 {
Kim Kempfafa1ab42017-11-13 09:31:47 -0800990 ASFVOLT_LOG(ASFVOLT_ERROR, "Processing BAL API '%s' IND callback (status is %s)",
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530991 bcmbal_objtype_str(obj->obj_type), bcmos_strerror(obj->status));
992 result = BCM_ERR_INTERNAL;
993 }
994 else
995 {
Kim Kempfafa1ab42017-11-13 09:31:47 -0800996 ASFVOLT_LOG(ASFVOLT_DEBUG, "Processing BAL API '%s' IND callback (status is %s)",
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +0530997 bcmbal_objtype_str(obj->obj_type), bcmos_strerror(obj->status));
VoLTHA753536e2017-11-02 20:15:09 +0530998 BalIndications *balIndCfg;
999 balIndCfg = malloc(sizeof(BalIndications));
1000 memset(balIndCfg, 0, sizeof(BalIndications));
1001 bal_indications__init(balIndCfg);
1002 balIndCfg->u_case = BAL_INDICATIONS__U_TERMINAL_DISC;
1003 balIndCfg->has_objtype = BAL_GRPC_PRES;
1004 balIndCfg->objtype = obj->obj_type;
1005 balIndCfg->has_sub_group = BAL_GRPC_PRES;
1006 balIndCfg->sub_group = obj->subgroup;
1007 balIndCfg->device_id = voltha_device_id;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301008
Rajeswara Raob2e441c2017-09-20 16:40:21 +05301009 bcmbal_subscriber_terminal_sub_term_disc *sub_disc_ind =
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301010 (bcmbal_subscriber_terminal_sub_term_disc *)obj;
1011
VoLTHA753536e2017-11-02 20:15:09 +05301012 BalSubscriberTerminalSubTermDisc *subDiscInd;
1013 subDiscInd = malloc(sizeof(BalSubscriberTerminalSubTermDisc));
1014 memset(subDiscInd, 0, sizeof(BalSubscriberTerminalSubTermDisc));
1015 bal_subscriber_terminal_sub_term_disc__init(subDiscInd);
1016 balIndCfg->terminal_disc = subDiscInd;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301017
VoLTHA753536e2017-11-02 20:15:09 +05301018 BalObj *hdr;
1019 hdr = malloc(sizeof(BalObj));
1020 memset(hdr, 0, sizeof(BalObj));
1021 bal_obj__init(hdr);
1022 balIndCfg->terminal_disc->hdr = hdr;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301023
VoLTHA753536e2017-11-02 20:15:09 +05301024 BalSubscriberTerminalKey *subkey;
1025 subkey = malloc(sizeof(BalSubscriberTerminalKey));
1026 memset(subkey, 0, sizeof(BalSubscriberTerminalKey));
1027 bal_subscriber_terminal_key__init(subkey);
1028 balIndCfg->terminal_disc->key = subkey;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301029
VoLTHA753536e2017-11-02 20:15:09 +05301030 balIndCfg->terminal_disc->key->has_intf_id = BAL_GRPC_PRES;
1031 balIndCfg->terminal_disc->key->intf_id = sub_disc_ind->key.intf_id;
1032 balIndCfg->terminal_disc->key->has_sub_term_id = BAL_GRPC_PRES;
1033 balIndCfg->terminal_disc->key->sub_term_id = sub_disc_ind->key.sub_term_id;
Rajeswara Raob2e441c2017-09-20 16:40:21 +05301034
VoLTHA753536e2017-11-02 20:15:09 +05301035 BalSubscriberTerminalSubTermDiscData *subDiscIndData;
1036 subDiscIndData = malloc(sizeof(BalSubscriberTerminalSubTermDiscData));
1037 memset(subDiscIndData, 0, sizeof(BalSubscriberTerminalSubTermDiscData));
1038 bal_subscriber_terminal_sub_term_disc_data__init(subDiscIndData);
1039 balIndCfg->terminal_disc->data = subDiscIndData;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301040
VoLTHA753536e2017-11-02 20:15:09 +05301041 BalSerialNumber *serial_number;
1042 serial_number = malloc(sizeof(BalSerialNumber));
1043 memset(serial_number, 0, sizeof(BalSerialNumber));
1044 bal_serial_number__init(serial_number);
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301045
VoLTHA753536e2017-11-02 20:15:09 +05301046 balIndCfg->terminal_disc->data->serial_number = serial_number;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301047
Kim Kempfafa1ab42017-11-13 09:31:47 -08001048 ASFVOLT_LOG(ASFVOLT_INFO, "Discovered ONU serial number "
1049 "%c%c%c%c%02X%02X%02X%02X",
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301050 sub_disc_ind->data.serial_number.vendor_id[0],
1051 sub_disc_ind->data.serial_number.vendor_id[1],
1052 sub_disc_ind->data.serial_number.vendor_id[2],
1053 sub_disc_ind->data.serial_number.vendor_id[3],
Kim Kempfafa1ab42017-11-13 09:31:47 -08001054 sub_disc_ind->data.serial_number.vendor_specific[0],
1055 sub_disc_ind->data.serial_number.vendor_specific[1],
1056 sub_disc_ind->data.serial_number.vendor_specific[2],
1057 sub_disc_ind->data.serial_number.vendor_specific[3]);
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301058
Kim Kempfafa1ab42017-11-13 09:31:47 -08001059 //ASFVOLT_LOG(ASFVOLT_DEBUG, "ONU Discovery:Before decoding:Vendor id is %s", sub_disc_ind->data.serial_number.vendor_id);
1060 //ASFVOLT_LOG(ASFVOLT_DEBUG, "ONU Discovery:Before decoding:Vendor specific is %s", sub_disc_ind->data.serial_number.vendor_specific);
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301061
VoLTHA753536e2017-11-02 20:15:09 +05301062 char *vendor_id = malloc(sizeof(char)*MAX_CHAR_LENGTH);
1063 memset(vendor_id, 0, MAX_CHAR_LENGTH);
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301064 sprintf(vendor_id,"%c%c%c%c",
1065 sub_disc_ind->data.serial_number.vendor_id[0],
1066 sub_disc_ind->data.serial_number.vendor_id[1],
1067 sub_disc_ind->data.serial_number.vendor_id[2],
1068 sub_disc_ind->data.serial_number.vendor_id[3]);
VoLTHA753536e2017-11-02 20:15:09 +05301069 balIndCfg->terminal_disc->data->serial_number->vendor_id = vendor_id;
Kim Kempfafa1ab42017-11-13 09:31:47 -08001070 ASFVOLT_LOG(ASFVOLT_DEBUG, "ONU Discovery:After decoding:Vendor id is %s", balIndCfg->terminal_disc->data->serial_number->vendor_id);
VoLTHA753536e2017-11-02 20:15:09 +05301071 char *vendor_specific = malloc(sizeof(char)*MAX_CHAR_LENGTH);
1072 memset(vendor_specific, 0, MAX_CHAR_LENGTH);
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301073 sprintf(vendor_specific,"%1X%1X%1X%1X%1X%1X%1X%1X",
1074 sub_disc_ind->data.serial_number.vendor_specific[0]>>4 & 0x0f,
1075 sub_disc_ind->data.serial_number.vendor_specific[0] & 0x0f,
1076 sub_disc_ind->data.serial_number.vendor_specific[1]>>4 & 0x0f,
1077 sub_disc_ind->data.serial_number.vendor_specific[1] & 0x0f,
1078 sub_disc_ind->data.serial_number.vendor_specific[2]>>4 & 0x0f,
1079 sub_disc_ind->data.serial_number.vendor_specific[2] & 0x0f,
1080 sub_disc_ind->data.serial_number.vendor_specific[3]>>4 & 0x0f,
1081 sub_disc_ind->data.serial_number.vendor_specific[3] & 0x0f);
VoLTHA753536e2017-11-02 20:15:09 +05301082 balIndCfg->terminal_disc->data->serial_number->vendor_specific = vendor_specific;
Kim Kempfafa1ab42017-11-13 09:31:47 -08001083 ASFVOLT_LOG(ASFVOLT_DEBUG, "ONU Discovery:After decoding:Vendor specific is %s", balIndCfg->terminal_disc->data->serial_number->vendor_specific);
Rajeswara Raob2e441c2017-09-20 16:40:21 +05301084
VoLTHA753536e2017-11-02 20:15:09 +05301085 list_node *bal_indication_node = malloc(sizeof(list_node));
1086 bal_indication_node->bal_indication = balIndCfg;
1087
1088 pthread_mutex_lock(&bal_ind_queue_lock);
1089 add_bal_indication_node(bal_indication_node);
1090 pthread_mutex_unlock(&bal_ind_queue_lock);
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301091 }
1092
1093 return result;
1094}
1095
1096/********************************************************************\
Rajeswara Raob2e441c2017-09-20 16:40:21 +05301097 * Function : bal_sub_term_alarm_indication_cb *
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301098 * Description : This function will handle the indications for *
1099 * Subscriber term alarm indication *
1100 * *
1101 ********************************************************************/
1102bcmos_errno bal_sub_term_alarm_indication_cb(bcmbal_obj *obj)
1103{
1104 bcmos_errno result = BCM_ERR_OK;
1105
Rajeswara Raob2e441c2017-09-20 16:40:21 +05301106 if(BCMBAL_OBJ_ID_SUBSCRIBER_TERMINAL != obj->obj_type ||
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301107 bcmbal_subscriber_terminal_auto_id_sub_term_alarm != obj->subgroup)
1108 {
Kim Kempfafa1ab42017-11-13 09:31:47 -08001109 ASFVOLT_LOG(ASFVOLT_ERROR, "Processing BAL API \'%s\' IND callback (status is %s)",
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301110 bcmbal_objtype_str(obj->obj_type), bcmos_strerror(obj->status));
1111 result = BCM_ERR_INTERNAL;
1112 }
1113 else
1114 {
VoLTHA753536e2017-11-02 20:15:09 +05301115 BalIndications *balIndCfg;
1116 balIndCfg = malloc(sizeof(BalIndications));
1117 memset(balIndCfg, 0, sizeof(BalIndications));
1118 bal_indications__init(balIndCfg);
1119 balIndCfg->has_objtype = BAL_GRPC_PRES;
1120 balIndCfg->objtype = BAL_OBJ_ID__BAL_OBJ_ID_SUBSCRIBER_TERMINAL;
1121 balIndCfg->has_sub_group = BAL_GRPC_PRES;
1122 balIndCfg->sub_group = obj->subgroup;
1123 balIndCfg->device_id = voltha_device_id;
Rajeswara Raob2e441c2017-09-20 16:40:21 +05301124
VoLTHA753536e2017-11-02 20:15:09 +05301125 balIndCfg->u_case = BAL_INDICATIONS__U_TERMINAL_ALARM;
Rajeswara Raob2e441c2017-09-20 16:40:21 +05301126 bcmbal_subscriber_terminal_sub_term_alarm *sub_term_alarm =
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301127 (bcmbal_subscriber_terminal_sub_term_alarm *)obj;
1128
VoLTHA753536e2017-11-02 20:15:09 +05301129 BalSubscriberTerminalSubTermAlarm *subTermAlarm;
1130 subTermAlarm = malloc(sizeof(BalSubscriberTerminalSubTermAlarm));
1131 memset(subTermAlarm, 0, sizeof(BalSubscriberTerminalSubTermAlarm));
1132 bal_subscriber_terminal_sub_term_alarm__init(subTermAlarm);
1133 balIndCfg->terminal_alarm = subTermAlarm;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301134
VoLTHA753536e2017-11-02 20:15:09 +05301135 BalObj *hdr;
1136 hdr = malloc(sizeof(BalObj));
1137 memset(hdr, 0, sizeof(BalObj));
1138 bal_obj__init(hdr);
1139 balIndCfg->terminal_alarm->hdr = hdr;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301140
VoLTHA753536e2017-11-02 20:15:09 +05301141 BalSubscriberTerminalKey *subkey;
1142 subkey = malloc(sizeof(BalSubscriberTerminalKey));
1143 memset(subkey, 0, sizeof(BalSubscriberTerminalKey));
1144 bal_subscriber_terminal_key__init(subkey);
1145 balIndCfg->terminal_alarm->key = subkey;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301146
VoLTHA753536e2017-11-02 20:15:09 +05301147 balIndCfg->terminal_alarm->key->has_sub_term_id = BAL_GRPC_PRES;
1148 balIndCfg->terminal_alarm->key->sub_term_id = sub_term_alarm->key.sub_term_id;
1149 balIndCfg->terminal_alarm->key->has_intf_id = BAL_GRPC_PRES;
1150 balIndCfg->terminal_alarm->key->intf_id = sub_term_alarm->key.intf_id;
Rajeswara Raob2e441c2017-09-20 16:40:21 +05301151
VoLTHA753536e2017-11-02 20:15:09 +05301152 BalsubscriberTerminalSubTermAlarmData *subTermAlarmData;
1153 subTermAlarmData = malloc(sizeof(BalsubscriberTerminalSubTermAlarmData));
1154 memset(subTermAlarmData, 0, sizeof(BalsubscriberTerminalSubTermAlarmData));
1155 balsubscriber_terminal_sub_term_alarm_data__init(subTermAlarmData);
1156 balIndCfg->terminal_alarm->data = subTermAlarmData;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301157
VoLTHA753536e2017-11-02 20:15:09 +05301158 BalSubscriberTerminalAlarms *balSubAlarms;
1159 balSubAlarms = malloc(sizeof(BalSubscriberTerminalAlarms));
1160 memset(balSubAlarms, 0, sizeof(BalSubscriberTerminalAlarms));
1161 bal_subscriber_terminal_alarms__init(balSubAlarms);
1162 balIndCfg->terminal_alarm->data->alarm = balSubAlarms;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301163
VoLTHA753536e2017-11-02 20:15:09 +05301164 balIndCfg->terminal_alarm->data->alarm->has_los = BAL_GRPC_PRES;
1165 balIndCfg->terminal_alarm->data->alarm->los = sub_term_alarm->data.alarm.los;
1166 balIndCfg->terminal_alarm->data->alarm->has_lob = BAL_GRPC_PRES;
1167 balIndCfg->terminal_alarm->data->alarm->lob = sub_term_alarm->data.alarm.lob;
1168 balIndCfg->terminal_alarm->data->alarm->has_lopc_miss = BAL_GRPC_PRES;
1169 balIndCfg->terminal_alarm->data->alarm->lopc_miss = sub_term_alarm->data.alarm.lopc_miss;
1170 balIndCfg->terminal_alarm->data->alarm->has_lopc_mic_error = BAL_GRPC_PRES;
1171 balIndCfg->terminal_alarm->data->alarm->lopc_mic_error = sub_term_alarm->data.alarm.lopc_mic_error;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301172
VoLTHA753536e2017-11-02 20:15:09 +05301173 list_node *bal_indication_node = malloc(sizeof(list_node));
1174 bal_indication_node->bal_indication = balIndCfg;
1175
1176 pthread_mutex_lock(&bal_ind_queue_lock);
1177 add_bal_indication_node(bal_indication_node);
1178 pthread_mutex_unlock(&bal_ind_queue_lock);
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301179 }
1180
1181 return result;
1182}
1183
1184/********************************************************************\
Rajeswara Raob2e441c2017-09-20 16:40:21 +05301185 * Function : bal_sub_term_dgi_indication_cb *
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301186 * Description : This function will handle the indications for *
1187 * Subscriber term dgi indication *
1188 * *
1189 ********************************************************************/
1190bcmos_errno bal_sub_term_dgi_indication_cb(bcmbal_obj *obj)
1191{
1192 bcmos_errno result = BCM_ERR_OK;
1193
Rajeswara Raob2e441c2017-09-20 16:40:21 +05301194 if(BCMBAL_OBJ_ID_SUBSCRIBER_TERMINAL != obj->obj_type ||
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301195 bcmbal_subscriber_terminal_auto_id_dgi != obj->subgroup)
1196 {
Kim Kempfafa1ab42017-11-13 09:31:47 -08001197 ASFVOLT_LOG(ASFVOLT_ERROR, "Processing BAL API '%s' IND callback (status is %s)",
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301198 bcmbal_objtype_str(obj->obj_type), bcmos_strerror(obj->status));
1199 result = BCM_ERR_INTERNAL;
1200 }
1201 else
1202 {
VoLTHA753536e2017-11-02 20:15:09 +05301203 BalIndications *balIndCfg;
1204 balIndCfg = malloc(sizeof(BalIndications));
1205 memset(balIndCfg, 0, sizeof(BalIndications));
1206 bal_indications__init(balIndCfg);
1207 balIndCfg->u_case = BAL_INDICATIONS__U_TERMINAL_DGI;
1208 balIndCfg->has_objtype = BAL_GRPC_PRES;
1209 balIndCfg->objtype = obj->obj_type;
1210 balIndCfg->has_sub_group = BAL_GRPC_PRES;
1211 balIndCfg->sub_group = obj->subgroup;
1212 balIndCfg->device_id = voltha_device_id;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301213
Rajeswara Raob2e441c2017-09-20 16:40:21 +05301214 bcmbal_subscriber_terminal_dgi *sub_dgi_ind =
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301215 (bcmbal_subscriber_terminal_dgi *)obj;
1216
VoLTHA753536e2017-11-02 20:15:09 +05301217 BalSubscriberTerminalDgi *subDgiInd;
1218 subDgiInd = malloc(sizeof(BalSubscriberTerminalDgi));
1219 memset(subDgiInd, 0, sizeof(BalSubscriberTerminalDgi));
1220 bal_subscriber_terminal_dgi__init(subDgiInd);
1221 balIndCfg->terminal_dgi= subDgiInd;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301222
VoLTHA753536e2017-11-02 20:15:09 +05301223 BalObj *hdr;
1224 hdr = malloc(sizeof(BalObj));
1225 memset(hdr, 0, sizeof(BalObj));
1226 bal_obj__init(hdr);
1227 balIndCfg->terminal_dgi->hdr = hdr;
Rajeswara Raob2e441c2017-09-20 16:40:21 +05301228
VoLTHA753536e2017-11-02 20:15:09 +05301229 BalSubscriberTerminalKey *subkey;
1230 subkey = malloc(sizeof(BalSubscriberTerminalKey));
1231 memset(subkey, 0, sizeof(BalSubscriberTerminalKey));
1232 bal_subscriber_terminal_key__init(subkey);
1233 balIndCfg->terminal_dgi->key = subkey;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301234
VoLTHA753536e2017-11-02 20:15:09 +05301235 balIndCfg->terminal_dgi->key->has_intf_id = BAL_GRPC_PRES;
1236 balIndCfg->terminal_dgi->key->intf_id = sub_dgi_ind->key.intf_id;
1237 balIndCfg->terminal_dgi->key->has_sub_term_id = BAL_GRPC_PRES;
1238 balIndCfg->terminal_dgi->key->sub_term_id = sub_dgi_ind->key.sub_term_id;
Rajeswara Raob2e441c2017-09-20 16:40:21 +05301239
VoLTHA753536e2017-11-02 20:15:09 +05301240 BalSubscriberTerminalDgiData *subDgiIndData;
1241 subDgiIndData = malloc(sizeof(BalSubscriberTerminalDgiData));
1242 memset(subDgiIndData, 0, sizeof(BalSubscriberTerminalDgiData));
1243 bal_subscriber_terminal_dgi_data__init(subDgiIndData);
1244 balIndCfg->terminal_dgi->data = subDgiIndData;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301245
VoLTHA753536e2017-11-02 20:15:09 +05301246 balIndCfg->terminal_dgi->data->has_dgi_status = BAL_GRPC_PRES;
1247 balIndCfg->terminal_dgi->data->dgi_status = sub_dgi_ind->data.dgi_status;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301248
VoLTHA753536e2017-11-02 20:15:09 +05301249 list_node *bal_indication_node = malloc(sizeof(list_node));
1250 bal_indication_node->bal_indication = balIndCfg;
1251
1252 pthread_mutex_lock(&bal_ind_queue_lock);
1253 add_bal_indication_node(bal_indication_node);
1254 pthread_mutex_unlock(&bal_ind_queue_lock);
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301255 }
1256
1257 return result;
1258}
1259
1260/********************************************************************\
Rajeswara Raob2e441c2017-09-20 16:40:21 +05301261 * Function : bal_sub_term_indication_cb *
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301262 * Description : This function will handle the indications for *
1263 * Subscriber term indication *
1264 * *
1265 ********************************************************************/
1266bcmos_errno bal_sub_term_indication_cb(bcmbal_obj *obj)
1267{
1268 bcmos_errno result = BCM_ERR_OK;
1269
Rajeswara Raob2e441c2017-09-20 16:40:21 +05301270 if(BCMBAL_OBJ_ID_SUBSCRIBER_TERMINAL != obj->obj_type ||
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301271 bcmbal_subscriber_terminal_auto_id_ind != obj->subgroup)
1272 {
Kim Kempfafa1ab42017-11-13 09:31:47 -08001273 ASFVOLT_LOG(ASFVOLT_ERROR, "Processing BAL API '%s' IND callback (status is %s)",
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301274 bcmbal_objtype_str(obj->obj_type), bcmos_strerror(obj->status));
1275 result = BCM_ERR_INTERNAL;
1276 }
1277 else
1278 {
VoLTHA753536e2017-11-02 20:15:09 +05301279 BalIndications *balIndCfg;
1280 balIndCfg = malloc(sizeof(BalIndications));
1281 memset(balIndCfg, 0, sizeof(BalIndications));
1282 bal_indications__init(balIndCfg);
1283 balIndCfg->u_case = BAL_INDICATIONS__U_TERMINAL_IND;
1284 balIndCfg->has_objtype = BAL_GRPC_PRES;
1285 balIndCfg->objtype = obj->obj_type;
1286 balIndCfg->has_sub_group = BAL_GRPC_PRES;
1287 balIndCfg->sub_group = obj->subgroup;
1288 balIndCfg->device_id = voltha_device_id;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301289
1290 bcmbal_subscriber_terminal_ind *sub_ind = (bcmbal_subscriber_terminal_ind *)obj;
1291
VoLTHA753536e2017-11-02 20:15:09 +05301292 BalSubscriberTerminalInd *subInd;
1293 subInd = malloc(sizeof(BalSubscriberTerminalInd));
1294 memset(subInd, 0, sizeof(BalSubscriberTerminalInd));
1295 bal_subscriber_terminal_ind__init(subInd);
1296 balIndCfg->terminal_ind = subInd;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301297
VoLTHA753536e2017-11-02 20:15:09 +05301298 BalObj *hdr;
1299 hdr = malloc(sizeof(BalObj));
1300 memset(hdr, 0, sizeof(BalObj));
1301 bal_obj__init(hdr);
1302 balIndCfg->terminal_ind->hdr = hdr;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301303
VoLTHA753536e2017-11-02 20:15:09 +05301304 BalSubscriberTerminalKey *subkey;
1305 subkey = malloc(sizeof(BalSubscriberTerminalKey));
1306 memset(subkey, 0, sizeof(BalSubscriberTerminalKey));
1307 bal_subscriber_terminal_key__init(subkey);
1308 balIndCfg->terminal_ind->key = subkey;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301309
VoLTHA753536e2017-11-02 20:15:09 +05301310 balIndCfg->terminal_ind->key->has_intf_id = BAL_GRPC_PRES;
1311 balIndCfg->terminal_ind->key->intf_id = sub_ind->key.intf_id;
1312 balIndCfg->terminal_ind->key->has_sub_term_id = BAL_GRPC_PRES;
1313 balIndCfg->terminal_ind->key->sub_term_id = sub_ind->key.sub_term_id;
Rajeswara Raob2e441c2017-09-20 16:40:21 +05301314
VoLTHA753536e2017-11-02 20:15:09 +05301315 BalSubscriberTerminalIndData *subIndData;
1316 subIndData = malloc(sizeof(BalSubscriberTerminalIndData));
1317 memset(subIndData, 0, sizeof(BalSubscriberTerminalIndData));
1318 bal_subscriber_terminal_ind_data__init(subIndData);
1319 balIndCfg->terminal_ind->data = subIndData;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301320
VoLTHA753536e2017-11-02 20:15:09 +05301321 balIndCfg->terminal_ind->data->has_admin_state = BAL_GRPC_PRES;
1322 balIndCfg->terminal_ind->data->admin_state = sub_ind->data.admin_state;
1323 balIndCfg->terminal_ind->data->has_oper_status = BAL_GRPC_PRES;
1324 balIndCfg->terminal_ind->data->oper_status = sub_ind->data.oper_status;
1325 balIndCfg->terminal_ind->data->has_svc_port_id = BAL_GRPC_PRES;
1326 balIndCfg->terminal_ind->data->svc_port_id = sub_ind->data.svc_port_id;
1327 balIndCfg->terminal_ind->data->has_ds_tm = BAL_GRPC_PRES;
1328 balIndCfg->terminal_ind->data->ds_tm = sub_ind->data.ds_tm;
1329 balIndCfg->terminal_ind->data->has_us_tm = BAL_GRPC_PRES;
1330 balIndCfg->terminal_ind->data->us_tm = sub_ind->data.us_tm;
1331 balIndCfg->terminal_ind->data->has_sub_term_rate = BAL_GRPC_PRES;
1332 balIndCfg->terminal_ind->data->sub_term_rate = sub_ind->data.sub_term_rate;
1333 char *password = malloc(sizeof(char)*MAX_CHAR_LENGTH*2);
1334 memset(password, 0, MAX_CHAR_LENGTH*2);
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301335 strcpy(password,(const char *)sub_ind->data.password.arr);
VoLTHA753536e2017-11-02 20:15:09 +05301336 balIndCfg->terminal_ind->data->password = password;
1337 char *registration_id = malloc(sizeof(char)*MAX_CHAR_LENGTH*8);
1338 memset(registration_id, 0, MAX_CHAR_LENGTH*8);
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301339 strcpy(registration_id,(const char *)sub_ind->data.registration_id.arr);
VoLTHA753536e2017-11-02 20:15:09 +05301340 balIndCfg->terminal_ind->data->registration_id = registration_id;
Rajeswara Raob2e441c2017-09-20 16:40:21 +05301341
1342#if 0
VoLTHA753536e2017-11-02 20:15:09 +05301343 balIndCfg->terminal_ind->data->has_mac_address = BAL_GRPC_PRES;
1344 balIndCfg->terminal_ind->data->mac_address.len =
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301345 (BCMOS_ETH_ALEN)*sizeof(sub_ind->data.mac_address.u8);
VoLTHA753536e2017-11-02 20:15:09 +05301346 uint8_t mac_address[balIndCfg->terminal_ind->data->mac_address.len];
1347 memset(&mac_address, 0 ,balIndCfg->terminal_ind->data->mac_address.len);
Rajeswara Raob2e441c2017-09-20 16:40:21 +05301348 strcpy((char *)mac_address,(const char *)sub_ind->data.mac_address.u8);
VoLTHA753536e2017-11-02 20:15:09 +05301349 balIndCfg->terminal_ind->data->mac_address.data = mac_address;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301350#endif
1351
VoLTHA753536e2017-11-02 20:15:09 +05301352 BalSerialNumber *serialNum;
1353 serialNum = malloc(sizeof(BalSerialNumber));
1354 memset(serialNum, 0, sizeof(BalSerialNumber));
1355 bal_serial_number__init(serialNum);
1356 balIndCfg->terminal_ind->data->serial_number = serialNum;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301357
Kim Kempfafa1ab42017-11-13 09:31:47 -08001358 //ASFVOLT_LOG(ASFVOLT_ERROR, "ONU Activation:Before decoding:Vendor id is %s", sub_ind->data.serial_number.vendor_id);
1359 //ASFVOLT_LOG(ASFVOLT_ERROR, "ONU Activation:Before decoding:Vendor specific is %s", sub_ind->data.serial_number.vendor_specific);
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301360
VoLTHA753536e2017-11-02 20:15:09 +05301361 char *vendor_id = malloc(sizeof(char)*MAX_CHAR_LENGTH);
1362 memset(vendor_id, 0, MAX_CHAR_LENGTH);
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301363 sprintf(vendor_id,"%c%c%c%c",
1364 sub_ind->data.serial_number.vendor_id[0],
1365 sub_ind->data.serial_number.vendor_id[1],
1366 sub_ind->data.serial_number.vendor_id[2],
1367 sub_ind->data.serial_number.vendor_id[3]);
VoLTHA753536e2017-11-02 20:15:09 +05301368 balIndCfg->terminal_ind->data->serial_number->vendor_id = vendor_id;
Suhas Gururaj07da86a2018-05-11 14:37:03 +05301369 ASFVOLT_LOG(ASFVOLT_DEBUG, "ONU Activation:After decoding:Vendor id is %s",
1370 balIndCfg->terminal_ind->data->serial_number->vendor_id);
VoLTHA753536e2017-11-02 20:15:09 +05301371 char *vendor_specific = malloc(sizeof(char)*MAX_CHAR_LENGTH);
1372 memset(vendor_specific, 0, MAX_CHAR_LENGTH);
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301373 sprintf(vendor_specific,"%1X%1X%1X%1X%1X%1X%1X%1X",
1374 sub_ind->data.serial_number.vendor_specific[0]>>4 & 0x0f,
1375 sub_ind->data.serial_number.vendor_specific[0] & 0x0f,
1376 sub_ind->data.serial_number.vendor_specific[1]>>4 & 0x0f,
1377 sub_ind->data.serial_number.vendor_specific[1] & 0x0f,
1378 sub_ind->data.serial_number.vendor_specific[2]>>4 & 0x0f,
1379 sub_ind->data.serial_number.vendor_specific[2] & 0x0f,
1380 sub_ind->data.serial_number.vendor_specific[3]>>4 & 0x0f,
1381 sub_ind->data.serial_number.vendor_specific[3] & 0x0f);
VoLTHA753536e2017-11-02 20:15:09 +05301382 balIndCfg->terminal_ind->data->serial_number->vendor_specific = vendor_specific;
Suhas Gururaj07da86a2018-05-11 14:37:03 +05301383 ASFVOLT_LOG(ASFVOLT_DEBUG, "ONU Activation:After decoding:Vendor specific is %s",
1384 balIndCfg->terminal_ind->data->serial_number->vendor_specific);
1385 ASFVOLT_LOG(ASFVOLT_DEBUG, "ONU Activation:After decoding:Registration ID is %s",
1386 balIndCfg->terminal_ind->data->registration_id);
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301387
VoLTHA753536e2017-11-02 20:15:09 +05301388 BalIdList *balAggportList;
1389 balAggportList = malloc(sizeof(BalIdList));
1390 memset(balAggportList, 0, sizeof(BalIdList));
1391 bal_id_list__init(balAggportList);
1392 balIndCfg->terminal_ind->data->agg_port_id_list = balAggportList;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301393
1394#if 0
VoLTHA753536e2017-11-02 20:15:09 +05301395 balIndCfg->terminal_ind->data->agg_port_id_list->n_val = sub_ind->data.agg_port_id_list.len;
1396 uint32_t agg_port_id_list[balIndCfg->terminal_ind->data->agg_port_id_list->n_val];
1397 memset(&agg_port_id_list, 0, balIndCfg->terminal_ind->data->agg_port_id_list->n_val);
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301398 strcpy((char *)agg_port_id_list,(const char *)sub_ind->data.agg_port_id_list.val);
VoLTHA753536e2017-11-02 20:15:09 +05301399 balIndCfg->terminal_ind->data->agg_port_id_list->val = agg_port_id_list;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301400#endif
1401
VoLTHA753536e2017-11-02 20:15:09 +05301402 list_node *bal_indication_node = malloc(sizeof(list_node));
1403 bal_indication_node->bal_indication = balIndCfg;
1404
1405 pthread_mutex_lock(&bal_ind_queue_lock);
1406 add_bal_indication_node(bal_indication_node);
1407 pthread_mutex_unlock(&bal_ind_queue_lock);
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301408 }
1409
1410 return result;
1411}
1412
1413/********************************************************************\
Rajeswara Raob2e441c2017-09-20 16:40:21 +05301414 * Function : fill_bal_tm_red *
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301415 * Description : This function will fill grpc-BalTmred struture *
1416 * from bal-bcmbal_tm_red structure *
1417 * *
1418 ********************************************************************/
1419void fill_bal_tm_red(BalTmred *grpc_red, bcmbal_tm_red *bal_red)
1420{
Rajeswara Raob2e441c2017-09-20 16:40:21 +05301421 grpc_red->has_min_threshold = BAL_GRPC_PRES;
1422 grpc_red->min_threshold = bal_red->min_threshold;
1423 grpc_red->has_max_threshold = BAL_GRPC_PRES;
1424 grpc_red->max_threshold = bal_red->max_threshold;
1425 grpc_red->has_max_probability = BAL_GRPC_PRES;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301426 grpc_red->max_probability = bal_red->max_probability;
Rajeswara Raob2e441c2017-09-20 16:40:21 +05301427 return;
1428}
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301429
1430/********************************************************************\
Rajeswara Raob2e441c2017-09-20 16:40:21 +05301431 * Function : bal_tm_queue_indication_cb *
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301432 * Description : This function will handle the indications for *
1433 * TM Queue indication *
1434 * *
1435 ********************************************************************/
1436bcmos_errno bal_tm_queue_indication_cb(bcmbal_obj *obj)
1437{
1438 bcmos_errno result = BCM_ERR_OK;
1439
Rajeswara Raob2e441c2017-09-20 16:40:21 +05301440 if(BCMBAL_OBJ_ID_TM_QUEUE != obj->obj_type ||
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301441 bcmbal_tm_queue_auto_id_ind != obj->subgroup)
1442 {
Kim Kempfafa1ab42017-11-13 09:31:47 -08001443 ASFVOLT_LOG(ASFVOLT_ERROR, "Processing BAL API '%s' IND callback (status is %s)",
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301444 bcmbal_objtype_str(obj->obj_type), bcmos_strerror(obj->status));
1445 result = BCM_ERR_INTERNAL;
1446 }
1447 else
1448 {
VoLTHA753536e2017-11-02 20:15:09 +05301449 BalIndications *balIndCfg;
1450 balIndCfg = malloc(sizeof(BalIndications));
1451 memset(balIndCfg, 0, sizeof(BalIndications));
1452 bal_indications__init(balIndCfg);
1453 balIndCfg->u_case = BAL_INDICATIONS__U_TM_QUEUE__IND;
1454 balIndCfg->has_objtype = BAL_GRPC_PRES;
1455 balIndCfg->objtype = obj->obj_type;
1456 balIndCfg->has_sub_group = BAL_GRPC_PRES;
1457 balIndCfg->sub_group = obj->subgroup;
1458 balIndCfg->device_id = voltha_device_id;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301459
1460 bcmbal_tm_queue_ind *tm_que_ind = (bcmbal_tm_queue_ind *)obj;
1461
VoLTHA753536e2017-11-02 20:15:09 +05301462 BalTmQueueInd *tmQueInd;
1463 tmQueInd = malloc(sizeof(BalTmQueueInd));
1464 memset(tmQueInd, 0, sizeof(BalTmQueueInd));
1465 bal_tm_queue_ind__init(tmQueInd);
1466 balIndCfg->tm_queue_ind = tmQueInd;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301467
VoLTHA753536e2017-11-02 20:15:09 +05301468 BalTmQueueKey *tmQkey;
1469 tmQkey = malloc(sizeof(BalTmQueueKey));
1470 memset(tmQkey, 0, sizeof(BalTmQueueKey));
1471 bal_tm_queue_key__init(tmQkey);
1472 balIndCfg->tm_queue_ind->key = tmQkey;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301473
VoLTHA753536e2017-11-02 20:15:09 +05301474 balIndCfg->tm_queue_ind->key->has_sched_id = BAL_GRPC_PRES;
1475 balIndCfg->tm_queue_ind->key->sched_id = tm_que_ind->key.sched_id;
1476 balIndCfg->tm_queue_ind->key->has_sched_dir = BAL_GRPC_PRES;
1477 balIndCfg->tm_queue_ind->key->sched_dir = tm_que_ind->key.sched_dir;
1478 balIndCfg->tm_queue_ind->key->has_id = BAL_GRPC_PRES;
1479 balIndCfg->tm_queue_ind->key->id = tm_que_ind->key.id;
Rajeswara Raob2e441c2017-09-20 16:40:21 +05301480
VoLTHA753536e2017-11-02 20:15:09 +05301481 BalTmQueueIndData *tmQIndData;
1482 tmQIndData = malloc(sizeof(BalTmQueueIndData));
1483 memset(tmQIndData, 0, sizeof(BalTmQueueIndData));
1484 bal_tm_queue_ind_data__init(tmQIndData);
1485 balIndCfg->tm_queue_ind->data = tmQIndData;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301486
VoLTHA753536e2017-11-02 20:15:09 +05301487 balIndCfg->tm_queue_ind->data->has_priority = BAL_GRPC_PRES;
1488 balIndCfg->tm_queue_ind->data->priority = tm_que_ind->data.priority;
1489 balIndCfg->tm_queue_ind->data->has_weight = BAL_GRPC_PRES;
1490 balIndCfg->tm_queue_ind->data->weight = tm_que_ind->data.weight;
1491 balIndCfg->tm_queue_ind->data->has_create_mode = BAL_GRPC_PRES;
1492 balIndCfg->tm_queue_ind->data->create_mode = tm_que_ind->data.create_mode;
1493 balIndCfg->tm_queue_ind->data->has_ref_count = BAL_GRPC_PRES;
1494 balIndCfg->tm_queue_ind->data->ref_count = tm_que_ind->data.ref_count;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301495
VoLTHA753536e2017-11-02 20:15:09 +05301496 BalTmShaping *balShape;
1497 balShape = malloc(sizeof(BalTmShaping));
1498 memset(balShape, 0, sizeof(BalTmShaping));
1499 bal_tm_shaping__init(balShape);
1500 balIndCfg->tm_queue_ind->data->rate = balShape;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301501
VoLTHA753536e2017-11-02 20:15:09 +05301502 balIndCfg->tm_queue_ind->data->rate->has_presence_mask = BAL_GRPC_PRES;
1503 balIndCfg->tm_queue_ind->data->rate->presence_mask = tm_que_ind->data.rate.presence_mask;
1504 balIndCfg->tm_queue_ind->data->rate->has_cir = BAL_GRPC_PRES;
1505 balIndCfg->tm_queue_ind->data->rate->cir = tm_que_ind->data.rate.cir;
1506 balIndCfg->tm_queue_ind->data->rate->has_pir = BAL_GRPC_PRES;
1507 balIndCfg->tm_queue_ind->data->rate->pir = tm_que_ind->data.rate.pir;
1508 balIndCfg->tm_queue_ind->data->rate->has_burst = BAL_GRPC_PRES;
1509 balIndCfg->tm_queue_ind->data->rate->burst = tm_que_ind->data.rate.burst;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301510
VoLTHA753536e2017-11-02 20:15:09 +05301511 BalTmBac *balBac;
1512 balBac = malloc(sizeof(BalTmBac));
1513 memset(balBac, 0, sizeof(BalTmBac));
1514 bal_tm_bac__init(balBac);
1515 balIndCfg->tm_queue_ind->data->bac = balBac;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301516
VoLTHA753536e2017-11-02 20:15:09 +05301517 balIndCfg->tm_queue_ind->data->bac->has_type = BAL_GRPC_PRES;
1518 balIndCfg->tm_queue_ind->data->bac->type = tm_que_ind->data.bac.type;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301519 switch(tm_que_ind->data.bac.type)
1520 {
1521 case BCMBAL_TM_BAC_TYPE_TAILDROP:
1522 {
VoLTHA753536e2017-11-02 20:15:09 +05301523 balIndCfg->tm_queue_ind->data->bac->u_case = BAL_TM_BAC__U_TAILDROP;
1524 BalTMBacTaildrop *balTaildrop;
1525 balTaildrop = malloc(sizeof(BalTMBacTaildrop));
1526 memset(balTaildrop, 0, sizeof(BalTMBacTaildrop));
1527 bal_tmbac_taildrop__init(balTaildrop);
1528 balIndCfg->tm_queue_ind->data->bac->taildrop = balTaildrop;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301529
VoLTHA753536e2017-11-02 20:15:09 +05301530 balIndCfg->tm_queue_ind->data->bac->taildrop->has_max_size = BAL_GRPC_PRES;
1531 balIndCfg->tm_queue_ind->data->bac->taildrop->max_size =
Rajeswara Raob2e441c2017-09-20 16:40:21 +05301532 tm_que_ind->data.bac.u.taildrop.max_size;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301533 }
1534 break;
1535 case BCMBAL_TM_BAC_TYPE_WTAILDROP:
1536 {
1537 /* No bal/grpc structure was defined */
1538 }
1539 break;
1540 case BCMBAL_TM_BAC_TYPE_RED:
1541 {
VoLTHA753536e2017-11-02 20:15:09 +05301542 balIndCfg->tm_queue_ind->data->bac->u_case = BAL_TM_BAC__U_RED;
1543 BalTMBacRed *balBacRed;
1544 balBacRed = malloc(sizeof(BalTMBacRed));
1545 memset(balBacRed, 0, sizeof(BalTMBacRed));
1546 bal_tmbac_red__init(balBacRed);
1547 balIndCfg->tm_queue_ind->data->bac->red = balBacRed;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301548
VoLTHA753536e2017-11-02 20:15:09 +05301549 BalTmred *balRed;
1550 balRed = malloc(sizeof(BalTmred));
1551 memset(balRed, 0, sizeof(BalTmred));
1552 bal_tmred__init(balRed);
1553 balIndCfg->tm_queue_ind->data->bac->red->red = balRed;
1554 fill_bal_tm_red(balIndCfg->tm_queue_ind->data->bac->red->red, &tm_que_ind->data.bac.u.red.red);
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301555 }
1556 break;
1557 case BCMBAL_TM_BAC_TYPE_WRED:
1558 {
VoLTHA753536e2017-11-02 20:15:09 +05301559 balIndCfg->tm_queue_ind->data->bac->u_case = BAL_TM_BAC__U_WRED;
1560 BalTMBacWred *balBacWred;
1561 balBacWred = malloc(sizeof(BalTMBacWred));
1562 memset(balBacWred, 0, sizeof(BalTMBacWred));
1563 bal_tmbac_wred__init(balBacWred);
1564 balIndCfg->tm_queue_ind->data->bac->wred = balBacWred;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301565
VoLTHA753536e2017-11-02 20:15:09 +05301566 BalTmred *balGreen;
1567 balGreen = malloc(sizeof(BalTmred));
1568 memset(balGreen, 0, sizeof(BalTmred));
1569 bal_tmred__init(balGreen);
1570 balIndCfg->tm_queue_ind->data->bac->wred->green = balGreen;
1571 fill_bal_tm_red(balIndCfg->tm_queue_ind->data->bac->wred->green, &tm_que_ind->data.bac.u.wred.green);
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301572
VoLTHA753536e2017-11-02 20:15:09 +05301573 BalTmred *balYellow;
1574 balYellow = malloc(sizeof(BalTmred));
1575 memset(balYellow, 0, sizeof(BalTmred));
1576 bal_tmred__init(balYellow);
1577 balIndCfg->tm_queue_ind->data->bac->wred->yellow = balYellow;
1578 fill_bal_tm_red(balIndCfg->tm_queue_ind->data->bac->wred->yellow, &tm_que_ind->data.bac.u.wred.yellow);
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301579
VoLTHA753536e2017-11-02 20:15:09 +05301580 BalTmred *balRed;
1581 balRed = malloc(sizeof(BalTmred));
1582 memset(balRed, 0, sizeof(BalTmred));
1583 bal_tmred__init(balRed);
1584 balIndCfg->tm_queue_ind->data->bac->wred->red = balRed;
1585 fill_bal_tm_red(balIndCfg->tm_queue_ind->data->bac->wred->red, &tm_que_ind->data.bac.u.wred.red);
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301586 }
1587 break;
1588 default:
1589 {
VoLTHA753536e2017-11-02 20:15:09 +05301590 balIndCfg->tm_queue_ind->data->bac->u_case = BAL_TM_BAC__U__NOT_SET;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301591 }
1592 break;
Rajeswara Raob2e441c2017-09-20 16:40:21 +05301593
1594 }
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301595
VoLTHA753536e2017-11-02 20:15:09 +05301596 list_node *bal_indication_node = malloc(sizeof(list_node));
1597 bal_indication_node->bal_indication = balIndCfg;
1598
1599 pthread_mutex_lock(&bal_ind_queue_lock);
1600 add_bal_indication_node(bal_indication_node);
1601 pthread_mutex_unlock(&bal_ind_queue_lock);
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301602 }
1603
1604 return result;
1605}
1606
1607/********************************************************************\
Rajeswara Raob2e441c2017-09-20 16:40:21 +05301608 * Function : bal_tm_sched_indication_cb *
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301609 * Description : This function will handle the indications for *
1610 * TM Sched indication *
1611 * *
1612 ********************************************************************/
1613bcmos_errno bal_tm_sched_indication_cb(bcmbal_obj *obj)
1614{
1615 bcmos_errno result = BCM_ERR_OK;
1616
Rajeswara Raob2e441c2017-09-20 16:40:21 +05301617 if(BCMBAL_OBJ_ID_TM_SCHED != obj->obj_type ||
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301618 bcmbal_tm_sched_auto_id_ind != obj->subgroup)
1619 {
Kim Kempfafa1ab42017-11-13 09:31:47 -08001620 ASFVOLT_LOG(ASFVOLT_ERROR, "Processing BAL API '%s' IND callback (status is %s)",
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301621 bcmbal_objtype_str(obj->obj_type), bcmos_strerror(obj->status));
1622 result = BCM_ERR_INTERNAL;
1623 }
1624 else
1625 {
VoLTHA753536e2017-11-02 20:15:09 +05301626 BalIndications *balIndCfg;
1627 balIndCfg = malloc(sizeof(BalIndications));
1628 memset(balIndCfg, 0, sizeof(BalIndications));
1629 bal_indications__init(balIndCfg);
1630 balIndCfg->u_case = BAL_INDICATIONS__U_TM_SCHED__IND;
1631 balIndCfg->has_objtype = BAL_GRPC_PRES;
1632 balIndCfg->objtype = obj->obj_type;
1633 balIndCfg->has_sub_group = BAL_GRPC_PRES;
1634 balIndCfg->sub_group = obj->subgroup;
1635 balIndCfg->device_id = voltha_device_id;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301636
1637 bcmbal_tm_sched_ind *tm_sched_ind = (bcmbal_tm_sched_ind *)obj;
1638
VoLTHA753536e2017-11-02 20:15:09 +05301639 BalTmSchedInd *tmSchedInd;
1640 tmSchedInd = malloc(sizeof(BalTmSchedInd));
1641 memset(tmSchedInd, 0, sizeof(BalTmSchedInd));
1642 bal_tm_sched_ind__init(tmSchedInd);
1643 balIndCfg->tm_sched_ind = tmSchedInd;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301644
VoLTHA753536e2017-11-02 20:15:09 +05301645 BalTmSchedKey *tmSchedkey;
1646 tmSchedkey = malloc(sizeof(BalTmSchedKey));
1647 memset(tmSchedkey, 0, sizeof(BalTmSchedKey));
1648 bal_tm_sched_key__init(tmSchedkey);
1649 balIndCfg->tm_sched_ind->key = tmSchedkey;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301650
VoLTHA753536e2017-11-02 20:15:09 +05301651 balIndCfg->tm_sched_ind->key->has_dir = BAL_GRPC_PRES;
1652 balIndCfg->tm_sched_ind->key->dir = tm_sched_ind->key.dir;
1653 balIndCfg->tm_sched_ind->key->has_id = BAL_GRPC_PRES;
1654 balIndCfg->tm_sched_ind->key->id = tm_sched_ind->key.id;
Rajeswara Raob2e441c2017-09-20 16:40:21 +05301655
VoLTHA753536e2017-11-02 20:15:09 +05301656 BalTmSchedIndData *tmSIndData;
1657 tmSIndData = malloc(sizeof(BalTmSchedIndData));
1658 memset(tmSIndData, 0, sizeof(BalTmSchedIndData));
1659 bal_tm_sched_ind_data__init(tmSIndData);
1660 balIndCfg->tm_sched_ind->data = tmSIndData;
Rajeswara Raob2e441c2017-09-20 16:40:21 +05301661 /* TODO: data should be populate */
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301662
VoLTHA753536e2017-11-02 20:15:09 +05301663 list_node *bal_indication_node = malloc(sizeof(list_node));
1664 bal_indication_node->bal_indication = balIndCfg;
1665
1666 pthread_mutex_lock(&bal_ind_queue_lock);
1667 add_bal_indication_node(bal_indication_node);
1668 pthread_mutex_unlock(&bal_ind_queue_lock);
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301669 }
1670
1671 return result;
1672}
1673
1674/********************************************************************\
Rajeswara Raob2e441c2017-09-20 16:40:21 +05301675 * Function : bal_packet_data_indication_cb *
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301676 * Description : This function will handle the indications for *
1677 * Packet Data indication *
1678 * *
1679 ********************************************************************/
1680bcmos_errno bal_packet_data_indication_cb(bcmbal_obj *obj)
1681{
1682 bcmos_errno result = BCM_ERR_OK;
1683
Rajeswara Raob2e441c2017-09-20 16:40:21 +05301684 if(BCMBAL_OBJ_ID_PACKET != obj->obj_type ||
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301685 bcmbal_packet_auto_id_bearer_channel_rx != obj->subgroup)
1686 {
Kim Kempfafa1ab42017-11-13 09:31:47 -08001687 ASFVOLT_LOG(ASFVOLT_ERROR, "Processing BAL API '%s' IND callback (status is %s)",
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301688 bcmbal_objtype_str(obj->obj_type), bcmos_strerror(obj->status));
1689 result = BCM_ERR_INTERNAL;
1690 }
1691 else
1692 {
1693 /*bcmos_mutex_lock(&bal_ind_lock);-- Need to define bcm independent mutex*/
1694
VoLTHA753536e2017-11-02 20:15:09 +05301695 BalIndications *balIndCfg;
1696 balIndCfg = malloc(sizeof(BalIndications));
1697 memset(balIndCfg, 0, sizeof(BalIndications));
1698 bal_indications__init(balIndCfg);
1699 balIndCfg->u_case = BAL_INDICATIONS__U_PKT_DATA;
1700 balIndCfg->has_objtype = BAL_GRPC_PRES;
1701 balIndCfg->objtype = obj->obj_type;
1702 balIndCfg->has_sub_group = BAL_GRPC_PRES;
1703 balIndCfg->sub_group = obj->subgroup;
1704 balIndCfg->device_id = voltha_device_id;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301705
VoLTHA753536e2017-11-02 20:15:09 +05301706 BalPacketBearerChannelRx *rxChannel;
1707 rxChannel = malloc(sizeof(BalPacketBearerChannelRx));
1708 memset(rxChannel, 0, sizeof(BalPacketBearerChannelRx));
1709 bal_packet_bearer_channel_rx__init(rxChannel);
1710 balIndCfg->pktdata = rxChannel;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301711
VoLTHA753536e2017-11-02 20:15:09 +05301712 BalObj *hdr;
1713 hdr = malloc(sizeof(BalObj));
1714 memset(hdr, 0, sizeof(BalObj));
1715 bal_obj__init(hdr);
1716 balIndCfg->pktdata->hdr = hdr;
Rajeswara Raob2e441c2017-09-20 16:40:21 +05301717
VoLTHA753536e2017-11-02 20:15:09 +05301718 BalPacketKey *packetkey;
1719 packetkey = malloc(sizeof(BalPacketKey));
1720 memset(packetkey, 0, sizeof(BalPacketKey));
1721 bal_packet_key__init(packetkey);
1722 balIndCfg->pktdata->key = packetkey;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301723
Rajeswara Raob2e441c2017-09-20 16:40:21 +05301724 bcmbal_packet_bearer_channel_rx *rx_channel =
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301725 (bcmbal_packet_bearer_channel_rx *)obj;
1726
VoLTHA753536e2017-11-02 20:15:09 +05301727 balIndCfg->pktdata->key->has_reserved = BAL_GRPC_PRES;
1728 balIndCfg->pktdata->key->reserved = rx_channel->key.reserved;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301729
VoLTHA753536e2017-11-02 20:15:09 +05301730 BalDest *PktSndDest;
1731 PktSndDest = malloc(sizeof(BalDest));
1732 memset(PktSndDest, 0, sizeof(BalDest));
1733 bal_dest__init(PktSndDest);
1734 balIndCfg->pktdata->key->packet_send_dest = PktSndDest;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301735
VoLTHA753536e2017-11-02 20:15:09 +05301736 balIndCfg->pktdata->key->packet_send_dest->has_type = BAL_GRPC_PRES;
1737 balIndCfg->pktdata->key->packet_send_dest->type =
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301738 rx_channel->key.packet_send_dest.type;
1739 switch( rx_channel->key.packet_send_dest.type)
1740 {
1741 case BCMBAL_DEST_TYPE_NNI:
1742 {
VoLTHA753536e2017-11-02 20:15:09 +05301743 balIndCfg->pktdata->key->packet_send_dest->u_case = BAL_DEST__U_NNI;
1744 BalDestNni *balNni;
1745 balNni = malloc(sizeof(BalDestNni));
1746 memset(balNni, 0, sizeof(BalDestNni));
1747 bal_dest_nni__init(balNni);
1748 balIndCfg->pktdata->key->packet_send_dest->nni = balNni;
1749 balIndCfg->pktdata->key->packet_send_dest->nni->has_intf_id = BAL_GRPC_PRES;
1750 balIndCfg->pktdata->key->packet_send_dest->nni->intf_id =
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301751 rx_channel->key.packet_send_dest.u.nni.intf_id;
1752 }
1753 break;
1754 case BCMBAL_DEST_TYPE_SUB_TERM:
1755 {
VoLTHA753536e2017-11-02 20:15:09 +05301756 balIndCfg->pktdata->key->packet_send_dest->u_case = BAL_DEST__U_SUB_TERM;
1757 BalDestSubTerm *balSubTerm;
1758 balSubTerm = malloc(sizeof(BalDestSubTerm));
1759 memset(balSubTerm, 0, sizeof(BalDestSubTerm));
1760 bal_dest_sub_term__init(balSubTerm);
1761 balIndCfg->pktdata->key->packet_send_dest->sub_term = balSubTerm;
1762 balIndCfg->pktdata->key->packet_send_dest->sub_term->has_sub_term_id =
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301763 BAL_GRPC_PRES;
VoLTHA753536e2017-11-02 20:15:09 +05301764 balIndCfg->pktdata->key->packet_send_dest->sub_term->sub_term_id =
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301765 rx_channel->key.packet_send_dest.u.sub_term.sub_term_id;
VoLTHA753536e2017-11-02 20:15:09 +05301766 balIndCfg->pktdata->key->packet_send_dest->sub_term->has_sub_term_uni =
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301767 BAL_GRPC_PRES;
VoLTHA753536e2017-11-02 20:15:09 +05301768 balIndCfg->pktdata->key->packet_send_dest->sub_term->sub_term_uni =
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301769 rx_channel->key.packet_send_dest.u.sub_term.sub_term_uni;
VoLTHA753536e2017-11-02 20:15:09 +05301770 balIndCfg->pktdata->key->packet_send_dest->sub_term->has_intf_id =
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301771 BAL_GRPC_PRES;
VoLTHA753536e2017-11-02 20:15:09 +05301772 balIndCfg->pktdata->key->packet_send_dest->sub_term->intf_id =
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301773 rx_channel->key.packet_send_dest.u.sub_term.intf_id;
1774 }
1775 break;
1776 case BCMBAL_DEST_TYPE_SVC_PORT:
1777 {
VoLTHA753536e2017-11-02 20:15:09 +05301778 balIndCfg->pktdata->key->packet_send_dest->u_case = BAL_DEST__U_SVC_PORT;
1779 BalDestSvcPort *balSvcPort;
1780 balSvcPort = malloc(sizeof(BalDestSvcPort));
1781 memset(balSvcPort, 0, sizeof(BalDestSvcPort));
1782 bal_dest_svc_port__init(balSvcPort);
1783 balIndCfg->pktdata->key->packet_send_dest->svc_port = balSvcPort;
1784 balIndCfg->pktdata->key->packet_send_dest->svc_port->has_svc_port_id =
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301785 BAL_GRPC_PRES;
VoLTHA753536e2017-11-02 20:15:09 +05301786 balIndCfg->pktdata->key->packet_send_dest->svc_port->svc_port_id =
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301787 rx_channel->key.packet_send_dest.u.svc_port.svc_port_id;
VoLTHA753536e2017-11-02 20:15:09 +05301788 balIndCfg->pktdata->key->packet_send_dest->svc_port->has_intf_id =
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301789 BAL_GRPC_PRES;
VoLTHA753536e2017-11-02 20:15:09 +05301790 balIndCfg->pktdata->key->packet_send_dest->svc_port->has_intf_id =
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301791 rx_channel->key.packet_send_dest.u.svc_port.intf_id;
1792 }
1793 break;
1794 default:
1795 {
VoLTHA753536e2017-11-02 20:15:09 +05301796 balIndCfg->pktdata->key->packet_send_dest->u_case = BAL_DEST__U__NOT_SET;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301797 }
1798 break;
1799 }
1800
VoLTHA753536e2017-11-02 20:15:09 +05301801 BalPacketBearerChannelRxData *pkdData;
1802 pkdData = malloc(sizeof(BalPacketBearerChannelRxData));
1803 memset(pkdData, 0, sizeof(BalPacketBearerChannelRxData));
1804 bal_packet_bearer_channel_rx_data__init(pkdData);
1805 balIndCfg->pktdata->data = pkdData;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301806
VoLTHA753536e2017-11-02 20:15:09 +05301807 balIndCfg->pktdata->data->has_flow_id = BAL_GRPC_PRES;
1808 balIndCfg->pktdata->data->flow_id = rx_channel->data.flow_id;
1809 balIndCfg->pktdata->data->has_flow_type = BAL_GRPC_PRES;
1810 balIndCfg->pktdata->data->flow_type = rx_channel->data.flow_type;
1811 balIndCfg->pktdata->data->has_intf_id = BAL_GRPC_PRES;
1812 balIndCfg->pktdata->data->intf_id = rx_channel->data.intf_id;
1813 balIndCfg->pktdata->data->has_intf_type = BAL_GRPC_PRES;
1814 balIndCfg->pktdata->data->intf_type = rx_channel->data.intf_type;
1815 balIndCfg->pktdata->data->has_svc_port = BAL_GRPC_PRES;
1816 balIndCfg->pktdata->data->svc_port = rx_channel->data.svc_port;
1817 balIndCfg->pktdata->data->has_flow_cookie = BAL_GRPC_PRES;
1818 balIndCfg->pktdata->data->flow_cookie = rx_channel->data.flow_cookie;
1819 balIndCfg->pktdata->data->has_pkt = BAL_GRPC_PRES;
1820 balIndCfg->pktdata->data->pkt.len = rx_channel->data.pkt.len;
1821 balIndCfg->pktdata->data->pkt.data = (uint8_t *)malloc((balIndCfg->pktdata->data->pkt.len)*sizeof(uint8_t));
1822 memcpy(balIndCfg->pktdata->data->pkt.data, rx_channel->data.pkt.val, balIndCfg->pktdata->data->pkt.len);
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301823
1824 /*bcmos_mutex_unlock(&bal_ind_lock);-- Need to define bcm independent mutex*/
1825
VoLTHA753536e2017-11-02 20:15:09 +05301826 list_node *bal_indication_node = malloc(sizeof(list_node));
1827 bal_indication_node->bal_indication = balIndCfg;
1828
1829 pthread_mutex_lock(&bal_ind_queue_lock);
1830 add_bal_indication_node(bal_indication_node);
1831 pthread_mutex_unlock(&bal_ind_queue_lock);
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301832 }
1833
1834 return result;
1835}
1836
1837/********************************************************************\
Rajeswara Raob2e441c2017-09-20 16:40:21 +05301838 * Function : bal_omci_data_indication_cb *
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301839 * Description : This function will handle the indications for *
1840 * OMCI Data Response *
1841 * *
1842 ********************************************************************/
1843bcmos_errno bal_omci_data_indication_cb(bcmbal_obj *obj)
1844{
1845 bcmos_errno result = BCM_ERR_OK;
1846
Rajeswara Raob2e441c2017-09-20 16:40:21 +05301847 if(BCMBAL_OBJ_ID_PACKET != obj->obj_type ||
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301848 bcmbal_packet_auto_id_itu_omci_channel_rx != obj->subgroup)
1849 {
Kim Kempfafa1ab42017-11-13 09:31:47 -08001850 ASFVOLT_LOG(ASFVOLT_ERROR, "Processing BAL API '%s' IND callback (status is %s)",
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301851 bcmbal_objtype_str(obj->obj_type), bcmos_strerror(obj->status));
1852 result = BCM_ERR_INTERNAL;
1853 }
1854 else
1855 {
Kim Kempfafa1ab42017-11-13 09:31:47 -08001856 ASFVOLT_LOG(ASFVOLT_DEBUG, "Received OMCI response via BAL APIs");
VoLTHA753536e2017-11-02 20:15:09 +05301857 BalIndications *balIndCfg;
1858 balIndCfg = malloc(sizeof(BalIndications));
1859 memset(balIndCfg, 0, sizeof(BalIndications));
1860 bal_indications__init(balIndCfg);
1861 balIndCfg->u_case = BAL_INDICATIONS__U_BAL_OMCI_RESP;
1862 balIndCfg->has_objtype = BAL_GRPC_PRES;
1863 balIndCfg->objtype = obj->obj_type;
1864 balIndCfg->has_sub_group = BAL_GRPC_PRES;
1865 balIndCfg->sub_group = obj->subgroup;
1866 balIndCfg->device_id = voltha_device_id;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301867
VoLTHA753536e2017-11-02 20:15:09 +05301868 BalPacketItuOmciChannelRx *omciChannel;
1869 omciChannel = malloc(sizeof(BalPacketItuOmciChannelRx));
1870 memset(omciChannel, 0, sizeof(BalPacketItuOmciChannelRx));
1871 bal_packet_itu_omci_channel_rx__init(omciChannel);
1872 balIndCfg->balomciresp = omciChannel;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301873
VoLTHA753536e2017-11-02 20:15:09 +05301874 BalObj *hdr;
1875 hdr = malloc(sizeof(BalObj));
1876 memset(hdr, 0, sizeof(BalObj));
1877 bal_obj__init(hdr);
1878 balIndCfg->balomciresp->hdr = hdr;
Rajeswara Raob2e441c2017-09-20 16:40:21 +05301879
VoLTHA753536e2017-11-02 20:15:09 +05301880 BalPacketKey *packetkey;
1881 packetkey = malloc(sizeof(BalPacketKey));
1882 memset(packetkey, 0, sizeof(BalPacketKey));
1883 bal_packet_key__init(packetkey);
1884 balIndCfg->balomciresp->key = packetkey;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301885
VoLTHA753536e2017-11-02 20:15:09 +05301886 BalPacketItuOmciChannelRxData *omciData;
1887 omciData = malloc(sizeof(BalPacketItuOmciChannelRxData));
1888 memset(omciData, 0, sizeof(BalPacketItuOmciChannelRxData));
1889 bal_packet_itu_omci_channel_rx_data__init(omciData);
1890 balIndCfg->balomciresp->data = omciData;
Rajeswara Raob2e441c2017-09-20 16:40:21 +05301891
1892 bcmbal_packet_itu_omci_channel_rx *omci_channel =
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301893 (bcmbal_packet_itu_omci_channel_rx *)obj;
1894
VoLTHA753536e2017-11-02 20:15:09 +05301895 balIndCfg->balomciresp->data->has_pkt = BAL_GRPC_PRES;
1896 balIndCfg->balomciresp->data->pkt.len = omci_channel->data.pkt.len;
1897 balIndCfg->balomciresp->data->pkt.data = (uint8_t *)malloc((omci_channel->data.pkt.len)*sizeof(uint8_t));
1898 memcpy(balIndCfg->balomciresp->data->pkt.data, omci_channel->data.pkt.val,
1899 balIndCfg->balomciresp->data->pkt.len);
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301900
VoLTHA753536e2017-11-02 20:15:09 +05301901 balIndCfg->balomciresp->key->has_reserved = BAL_GRPC_PRES;
1902 balIndCfg->balomciresp->key->reserved = omci_channel->key.reserved;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301903
VoLTHA753536e2017-11-02 20:15:09 +05301904 BalDest *PktSndDest;
1905 PktSndDest = malloc(sizeof(BalDest));
1906 memset(PktSndDest, 0, sizeof(BalDest));
1907 bal_dest__init(PktSndDest);
1908 balIndCfg->balomciresp->key->packet_send_dest = PktSndDest;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301909
VoLTHA753536e2017-11-02 20:15:09 +05301910 balIndCfg->balomciresp->key->packet_send_dest->has_type = BAL_GRPC_PRES;
1911 balIndCfg->balomciresp->key->packet_send_dest->type =
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301912 omci_channel->key.packet_send_dest.type;
1913 switch( omci_channel->key.packet_send_dest.type)
1914 {
1915 case BCMBAL_DEST_TYPE_ITU_OMCI_CHANNEL:
1916 {
VoLTHA753536e2017-11-02 20:15:09 +05301917 balIndCfg->balomciresp->key->packet_send_dest->u_case = BAL_DEST__U_ITU_OMCI_CHANNEL;
1918 BalItuOmciChannel *balOmci;
1919 balOmci = malloc(sizeof(BalItuOmciChannel));
1920 memset(balOmci, 0, sizeof(BalItuOmciChannel));
1921 bal_itu_omci_channel__init(balOmci);
1922 balIndCfg->balomciresp->key->packet_send_dest->itu_omci_channel = balOmci;
1923 balIndCfg->balomciresp->key->packet_send_dest->itu_omci_channel->has_sub_term_id =
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301924 BAL_GRPC_PRES;
VoLTHA753536e2017-11-02 20:15:09 +05301925 balIndCfg->balomciresp->key->packet_send_dest->itu_omci_channel->sub_term_id =
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301926 omci_channel->key.packet_send_dest.u.itu_omci_channel.sub_term_id;
VoLTHA753536e2017-11-02 20:15:09 +05301927 balIndCfg->balomciresp->key->packet_send_dest->itu_omci_channel->has_intf_id =
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301928 BAL_GRPC_PRES;
VoLTHA753536e2017-11-02 20:15:09 +05301929 balIndCfg->balomciresp->key->packet_send_dest->itu_omci_channel->intf_id =
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301930 omci_channel->key.packet_send_dest.u.itu_omci_channel.intf_id;
Kim Kempfafa1ab42017-11-13 09:31:47 -08001931 ASFVOLT_LOG(ASFVOLT_DEBUG, "OMCI Response for ONU id %d",
VoLTHA753536e2017-11-02 20:15:09 +05301932 balIndCfg->balomciresp->key->packet_send_dest->itu_omci_channel->sub_term_id);
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301933 }
1934 break;
1935 default:
1936 {
VoLTHA753536e2017-11-02 20:15:09 +05301937 balIndCfg->balomciresp->key->packet_send_dest->u_case = BAL_DEST__U__NOT_SET;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301938 }
1939 break;
1940 }
1941
Kim Kempfafa1ab42017-11-13 09:31:47 -08001942 ASFVOLT_HEX2LOG(ASFVOLT_DEBUG, "OMCI Response with %zd bytes is ",
1943 balIndCfg->balomciresp->data->pkt.data, balIndCfg->balomciresp->data->pkt.len);
1944
1945 ASFVOLT_LOG(ASFVOLT_DEBUG, "OMCI Response for ONU id %d",
VoLTHA753536e2017-11-02 20:15:09 +05301946 balIndCfg->balomciresp->key->packet_send_dest->itu_omci_channel->sub_term_id);
Kim Kempfafa1ab42017-11-13 09:31:47 -08001947
VoLTHA753536e2017-11-02 20:15:09 +05301948 list_node *bal_indication_node = malloc(sizeof(list_node));
1949 bal_indication_node->bal_indication = balIndCfg;
1950
1951 pthread_mutex_lock(&bal_ind_queue_lock);
1952 add_bal_indication_node(bal_indication_node);
1953 pthread_mutex_unlock(&bal_ind_queue_lock);
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301954 }
1955
1956 return result;
1957}
1958
1959/********************************************************************\
Rajeswara Raob2e441c2017-09-20 16:40:21 +05301960 * Function : bal_oam_data_indication_cb *
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301961 * Description : This function will handle the indications for *
1962 * OAM Data Response *
1963 * *
1964 ********************************************************************/
1965bcmos_errno bal_oam_data_indication_cb(bcmbal_obj *obj)
1966{
1967 bcmos_errno result = BCM_ERR_OK;
1968
Rajeswara Raob2e441c2017-09-20 16:40:21 +05301969 if(BCMBAL_OBJ_ID_PACKET != obj->obj_type ||
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301970 bcmbal_packet_auto_id_ieee_oam_channel_rx != obj->subgroup)
1971 {
Kim Kempfafa1ab42017-11-13 09:31:47 -08001972 ASFVOLT_LOG(ASFVOLT_ERROR, "Processing BAL API '%s' IND callback (status is %s)",
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301973 bcmbal_objtype_str(obj->obj_type), bcmos_strerror(obj->status));
1974 result = BCM_ERR_INTERNAL;
1975 }
1976 else
1977 {
VoLTHA753536e2017-11-02 20:15:09 +05301978 BalIndications *balIndCfg;
1979 balIndCfg = malloc(sizeof(BalIndications));
1980 memset(balIndCfg, 0, sizeof(BalIndications));
1981 bal_indications__init(balIndCfg);
1982 balIndCfg->u_case = BAL_INDICATIONS__U_BAL_OAM_RESP;
1983 balIndCfg->has_objtype = BAL_GRPC_PRES;
1984 balIndCfg->objtype = obj->obj_type;
1985 balIndCfg->has_sub_group = BAL_GRPC_PRES;
1986 balIndCfg->sub_group = obj->subgroup;
1987 balIndCfg->device_id = voltha_device_id;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301988
VoLTHA753536e2017-11-02 20:15:09 +05301989 BalPacketIeeeOamChannelRx *oamChannel;
1990 oamChannel = malloc(sizeof(BalPacketIeeeOamChannelRx));
1991 memset(oamChannel, 0, sizeof(BalPacketIeeeOamChannelRx));
1992 bal_packet_ieee_oam_channel_rx__init(oamChannel);
1993 balIndCfg->baloamresp = oamChannel;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05301994
VoLTHA753536e2017-11-02 20:15:09 +05301995 BalObj *hdr;
1996 hdr = malloc(sizeof(BalObj));
1997 memset(hdr, 0, sizeof(BalObj));
1998 bal_obj__init(hdr);
1999 balIndCfg->baloamresp->hdr = hdr;
Rajeswara Raob2e441c2017-09-20 16:40:21 +05302000
VoLTHA753536e2017-11-02 20:15:09 +05302001 BalPacketKey *packetkey;
2002 packetkey = malloc(sizeof(BalPacketKey));
2003 memset(packetkey, 0, sizeof(BalPacketKey));
2004 bal_packet_key__init(packetkey);
2005 balIndCfg->baloamresp->key = packetkey;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05302006
Rajeswara Raob2e441c2017-09-20 16:40:21 +05302007 bcmbal_packet_ieee_oam_channel_rx *oam_channel =
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05302008 (bcmbal_packet_ieee_oam_channel_rx *)obj;
2009
VoLTHA753536e2017-11-02 20:15:09 +05302010 balIndCfg->baloamresp->key->has_reserved = BAL_GRPC_PRES;
2011 balIndCfg->baloamresp->key->reserved = oam_channel->key.reserved;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05302012
VoLTHA753536e2017-11-02 20:15:09 +05302013 BalDest *PktSndDest;
2014 PktSndDest = malloc(sizeof(BalDest));
2015 memset(PktSndDest, 0, sizeof(BalDest));
2016 bal_dest__init(PktSndDest);
2017 balIndCfg->baloamresp->key->packet_send_dest = PktSndDest;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05302018
VoLTHA753536e2017-11-02 20:15:09 +05302019 balIndCfg->baloamresp->key->packet_send_dest->has_type = BAL_GRPC_PRES;
2020 balIndCfg->baloamresp->key->packet_send_dest->type =
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05302021 oam_channel->key.packet_send_dest.type;
2022 switch( oam_channel->key.packet_send_dest.type)
2023 {
2024 case BCMBAL_DEST_TYPE_IEEE_OAM_CHANNEL:
2025 {
VoLTHA753536e2017-11-02 20:15:09 +05302026 balIndCfg->baloamresp->key->packet_send_dest->u_case = BAL_DEST__U_IEEE_OAM_CHANNEL;
2027 BalIeeeOamChannel *balOam;
2028 balOam = malloc(sizeof(BalIeeeOamChannel));
2029 memset(balOam, 0, sizeof(BalIeeeOamChannel));
2030 bal_ieee_oam_channel__init(balOam);
2031 balIndCfg->baloamresp->key->packet_send_dest->ieee_oam_channel = balOam;
2032 balIndCfg->baloamresp->key->packet_send_dest->ieee_oam_channel->has_intf_id =
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05302033 BAL_GRPC_PRES;
VoLTHA753536e2017-11-02 20:15:09 +05302034 balIndCfg->baloamresp->key->packet_send_dest->ieee_oam_channel->intf_id =
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05302035 oam_channel->key.packet_send_dest.u.ieee_oam_channel.intf_id;
VoLTHA753536e2017-11-02 20:15:09 +05302036 balIndCfg->baloamresp->key->packet_send_dest->ieee_oam_channel->has_mac_address = BAL_GRPC_PRES;
2037 balIndCfg->baloamresp->key->packet_send_dest->ieee_oam_channel->mac_address.len =
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05302038 (BCMOS_ETH_ALEN)*sizeof(oam_channel->key.packet_send_dest.u.ieee_oam_channel.mac_address.u8);
VoLTHA753536e2017-11-02 20:15:09 +05302039 balIndCfg->baloamresp->key->packet_send_dest->ieee_oam_channel->mac_address.data =
2040 (uint8_t *)malloc((balIndCfg->baloamresp->key->packet_send_dest->ieee_oam_channel->mac_address.len)*sizeof(uint8_t));
2041 memcpy(balIndCfg->baloamresp->key->packet_send_dest->ieee_oam_channel->mac_address.data,
Rajeswara Raob2e441c2017-09-20 16:40:21 +05302042 oam_channel->key.packet_send_dest.u.ieee_oam_channel.mac_address.u8,
VoLTHA753536e2017-11-02 20:15:09 +05302043 balIndCfg->baloamresp->key->packet_send_dest->ieee_oam_channel->mac_address.len);
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05302044
2045 }
2046 break;
2047 default:
2048 {
VoLTHA753536e2017-11-02 20:15:09 +05302049 balIndCfg->baloamresp->key->packet_send_dest->u_case = BAL_DEST__U__NOT_SET;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05302050 }
2051 break;
2052 }
2053
VoLTHA753536e2017-11-02 20:15:09 +05302054 BalPacketIeeeOamChannelRxData *oamData;
2055 oamData = malloc(sizeof(BalPacketIeeeOamChannelRxData));
2056 memset(oamData, 0, sizeof(BalPacketIeeeOamChannelRxData));
2057 bal_packet_ieee_oam_channel_rx_data__init(oamData);
2058 balIndCfg->baloamresp->data = oamData;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05302059
VoLTHA753536e2017-11-02 20:15:09 +05302060 balIndCfg->baloamresp->data->pkt.len = oam_channel->data.pkt.len;
2061 balIndCfg->baloamresp->data->pkt.data = (uint8_t *)malloc((balIndCfg->baloamresp->data->pkt.len)*sizeof(uint8_t));
2062 memcpy(balIndCfg->baloamresp->data->pkt.data, oam_channel->data.pkt.val,
2063 balIndCfg->baloamresp->data->pkt.len);
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05302064
VoLTHA753536e2017-11-02 20:15:09 +05302065 list_node *bal_indication_node = malloc(sizeof(list_node));
2066 bal_indication_node->bal_indication = balIndCfg;
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05302067
VoLTHA753536e2017-11-02 20:15:09 +05302068 pthread_mutex_lock(&bal_ind_queue_lock);
2069 add_bal_indication_node(bal_indication_node);
2070 pthread_mutex_unlock(&bal_ind_queue_lock);
Rajeswara Raof6b4e6c2017-08-31 17:26:27 +05302071 }
2072
2073 return result;
2074}