5 * Copyright (C) 2007-2014 Intel Corporation. All rights reserved.
7 * This program is free software; you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License version 2 as
9 * published by the Free Software Foundation.
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
16 * You should have received a copy of the GNU General Public License
17 * along with this program; if not, write to the Free Software
18 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
31 #include <sys/ioctl.h>
32 #include <net/ethernet.h>
37 static GSList *device_list = NULL;
38 static gchar **device_filter = NULL;
39 static gchar **nodevice_filter = NULL;
42 static DBusConnection *connection;
45 enum connman_pending_type {
51 struct connman_device {
53 enum connman_device_type type;
54 enum connman_pending_type powered_pending; /* Indicates a pending
59 bool scanning[MAX_CONNMAN_SERVICE_TYPES];
67 guint pending_timeout;
69 struct connman_device_driver *driver;
73 struct connman_network *network;
76 time_t last_user_selection_time;
77 char *last_user_selection_ident;
78 char *last_connected_ident;
79 GList *pending_reply_list; /* List of DBusMessage* for async reply to multiple
80 * device power dbus calls, which are made before
81 * connman_device_set_powered().
84 bool is_5_0_ghz_supported;
85 unsigned int mac_policy;
86 unsigned int preassoc_mac_policy;
87 unsigned int random_mac_lifetime;
92 static void __clear_pending_trigger(gpointer data, gpointer user_data)
94 DBusMessage *msg = (DBusMessage *)data;
95 dbus_message_unref(msg);
99 static void clear_pending_trigger(struct connman_device *device)
101 #if defined TIZEN_EXT
102 if (device->pending_reply_list) {
103 g_list_foreach(device->pending_reply_list, __clear_pending_trigger, NULL);
104 g_list_free(device->pending_reply_list);
105 device->pending_reply_list = NULL;
108 if (device->pending_timeout > 0) {
109 g_source_remove(device->pending_timeout);
110 device->pending_timeout = 0;
114 static const char *type2description(enum connman_device_type type)
117 case CONNMAN_DEVICE_TYPE_UNKNOWN:
118 case CONNMAN_DEVICE_TYPE_VENDOR:
120 case CONNMAN_DEVICE_TYPE_ETHERNET:
122 case CONNMAN_DEVICE_TYPE_WIFI:
124 case CONNMAN_DEVICE_TYPE_BLUETOOTH:
126 case CONNMAN_DEVICE_TYPE_GPS:
128 case CONNMAN_DEVICE_TYPE_CELLULAR:
130 case CONNMAN_DEVICE_TYPE_GADGET:
138 static const char *type2string(enum connman_device_type type)
141 case CONNMAN_DEVICE_TYPE_UNKNOWN:
142 case CONNMAN_DEVICE_TYPE_VENDOR:
144 case CONNMAN_DEVICE_TYPE_ETHERNET:
146 case CONNMAN_DEVICE_TYPE_WIFI:
148 case CONNMAN_DEVICE_TYPE_BLUETOOTH:
150 case CONNMAN_DEVICE_TYPE_GPS:
152 case CONNMAN_DEVICE_TYPE_CELLULAR:
154 case CONNMAN_DEVICE_TYPE_GADGET:
162 enum connman_service_type __connman_device_get_service_type(
163 struct connman_device *device)
165 enum connman_device_type type = connman_device_get_type(device);
168 case CONNMAN_DEVICE_TYPE_UNKNOWN:
169 case CONNMAN_DEVICE_TYPE_VENDOR:
170 case CONNMAN_DEVICE_TYPE_GPS:
172 case CONNMAN_DEVICE_TYPE_ETHERNET:
173 return CONNMAN_SERVICE_TYPE_ETHERNET;
174 case CONNMAN_DEVICE_TYPE_WIFI:
175 return CONNMAN_SERVICE_TYPE_WIFI;
176 case CONNMAN_DEVICE_TYPE_BLUETOOTH:
177 return CONNMAN_SERVICE_TYPE_BLUETOOTH;
178 case CONNMAN_DEVICE_TYPE_CELLULAR:
179 return CONNMAN_SERVICE_TYPE_CELLULAR;
180 case CONNMAN_DEVICE_TYPE_GADGET:
181 return CONNMAN_SERVICE_TYPE_GADGET;
185 return CONNMAN_SERVICE_TYPE_UNKNOWN;
188 static bool device_has_service_type(struct connman_device *device,
189 enum connman_service_type service_type)
191 enum connman_service_type device_service_type =
192 __connman_device_get_service_type(device);
195 * For devices whose device_service_type is unknown we should
196 * allow to decide whether they support specific service_type
199 if (device_service_type == CONNMAN_SERVICE_TYPE_UNKNOWN)
202 #if defined TIZEN_EXT_WIFI_MESH
203 if (device_service_type == CONNMAN_SERVICE_TYPE_MESH)
204 return service_type != CONNMAN_SERVICE_TYPE_MESH;
207 if (device_service_type == CONNMAN_SERVICE_TYPE_WIFI) {
208 return service_type == CONNMAN_SERVICE_TYPE_WIFI ||
209 service_type == CONNMAN_SERVICE_TYPE_P2P;
212 return service_type == device_service_type;
215 #if defined TIZEN_EXT
216 static void __device_pending_reset(gpointer data, gpointer user_data)
218 DBusMessage *msg = (DBusMessage *)data;
221 reply = __connman_error_failed(msg, ETIMEDOUT);
223 g_dbus_send_message(connection, reply);
225 dbus_message_unref(msg);
229 static gboolean device_pending_reset(gpointer user_data)
231 struct connman_device *device = user_data;
233 DBG("device %p", device);
235 #if defined TIZEN_EXT
238 /* Power request timed out, send ETIMEDOUT. */
239 if (device->pending_reply_list) {
240 g_list_foreach(device->pending_reply_list, __device_pending_reset, NULL);
241 g_list_free(device->pending_reply_list);
242 device->pending_reply_list = NULL;
245 /* Power request timedout, reset power pending state. */
246 device->pending_timeout = 0;
247 device->powered_pending = PENDING_NONE;
252 int __connman_device_enable(struct connman_device *device)
256 DBG("device %p", device);
258 if (!device->driver || !device->driver->enable)
261 /* There is an ongoing power disable request. */
262 if (device->powered_pending == PENDING_DISABLE)
265 if (device->powered_pending == PENDING_ENABLE)
268 if (device->powered_pending == PENDING_NONE && device->powered)
271 if (device->index > 0) {
272 err = connman_inet_ifup(device->index);
273 if (err < 0 && err != -EALREADY)
277 device->powered_pending = PENDING_ENABLE;
279 err = device->driver->enable(device);
281 * device gets enabled right away.
282 * Invoke the callback
285 connman_device_set_powered(device, true);
289 if (err == -EALREADY) {
290 /* If device is already powered, but connman is not updated */
291 connman_device_set_powered(device, true);
293 if (device->type == CONNMAN_DEVICE_TYPE_WIFI) {
294 device->driver->set_mac_policy(device, device->mac_policy);
295 device->driver->set_preassoc_mac_policy(device, device->preassoc_mac_policy);
296 device->driver->set_random_mac_lifetime(device, device->random_mac_lifetime);
298 #endif /* TIZEN_EXT */
302 * if err == -EINPROGRESS, then the DBus call to the respective daemon
303 * was successful. We set a 10 sec timeout so if the daemon never
304 * returns a reply, we would reset the pending request.
306 if (err == -EINPROGRESS)
307 device->pending_timeout = g_timeout_add_seconds(10,
308 device_pending_reset, device);
313 int __connman_device_disable(struct connman_device *device)
317 DBG("device %p", device);
319 /* Ongoing power enable request */
320 if (device->powered_pending == PENDING_ENABLE)
323 if (device->powered_pending == PENDING_DISABLE)
326 if (device->powered_pending == PENDING_NONE && !device->powered)
329 device->powered_pending = PENDING_DISABLE;
331 if (device->network) {
332 struct connman_service *service =
333 connman_service_lookup_from_network(device->network);
336 __connman_service_disconnect(service);
338 connman_network_set_connected(device->network, false);
341 if (!device->driver || !device->driver->disable)
344 err = device->driver->disable(device);
345 if (err == 0 || err == -EALREADY) {
346 connman_device_set_powered(device, false);
350 if (err == -EINPROGRESS)
351 device->pending_timeout = g_timeout_add_seconds(4,
352 device_pending_reset, device);
357 static void probe_driver(struct connman_device_driver *driver)
361 DBG("driver %p name %s", driver, driver->name);
363 for (list = device_list; list; list = list->next) {
364 struct connman_device *device = list->data;
369 if (driver->type != device->type)
372 if (driver->probe(device) < 0)
375 device->driver = driver;
377 __connman_technology_add_device(device);
381 static void remove_device(struct connman_device *device)
383 DBG("device %p", device);
385 __connman_device_disable(device);
387 __connman_technology_remove_device(device);
389 if (device->driver->remove)
390 device->driver->remove(device);
392 device->driver = NULL;
395 static void remove_driver(struct connman_device_driver *driver)
399 DBG("driver %p name %s", driver, driver->name);
401 for (list = device_list; list; list = list->next) {
402 struct connman_device *device = list->data;
404 if (device->driver == driver)
405 remove_device(device);
409 bool __connman_device_has_driver(struct connman_device *device)
411 if (!device || !device->driver)
417 static GSList *driver_list = NULL;
419 static gint compare_priority(gconstpointer a, gconstpointer b)
421 const struct connman_device_driver *driver1 = a;
422 const struct connman_device_driver *driver2 = b;
424 return driver2->priority - driver1->priority;
428 * connman_device_driver_register:
429 * @driver: device driver definition
431 * Register a new device driver
433 * Returns: %0 on success
435 int connman_device_driver_register(struct connman_device_driver *driver)
437 DBG("driver %p name %s", driver, driver->name);
439 driver_list = g_slist_insert_sorted(driver_list, driver,
441 probe_driver(driver);
447 * connman_device_driver_unregister:
448 * @driver: device driver definition
450 * Remove a previously registered device driver
452 void connman_device_driver_unregister(struct connman_device_driver *driver)
454 DBG("driver %p name %s", driver, driver->name);
456 driver_list = g_slist_remove(driver_list, driver);
458 remove_driver(driver);
461 static void free_network(gpointer data)
463 struct connman_network *network = data;
465 DBG("network %p", network);
467 __connman_network_set_device(network, NULL);
469 connman_network_unref(network);
472 static void device_destruct(struct connman_device *device)
474 DBG("device %p name %s", device, device->name);
476 clear_pending_trigger(device);
478 g_hash_table_destroy(device->networks);
479 device->networks = NULL;
481 g_free(device->ident);
482 g_free(device->node);
483 g_free(device->name);
484 g_free(device->address);
485 g_free(device->interface);
486 g_free(device->path);
488 g_free(device->last_network);
490 #if defined TIZEN_EXT
491 g_free(device->last_user_selection_ident);
492 g_free(device->last_connected_ident);
498 #if defined TIZEN_EXT
499 static void device_send_changed(const char *ifname, enum connman_service_type type,
500 const char *key, bool state)
503 DBusMessageIter iter, dict;
504 dbus_bool_t value = state;
505 const char *tech_path = connman_techonology_get_path(type);
507 if (!tech_path || !ifname)
510 DBG("%s %s %s", ifname, key, state ? "TRUE" : "FALSE");
512 signal = dbus_message_new_signal(tech_path,
513 CONNMAN_TECHNOLOGY_INTERFACE, "DeviceChanged");
517 dbus_message_iter_init_append(signal, &iter);
519 connman_dbus_dict_open(&iter, &dict);
520 connman_dbus_dict_append_basic(&dict, "Ifname",
523 connman_dbus_dict_append_basic(&dict, key,
526 connman_dbus_dict_close(&iter, &dict);
528 dbus_connection_send(connection, signal, NULL);
529 dbus_message_unref(signal);
532 static void __device_send_reply(gpointer data, gpointer user_data)
534 DBusMessage *msg = (DBusMessage *)data;
535 g_dbus_send_reply(connection, msg, DBUS_TYPE_INVALID);
536 dbus_message_unref(msg);
539 static void device_send_reply(struct connman_device *device)
541 if (device->pending_reply_list) {
542 g_list_foreach(device->pending_reply_list, __device_send_reply, NULL);
543 g_list_free(device->pending_reply_list);
544 device->pending_reply_list = NULL;
550 * connman_device_create:
551 * @node: device node name (for example an address)
554 * Allocate a new device of given #type and assign the #node name to it.
556 * Returns: a newly-allocated #connman_device structure
558 struct connman_device *connman_device_create(const char *node,
559 enum connman_device_type type)
561 struct connman_device *device;
563 DBG("node %s type %d", node, type);
565 device = g_try_new0(struct connman_device, 1);
569 DBG("device %p", device);
571 device->refcount = 1;
574 device->name = g_strdup(type2description(device->type));
576 device->networks = g_hash_table_new_full(g_str_hash, g_str_equal,
577 g_free, free_network);
579 device_list = g_slist_prepend(device_list, device);
585 * connman_device_ref:
586 * @device: device structure
588 * Increase reference counter of device
590 struct connman_device *connman_device_ref_debug(struct connman_device *device,
591 const char *file, int line, const char *caller)
593 DBG("%p ref %d by %s:%d:%s()", device, device->refcount + 1,
596 __sync_fetch_and_add(&device->refcount, 1);
602 * connman_device_unref:
603 * @device: device structure
605 * Decrease reference counter of device
607 void connman_device_unref_debug(struct connman_device *device,
608 const char *file, int line, const char *caller)
610 DBG("%p ref %d by %s:%d:%s()", device, device->refcount - 1,
613 if (__sync_fetch_and_sub(&device->refcount, 1) != 1)
616 if (device->driver) {
617 device->driver->remove(device);
618 device->driver = NULL;
621 device_list = g_slist_remove(device_list, device);
623 device_destruct(device);
626 const char *__connman_device_get_type(struct connman_device *device)
628 return type2string(device->type);
632 * connman_device_get_type:
633 * @device: device structure
637 enum connman_device_type connman_device_get_type(struct connman_device *device)
643 * connman_device_set_index:
644 * @device: device structure
645 * @index: index number
647 * Set index number of device
649 void connman_device_set_index(struct connman_device *device, int index)
651 device->index = index;
655 * connman_device_get_index:
656 * @device: device structure
658 * Get index number of device
660 int connman_device_get_index(struct connman_device *device)
662 return device->index;
666 * connman_device_set_interface:
667 * @device: device structure
668 * @interface: interface name
670 * Set interface name of device
672 void connman_device_set_interface(struct connman_device *device,
673 const char *interface)
675 g_free(device->interface);
676 device->interface = g_strdup(interface);
679 const char *str = type2description(device->type);
680 if (str && device->interface)
681 device->name = g_strdup_printf("%s (%s)", str,
687 * connman_device_set_ident:
688 * @device: device structure
689 * @ident: unique identifier
691 * Set unique identifier of device
693 void connman_device_set_ident(struct connman_device *device,
697 if (device->ident && device->powered)
701 g_free(device->ident);
702 device->ident = g_strdup(ident);
705 const char *connman_device_get_ident(struct connman_device *device)
707 return device->ident;
711 * connman_device_set_powered:
712 * @device: device structure
713 * @powered: powered state
715 * Change power state of device
717 int connman_device_set_powered(struct connman_device *device,
720 struct connman_device_scan_params params;
721 enum connman_service_type type;
724 DBG("device %p powered %d", device, powered);
726 if (device->powered == powered)
729 #if defined TIZEN_EXT
730 device_send_reply(device);
733 clear_pending_trigger(device);
735 device->powered_pending = PENDING_NONE;
737 device->powered = powered;
739 type = __connman_device_get_service_type(device);
741 #if defined TIZEN_EXT
742 device_send_changed(device->interface, type, "Powered", powered);
743 technology_save_device(device);
746 if (!device->powered) {
747 __connman_technology_disabled(type);
751 __connman_technology_enabled(type);
753 for (i = 0; i < MAX_CONNMAN_SERVICE_TYPES; i++)
754 device->scanning[i] = false;
756 if (device->driver && device->driver->scan) {
757 memset(¶ms, 0, sizeof(params));
758 params.type = CONNMAN_SERVICE_TYPE_UNKNOWN;
760 device->driver->scan(device, ¶ms);
766 bool connman_device_get_powered(struct connman_device *device)
768 return device->powered;
771 static int device_scan(enum connman_service_type type,
772 struct connman_device *device,
773 bool force_full_scan)
775 struct connman_device_scan_params params;
777 if (!device->driver || !device->driver->scan)
780 if (!device->powered)
783 memset(¶ms, 0, sizeof(params));
785 params.force_full_scan = force_full_scan;
787 return device->driver->scan(device, ¶ms);
790 int __connman_device_disconnect(struct connman_device *device)
795 DBG("device %p", device);
797 g_hash_table_iter_init(&iter, device->networks);
799 while (g_hash_table_iter_next(&iter, &key, &value)) {
800 struct connman_network *network = value;
802 if (connman_network_get_connecting(network)) {
804 * Skip network in the process of connecting.
805 * This is a workaround for WiFi networks serviced
806 * by the supplicant plugin that hold a reference
807 * to the network. If we disconnect the network
808 * here then the referenced object will not be
809 * registered and usage (like launching DHCP client)
810 * will fail. There is nothing to be gained by
811 * removing the network here anyway.
813 connman_warn("Skipping disconnect of %s, network is connecting.",
814 connman_network_get_identifier(network));
818 __connman_network_disconnect(network);
824 int connman_device_reconnect_service(struct connman_device *device)
826 DBG("device %p", device);
828 __connman_service_auto_connect(CONNMAN_SERVICE_CONNECT_REASON_AUTO);
833 #if defined TIZEN_EXT
834 bool connman_device_set_last_user_selection_time(struct connman_device *device,
837 if (device->last_user_selection_time != time) {
838 device->last_user_selection_time = time;
845 time_t connman_device_get_last_user_selection_time(struct connman_device *device)
847 return device->last_user_selection_time;
850 bool connman_device_set_last_user_selection_ident(struct connman_device *device,
853 if (g_strcmp0(device->last_user_selection_ident, ident) != 0) {
854 g_free(device->last_user_selection_ident);
855 device->last_user_selection_ident = g_strdup(ident);
863 const char *connman_device_get_last_user_selection_ident(struct connman_device *device)
865 return device->last_user_selection_ident;
868 bool connman_device_set_last_connected_ident(struct connman_device *device,
871 if (g_strcmp0(device->last_connected_ident, ident) != 0) {
872 g_free(device->last_connected_ident);
873 device->last_connected_ident = g_strdup(ident);
881 const char *connman_device_get_last_connected_ident(struct connman_device *device)
883 return device->last_connected_ident;
887 #if defined TIZEN_EXT && defined TIZEN_EXT_INS
888 void connman_device_save_last_user_selection(struct connman_device *device)
892 gchar *selection_str;
894 keyfile = __connman_storage_load_ins();
896 selection_str = g_strdup_printf("%s:%ld",
897 device->last_user_selection_ident, device->last_user_selection_time);
900 keyfile = g_key_file_new();
902 g_key_file_set_string(keyfile, device->interface, "LastUserSelection", selection_str);
903 DBG("%s", selection_str);
904 __connman_storage_save_ins(keyfile);
907 get_str = g_key_file_get_string(keyfile, device->interface, "LastUserSelection", NULL);
908 if (!get_str || g_strcmp0(get_str, selection_str) != 0) {
909 g_key_file_set_string(keyfile, device->interface, "LastUserSelection", selection_str);
910 DBG("%s -> %s", get_str, selection_str);
911 __connman_storage_save_ins(keyfile);
917 g_free(selection_str);
918 g_key_file_free(keyfile);
921 void connman_device_load_last_user_selection(struct connman_device *device)
925 char **selection_str;
927 keyfile = __connman_storage_load_ins();
931 get_str = g_key_file_get_string(keyfile, device->interface, "LastUserSelection", NULL);
933 selection_str = g_strsplit(get_str, ":", 0);
937 time_t last_user_selection_time;
939 /* Only events that occur within 8 hours are counted. */
940 ref_time = time(NULL);
941 timeinfo = localtime(&ref_time);
942 timeinfo->tm_hour -= 8;
943 ref_time = mktime(timeinfo);
945 last_user_selection_time = strtol(selection_str[1], NULL, 10);
947 if (last_user_selection_time > ref_time) {
948 if (g_strcmp0(selection_str[0], device->last_user_selection_ident) != 0) {
949 g_free(device->last_user_selection_ident);
950 device->last_user_selection_ident = g_strdup(selection_str[0]);
953 device->last_user_selection_time = last_user_selection_time;
955 DBG("%s %ld", device->last_user_selection_ident, device->last_user_selection_time);
958 g_strfreev(selection_str);
964 g_key_file_free(keyfile);
967 void connman_device_save_last_connected(struct connman_device *device)
972 if (!device->last_connected_ident)
975 keyfile = __connman_storage_load_ins();
978 keyfile = g_key_file_new();
980 g_key_file_set_string(keyfile, device->interface, "LastConnected", device->last_connected_ident);
981 DBG("%s", device->last_connected_ident);
982 __connman_storage_save_ins(keyfile);
985 get_str = g_key_file_get_string(keyfile, device->interface, "LastConnected", NULL);
986 if (!get_str || g_strcmp0(get_str, device->last_connected_ident) != 0) {
987 g_key_file_set_string(keyfile, device->interface, "LastConnected", device->last_connected_ident);
988 DBG("%s -> %s", get_str, device->last_connected_ident);
989 __connman_storage_save_ins(keyfile);
995 g_key_file_free(keyfile);
998 void connman_device_load_last_connected(struct connman_device *device)
1003 keyfile = __connman_storage_load_ins();
1007 get_str = g_key_file_get_string(keyfile, device->interface, "LastConnected", NULL);
1009 if (g_strcmp0(get_str, device->last_connected_ident) != 0) {
1010 g_free(device->last_connected_ident);
1011 device->last_connected_ident = g_strdup(get_str);
1014 DBG("%s", device->last_connected_ident);
1019 g_key_file_free(keyfile);
1021 #endif /* defined TIZEN_EXT && defined TIZEN_EXT_INS */
1023 static void mark_network_available(gpointer key, gpointer value,
1026 struct connman_network *network = value;
1028 connman_network_set_available(network, true);
1031 static void mark_network_unavailable(gpointer key, gpointer value,
1034 struct connman_network *network = value;
1036 if (connman_network_get_connected(network) ||
1037 connman_network_get_connecting(network))
1040 connman_network_set_available(network, false);
1043 static gboolean remove_unavailable_network(gpointer key, gpointer value,
1046 struct connman_network *network = value;
1048 if (connman_network_get_connected(network) ||
1049 connman_network_get_connecting(network))
1052 if (connman_network_get_available(network))
1058 void __connman_device_cleanup_networks(struct connman_device *device)
1060 g_hash_table_foreach_remove(device->networks,
1061 remove_unavailable_network, NULL);
1064 bool connman_device_get_scanning(struct connman_device *device,
1065 enum connman_service_type type)
1069 if (type != CONNMAN_SERVICE_TYPE_UNKNOWN)
1070 return device->scanning[type];
1072 for (i = 0; i < MAX_CONNMAN_SERVICE_TYPES; i++)
1073 if (device->scanning[i])
1079 void connman_device_reset_scanning(struct connman_device *device)
1081 g_hash_table_foreach(device->networks,
1082 mark_network_available, NULL);
1086 * connman_device_set_scanning:
1087 * @device: device structure
1088 * @scanning: scanning state
1090 * Change scanning state of device
1092 int connman_device_set_scanning(struct connman_device *device,
1093 enum connman_service_type type, bool scanning)
1095 DBG("device %p scanning %d", device, scanning);
1097 if (!device->driver || !device->driver->scan)
1100 if (type == CONNMAN_SERVICE_TYPE_UNKNOWN)
1103 if (device->scanning[type] == scanning)
1106 device->scanning[type] = scanning;
1109 __connman_technology_scan_started(device);
1111 g_hash_table_foreach(device->networks,
1112 mark_network_unavailable, NULL);
1117 __connman_device_cleanup_networks(device);
1119 __connman_technology_scan_stopped(device, type);
1121 __connman_service_auto_connect(CONNMAN_SERVICE_CONNECT_REASON_AUTO);
1123 #if defined TIZEN_EXT_WIFI_MESH
1124 if (type == CONNMAN_SERVICE_TYPE_MESH)
1125 __connman_mesh_auto_connect();
1132 * connman_device_set_string:
1133 * @device: device structure
1134 * @key: unique identifier
1135 * @value: string value
1137 * Set string value for specific key
1139 int connman_device_set_string(struct connman_device *device,
1140 const char *key, const char *value)
1142 DBG("device %p key %s value %s", device, key, value);
1144 if (g_str_equal(key, "Address")) {
1146 if (device->address && device->powered)
1150 g_free(device->address);
1151 device->address = g_strdup(value);
1152 } else if (g_str_equal(key, "Name")) {
1153 g_free(device->name);
1154 device->name = g_strdup(value);
1155 } else if (g_str_equal(key, "Node")) {
1156 g_free(device->node);
1157 device->node = g_strdup(value);
1158 } else if (g_str_equal(key, "Path")) {
1159 g_free(device->path);
1160 device->path = g_strdup(value);
1169 * connman_device_get_string:
1170 * @device: device structure
1171 * @key: unique identifier
1173 * Get string value for specific key
1175 const char *connman_device_get_string(struct connman_device *device,
1178 #if defined TIZEN_EXT
1179 if (!simplified_log)
1181 DBG("device %p key %s", device, key);
1183 if (g_str_equal(key, "Address"))
1184 return device->address;
1185 else if (g_str_equal(key, "Name"))
1186 return device->name;
1187 else if (g_str_equal(key, "Node"))
1188 return device->node;
1189 else if (g_str_equal(key, "Interface"))
1190 return device->interface;
1191 else if (g_str_equal(key, "Path"))
1192 return device->path;
1198 * connman_device_add_network:
1199 * @device: device structure
1200 * @network: network structure
1202 * Add new network to the device
1204 int connman_device_add_network(struct connman_device *device,
1205 struct connman_network *network)
1207 const char *identifier = connman_network_get_identifier(network);
1208 #if defined TIZEN_EXT
1209 if (!simplified_log)
1211 DBG("device %p network %p", device, network);
1216 connman_network_ref(network);
1218 __connman_network_set_device(network, device);
1220 g_hash_table_replace(device->networks, g_strdup(identifier),
1227 * connman_device_get_network:
1228 * @device: device structure
1229 * @identifier: network identifier
1231 * Get network for given identifier
1233 struct connman_network *connman_device_get_network(struct connman_device *device,
1234 const char *identifier)
1236 #if defined TIZEN_EXT
1237 if (!simplified_log)
1239 DBG("device %p identifier %s", device, identifier);
1241 return g_hash_table_lookup(device->networks, identifier);
1244 #if defined TIZEN_EXT
1245 struct connman_network *connman_device_get_default_network(
1246 struct connman_device *device)
1248 return device->network;
1251 void connman_device_set_pending_reply(struct connman_device *device,
1254 device->pending_reply_list = g_list_prepend(device->pending_reply_list, dbus_message_ref(msg));
1257 void connman_device_send_connected_signal(struct connman_device *device,
1260 enum connman_service_type type;
1265 type = __connman_device_get_service_type(device);
1266 device_send_changed(device->interface, type, "Connected", connected);
1269 void connman_device_set_max_scan_ssids(struct connman_device *device,
1272 device->max_scan_ssids = max_scan_ssids;
1275 int connman_device_get_max_scan_ssids(struct connman_device *device)
1277 return device->max_scan_ssids;
1280 void connman_device_set_wifi_5ghz_supported(struct connman_device *device,
1281 bool is_5_0_ghz_supported)
1283 device->is_5_0_ghz_supported = is_5_0_ghz_supported;
1286 bool connman_device_get_wifi_5ghz_supported(struct connman_device *device)
1288 return device->is_5_0_ghz_supported;
1293 * connman_device_remove_network:
1294 * @device: device structure
1295 * @identifier: network identifier
1297 * Remove network for given identifier
1299 int connman_device_remove_network(struct connman_device *device,
1300 struct connman_network *network)
1302 const char *identifier;
1304 DBG("device %p network %p", device, network);
1309 identifier = connman_network_get_identifier(network);
1310 g_hash_table_remove(device->networks, identifier);
1315 void __connman_device_set_network(struct connman_device *device,
1316 struct connman_network *network)
1323 if (device->network == network)
1327 name = connman_network_get_string(network, "Name");
1328 g_free(device->last_network);
1329 device->last_network = g_strdup(name);
1331 device->network = network;
1333 g_free(device->last_network);
1334 device->last_network = NULL;
1336 device->network = NULL;
1340 static bool match_driver(struct connman_device *device,
1341 struct connman_device_driver *driver)
1343 if (device->type == driver->type ||
1344 driver->type == CONNMAN_DEVICE_TYPE_UNKNOWN)
1351 * connman_device_register:
1352 * @device: device structure
1354 * Register device with the system
1356 int connman_device_register(struct connman_device *device)
1360 DBG("device %p name %s", device, device->name);
1365 for (list = driver_list; list; list = list->next) {
1366 struct connman_device_driver *driver = list->data;
1368 if (!match_driver(device, driver))
1371 DBG("driver %p name %s", driver, driver->name);
1373 if (driver->probe(device) == 0) {
1374 device->driver = driver;
1379 if (!device->driver)
1382 return __connman_technology_add_device(device);
1386 * connman_device_unregister:
1387 * @device: device structure
1389 * Unregister device with the system
1391 void connman_device_unregister(struct connman_device *device)
1393 DBG("device %p name %s", device, device->name);
1395 if (!device->driver)
1398 remove_device(device);
1402 * connman_device_get_data:
1403 * @device: device structure
1405 * Get private device data pointer
1407 void *connman_device_get_data(struct connman_device *device)
1409 return device->driver_data;
1413 * connman_device_set_data:
1414 * @device: device structure
1415 * @data: data pointer
1417 * Set private device data pointer
1419 void connman_device_set_data(struct connman_device *device, void *data)
1421 device->driver_data = data;
1424 struct connman_device *__connman_device_find_device(
1425 enum connman_service_type type)
1429 for (list = device_list; list; list = list->next) {
1430 struct connman_device *device = list->data;
1431 enum connman_service_type service_type =
1432 __connman_device_get_service_type(device);
1434 if (service_type != type)
1443 struct connman_device *connman_device_find_by_index(int index)
1447 for (list = device_list; list; list = list->next) {
1448 struct connman_device *device = list->data;
1449 if (device->index == index)
1457 * connman_device_set_regdom
1458 * @device: device structure
1459 * @alpha2: string representing regulatory domain
1461 * Set regulatory domain on device basis
1463 int connman_device_set_regdom(struct connman_device *device,
1466 if (!device->driver || !device->driver->set_regdom)
1469 if (!device->powered)
1472 return device->driver->set_regdom(device, alpha2);
1476 * connman_device_regdom_notify
1477 * @device: device structure
1478 * @alpha2: string representing regulatory domain
1480 * Notify on setting regulatory domain on device basis
1482 void connman_device_regdom_notify(struct connman_device *device,
1483 int result, const char *alpha2)
1485 __connman_technology_notify_regdom_by_device(device, result, alpha2);
1488 #if defined TIZEN_EXT
1489 static int device_specific_scan(enum connman_service_type type,
1490 struct connman_device *device,
1491 int scan_type, GSList *specific_scan_list)
1493 if (!device->driver || !device->driver->specific_scan)
1496 if (!device->powered)
1499 return device->driver->specific_scan(type, device, scan_type,
1500 specific_scan_list, NULL);
1503 int __connman_device_request_specific_scan(enum connman_service_type type,
1504 const char *ifname, int scan_type, GSList *specific_scan_list)
1506 bool success = false;
1507 int last_err = -ENOSYS;
1512 case CONNMAN_SERVICE_TYPE_UNKNOWN:
1513 case CONNMAN_SERVICE_TYPE_SYSTEM:
1514 case CONNMAN_SERVICE_TYPE_ETHERNET:
1515 case CONNMAN_SERVICE_TYPE_BLUETOOTH:
1516 case CONNMAN_SERVICE_TYPE_CELLULAR:
1517 case CONNMAN_SERVICE_TYPE_GPS:
1518 case CONNMAN_SERVICE_TYPE_VPN:
1519 case CONNMAN_SERVICE_TYPE_GADGET:
1521 case CONNMAN_SERVICE_TYPE_WIFI:
1522 case CONNMAN_SERVICE_TYPE_P2P:
1523 #if defined TIZEN_EXT_WIFI_MESH
1524 case CONNMAN_SERVICE_TYPE_MESH:
1529 for (list = device_list; list; list = list->next) {
1530 struct connman_device *device = list->data;
1531 enum connman_service_type service_type =
1532 __connman_device_get_service_type(device);
1534 if (service_type != CONNMAN_SERVICE_TYPE_UNKNOWN) {
1535 if (type == CONNMAN_SERVICE_TYPE_P2P) {
1536 if (service_type != CONNMAN_SERVICE_TYPE_WIFI)
1538 } else if (service_type != type)
1542 if (ifname && g_strcmp0(device->interface, ifname) != 0)
1545 err = device_specific_scan(type, device, scan_type, specific_scan_list);
1546 if (err == 0 || err == -EINPROGRESS) {
1550 DBG("device %p err %d", device, err);
1560 int connman_device_request_device_scan(enum connman_service_type type,
1561 const char * ifname, bool force_full_scan)
1563 bool success = false;
1564 int last_err = -ENOSYS;
1569 case CONNMAN_SERVICE_TYPE_UNKNOWN:
1570 case CONNMAN_SERVICE_TYPE_SYSTEM:
1571 case CONNMAN_SERVICE_TYPE_ETHERNET:
1572 case CONNMAN_SERVICE_TYPE_BLUETOOTH:
1573 case CONNMAN_SERVICE_TYPE_CELLULAR:
1574 case CONNMAN_SERVICE_TYPE_GPS:
1575 case CONNMAN_SERVICE_TYPE_VPN:
1576 case CONNMAN_SERVICE_TYPE_GADGET:
1578 case CONNMAN_SERVICE_TYPE_WIFI:
1579 case CONNMAN_SERVICE_TYPE_P2P:
1580 #if defined TIZEN_EXT_WIFI_MESH
1581 case CONNMAN_SERVICE_TYPE_MESH:
1586 for (list = device_list; list; list = list->next) {
1587 struct connman_device *device = list->data;
1589 if (!device_has_service_type(device, type))
1592 if (g_strcmp0(device->interface, ifname) != 0)
1595 err = device_scan(type, device, force_full_scan);
1597 if (err == 0 || err == -EINPROGRESS) {
1601 DBG("device %p err %d", device, err);
1612 #if defined TIZEN_EXT_WIFI_MESH
1613 static int device_abort_scan(enum connman_service_type type,
1614 struct connman_device *device)
1616 if (!device->driver || !device->driver->scan)
1619 if (!device->powered)
1622 return device->driver->abort_scan(type, device);
1625 int __connman_device_abort_scan(enum connman_service_type type)
1630 if (type != CONNMAN_SERVICE_TYPE_MESH)
1633 for (list = device_list; list; list = list->next) {
1634 struct connman_device *device = list->data;
1635 enum connman_service_type service_type =
1636 __connman_device_get_service_type(device);
1638 if (service_type != CONNMAN_SERVICE_TYPE_UNKNOWN) {
1639 if (type == CONNMAN_SERVICE_TYPE_MESH)
1640 if (service_type != CONNMAN_SERVICE_TYPE_WIFI)
1643 if (!device->scanning) {
1648 err = device_abort_scan(type, device);
1654 static int device_mesh_specific_scan(enum connman_service_type type,
1655 struct connman_device *device, const char *name,
1658 if (!device->driver || !device->driver->mesh_specific_scan)
1661 if (!device->powered)
1664 return device->driver->mesh_specific_scan(type, device, name, freq, NULL);
1667 int __connman_device_request_mesh_specific_scan(enum connman_service_type type,
1671 bool success = false;
1672 int last_err = -ENOSYS;
1676 if (type != CONNMAN_SERVICE_TYPE_MESH)
1679 for (list = device_list; list; list = list->next) {
1680 struct connman_device *device = list->data;
1681 enum connman_service_type service_type =
1682 __connman_device_get_service_type(device);
1684 if (service_type != CONNMAN_SERVICE_TYPE_UNKNOWN) {
1685 if (type == CONNMAN_SERVICE_TYPE_MESH)
1686 if (service_type != CONNMAN_SERVICE_TYPE_WIFI)
1690 err = device_mesh_specific_scan(type, device, name, freq);
1691 if (err == 0 || err == -EALREADY || err == -EINPROGRESS) {
1695 DBG("device %p err %d", device, err);
1704 #endif /* TIZEN_EXT_WIFI_MESH */
1707 static int connman_device_request_scan(enum connman_service_type type,
1708 bool force_full_scan)
1710 bool success = false;
1711 int last_err = -ENOSYS;
1716 case CONNMAN_SERVICE_TYPE_UNKNOWN:
1717 case CONNMAN_SERVICE_TYPE_SYSTEM:
1718 case CONNMAN_SERVICE_TYPE_ETHERNET:
1719 case CONNMAN_SERVICE_TYPE_BLUETOOTH:
1720 case CONNMAN_SERVICE_TYPE_CELLULAR:
1721 case CONNMAN_SERVICE_TYPE_GPS:
1722 case CONNMAN_SERVICE_TYPE_VPN:
1723 case CONNMAN_SERVICE_TYPE_GADGET:
1725 case CONNMAN_SERVICE_TYPE_WIFI:
1726 case CONNMAN_SERVICE_TYPE_P2P:
1727 #if defined TIZEN_EXT_WIFI_MESH
1728 case CONNMAN_SERVICE_TYPE_MESH:
1733 for (list = device_list; list; list = list->next) {
1734 struct connman_device *device = list->data;
1736 if (!device_has_service_type(device, type))
1739 err = device_scan(type, device, force_full_scan);
1740 #if defined TIZEN_EXT
1741 /* When Scan is already in progress then return Error so that
1742 * wifi-manager can block the scan-done signal to be sent to
1743 * application and start requested scan after scan already in progress
1744 * is completed then notify to application about the scan event */
1745 if (err == 0 || err == -EINPROGRESS) {
1747 if (err == 0 || err == -EALREADY || err == -EINPROGRESS) {
1752 DBG("device %p err %d", device, err);
1762 int __connman_device_request_scan(enum connman_service_type type)
1764 return connman_device_request_scan(type, false);
1767 int __connman_device_request_scan_full(enum connman_service_type type)
1769 return connman_device_request_scan(type, true);
1772 int __connman_device_request_hidden_scan(struct connman_device *device,
1773 const char *ssid, unsigned int ssid_len,
1774 const char *identity, const char *passphrase,
1775 const char *security, void *user_data)
1777 struct connman_device_scan_params params;
1779 DBG("device %p", device);
1781 if (!device || !device->driver ||
1782 !device->driver->scan)
1785 params.type = CONNMAN_SERVICE_TYPE_UNKNOWN;
1787 params.ssid_len = ssid_len;
1788 params.identity = identity;
1789 params.passphrase = passphrase;
1790 params.security = security;
1791 params.user_data = user_data;
1793 return device->driver->scan(device, ¶ms);
1796 void __connman_device_stop_scan(enum connman_service_type type)
1800 for (list = device_list; list; list = list->next) {
1801 struct connman_device *device = list->data;
1803 if (!device_has_service_type(device, type))
1806 if (device->driver && device->driver->stop_scan)
1807 device->driver->stop_scan(type, device);
1811 #if defined TIZEN_EXT
1812 #define WIFI_MAC "/opt/etc/.mac.info"
1813 #define MAC_ADDR_LEN 18
1815 char *_get_wifi_addr(void)
1819 char wifi_mac[MAC_ADDR_LEN + 1];
1822 fp = fopen(WIFI_MAC, "r");
1824 connman_error("[%s] not present", WIFI_MAC);
1828 rv = fgets(wifi_mac, MAC_ADDR_LEN, fp);
1830 connman_error("Failed to get wifi mac address");
1835 str = g_try_malloc0(MAC_ADDR_LEN);
1837 connman_error("memory allocation failed");
1842 snprintf(str, MAC_ADDR_LEN, "%c%c:%c%c:%c%c:%c%c:%c%c:%c%c",
1843 g_ascii_tolower(wifi_mac[0]), g_ascii_tolower(wifi_mac[1]),
1844 g_ascii_tolower(wifi_mac[3]), g_ascii_tolower(wifi_mac[4]),
1845 g_ascii_tolower(wifi_mac[6]), g_ascii_tolower(wifi_mac[7]),
1846 g_ascii_tolower(wifi_mac[9]), g_ascii_tolower(wifi_mac[10]),
1847 g_ascii_tolower(wifi_mac[12]), g_ascii_tolower(wifi_mac[13]),
1848 g_ascii_tolower(wifi_mac[15]), g_ascii_tolower(wifi_mac[16]));
1853 char *_get_wifi_ident(void)
1857 char wifi_mac[MAC_ADDR_LEN + 1];
1860 fp = fopen(WIFI_MAC, "r");
1862 connman_error("[%s] not present", WIFI_MAC);
1866 rv = fgets(wifi_mac, MAC_ADDR_LEN, fp);
1868 connman_error("Failed to get wifi mac address");
1873 str = g_try_malloc0(MAC_ADDR_LEN);
1875 connman_error("memory allocation failed");
1880 snprintf(str, MAC_ADDR_LEN, "%c%c%c%c%c%c%c%c%c%c%c%c",
1881 g_ascii_tolower(wifi_mac[0]), g_ascii_tolower(wifi_mac[1]),
1882 g_ascii_tolower(wifi_mac[3]), g_ascii_tolower(wifi_mac[4]),
1883 g_ascii_tolower(wifi_mac[6]), g_ascii_tolower(wifi_mac[7]),
1884 g_ascii_tolower(wifi_mac[9]), g_ascii_tolower(wifi_mac[10]),
1885 g_ascii_tolower(wifi_mac[12]), g_ascii_tolower(wifi_mac[13]),
1886 g_ascii_tolower(wifi_mac[15]), g_ascii_tolower(wifi_mac[16]));
1892 #if defined TIZEN_EXT
1893 char *index2ident(int index, const char *prefix)
1895 static char *index2ident(int index, const char *prefix)
1899 struct ether_addr eth;
1906 sk = socket(PF_INET, SOCK_DGRAM | SOCK_CLOEXEC, 0);
1910 memset(&ifr, 0, sizeof(ifr));
1911 ifr.ifr_ifindex = index;
1913 err = ioctl(sk, SIOCGIFNAME, &ifr);
1916 err = ioctl(sk, SIOCGIFHWADDR, &ifr);
1923 len = prefix ? strlen(prefix) + 18 : 18;
1925 str = g_malloc(len);
1929 memcpy(ð, &ifr.ifr_hwaddr.sa_data, sizeof(eth));
1930 snprintf(str, len, "%s%02x%02x%02x%02x%02x%02x",
1931 prefix ? prefix : "",
1932 eth.ether_addr_octet[0],
1933 eth.ether_addr_octet[1],
1934 eth.ether_addr_octet[2],
1935 eth.ether_addr_octet[3],
1936 eth.ether_addr_octet[4],
1937 eth.ether_addr_octet[5]);
1942 #if defined TIZEN_EXT
1943 char *index2addr(int index)
1945 static char *index2addr(int index)
1949 struct ether_addr eth;
1956 sk = socket(PF_INET, SOCK_DGRAM | SOCK_CLOEXEC, 0);
1960 memset(&ifr, 0, sizeof(ifr));
1961 ifr.ifr_ifindex = index;
1963 err = ioctl(sk, SIOCGIFNAME, &ifr);
1966 err = ioctl(sk, SIOCGIFHWADDR, &ifr);
1977 memcpy(ð, &ifr.ifr_hwaddr.sa_data, sizeof(eth));
1978 snprintf(str, 18, "%02X:%02X:%02X:%02X:%02X:%02X",
1979 eth.ether_addr_octet[0],
1980 eth.ether_addr_octet[1],
1981 eth.ether_addr_octet[2],
1982 eth.ether_addr_octet[3],
1983 eth.ether_addr_octet[4],
1984 eth.ether_addr_octet[5]);
1989 struct connman_device *connman_device_create_from_index(int index)
1991 enum connman_device_type type;
1992 struct connman_device *device;
1993 char *devname, *ident = NULL;
1994 char *addr = NULL, *name = NULL;
1999 devname = connman_inet_ifname(index);
2003 if (__connman_device_isfiltered(devname)) {
2004 connman_info("Ignoring interface %s (filtered)", devname);
2009 type = __connman_rtnl_get_device_type(index);
2012 case CONNMAN_DEVICE_TYPE_UNKNOWN:
2013 connman_info("Ignoring interface %s (type unknown)", devname);
2016 case CONNMAN_DEVICE_TYPE_ETHERNET:
2017 case CONNMAN_DEVICE_TYPE_GADGET:
2018 case CONNMAN_DEVICE_TYPE_WIFI:
2019 name = index2ident(index, "");
2020 addr = index2addr(index);
2022 case CONNMAN_DEVICE_TYPE_BLUETOOTH:
2023 case CONNMAN_DEVICE_TYPE_CELLULAR:
2024 case CONNMAN_DEVICE_TYPE_GPS:
2025 case CONNMAN_DEVICE_TYPE_VENDOR:
2026 name = g_strdup(devname);
2030 device = connman_device_create(name, type);
2035 case CONNMAN_DEVICE_TYPE_UNKNOWN:
2036 case CONNMAN_DEVICE_TYPE_VENDOR:
2037 case CONNMAN_DEVICE_TYPE_GPS:
2039 case CONNMAN_DEVICE_TYPE_ETHERNET:
2040 case CONNMAN_DEVICE_TYPE_GADGET:
2041 ident = index2ident(index, NULL);
2043 case CONNMAN_DEVICE_TYPE_WIFI:
2044 ident = index2ident(index, NULL);
2046 case CONNMAN_DEVICE_TYPE_BLUETOOTH:
2048 case CONNMAN_DEVICE_TYPE_CELLULAR:
2049 ident = index2ident(index, NULL);
2053 connman_device_set_index(device, index);
2054 connman_device_set_interface(device, devname);
2055 #if defined TIZEN_EXT && defined TIZEN_EXT_INS
2056 connman_device_load_last_connected(device);
2057 connman_device_load_last_user_selection(device);
2058 #endif /* defined TIZEN_EXT && defined TIZEN_EXT_INS */
2061 connman_device_set_ident(device, ident);
2065 connman_device_set_string(device, "Address", addr);
2075 bool __connman_device_isfiltered(const char *devname)
2078 char **blacklisted_interfaces;
2084 for (pattern = device_filter, match = false; *pattern; pattern++) {
2085 if (g_pattern_match_simple(*pattern, devname)) {
2092 DBG("ignoring device %s (match)", devname);
2097 if (g_pattern_match_simple("dummy*", devname)) {
2098 DBG("ignoring dummy networking devices");
2102 if (!nodevice_filter)
2105 for (pattern = nodevice_filter; *pattern; pattern++) {
2106 if (g_pattern_match_simple(*pattern, devname)) {
2107 DBG("ignoring device %s (no match)", devname);
2113 if (__connman_inet_isrootnfs_device(devname)) {
2114 DBG("ignoring device %s (rootnfs)", devname);
2118 blacklisted_interfaces =
2119 connman_setting_get_string_list("NetworkInterfaceBlacklist");
2120 if (!blacklisted_interfaces)
2123 for (pattern = blacklisted_interfaces; *pattern; pattern++) {
2124 if (g_str_has_prefix(devname, *pattern)) {
2125 DBG("ignoring device %s (blacklist)", devname);
2133 static void cleanup_devices(void)
2136 * Check what interfaces are currently up and if connman is
2137 * suppose to handle the interface, then cleanup the mess
2138 * related to that interface. There might be weird routes etc
2139 * that are related to that interface and that might confuse
2140 * connmand. So in this case we just turn the interface down
2141 * so that kernel removes routes/addresses automatically and
2142 * then proceed the startup.
2144 * Note that this cleanup must be done before rtnl/detect code
2145 * has activated interface watches.
2151 interfaces = __connman_inet_get_running_interfaces();
2156 for (i = 0; interfaces[i]; i++) {
2159 struct sockaddr_in sin_addr, sin_mask;
2161 filtered = __connman_device_isfiltered(interfaces[i]);
2165 index = connman_inet_ifindex(interfaces[i]);
2169 if (!__connman_inet_get_address_netmask(index, &sin_addr,
2171 char *address = g_strdup(inet_ntoa(sin_addr.sin_addr));
2172 char *netmask = g_strdup(inet_ntoa(sin_mask.sin_addr));
2174 if (__connman_config_address_provisioned(address,
2176 DBG("Skip %s which is already provisioned "
2177 "with %s/%s", interfaces[i], address,
2188 DBG("cleaning up %s index %d", interfaces[i], index);
2190 #if defined TIZEN_EXT
2191 if (strcmp(interfaces[i], "wlan0") != 0)
2193 connman_inet_ifdown(index);
2196 * ConnMan will turn the interface UP automatically so
2197 * no need to do it here.
2201 g_strfreev(interfaces);
2204 int __connman_device_init(const char *device, const char *nodevice)
2208 #if defined TIZEN_EXT
2209 connection = connman_dbus_get_connection();
2213 device_filter = g_strsplit(device, ",", -1);
2216 nodevice_filter = g_strsplit(nodevice, ",", -1);
2223 void __connman_device_cleanup(void)
2227 g_strfreev(nodevice_filter);
2228 g_strfreev(device_filter);
2230 #if defined TIZEN_EXT
2231 dbus_connection_unref(connection);
2236 void connman_device_mac_policy_notify(struct connman_device *device,
2237 int result, unsigned int policy)
2239 device->mac_policy = policy;
2240 __connman_technology_notify_mac_policy_by_device(device, result, policy);
2243 int connman_device_set_mac_policy(struct connman_device *device,
2244 unsigned int policy)
2248 if (!device || !device->driver || !device->driver->set_mac_policy)
2251 device->mac_policy = policy;
2252 err = device->driver->set_mac_policy(device, policy);
2256 unsigned int connman_device_get_mac_policy(struct connman_device *device)
2258 return device->mac_policy;
2261 void connman_device_preassoc_mac_policy_notify(struct connman_device *device,
2262 int result, unsigned int policy)
2264 device->preassoc_mac_policy = policy;
2265 __connman_technology_notify_preassoc_mac_policy_by_device(device, result, policy);
2268 int connman_device_set_preassoc_mac_policy(struct connman_device *device,
2269 unsigned int policy)
2273 if (!device || !device->driver || !device->driver->set_preassoc_mac_policy)
2276 device->preassoc_mac_policy = policy;
2277 err = device->driver->set_preassoc_mac_policy(device, policy);
2281 unsigned int connman_device_get_preassoc_mac_policy(struct connman_device *device)
2283 return device->preassoc_mac_policy;
2286 void connman_device_random_mac_lifetime_notify(struct connman_device *device,
2287 int result, unsigned int lifetime)
2289 device->random_mac_lifetime = lifetime;
2290 __connman_technology_notify_random_mac_lifetime_by_device(device, result, lifetime);
2293 int connman_device_set_random_mac_lifetime(struct connman_device *device,
2294 unsigned int lifetime)
2298 if (!device || !device->driver || !device->driver->set_random_mac_lifetime)
2301 device->random_mac_lifetime = lifetime;
2302 err = device->driver->set_random_mac_lifetime(device, lifetime);
2306 unsigned int connman_device_get_random_mac_lifetime(struct connman_device *device)
2308 return device->random_mac_lifetime;