static gboolean __zblib_driver_service_dispatcher(ZigBeeDriver *driver, guint request_id)
{
ZigBeeService *service = NULL;
+ ZblibDriverServicePrivData_t *priv_data = NULL;
+ ZblibDriverServiceOps_t *ops = NULL;
guint request_type;
guint ops_id;
+ gboolean ret = FALSE;
- if (NULL == driver) {
- Z_LOGE("driver is NULL");
- return FALSE;
- }
+ zblib_check_null_ret_error("driver", driver, FALSE);
service = zblib_driver_ref_service(driver);
- if (NULL == service) {
- Z_LOGE("service is NULL");
- return FALSE;
- }
+ zblib_check_null_ret_error("service", service, FALSE);
+
+ /* Fetch private data */
+ priv_data = zblib_driver_ref_object(driver);
+ zblib_check_null_ret_error("priv_data", priv_data, FALSE);
+
+ ops = priv_data->ops;
+ zblib_check_null_ret_error("ops", ops, FALSE);
/* Fetch request_type using request_id */
request_type = zblib_request_ref_request_type_by_request_id(service, request_id);
ops_id = zblib_request_get_ops_id(request_type);
switch (ops_id) {
case ZBLIB_SERVICE_OPS_ENABLE: {
+ zblib_check_null_ret_error("ops->enable",
+ ops->enable, FALSE);
+
+ ret = ops->enable(driver, request_id);
}
break;
case ZBLIB_SERVICE_OPS_DISABLE: {
+ zblib_check_null_ret_error("ops->disable",
+ ops->disable, FALSE);
+
+ ret = ops->disable(driver, request_id);
}
break;
case ZBLIB_SERVICE_OPS_ZB_HW_RESET: {
+ zblib_check_null_ret_error("ops->zb_hw_reset",
+ ops->zb_hw_reset, FALSE);
+
+ ret = ops->zb_hw_reset(driver, request_id);
}
break;
case ZBLIB_SERVICE_OPS_FORM_NETWORK: {
+ zblib_check_null_ret_error("ops->form_network",
+ ops->form_network, FALSE);
+
+ ret = ops->form_network(driver, request_id);
}
break;
case ZBLIB_SERVICE_OPS_COEX_START: {
+ zblib_check_null_ret_error("ops->coex_start",
+ ops->coex_start, FALSE);
+
+ ret = ops->coex_start(driver, request_id);
}
break;
case ZBLIB_SERVICE_OPS_COEX_STOP: {
+ zblib_check_null_ret_error("ops->coex_stop",
+ ops->coex_stop, FALSE);
+
+ ret = ops->coex_stop(driver, request_id);
}
break;
case ZBLIB_SERVICE_OPS_LEAVE_NETWORK: {
+ zblib_check_null_ret_error("ops->leave_network",
+ ops->leave_network, FALSE);
+
+ ret = ops->leave_network(driver, request_id);
}
break;
case ZBLIB_SERVICE_OPS_GET_NETWORK_INFO: {
+ zblib_check_null_ret_error("ops->get_network_info",
+ ops->get_network_info, FALSE);
+
+ ret = ops->get_network_info(driver, request_id);
}
break;
case ZBLIB_SERVICE_OPS_PERMIT_JOIN: {
+ zblib_check_null_ret_error("ops->permit_join",
+ ops->permit_join, FALSE);
+
+ ret = ops->permit_join(driver, request_id);
}
break;
case ZBLIB_SERVICE_OPS_LEAVE_REQUEST: {
+ zblib_check_null_ret_error("ops->leave_request",
+ ops->leave_request, FALSE);
+
+ ret = ops->leave_request(driver, request_id);
}
break;
case ZBLIB_SERVICE_OPS_GET_DEVICE_LIST: {
+ zblib_check_null_ret_error("ops->get_device_list",
+ ops->get_device_list, FALSE);
+
+ ret = ops->get_device_list(driver, request_id);
}
break;
case ZBLIB_SERVICE_OPS_GET_MAC: {
+ zblib_check_null_ret_error("ops->get_mac",
+ ops->get_mac, FALSE);
+
+ ret = ops->get_mac(driver, request_id);
}
break;
case ZBLIB_SERVICE_OPS_GET_DEVICE_INFO: {
+ zblib_check_null_ret_error("ops->get_device_info",
+ ops->get_device_info, FALSE);
+
+ ret = ops->get_device_info(driver, request_id);
}
break;
case ZBLIB_SERVICE_OPS_GET_ENDPOINT_LIST: {
+ zblib_check_null_ret_error("ops->get_endpoint_list",
+ ops->get_endpoint_list, FALSE);
+
+ ret = ops->get_endpoint_list(driver, request_id);
}
break;
case ZBLIB_SERVICE_OPS_GET_CLUSTER_LIST: {
+ zblib_check_null_ret_error("ops->get_cluster_list",
+ ops->get_cluster_list, FALSE);
+
+ ret = ops->get_cluster_list(driver, request_id);
}
break;
case ZBLIB_SERVICE_OPS_GET_NODE_TYPE: {
+ zblib_check_null_ret_error("ops->get_node_type",
+ ops->get_node_type, FALSE);
+
+ ret = ops->get_node_type(driver, request_id);
}
break;
break;
}
- return TRUE;
+ Z_LOGD("ret: [%d]", ret);
+
+ return ret;
}
static void __zblib_driver_service_free_hook(ZigBeeDriver *driver)
{
ZblibDriverServicePrivData_t *priv_data = NULL;
- if (NULL == driver) {
- Z_LOGE("driver is NULL");
- return;
- }
+ zblib_check_null_ret("driver", driver);
/* Fetch private data */
priv_data = zblib_driver_ref_object(driver);
- if (NULL == priv_data) {
- Z_LOGE("priv_data is NULL");
- return;
- }
+ zblib_check_null_ret("priv_data", priv_data);
/* Free resources */
g_free(priv_data);
ZblibDriverServicePrivData_t *priv_data = NULL;
gboolean ret;
- if (NULL == plugin) {
- Z_LOGE("plugin is NULL");
- return NULL;
- }
+ zblib_check_null_ret_error("plugin", plugin, NULL);
/* Create new driver */
driver = zblib_driver_new(plugin, driver_name, ZBLIB_DRIVER_TYPE_SERVICE);
- if (NULL == driver) {
- Z_LOGE("driver is NULL");
- return NULL;
- }
+ zblib_check_null_ret_error("driver", driver, NULL);
/* Allocate memory for private data */
priv_data = g_malloc0(sizeof(ZblibDriverServicePrivData_t));
void zblib_driver_service_free(ZigBeeDriver *driver)
{
- if (NULL == driver) {
- Z_LOGE("driver is NULL");
- return;
- }
+ zblib_check_null_ret("driver", driver);
/* Free driver */
zblib_driver_free(driver);