X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;f=src%2Flibnetwork.c;h=abe373e6f5c8d5b3479f2a7baa0379fdc771d1a3;hb=7dbac2ab07e3df595736f2755543bb660cef6743;hp=daf7bfffa0ea6eb36c3ac8b1312d77eb80e96889;hpb=d62edd074e2b1ea6d9656a607987d85ccb26a242;p=platform%2Fcore%2Fapi%2Fconnection.git diff --git a/src/libnetwork.c b/src/libnetwork.c index daf7bff..abe373e 100755 --- a/src/libnetwork.c +++ b/src/libnetwork.c @@ -80,6 +80,7 @@ static void __connection_set_created(bool tag) libnet.is_created = tag; } +//LCOV_EXCL_START static connection_error_e __libnet_convert_to_cp_error_type(net_err_t err_type) { switch (err_type) { @@ -389,7 +390,7 @@ static void __libnet_evt_cb(net_event_info_t *event_cb, void *user_data) case NET_EVENT_OPEN_IND: result = __libnet_convert_to_cp_error_type(event_cb->Error); CONNECTION_LOG(CONNECTION_INFO, "Connection opened %s[%s]", - (is_requested) ? "RSP":"IND", + (is_requested) ? "RSP" : "IND", __libnet_convert_cp_error_type_to_string(result)); if (is_requested) @@ -416,7 +417,7 @@ static void __libnet_evt_cb(net_event_info_t *event_cb, void *user_data) case NET_EVENT_CLOSE_IND: result = __libnet_convert_to_cp_error_type(event_cb->Error); CONNECTION_LOG(CONNECTION_INFO, "Connection closed %s[%s]", - (is_requested) ? "RSP":"IND", + (is_requested) ? "RSP" : "IND", __libnet_convert_cp_error_type_to_string(result)); if (is_requested) @@ -469,10 +470,11 @@ static void __libnet_evt_cb(net_event_info_t *event_cb, void *user_data) __libnet_ethernet_cable_state_changed_cb(CONNECTION_ETHERNET_CABLE_DETACHED); break; - default : + default: break; } } +//LCOV_EXCL_STOP static int __libnet_check_address_type(int address_family, const char *address) { @@ -480,7 +482,7 @@ static int __libnet_check_address_type(int address_family, const char *address) int err = 0; err = inet_pton(address_family, address, &buf); - if(err > 0) + if (err > 0) return 1; return 0; @@ -491,7 +493,7 @@ int __libnet_get_connected_count(struct _profile_list_s *profile_list) int count = 0; int i = 0; - for (;i < profile_list->count;i++) { + for (; i < profile_list->count; i++) { if (profile_list->profiles[i].ProfileState == NET_STATE_TYPE_ONLINE || profile_list->profiles[i].ProfileState == NET_STATE_TYPE_READY) count++; @@ -504,7 +506,7 @@ void __libnet_copy_connected_profile(net_profile_info_t **dest, struct _profile_ { int i = 0; - for (;i < source->count;i++) { + for (; i < source->count; i++) { if (source->profiles[i].ProfileState == NET_STATE_TYPE_ONLINE || source->profiles[i].ProfileState == NET_STATE_TYPE_READY) { memcpy(*dest, &source->profiles[i], sizeof(net_profile_info_t)); @@ -513,12 +515,13 @@ void __libnet_copy_connected_profile(net_profile_info_t **dest, struct _profile_ } } +//LCOV_EXCL_START int __libnet_get_default_count(struct _profile_list_s *profile_list) { int count = 0; int i = 0; - for (;i < profile_list->count;i++) { + for (; i < profile_list->count; i++) { if (profile_list->profiles[i].ProfileInfo.Pdp.DefaultConn == TRUE) count++; } @@ -530,13 +533,14 @@ void __libnet_copy_default_profile(net_profile_info_t **dest, struct _profile_li { int i = 0; - for (;i < source->count;i++) { + for (; i < source->count; i++) { if (source->profiles[i].ProfileInfo.Pdp.DefaultConn == TRUE) { memcpy(*dest, &source->profiles[i], sizeof(net_profile_info_t)); (*dest)++; } } } +//LCOV_EXCL_STOP int _connection_libnet_init(void) { @@ -591,12 +595,13 @@ bool _connection_libnet_check_profile_validity(connection_profile_h profile) for (list = prof_handle_list; list; list = list->next) if (profile == list->data) return true; - for (;i < profile_iterator.count;i++) + for (; i < profile_iterator.count; i++) if (profile == &profile_iterator.profiles[i]) return true; return false; } +//LCOV_EXCL_START bool _connection_libnet_check_profile_cb_validity(connection_profile_h profile) { struct _profile_cb_s *cb_info; @@ -611,21 +616,20 @@ bool _connection_libnet_check_profile_cb_validity(connection_profile_h profile) return false; } - +//LCOV_EXCL_STOP int _connection_libnet_get_wifi_state(connection_wifi_state_e *state) { int rv; net_wifi_state_t wlan_state; - net_profile_name_t profile_name; - rv = net_get_wifi_state(&wlan_state, &profile_name); + rv = net_get_wifi_state(&wlan_state); if (rv == NET_ERR_ACCESS_DENIED) { - CONNECTION_LOG(CONNECTION_ERROR, "Access denied"); - return CONNECTION_ERROR_PERMISSION_DENIED; + CONNECTION_LOG(CONNECTION_ERROR, "Access denied"); //LCOV_EXCL_LINE + return CONNECTION_ERROR_PERMISSION_DENIED; //LCOV_EXCL_LINE } else if (rv != NET_ERR_NONE) { - CONNECTION_LOG(CONNECTION_ERROR, "Failed to get Wi-Fi state[%d]", rv); - return CONNECTION_ERROR_OPERATION_FAILED; + CONNECTION_LOG(CONNECTION_ERROR, "Failed to get Wi-Fi state[%d]", rv); //LCOV_EXCL_LINE + return CONNECTION_ERROR_OPERATION_FAILED; //LCOV_EXCL_LINE } switch (wlan_state) { @@ -641,15 +645,16 @@ int _connection_libnet_get_wifi_state(connection_wifi_state_e *state) case WIFI_DISCONNECTING: *state = CONNECTION_WIFI_STATE_CONNECTED; break; - default : - CONNECTION_LOG(CONNECTION_ERROR, "Unknown Wi-Fi state"); - return CONNECTION_ERROR_INVALID_OPERATION; + default: + CONNECTION_LOG(CONNECTION_ERROR, "Unknown Wi-Fi state"); //LCOV_EXCL_LINE + return CONNECTION_ERROR_INVALID_OPERATION; //LCOV_EXCL_LINE } return CONNECTION_ERROR_NONE; } -int _connection_libnet_get_ethernet_state(connection_ethernet_state_e* state) +//LCOV_EXCL_START +int _connection_libnet_get_ethernet_state(connection_ethernet_state_e *state) { int rv; struct _profile_list_s ethernet_profiles = {0, 0, NULL}; @@ -700,7 +705,7 @@ int _connection_libnet_get_ethernet_cable_state(connection_ethernet_cable_state_ return CONNECTION_ERROR_OPERATION_FAILED; } - if(status == 1) + if (status == 1) *state = CONNECTION_ETHERNET_CABLE_ATTACHED; else *state = CONNECTION_ETHERNET_CABLE_DETACHED; @@ -714,16 +719,17 @@ int _connection_libnet_set_ethernet_cable_state_changed_cb( return CONNECTION_ERROR_NONE; } +//LCOV_EXCL_STOP -int _connection_libnet_get_bluetooth_state(connection_bt_state_e* state) +int _connection_libnet_get_bluetooth_state(connection_bt_state_e *state) { int i = 0; int rv = 0; struct _profile_list_s bluetooth_profiles = {0, 0, NULL}; rv = net_get_profile_list(NET_DEVICE_BLUETOOTH, &bluetooth_profiles.profiles, &bluetooth_profiles.count); if (rv == NET_ERR_ACCESS_DENIED) { - CONNECTION_LOG(CONNECTION_ERROR, "Access denied"); - return CONNECTION_ERROR_PERMISSION_DENIED; + CONNECTION_LOG(CONNECTION_ERROR, "Access denied"); //LCOV_EXCL_LINE + return CONNECTION_ERROR_PERMISSION_DENIED; //LCOV_EXCL_LINE } if (bluetooth_profiles.count == 0) { @@ -731,6 +737,7 @@ int _connection_libnet_get_bluetooth_state(connection_bt_state_e* state) return CONNECTION_ERROR_NONE; } + //LCOV_EXCL_START for (; i < bluetooth_profiles.count; i++) { switch (bluetooth_profiles.profiles[i].ProfileState) { case NET_STATE_TYPE_ONLINE: @@ -749,8 +756,9 @@ int _connection_libnet_get_bluetooth_state(connection_bt_state_e* state) return CONNECTION_ERROR_OPERATION_FAILED; } } + //LCOV_EXCL_STOP -done: +done : __libnet_clear_profile_list(&bluetooth_profiles); return CONNECTION_ERROR_NONE; @@ -771,49 +779,49 @@ int _connection_libnet_get_profile_iterator(connection_iterator_type_e type, con rv1 = net_get_profile_list(NET_DEVICE_WIFI, &wifi_profiles.profiles, &wifi_profiles.count); if (rv1 == NET_ERR_ACCESS_DENIED) { - CONNECTION_LOG(CONNECTION_ERROR, "Access denied"); - return CONNECTION_ERROR_PERMISSION_DENIED; + CONNECTION_LOG(CONNECTION_ERROR, "Access denied"); //LCOV_EXCL_LINE + return CONNECTION_ERROR_PERMISSION_DENIED; //LCOV_EXCL_LINE } else if (rv1 != NET_ERR_NO_SERVICE && rv1 != NET_ERR_NONE) - return CONNECTION_ERROR_OPERATION_FAILED; + return CONNECTION_ERROR_OPERATION_FAILED; //LCOV_EXCL_LINE CONNECTION_LOG(CONNECTION_INFO, "Wi-Fi profile count: %d", wifi_profiles.count); rv2 = net_get_profile_list(NET_DEVICE_CELLULAR, &cellular_profiles.profiles, &cellular_profiles.count); if (rv2 == NET_ERR_ACCESS_DENIED) { - CONNECTION_LOG(CONNECTION_ERROR, "Access denied"); + CONNECTION_LOG(CONNECTION_ERROR, "Access denied"); //LCOV_EXCL_LINE __libnet_clear_profile_list(&wifi_profiles); - return CONNECTION_ERROR_PERMISSION_DENIED; + return CONNECTION_ERROR_PERMISSION_DENIED; //LCOV_EXCL_LINE } else if (rv2 != NET_ERR_NO_SERVICE && rv2 != NET_ERR_NONE) { __libnet_clear_profile_list(&wifi_profiles); - return CONNECTION_ERROR_OPERATION_FAILED; + return CONNECTION_ERROR_OPERATION_FAILED; //LCOV_EXCL_LINE } CONNECTION_LOG(CONNECTION_INFO, "Cellular profile count: %d", cellular_profiles.count); rv3 = net_get_profile_list(NET_DEVICE_ETHERNET, ðernet_profiles.profiles, ðernet_profiles.count); if (rv3 == NET_ERR_ACCESS_DENIED) { - CONNECTION_LOG(CONNECTION_ERROR, "Access denied"); + CONNECTION_LOG(CONNECTION_ERROR, "Access denied"); //LCOV_EXCL_LINE __libnet_clear_profile_list(&wifi_profiles); __libnet_clear_profile_list(&cellular_profiles); - return CONNECTION_ERROR_PERMISSION_DENIED; + return CONNECTION_ERROR_PERMISSION_DENIED; //LCOV_EXCL_LINE } else if (rv3 != NET_ERR_NO_SERVICE && rv3 != NET_ERR_NONE) { __libnet_clear_profile_list(&wifi_profiles); __libnet_clear_profile_list(&cellular_profiles); - return CONNECTION_ERROR_OPERATION_FAILED; + return CONNECTION_ERROR_OPERATION_FAILED; //LCOV_EXCL_LINE } CONNECTION_LOG(CONNECTION_INFO, "Ethernet profile count : %d", ethernet_profiles.count); rv4 = net_get_profile_list(NET_DEVICE_BLUETOOTH, &bluetooth_profiles.profiles, &bluetooth_profiles.count); if (rv4 == NET_ERR_ACCESS_DENIED) { - CONNECTION_LOG(CONNECTION_ERROR, "Access denied"); + CONNECTION_LOG(CONNECTION_ERROR, "Access denied"); //LCOV_EXCL_LINE __libnet_clear_profile_list(&wifi_profiles); __libnet_clear_profile_list(&cellular_profiles); __libnet_clear_profile_list(ðernet_profiles); - return CONNECTION_ERROR_PERMISSION_DENIED; + return CONNECTION_ERROR_PERMISSION_DENIED; //LCOV_EXCL_LINE } else if (rv4 != NET_ERR_NO_SERVICE && rv4 != NET_ERR_NONE) { __libnet_clear_profile_list(&wifi_profiles); __libnet_clear_profile_list(&cellular_profiles); __libnet_clear_profile_list(ðernet_profiles); - return CONNECTION_ERROR_OPERATION_FAILED; + return CONNECTION_ERROR_OPERATION_FAILED; //LCOV_EXCL_LINE } CONNECTION_LOG(CONNECTION_INFO, "Bluetooth profile count : %d", bluetooth_profiles.count); @@ -832,7 +840,7 @@ int _connection_libnet_get_profile_iterator(connection_iterator_type_e type, con __libnet_clear_profile_list(&cellular_profiles); __libnet_clear_profile_list(ðernet_profiles); __libnet_clear_profile_list(&bluetooth_profiles); - return CONNECTION_ERROR_OUT_OF_MEMORY; + return CONNECTION_ERROR_OUT_OF_MEMORY; //LCOV_EXCL_LINE } profile_iterator.profiles = profiles; @@ -875,7 +883,7 @@ int _connection_libnet_get_profile_iterator(connection_iterator_type_e type, con __libnet_clear_profile_list(&cellular_profiles); __libnet_clear_profile_list(ðernet_profiles); __libnet_clear_profile_list(&bluetooth_profiles); - return CONNECTION_ERROR_OUT_OF_MEMORY; + return CONNECTION_ERROR_OUT_OF_MEMORY; //LCOV_EXCL_LINE } profile_iterator.profiles = profiles; @@ -895,7 +903,7 @@ int _connection_libnet_get_profile_iterator(connection_iterator_type_e type, con break; case CONNECTION_ITERATOR_TYPE_DEFAULT: count = __libnet_get_default_count(&cellular_profiles); - CONNECTION_LOG(CONNECTION_INFO, "Total default profile count : %d", count); + CONNECTION_LOG(CONNECTION_INFO, "Total default profile count : %d", count); //LCOV_EXCL_LINE if (count == 0) return CONNECTION_ERROR_NONE; @@ -905,7 +913,7 @@ int _connection_libnet_get_profile_iterator(connection_iterator_type_e type, con __libnet_clear_profile_list(&cellular_profiles); __libnet_clear_profile_list(ðernet_profiles); __libnet_clear_profile_list(&bluetooth_profiles); - return CONNECTION_ERROR_OUT_OF_MEMORY; + return CONNECTION_ERROR_OUT_OF_MEMORY; //LCOV_EXCL_LINE } profile_iterator.profiles = profiles; @@ -953,7 +961,7 @@ bool _connection_libnet_iterator_has_next(connection_profile_iterator_h profile_ int _connection_libnet_destroy_iterator(connection_profile_iterator_h profile_iter_h) { if (profile_iter_h != &profile_iterator) - return CONNECTION_ERROR_INVALID_PARAMETER; + return CONNECTION_ERROR_INVALID_PARAMETER; //LCOV_EXCL_LINE __libnet_clear_profile_list(&profile_iterator); @@ -967,16 +975,16 @@ int _connection_libnet_get_current_profile(connection_profile_h *profile) rv = net_get_active_net_info(&active_profile); if (rv == NET_ERR_NO_SERVICE) - return CONNECTION_ERROR_NO_CONNECTION; + return CONNECTION_ERROR_NO_CONNECTION; //LCOV_EXCL_LINE else if (rv == NET_ERR_ACCESS_DENIED) { - CONNECTION_LOG(CONNECTION_ERROR, "Access denied"); - return CONNECTION_ERROR_PERMISSION_DENIED; + CONNECTION_LOG(CONNECTION_ERROR, "Access denied"); //LCOV_EXCL_LINE + return CONNECTION_ERROR_PERMISSION_DENIED; //LCOV_EXCL_LINE } else if (rv != NET_ERR_NONE) - return CONNECTION_ERROR_OPERATION_FAILED; + return CONNECTION_ERROR_OPERATION_FAILED; //LCOV_EXCL_LINE *profile = g_try_malloc0(sizeof(net_profile_info_t)); if (*profile == NULL) - return CONNECTION_ERROR_OUT_OF_MEMORY; + return CONNECTION_ERROR_OUT_OF_MEMORY; //LCOV_EXCL_LINE memcpy(*profile, &active_profile, sizeof(net_profile_info_t)); prof_handle_list = g_slist_append(prof_handle_list, *profile); @@ -991,11 +999,11 @@ int _connection_libnet_reset_profile(connection_reset_option_e type, rv = net_reset_profile(type, id); if (rv == NET_ERR_ACCESS_DENIED) { - CONNECTION_LOG(CONNECTION_ERROR, "Access denied"); - return CONNECTION_ERROR_PERMISSION_DENIED; + CONNECTION_LOG(CONNECTION_ERROR, "Access denied"); //LCOV_EXCL_LINE + return CONNECTION_ERROR_PERMISSION_DENIED; //LCOV_EXCL_LINE } else if (rv != NET_ERR_NONE) { - CONNECTION_LOG(CONNECTION_ERROR, "Failed to add profile[%d]", rv); - return CONNECTION_ERROR_OPERATION_FAILED; + CONNECTION_LOG(CONNECTION_ERROR, "Failed to add profile[%d]", rv); //LCOV_EXCL_LINE + return CONNECTION_ERROR_OPERATION_FAILED; //LCOV_EXCL_LINE } __libnet_set_reset_profile_cb(callback, user_data); @@ -1009,18 +1017,18 @@ int _connection_libnet_open_profile(connection_profile_h profile, int rv; if (!(_connection_libnet_check_profile_validity(profile))) { - CONNECTION_LOG(CONNECTION_ERROR, "Invalid parameter"); - return CONNECTION_ERROR_INVALID_PARAMETER; + CONNECTION_LOG(CONNECTION_ERROR, "Invalid parameter"); //LCOV_EXCL_LINE + return CONNECTION_ERROR_INVALID_PARAMETER; //LCOV_EXCL_LINE } net_profile_info_t *profile_info = profile; rv = net_open_connection_with_profile(profile_info->ProfileName); if (rv == NET_ERR_ACCESS_DENIED) { - CONNECTION_LOG(CONNECTION_ERROR, "Access denied"); - return CONNECTION_ERROR_PERMISSION_DENIED; + CONNECTION_LOG(CONNECTION_ERROR, "Access denied"); //LCOV_EXCL_LINE + return CONNECTION_ERROR_PERMISSION_DENIED; //LCOV_EXCL_LINE } else if (rv != NET_ERR_NONE) - return CONNECTION_ERROR_OPERATION_FAILED; + return CONNECTION_ERROR_OPERATION_FAILED; //LCOV_EXCL_LINE __libnet_set_opened_cb(callback, user_data); @@ -1042,11 +1050,11 @@ int _connection_libnet_get_cellular_service_profile( rv = net_get_profile_list(NET_DEVICE_CELLULAR, &cellular_profiles.profiles, &cellular_profiles.count); if (rv == NET_ERR_ACCESS_DENIED) { - CONNECTION_LOG(CONNECTION_ERROR, "Access denied"); - return CONNECTION_ERROR_PERMISSION_DENIED; + CONNECTION_LOG(CONNECTION_ERROR, "Access denied"); //LCOV_EXCL_LINE + return CONNECTION_ERROR_PERMISSION_DENIED; //LCOV_EXCL_LINE } else if (rv != NET_ERR_NONE) { - CONNECTION_LOG(CONNECTION_ERROR, "Failed to get profile list (%d)", rv); - return CONNECTION_ERROR_OPERATION_FAILED; + CONNECTION_LOG(CONNECTION_ERROR, "Failed to get profile list (%d)", rv); //LCOV_EXCL_LINE + return CONNECTION_ERROR_OPERATION_FAILED; //LCOV_EXCL_LINE } #if defined TIZEN_DUALSIM_ENABLE @@ -1054,8 +1062,8 @@ int _connection_libnet_get_cellular_service_profile( &default_subscriber_id) != 0) { CONNECTION_LOG(CONNECTION_ERROR, "Failed to get VCONF_TELEPHONY_DEFAULT_DATA_SERVICE"); - __libnet_clear_profile_list(&cellular_profiles); - return CONNECTION_ERROR_OPERATION_FAILED; + __libnet_clear_profile_list(&cellular_profiles); //LCOV_EXCL_LINE + return CONNECTION_ERROR_OPERATION_FAILED; //LCOV_EXCL_LINE } g_snprintf(subscriber_id, sizeof(subscriber_id), "%d", default_subscriber_id); @@ -1071,14 +1079,14 @@ int _connection_libnet_get_cellular_service_profile( break; if (i >= cellular_profiles.count) { - __libnet_clear_profile_list(&cellular_profiles); - return CONNECTION_ERROR_OPERATION_FAILED; + __libnet_clear_profile_list(&cellular_profiles); //LCOV_EXCL_LINE + return CONNECTION_ERROR_OPERATION_FAILED; //LCOV_EXCL_LINE } *profile = g_try_malloc0(sizeof(net_profile_info_t)); if (*profile == NULL) { - __libnet_clear_profile_list(&cellular_profiles); - return CONNECTION_ERROR_OUT_OF_MEMORY; + __libnet_clear_profile_list(&cellular_profiles); //LCOV_EXCL_LINE + return CONNECTION_ERROR_OUT_OF_MEMORY; //LCOV_EXCL_LINE } memcpy(*profile, &cellular_profiles.profiles[i], sizeof(net_profile_info_t)); @@ -1086,6 +1094,7 @@ int _connection_libnet_get_cellular_service_profile( if (cellular_profiles.profiles[i].ProfileInfo.Pdp.DefaultConn) goto done; + //LCOV_EXCL_START if (type != CONNECTION_CELLULAR_SERVICE_TYPE_INTERNET && type != CONNECTION_CELLULAR_SERVICE_TYPE_PREPAID_INTERNET) goto done; @@ -1102,8 +1111,9 @@ int _connection_libnet_get_cellular_service_profile( goto done; } } + //LCOV_EXCL_STOP -done: +done : __libnet_clear_profile_list(&cellular_profiles); prof_handle_list = g_slist_append(prof_handle_list, *profile); @@ -1115,8 +1125,8 @@ int _connection_libnet_set_cellular_service_profile_sync(connection_cellular_ser int rv; if (!(_connection_libnet_check_profile_validity(profile))) { - CONNECTION_LOG(CONNECTION_ERROR, "Invalid parameter"); - return CONNECTION_ERROR_INVALID_PARAMETER; + CONNECTION_LOG(CONNECTION_ERROR, "Invalid parameter"); //LCOV_EXCL_LINE + return CONNECTION_ERROR_INVALID_PARAMETER; //LCOV_EXCL_LINE } net_profile_info_t *profile_info = profile; @@ -1125,14 +1135,14 @@ int _connection_libnet_set_cellular_service_profile_sync(connection_cellular_ser service_type = _profile_convert_to_connection_cellular_service_type(profile_info->ProfileInfo.Pdp.ServiceType); if (service_type != type) - return CONNECTION_ERROR_INVALID_PARAMETER; + return CONNECTION_ERROR_INVALID_PARAMETER; //LCOV_EXCL_LINE rv = net_set_default_cellular_service_profile(profile_info->ProfileName); if (rv == NET_ERR_ACCESS_DENIED) { - CONNECTION_LOG(CONNECTION_ERROR, "Access denied"); - return CONNECTION_ERROR_PERMISSION_DENIED; + CONNECTION_LOG(CONNECTION_ERROR, "Access denied"); //LCOV_EXCL_LINE + return CONNECTION_ERROR_PERMISSION_DENIED; //LCOV_EXCL_LINE } else if (rv != NET_ERR_NONE) - return CONNECTION_ERROR_OPERATION_FAILED; + return CONNECTION_ERROR_OPERATION_FAILED; //LCOV_EXCL_LINE return CONNECTION_ERROR_NONE; } @@ -1143,8 +1153,8 @@ int _connection_libnet_set_cellular_service_profile_async(connection_cellular_se int rv; if (!(_connection_libnet_check_profile_validity(profile))) { - CONNECTION_LOG(CONNECTION_ERROR, "Invalid parameter"); - return CONNECTION_ERROR_INVALID_PARAMETER; + CONNECTION_LOG(CONNECTION_ERROR, "Invalid parameter"); //LCOV_EXCL_LINE + return CONNECTION_ERROR_INVALID_PARAMETER; //LCOV_EXCL_LINE } net_profile_info_t *profile_info = profile; @@ -1153,14 +1163,14 @@ int _connection_libnet_set_cellular_service_profile_async(connection_cellular_se service_type = _profile_convert_to_connection_cellular_service_type(profile_info->ProfileInfo.Pdp.ServiceType); if (service_type != type) - return CONNECTION_ERROR_INVALID_PARAMETER; + return CONNECTION_ERROR_INVALID_PARAMETER; //LCOV_EXCL_LINE rv = net_set_default_cellular_service_profile_async(profile_info->ProfileName); if (rv == NET_ERR_ACCESS_DENIED) { - CONNECTION_LOG(CONNECTION_ERROR, "Access denied"); - return CONNECTION_ERROR_PERMISSION_DENIED; + CONNECTION_LOG(CONNECTION_ERROR, "Access denied"); //LCOV_EXCL_LINE + return CONNECTION_ERROR_PERMISSION_DENIED; //LCOV_EXCL_LINE } else if (rv != NET_ERR_NONE) - return CONNECTION_ERROR_OPERATION_FAILED; + return CONNECTION_ERROR_OPERATION_FAILED; //LCOV_EXCL_LINE __libnet_set_default_cb(callback, user_data); @@ -1172,18 +1182,18 @@ int _connection_libnet_close_profile(connection_profile_h profile, connection_cl int rv; if (!(_connection_libnet_check_profile_validity(profile))) { - CONNECTION_LOG(CONNECTION_ERROR, "Invalid parameter"); - return CONNECTION_ERROR_INVALID_PARAMETER; + CONNECTION_LOG(CONNECTION_ERROR, "Invalid parameter"); //LCOV_EXCL_LINE + return CONNECTION_ERROR_INVALID_PARAMETER; //LCOV_EXCL_LINE } net_profile_info_t *profile_info = profile; rv = net_close_connection(profile_info->ProfileName); if (rv == NET_ERR_ACCESS_DENIED) { - CONNECTION_LOG(CONNECTION_ERROR, "Access denied"); - return CONNECTION_ERROR_PERMISSION_DENIED; + CONNECTION_LOG(CONNECTION_ERROR, "Access denied"); //LCOV_EXCL_LINE + return CONNECTION_ERROR_PERMISSION_DENIED; //LCOV_EXCL_LINE } else if (rv != NET_ERR_NONE) - return CONNECTION_ERROR_OPERATION_FAILED; + return CONNECTION_ERROR_OPERATION_FAILED; //LCOV_EXCL_LINE __libnet_set_closed_cb(callback, user_data); @@ -1196,32 +1206,32 @@ int _connection_libnet_add_route(const char *interface_name, const char *host_ad char *endstr = NULL; int address_family = 0; - if(__libnet_check_address_type(AF_INET, host_address)) + if (__libnet_check_address_type(AF_INET, host_address)) address_family = AF_INET; else - return CONNECTION_ERROR_INVALID_PARAMETER; + return CONNECTION_ERROR_INVALID_PARAMETER; //LCOV_EXCL_LINE - switch(address_family) { - case AF_INET: - endstr = strrchr(host_address, '.'); - if (endstr == NULL || - strcmp(endstr, ".0") == 0 || - strncmp(host_address, "0.", 2) == 0 || - strstr(host_address, "255") != NULL) { - CONNECTION_LOG(CONNECTION_ERROR, "Invalid IP address Passed\n"); - return CONNECTION_ERROR_INVALID_PARAMETER; - } - break; - default: - return CONNECTION_ERROR_OPERATION_FAILED; + switch (address_family) { + case AF_INET: + endstr = strrchr(host_address, '.'); + if (endstr == NULL || + strcmp(endstr, ".0") == 0 || + strncmp(host_address, "0.", 2) == 0 || + strstr(host_address, "255") != NULL) { + CONNECTION_LOG(CONNECTION_ERROR, "Invalid IP address Passed\n"); //LCOV_EXCL_LINE + return CONNECTION_ERROR_INVALID_PARAMETER; //LCOV_EXCL_LINE + } + break; + default: + return CONNECTION_ERROR_OPERATION_FAILED; //LCOV_EXCL_LINE } rv = net_add_route(host_address, interface_name, address_family); if (rv == NET_ERR_ACCESS_DENIED) { - CONNECTION_LOG(CONNECTION_ERROR, "Access denied"); - return CONNECTION_ERROR_PERMISSION_DENIED; + CONNECTION_LOG(CONNECTION_ERROR, "Access denied"); //LCOV_EXCL_LINE + return CONNECTION_ERROR_PERMISSION_DENIED; //LCOV_EXCL_LINE } else if (rv != NET_ERR_NONE) - return CONNECTION_ERROR_OPERATION_FAILED; + return CONNECTION_ERROR_OPERATION_FAILED; //LCOV_EXCL_LINE return CONNECTION_ERROR_NONE; } @@ -1235,29 +1245,29 @@ int _connection_libnet_remove_route(const char *interface_name, const char *host if (__libnet_check_address_type(AF_INET, host_address)) address_family = AF_INET; else - return CONNECTION_ERROR_INVALID_PARAMETER; - - switch(address_family) { - case AF_INET: - endstr = strrchr(host_address, '.'); - if (endstr == NULL || - strcmp(endstr, ".0") == 0 || - strncmp(host_address, "0.", 2) == 0 || - strstr(host_address, ".0.") != NULL ||strstr(host_address, "255") != NULL) { - CONNECTION_LOG(CONNECTION_ERROR, "Invalid IP address Passed"); - return CONNECTION_ERROR_INVALID_PARAMETER; - } - break; - default: - return CONNECTION_ERROR_OPERATION_FAILED; + return CONNECTION_ERROR_INVALID_PARAMETER; //LCOV_EXCL_LINE + + switch (address_family) { + case AF_INET: + endstr = strrchr(host_address, '.'); + if (endstr == NULL || + strcmp(endstr, ".0") == 0 || + strncmp(host_address, "0.", 2) == 0 || + strstr(host_address, ".0.") != NULL || strstr(host_address, "255") != NULL) { + CONNECTION_LOG(CONNECTION_ERROR, "Invalid IP address Passed"); //LCOV_EXCL_LINE + return CONNECTION_ERROR_INVALID_PARAMETER; //LCOV_EXCL_LINE + } + break; + default: + return CONNECTION_ERROR_OPERATION_FAILED; //LCOV_EXCL_LINE } rv = net_remove_route(host_address, interface_name, address_family); if (rv == NET_ERR_ACCESS_DENIED) { - CONNECTION_LOG(CONNECTION_ERROR, "Access denied"); - return CONNECTION_ERROR_PERMISSION_DENIED; + CONNECTION_LOG(CONNECTION_ERROR, "Access denied"); //LCOV_EXCL_LINE + return CONNECTION_ERROR_PERMISSION_DENIED; //LCOV_EXCL_LINE } else if (rv != NET_ERR_NONE) - return CONNECTION_ERROR_OPERATION_FAILED; + return CONNECTION_ERROR_OPERATION_FAILED; //LCOV_EXCL_LINE return CONNECTION_ERROR_NONE; } @@ -1273,25 +1283,25 @@ int _connection_libnet_add_route_ipv6(const char *interface_name, const char *ho else return CONNECTION_ERROR_INVALID_PARAMETER;*/ - switch(address_family) { - case AF_INET6: - if (strncmp(host_address, "fe80:", 5) == 0 || - strncmp(host_address, "ff00:", 5) == 0 || - strncmp(host_address, "::", 2) == 0) { - CONNECTION_LOG(CONNECTION_ERROR, "Invalid IP address Passed\n"); - return CONNECTION_ERROR_INVALID_PARAMETER; - } - break; - default: - return CONNECTION_ERROR_OPERATION_FAILED; + switch (address_family) { + case AF_INET6: + if (strncmp(host_address, "fe80:", 5) == 0 || + strncmp(host_address, "ff00:", 5) == 0 || + strncmp(host_address, "::", 2) == 0) { + CONNECTION_LOG(CONNECTION_ERROR, "Invalid IP address Passed\n"); //LCOV_EXCL_LINE + return CONNECTION_ERROR_INVALID_PARAMETER; //LCOV_EXCL_LINE + } + break; + default: + return CONNECTION_ERROR_OPERATION_FAILED; //LCOV_EXCL_LINE } rv = net_add_route_ipv6(host_address, interface_name, address_family, gateway); if (rv == NET_ERR_ACCESS_DENIED) { - CONNECTION_LOG(CONNECTION_ERROR, "Access denied"); - return CONNECTION_ERROR_PERMISSION_DENIED; + CONNECTION_LOG(CONNECTION_ERROR, "Access denied"); //LCOV_EXCL_LINE + return CONNECTION_ERROR_PERMISSION_DENIED; //LCOV_EXCL_LINE } else if (rv != NET_ERR_NONE) - return CONNECTION_ERROR_OPERATION_FAILED; + return CONNECTION_ERROR_OPERATION_FAILED; //LCOV_EXCL_LINE return CONNECTION_ERROR_NONE; } @@ -1307,25 +1317,25 @@ int _connection_libnet_remove_route_ipv6(const char *interface_name, const char else return CONNECTION_ERROR_INVALID_PARAMETER;*/ - switch(address_family) { - case AF_INET6: - if (strncmp(host_address, "fe80:", 5) == 0 || - strncmp(host_address, "ff00:", 5) == 0 || - strncmp(host_address, "::", 2) == 0) { - CONNECTION_LOG(CONNECTION_ERROR, "Invalid IP address Passed\n"); - return CONNECTION_ERROR_INVALID_PARAMETER; - } - break; - default: - return CONNECTION_ERROR_OPERATION_FAILED; + switch (address_family) { + case AF_INET6: + if (strncmp(host_address, "fe80:", 5) == 0 || + strncmp(host_address, "ff00:", 5) == 0 || + strncmp(host_address, "::", 2) == 0) { + CONNECTION_LOG(CONNECTION_ERROR, "Invalid IP address Passed\n"); //LCOV_EXCL_LINE + return CONNECTION_ERROR_INVALID_PARAMETER; //LCOV_EXCL_LINE + } + break; + default: + return CONNECTION_ERROR_OPERATION_FAILED; //LCOV_EXCL_LINE } rv = net_remove_route_ipv6(host_address, interface_name, address_family, gateway); if (rv == NET_ERR_ACCESS_DENIED) { - CONNECTION_LOG(CONNECTION_ERROR, "Access denied"); - return CONNECTION_ERROR_PERMISSION_DENIED; + CONNECTION_LOG(CONNECTION_ERROR, "Access denied"); //LCOV_EXCL_LINE + return CONNECTION_ERROR_PERMISSION_DENIED; //LCOV_EXCL_LINE } else if (rv != NET_ERR_NONE) - return CONNECTION_ERROR_OPERATION_FAILED; + return CONNECTION_ERROR_OPERATION_FAILED; //LCOV_EXCL_LINE return CONNECTION_ERROR_NONE; } @@ -1349,8 +1359,8 @@ bool _connection_libnet_add_to_profile_cb_list(connection_profile_h profile, struct _profile_cb_s *profile_cb_info = g_try_malloc0(sizeof(struct _profile_cb_s)); if (profile_cb_info == NULL) { - g_free(profile_name); - return false; + g_free(profile_name); //LCOV_EXCL_LINE + return false; //LCOV_EXCL_LINE } profile_cb_info->callback = callback; @@ -1369,7 +1379,7 @@ bool _connection_libnet_remove_from_profile_cb_list(connection_profile_h profile if (g_hash_table_remove(profile_cb_table, profile_info->ProfileName) == TRUE) return true; - return false; + return false; //LCOV_EXCL_LINE } int _connection_libnet_set_statistics(net_device_t device_type, net_statistics_type_e statistics_type) @@ -1377,10 +1387,10 @@ int _connection_libnet_set_statistics(net_device_t device_type, net_statistics_t int rv; rv = net_set_statistics(device_type, statistics_type); if (rv == NET_ERR_ACCESS_DENIED) { - CONNECTION_LOG(CONNECTION_ERROR, "Access denied"); - return CONNECTION_ERROR_PERMISSION_DENIED; + CONNECTION_LOG(CONNECTION_ERROR, "Access denied"); //LCOV_EXCL_LINE + return CONNECTION_ERROR_PERMISSION_DENIED; //LCOV_EXCL_LINE } else if (rv != NET_ERR_NONE) - return CONNECTION_ERROR_OPERATION_FAILED; + return CONNECTION_ERROR_OPERATION_FAILED; //LCOV_EXCL_LINE return CONNECTION_ERROR_NONE; } @@ -1390,10 +1400,10 @@ int _connection_libnet_get_statistics(net_statistics_type_e statistics_type, uns int rv; rv = net_get_statistics(NET_DEVICE_WIFI, statistics_type, size); if (rv == NET_ERR_ACCESS_DENIED) { - CONNECTION_LOG(CONNECTION_ERROR, "Access denied"); - return CONNECTION_ERROR_PERMISSION_DENIED; - }else if (rv != NET_ERR_NONE) - return CONNECTION_ERROR_OPERATION_FAILED; + CONNECTION_LOG(CONNECTION_ERROR, "Access denied"); //LCOV_EXCL_LINE + return CONNECTION_ERROR_PERMISSION_DENIED; //LCOV_EXCL_LINE + } else if (rv != NET_ERR_NONE) + return CONNECTION_ERROR_OPERATION_FAILED; //LCOV_EXCL_LINE return CONNECTION_ERROR_NONE; } @@ -1405,13 +1415,13 @@ int _connection_libnet_set_cellular_subscriber_id(connection_profile_h profile, net_profile_info_t *profile_info = (net_profile_info_t *)profile; if (net_get_cellular_modem_object_path(&modem_path, sim_id) != NET_ERR_NONE) { - CONNECTION_LOG(CONNECTION_ERROR, "Failed to get subscriber[%d]", sim_id); - return CONNECTION_ERROR_OPERATION_FAILED; + CONNECTION_LOG(CONNECTION_ERROR, "Failed to get subscriber[%d]", sim_id); //LCOV_EXCL_LINE + return CONNECTION_ERROR_OPERATION_FAILED; //LCOV_EXCL_LINE } if (!modem_path) { - CONNECTION_LOG(CONNECTION_ERROR, "NULL modem object path"); - return CONNECTION_ERROR_OPERATION_FAILED; + CONNECTION_LOG(CONNECTION_ERROR, "NULL modem object path"); //LCOV_EXCL_LINE + return CONNECTION_ERROR_OPERATION_FAILED; //LCOV_EXCL_LINE } g_strlcpy(profile_info->ProfileInfo.Pdp.PSModemPath, modem_path, @@ -1444,6 +1454,8 @@ guint _connection_callback_add(GSourceFunc func, gpointer user_data) { guint id; struct managed_idle_data *data; + GMainContext *context; + GSource *src; if (!func) return 0; @@ -1455,8 +1467,12 @@ guint _connection_callback_add(GSourceFunc func, gpointer user_data) data->func = func; data->user_data = user_data; - id = g_idle_add_full(G_PRIORITY_DEFAULT_IDLE, __connection_idle_cb, data, - __connection_idle_destroy_cb); + context = g_main_context_get_thread_default(); + src = g_idle_source_new(); + g_source_set_callback(src, __connection_idle_cb, data, + __connection_idle_destroy_cb); + id = g_source_attach(src, context); + g_source_unref(src); if (!id) { g_free(data); return id; @@ -1476,6 +1492,7 @@ void _connection_callback_cleanup(void) struct managed_idle_data *data; while (cur) { + //LCOV_EXCL_START GSList *next = cur->next; data = (struct managed_idle_data *)cur->data; @@ -1485,6 +1502,7 @@ void _connection_callback_cleanup(void) cur = managed_idler_list; } else cur = next; + //LCOV_EXCL_STOP } g_slist_free(managed_idler_list); @@ -1497,10 +1515,10 @@ int _connection_libnet_check_get_privilege() rv = net_check_get_privilege(); if (rv == NET_ERR_ACCESS_DENIED) { - CONNECTION_LOG(CONNECTION_ERROR, "Access denied"); - return CONNECTION_ERROR_PERMISSION_DENIED; + CONNECTION_LOG(CONNECTION_ERROR, "Access denied"); //LCOV_EXCL_LINE + return CONNECTION_ERROR_PERMISSION_DENIED; //LCOV_EXCL_LINE } else if (rv != NET_ERR_NONE) - return CONNECTION_ERROR_OPERATION_FAILED; + return CONNECTION_ERROR_OPERATION_FAILED; //LCOV_EXCL_LINE return CONNECTION_ERROR_NONE; } @@ -1511,21 +1529,21 @@ int _connection_libnet_check_profile_privilege() rv = net_check_profile_privilege(); if (rv == NET_ERR_ACCESS_DENIED) { - CONNECTION_LOG(CONNECTION_ERROR, "Access denied"); - return CONNECTION_ERROR_PERMISSION_DENIED; + CONNECTION_LOG(CONNECTION_ERROR, "Access denied"); //LCOV_EXCL_LINE + return CONNECTION_ERROR_PERMISSION_DENIED; //LCOV_EXCL_LINE } else if (rv != NET_ERR_NONE) - return CONNECTION_ERROR_OPERATION_FAILED; + return CONNECTION_ERROR_OPERATION_FAILED; //LCOV_EXCL_LINE return CONNECTION_ERROR_NONE; } bool __libnet_check_feature_supported(const char *key, connection_supported_feature_e feature) { - if(!connection_is_feature_checked[feature]) { - if(system_info_get_platform_bool(key, &connection_feature_supported[feature]) < 0) { - CONNECTION_LOG(CONNECTION_ERROR, "Error - Feature getting from System Info"); - set_last_result(CONNECTION_ERROR_OPERATION_FAILED); - return CONNECTION_ERROR_OPERATION_FAILED; + if (!connection_is_feature_checked[feature]) { + if (system_info_get_platform_bool(key, &connection_feature_supported[feature]) < 0) { + CONNECTION_LOG(CONNECTION_ERROR, "Error - Feature getting from System Info"); //LCOV_EXCL_LINE + set_last_result(CONNECTION_ERROR_OPERATION_FAILED); //LCOV_EXCL_LINE + return CONNECTION_ERROR_OPERATION_FAILED; //LCOV_EXCL_LINE } connection_is_feature_checked[feature] = true; } @@ -1541,21 +1559,16 @@ int _connection_check_feature_supported(const char *feature_name, ...) va_start(list, feature_name); key = feature_name; - while(1) { - if((strcmp(key, TELEPHONY_FEATURE) == 0)){ + while (1) { + if (strcmp(key, TELEPHONY_FEATURE) == 0) value = __libnet_check_feature_supported(key, CONNECTION_SUPPORTED_FEATURE_TELEPHONY); - } - if((strcmp(key, WIFI_FEATURE) == 0)){ + if (strcmp(key, WIFI_FEATURE) == 0) value = __libnet_check_feature_supported(key, CONNECTION_SUPPORTED_FEATURE_WIFI); - } - if((strcmp(key, TETHERING_BLUETOOTH_FEATURE) == 0)){ + if (strcmp(key, TETHERING_BLUETOOTH_FEATURE) == 0) value = __libnet_check_feature_supported(key, CONNECTION_SUPPORTED_FEATURE_TETHERING_BLUETOOTH); - } - if((strcmp(key, ETHERNET_FEATURE) == 0)){ + if (strcmp(key, ETHERNET_FEATURE) == 0) value = __libnet_check_feature_supported(key, CONNECTION_SUPPORTED_FEATURE_ETHERNET); - } - SECURE_CONNECTION_LOG(CONNECTION_INFO, "%s feature is %s", key, (value?"true":"false")); feature_supported |= value; key = va_arg(list, const char *); if (!key) break;