aboutsummaryrefslogtreecommitdiffstats
path: root/wpa_supplicant
diff options
context:
space:
mode:
authorJouni Malinen <j@w1.fi>2009-11-14 18:18:07 +0200
committerJouni Malinen <j@w1.fi>2009-11-14 18:18:07 +0200
commit9b61515c26136878b86ee2e0188bfa1270be392f (patch)
treeceba91a1bec1c5bce766e8940370305c55cbafbf /wpa_supplicant
parent485ec2ae48d6eb8821d2147a0de9d3312c64e4ee (diff)
downloadexternal_wpa_supplicant_8_ti-9b61515c26136878b86ee2e0188bfa1270be392f.zip
external_wpa_supplicant_8_ti-9b61515c26136878b86ee2e0188bfa1270be392f.tar.gz
external_wpa_supplicant_8_ti-9b61515c26136878b86ee2e0188bfa1270be392f.tar.bz2
dbus: Use method/property/signal handler arrays for registration
Clean up registration of large number of dbus method/property/signal handlers by using arrays containing all the information needed to call the registration functions.
Diffstat (limited to 'wpa_supplicant')
-rw-r--r--wpa_supplicant/ctrl_iface_dbus_new.c686
-rw-r--r--wpa_supplicant/ctrl_iface_dbus_new_helpers.c4
-rw-r--r--wpa_supplicant/ctrl_iface_dbus_new_helpers.h4
3 files changed, 336 insertions, 358 deletions
diff --git a/wpa_supplicant/ctrl_iface_dbus_new.c b/wpa_supplicant/ctrl_iface_dbus_new.c
index 598be91..019bfb0 100644
--- a/wpa_supplicant/ctrl_iface_dbus_new.c
+++ b/wpa_supplicant/ctrl_iface_dbus_new.c
@@ -914,121 +914,126 @@ static void wpas_dbus_signal_debug_params_changed(struct wpa_global *global)
}
-static void wpas_dbus_meth_reg_create_interface(
- struct wpa_global *global, struct wpa_dbus_object_desc *obj_desc)
-{
- struct wpa_dbus_argument margs[] = {
- { "args", "a{sv}", ARG_IN },
- { "path", "o", ARG_OUT },
- END_ARGS
- };
- wpa_dbus_method_register(obj_desc, WPAS_DBUS_NEW_INTERFACE,
- "CreateInterface",
- (WPADBusMethodHandler)
- &wpas_dbus_handler_create_interface,
- global, NULL, margs);
-}
-
-
-static void wpas_dbus_meth_reg_remove_interface(
- struct wpa_global *global, struct wpa_dbus_object_desc *obj_desc)
-{
- struct wpa_dbus_argument margs[] = {
- { "path", "o", ARG_IN },
- END_ARGS
- };
- wpa_dbus_method_register(obj_desc, WPAS_DBUS_NEW_INTERFACE,
- "RemoveInterface",
- (WPADBusMethodHandler)
- &wpas_dbus_handler_remove_interface,
- global, NULL, margs);
-}
-
-
-static void wpas_dbus_meth_reg_get_interface(
- struct wpa_global *global, struct wpa_dbus_object_desc *obj_desc)
-{
- struct wpa_dbus_argument margs[] = {
- { "ifname", "s", ARG_IN },
- { "path", "o", ARG_OUT },
- END_ARGS
- };
- wpa_dbus_method_register(obj_desc, WPAS_DBUS_NEW_INTERFACE,
- "GetInterface",
- (WPADBusMethodHandler)
- &wpas_dbus_handler_get_interface,
- global, NULL, margs);
-}
+struct wpas_dbus_method {
+ const char *name;
+ const char *iface;
+ WPADBusMethodHandler handler;
+ struct wpa_dbus_argument args[3];
+};
+struct wpas_dbus_property {
+ const char *name;
+ const char *iface;
+ const char *type;
+ WPADBusPropertyAccessor getter;
+ WPADBusPropertyAccessor setter;
+ enum dbus_prop_access _access;
+};
-static void wpas_dbus_prop_reg_debug_params(
- struct wpa_global *global, struct wpa_dbus_object_desc *obj_desc)
-{
- wpa_dbus_property_register(obj_desc, WPAS_DBUS_NEW_INTERFACE,
- "DebugParams", "(ibb)",
- (WPADBusPropertyAccessor)
- &wpas_dbus_getter_debug_params,
- (WPADBusPropertyAccessor)
- &wpas_dbus_setter_debug_params,
- global, NULL, RW);
-}
+struct wpas_dbus_signal {
+ const char *name;
+ const char *iface;
+ struct wpa_dbus_argument args[3];
+};
-static void wpas_dbus_prop_reg_interfaces(
- struct wpa_global *global, struct wpa_dbus_object_desc *obj_desc)
+static void wpas_dbus_register(struct wpa_dbus_object_desc *obj_desc,
+ void *priv,
+ const struct wpas_dbus_method *methods,
+ const struct wpas_dbus_property *properties,
+ const struct wpas_dbus_signal *signals)
{
- wpa_dbus_property_register(obj_desc, WPAS_DBUS_NEW_INTERFACE,
- "Interfaces", "ao",
- (WPADBusPropertyAccessor)
- &wpas_dbus_getter_interfaces,
- NULL, global, NULL, R);
-}
-
+ int i;
-static void wpas_dbus_prop_reg_eap_methods(
- struct wpa_dbus_object_desc *obj_desc)
-{
- wpa_dbus_property_register(obj_desc, WPAS_DBUS_NEW_INTERFACE,
- "EapMethods", "as",
- wpas_dbus_getter_eap_methods,
- NULL, NULL, NULL, R);
-}
+ for (i = 0; methods && methods[i].name; i++) {
+ wpa_dbus_method_register(obj_desc, methods[i].iface,
+ methods[i].name, methods[i].handler,
+ priv, NULL, methods[i].args);
+ }
+ for (i = 0; properties && properties[i].name; i++) {
+ wpa_dbus_property_register(obj_desc, properties[i].iface,
+ properties[i].name,
+ properties[i].type,
+ properties[i].getter,
+ properties[i].setter,
+ priv, NULL, properties[i]._access);
+ }
-static void wpas_dbus_sign_reg_interface_added(
- struct wpa_global *global, struct wpa_dbus_object_desc *obj_desc)
-{
- struct wpa_dbus_argument sargs[] = {
- { "path", "o", ARG_OUT },
- END_ARGS
- };
- wpa_dbus_signal_register(obj_desc, WPAS_DBUS_NEW_INTERFACE,
- "InterfaceAdded", sargs);
+ for (i = 0; signals && signals[i].name; i++) {
+ wpa_dbus_signal_register(obj_desc, signals[i].iface,
+ signals[i].name, signals[i].args);
+ }
}
-static void wpas_dbus_sign_reg_interface_removed(
- struct wpa_global *global, struct wpa_dbus_object_desc *obj_desc)
-{
- struct wpa_dbus_argument sargs[] = {
- { "path", "o", ARG_OUT },
- END_ARGS
- };
- wpa_dbus_signal_register(obj_desc, WPAS_DBUS_NEW_INTERFACE,
- "InterfaceRemoved", sargs);
-}
+static const struct wpas_dbus_method wpas_dbus_global_methods[] = {
+ { "CreateInterface", WPAS_DBUS_NEW_INTERFACE,
+ (WPADBusMethodHandler) &wpas_dbus_handler_create_interface,
+ {
+ { "args", "a{sv}", ARG_IN },
+ { "path", "o", ARG_OUT },
+ END_ARGS
+ }
+ },
+ { "RemoveInterface", WPAS_DBUS_NEW_INTERFACE,
+ (WPADBusMethodHandler) &wpas_dbus_handler_remove_interface,
+ {
+ { "path", "o", ARG_IN },
+ END_ARGS
+ }
+ },
+ { "GetInterface", WPAS_DBUS_NEW_INTERFACE,
+ (WPADBusMethodHandler) &wpas_dbus_handler_get_interface,
+ {
+ { "ifname", "s", ARG_IN },
+ { "path", "o", ARG_OUT },
+ END_ARGS
+ }
+ },
+ { NULL, NULL, NULL, { END_ARGS } }
+};
+static const struct wpas_dbus_property wpas_dbus_global_properties[] = {
+ { "DebugParams", WPAS_DBUS_NEW_INTERFACE, "(ibb)",
+ (WPADBusPropertyAccessor) &wpas_dbus_getter_debug_params,
+ (WPADBusPropertyAccessor) &wpas_dbus_setter_debug_params,
+ RW
+ },
+ { "Interfaces", WPAS_DBUS_NEW_INTERFACE, "ao",
+ (WPADBusPropertyAccessor) &wpas_dbus_getter_interfaces,
+ NULL,
+ R
+ },
+ { "EapMethods", WPAS_DBUS_NEW_INTERFACE, "as",
+ wpas_dbus_getter_eap_methods,
+ NULL,
+ R
+ },
+ { NULL, NULL, NULL, NULL, NULL, 0 }
+};
-static void wpas_dbus_sign_reg_properties_changed(
- struct wpa_global *global, struct wpa_dbus_object_desc *obj_desc)
-{
- struct wpa_dbus_argument sargs[] = {
- { "properties", "a{sv}", ARG_OUT },
- END_ARGS
- };
- wpa_dbus_signal_register(obj_desc, WPAS_DBUS_NEW_INTERFACE,
- "PropertiesChanged", sargs);
-}
+static const struct wpas_dbus_signal wpas_dbus_global_signals[] = {
+ { "InterfaceAdded", WPAS_DBUS_NEW_INTERFACE,
+ {
+ { "path", "o", ARG_OUT },
+ END_ARGS
+ }
+ },
+ { "InterfaceRemoved", WPAS_DBUS_NEW_INTERFACE,
+ {
+ { "path", "o", ARG_OUT },
+ END_ARGS
+ }
+ },
+ { "PropertiesChanged", WPAS_DBUS_NEW_INTERFACE,
+ {
+ { "properties", "a{sv}", ARG_OUT },
+ END_ARGS
+ }
+ },
+ { NULL, NULL, { END_ARGS } }
+};
/**
@@ -1052,17 +1057,9 @@ static struct ctrl_iface_dbus_new_priv * wpas_dbus_ctrl_iface_init(
return NULL;
}
- wpas_dbus_meth_reg_create_interface(global, obj_desc);
- wpas_dbus_meth_reg_remove_interface(global, obj_desc);
- wpas_dbus_meth_reg_get_interface(global, obj_desc);
-
- wpas_dbus_prop_reg_debug_params(global, obj_desc);
- wpas_dbus_prop_reg_interfaces(global, obj_desc);
- wpas_dbus_prop_reg_eap_methods(obj_desc);
-
- wpas_dbus_sign_reg_interface_added(global, obj_desc);
- wpas_dbus_sign_reg_interface_removed(global, obj_desc);
- wpas_dbus_sign_reg_properties_changed(global, obj_desc);
+ wpas_dbus_register(obj_desc, global, wpas_dbus_global_methods,
+ wpas_dbus_global_properties,
+ wpas_dbus_global_signals);
ctrl_iface = wpa_dbus_ctrl_iface_init(global, WPAS_DBUS_NEW_PATH,
WPAS_DBUS_NEW_SERVICE,
@@ -1109,7 +1106,6 @@ static int wpas_dbus_register_network(struct wpa_supplicant *wpa_s,
struct network_handler_args *arg1 = NULL;
struct network_handler_args *arg2 = NULL;
- struct network_handler_args *arg3 = NULL;
char *net_obj_path;
@@ -1194,7 +1190,6 @@ err:
os_free(obj_desc);
os_free(arg1);
os_free(arg2);
- os_free(arg3);
return -1;
}
@@ -1357,6 +1352,225 @@ err:
}
+static const struct wpas_dbus_method wpas_dbus_interface_methods[] = {
+ { "Scan", WPAS_DBUS_NEW_IFACE_INTERFACE,
+ (WPADBusMethodHandler) &wpas_dbus_handler_scan,
+ {
+ { "args", "a{sv}", ARG_IN },
+ END_ARGS
+ }
+ },
+ { "Disconnect", WPAS_DBUS_NEW_IFACE_INTERFACE,
+ (WPADBusMethodHandler) &wpas_dbus_handler_disconnect,
+ {
+ END_ARGS
+ }
+ },
+ { "AddNetwork", WPAS_DBUS_NEW_IFACE_INTERFACE,
+ (WPADBusMethodHandler) &wpas_dbus_handler_add_network,
+ {
+ { "args", "a{sv}", ARG_IN },
+ { "path", "o", ARG_OUT },
+ END_ARGS
+ }
+ },
+ { "RemoveNetwork", WPAS_DBUS_NEW_IFACE_INTERFACE,
+ (WPADBusMethodHandler) &wpas_dbus_handler_remove_network,
+ {
+ { "path", "o", ARG_IN },
+ END_ARGS
+ }
+ },
+ { "SelectNetwork", WPAS_DBUS_NEW_IFACE_INTERFACE,
+ (WPADBusMethodHandler) &wpas_dbus_handler_select_network,
+ {
+ { "path", "o", ARG_IN },
+ END_ARGS
+ }
+ },
+ { "AddBlob", WPAS_DBUS_NEW_IFACE_INTERFACE,
+ (WPADBusMethodHandler) &wpas_dbus_handler_add_blob,
+ {
+ { "name", "s", ARG_IN },
+ { "data", "ay", ARG_IN },
+ END_ARGS
+ }
+ },
+ { "GetBlob", WPAS_DBUS_NEW_IFACE_INTERFACE,
+ (WPADBusMethodHandler) &wpas_dbus_handler_get_blob,
+ {
+ { "name", "s", ARG_IN },
+ { "data", "ay", ARG_OUT },
+ END_ARGS
+ }
+ },
+ { "RemoveBlob", WPAS_DBUS_NEW_IFACE_INTERFACE,
+ (WPADBusMethodHandler) &wpas_dbus_handler_remove_blob,
+ {
+ { "name", "s", ARG_IN },
+ END_ARGS
+ }
+ },
+#ifdef CONFIG_WPS
+ { "Start", WPAS_DBUS_NEW_IFACE_WPS,
+ (WPADBusMethodHandler) &wpas_dbus_handler_wps_start,
+ {
+ { "args", "a{sv}", ARG_IN },
+ { "output", "a{sv}", ARG_OUT },
+ END_ARGS
+ }
+ },
+#endif /* CONFIG_WPS */
+ { NULL, NULL, NULL, { END_ARGS } }
+};
+
+static const struct wpas_dbus_property wpas_dbus_interface_properties[] = {
+ { "Capabilities", WPAS_DBUS_NEW_IFACE_INTERFACE, "a{sv}",
+ (WPADBusPropertyAccessor) wpas_dbus_getter_capabilities,
+ NULL, R
+ },
+ { "State", WPAS_DBUS_NEW_IFACE_INTERFACE, "s",
+ (WPADBusPropertyAccessor) wpas_dbus_getter_state,
+ NULL, R
+ },
+ { "Scanning", WPAS_DBUS_NEW_IFACE_INTERFACE, "b",
+ (WPADBusPropertyAccessor) wpas_dbus_getter_scanning,
+ NULL, R
+ },
+ { "ApScan", WPAS_DBUS_NEW_IFACE_INTERFACE, "u",
+ (WPADBusPropertyAccessor) wpas_dbus_getter_ap_scan,
+ (WPADBusPropertyAccessor) wpas_dbus_setter_ap_scan,
+ RW
+ },
+ { "Ifname", WPAS_DBUS_NEW_IFACE_INTERFACE, "s",
+ (WPADBusPropertyAccessor) wpas_dbus_getter_ifname,
+ NULL, R
+ },
+ { "Driver", WPAS_DBUS_NEW_IFACE_INTERFACE, "s",
+ (WPADBusPropertyAccessor) wpas_dbus_getter_driver,
+ NULL, R
+ },
+ { "BridgeIfname", WPAS_DBUS_NEW_IFACE_INTERFACE, "s",
+ (WPADBusPropertyAccessor) wpas_dbus_getter_bridge_ifname,
+ NULL, R
+ },
+ { "CurrentBSS", WPAS_DBUS_NEW_IFACE_INTERFACE, "o",
+ (WPADBusPropertyAccessor) wpas_dbus_getter_current_bss,
+ NULL, R
+ },
+ { "CurrentNetwork", WPAS_DBUS_NEW_IFACE_INTERFACE, "o",
+ (WPADBusPropertyAccessor) wpas_dbus_getter_current_network,
+ NULL, R
+ },
+ { "Blobs", WPAS_DBUS_NEW_IFACE_INTERFACE, "a{say}",
+ (WPADBusPropertyAccessor) wpas_dbus_getter_blobs,
+ NULL, R
+ },
+ { "BSSs", WPAS_DBUS_NEW_IFACE_INTERFACE, "ao",
+ (WPADBusPropertyAccessor) wpas_dbus_getter_bsss,
+ NULL, R
+ },
+ { "Networks", WPAS_DBUS_NEW_IFACE_INTERFACE, "ao",
+ (WPADBusPropertyAccessor) wpas_dbus_getter_networks,
+ NULL, R
+ },
+#ifdef CONFIG_WPS
+ { "ProcessCredentials", WPAS_DBUS_NEW_IFACE_WPS, "b",
+ (WPADBusPropertyAccessor) wpas_dbus_getter_process_credentials,
+ (WPADBusPropertyAccessor) wpas_dbus_setter_process_credentials,
+ RW
+ },
+#endif /* CONFIG_WPS */
+ { NULL, NULL, NULL, NULL, NULL, 0 }
+};
+
+static const struct wpas_dbus_signal wpas_dbus_interface_signals[] = {
+ { "ScanDone", WPAS_DBUS_NEW_IFACE_INTERFACE,
+ {
+ { "success", "b", ARG_OUT },
+ END_ARGS
+ }
+ },
+ { "StateChanged", WPAS_DBUS_NEW_IFACE_INTERFACE,
+ {
+ { "newState", "s", ARG_OUT },
+ { "oldState", "s", ARG_OUT },
+ END_ARGS
+ }
+ },
+ { "BSSAdded", WPAS_DBUS_NEW_IFACE_INTERFACE,
+ {
+ { "path", "o", ARG_OUT },
+ END_ARGS
+ }
+ },
+ { "BSSRemoved", WPAS_DBUS_NEW_IFACE_INTERFACE,
+ {
+ { "path", "o", ARG_OUT },
+ END_ARGS
+ }
+ },
+ { "BlobAdded", WPAS_DBUS_NEW_IFACE_INTERFACE,
+ {
+ { "name", "s", ARG_OUT },
+ END_ARGS
+ }
+ },
+ { "BlobRemoved", WPAS_DBUS_NEW_IFACE_INTERFACE,
+ {
+ { "name", "s", ARG_OUT },
+ END_ARGS
+ }
+ },
+ { "NetworkAdded", WPAS_DBUS_NEW_IFACE_INTERFACE,
+ {
+ { "path", "o", ARG_OUT },
+ END_ARGS
+ }
+ },
+ { "NetworkRemoved", WPAS_DBUS_NEW_IFACE_INTERFACE,
+ {
+ { "path", "o", ARG_OUT },
+ END_ARGS
+ }
+ },
+ { "NetworkSelected", WPAS_DBUS_NEW_IFACE_INTERFACE,
+ {
+ { "path", "o", ARG_OUT },
+ END_ARGS
+ }
+ },
+ { "PropertiesChanged", WPAS_DBUS_NEW_IFACE_INTERFACE,
+ {
+ { "properties", "a{sv}", ARG_OUT },
+ END_ARGS
+ }
+ },
+#ifdef CONFIG_WPS
+ { "Event", WPAS_DBUS_NEW_IFACE_WPS,
+ {
+ { "name", "s", ARG_OUT },
+ { "args", "a{sv}", ARG_OUT },
+ END_ARGS
+ }
+ },
+ { "Credentials", WPAS_DBUS_NEW_IFACE_WPS,
+ {
+ { "credentials", "a{sv}", ARG_OUT },
+ END_ARGS
+ }
+ },
+ { "PropertiesChanged", WPAS_DBUS_NEW_IFACE_WPS,
+ {
+ { "properties", "a{sv}", ARG_OUT },
+ END_ARGS
+ }
+ },
+#endif /* CONFIG_WPS */
+ { NULL, NULL, { END_ARGS } }
+};
+
+
static int wpas_dbus_register_interface(struct wpa_supplicant *wpa_s)
{
@@ -1366,99 +1580,6 @@ static int wpas_dbus_register_interface(struct wpa_supplicant *wpa_s)
wpa_s->global->dbus_new_ctrl_iface;
int next;
- struct wpa_dbus_argument args1[] = {
- { "args", "a{sv}", ARG_IN },
- END_ARGS
- };
- struct wpa_dbus_argument args3[] = {
- { "args", "a{sv}", ARG_IN },
- { "path", "o", ARG_OUT },
- END_ARGS
- };
- struct wpa_dbus_argument args4[] = {
- { "path", "o", ARG_IN },
- END_ARGS
- };
- struct wpa_dbus_argument args5[] = {
- { "path", "o", ARG_IN },
- END_ARGS
- };
- struct wpa_dbus_argument args6[] = {
- { "name", "s", ARG_IN },
- { "data", "ay", ARG_IN },
- END_ARGS
- };
- struct wpa_dbus_argument args7[] = {
- { "name", "s", ARG_IN },
- { "data", "ay", ARG_OUT },
- END_ARGS
- };
- struct wpa_dbus_argument args8[] = {
- { "name", "s", ARG_IN },
- END_ARGS
- };
- struct wpa_dbus_argument sargs1[] = {
- { "success", "b", ARG_OUT },
- END_ARGS
- };
- struct wpa_dbus_argument sargs2[] = {
- { "newState", "s", ARG_OUT },
- { "oldState", "s", ARG_OUT },
- END_ARGS
- };
- struct wpa_dbus_argument sargs3[] = {
- { "path", "o", ARG_OUT },
- END_ARGS
- };
- struct wpa_dbus_argument sargs4[] = {
- { "path", "o", ARG_OUT },
- END_ARGS
- };
- struct wpa_dbus_argument sargs5[] = {
- { "name", "s", ARG_OUT },
- END_ARGS
- };
- struct wpa_dbus_argument sargs6[] = {
- { "name", "s", ARG_OUT },
- END_ARGS
- };
- struct wpa_dbus_argument sargs7[] = {
- { "path", "o", ARG_OUT },
- END_ARGS
- };
- struct wpa_dbus_argument sargs8[] = {
- { "path", "o", ARG_OUT },
- END_ARGS
- };
- struct wpa_dbus_argument sargs9[] = {
- { "path", "o", ARG_OUT },
- END_ARGS
- };
- struct wpa_dbus_argument sargs10[] = {
- { "properties", "a{sv}", ARG_OUT },
- END_ARGS
- };
-
-#ifdef CONFIG_WPS
- struct wpa_dbus_argument args9[] = {
- { "args", "a{sv}", ARG_IN },
- { "output", "a{sv}", ARG_OUT },
- END_ARGS
- };
- struct wpa_dbus_argument sargs11[] = {
- { "name", "s", ARG_OUT },
- { "args", "a{sv}", ARG_OUT },
- END_ARGS
- };
- struct wpa_dbus_argument sargs12[] = {
- { "credentials", "a{sv}", ARG_OUT },
- END_ARGS
- };
- struct wpa_dbus_argument sargs13[] = {
- { "properties", "a{sv}", ARG_OUT },
- END_ARGS
- };
-#endif /* CONFIG_WPS */
/* Do nothing if the control interface is not turned on */
if (ctrl_iface == NULL)
return 0;
@@ -1485,152 +1606,9 @@ static int wpas_dbus_register_interface(struct wpa_supplicant *wpa_s)
goto err;
}
- wpa_dbus_method_register(obj_desc, WPAS_DBUS_NEW_IFACE_INTERFACE,
- "Scan",
- (WPADBusMethodHandler)
- &wpas_dbus_handler_scan,
- wpa_s, NULL, args1);
- wpa_dbus_method_register(obj_desc, WPAS_DBUS_NEW_IFACE_INTERFACE,
- "Disconnect",
- (WPADBusMethodHandler)
- &wpas_dbus_handler_disconnect,
- wpa_s, NULL, NULL);
- wpa_dbus_method_register(obj_desc, WPAS_DBUS_NEW_IFACE_INTERFACE,
- "AddNetwork",
- (WPADBusMethodHandler)
- &wpas_dbus_handler_add_network,
- wpa_s, NULL, args3);
- wpa_dbus_method_register(obj_desc, WPAS_DBUS_NEW_IFACE_INTERFACE,
- "RemoveNetwork",
- (WPADBusMethodHandler)
- &wpas_dbus_handler_remove_network,
- wpa_s, NULL, args4);
- wpa_dbus_method_register(obj_desc, WPAS_DBUS_NEW_IFACE_INTERFACE,
- "SelectNetwork",
- (WPADBusMethodHandler)
- &wpas_dbus_handler_select_network,
- wpa_s, NULL, args5);
- wpa_dbus_method_register(obj_desc, WPAS_DBUS_NEW_IFACE_INTERFACE,
- "AddBlob",
- (WPADBusMethodHandler)
- &wpas_dbus_handler_add_blob,
- wpa_s, NULL, args6);
- wpa_dbus_method_register(obj_desc, WPAS_DBUS_NEW_IFACE_INTERFACE,
- "GetBlob",
- (WPADBusMethodHandler)
- &wpas_dbus_handler_get_blob,
- wpa_s, NULL, args7);
- wpa_dbus_method_register(obj_desc, WPAS_DBUS_NEW_IFACE_INTERFACE,
- "RemoveBlob",
- (WPADBusMethodHandler)
- &wpas_dbus_handler_remove_blob,
- wpa_s, NULL, args8);
-
- wpa_dbus_property_register(obj_desc, WPAS_DBUS_NEW_IFACE_INTERFACE,
- "Capabilities", "a{sv}",
- (WPADBusPropertyAccessor)
- wpas_dbus_getter_capabilities, NULL,
- wpa_s, NULL, R);
- wpa_dbus_property_register(obj_desc, WPAS_DBUS_NEW_IFACE_INTERFACE,
- "State", "s",
- (WPADBusPropertyAccessor)
- wpas_dbus_getter_state, NULL,
- wpa_s, NULL, R);
- wpa_dbus_property_register(obj_desc, WPAS_DBUS_NEW_IFACE_INTERFACE,
- "Scanning", "b",
- (WPADBusPropertyAccessor)
- wpas_dbus_getter_scanning, NULL,
- wpa_s, NULL, R);
- wpa_dbus_property_register(obj_desc, WPAS_DBUS_NEW_IFACE_INTERFACE,
- "ApScan", "u",
- (WPADBusPropertyAccessor)
- wpas_dbus_getter_ap_scan,
- (WPADBusPropertyAccessor)
- wpas_dbus_setter_ap_scan,
- wpa_s, NULL, RW);
- wpa_dbus_property_register(obj_desc, WPAS_DBUS_NEW_IFACE_INTERFACE,
- "Ifname", "s",
- (WPADBusPropertyAccessor)
- wpas_dbus_getter_ifname, NULL,
- wpa_s, NULL, R);
- wpa_dbus_property_register(obj_desc, WPAS_DBUS_NEW_IFACE_INTERFACE,
- "Driver", "s",
- (WPADBusPropertyAccessor)
- wpas_dbus_getter_driver, NULL,
- wpa_s, NULL, R);
- wpa_dbus_property_register(obj_desc, WPAS_DBUS_NEW_IFACE_INTERFACE,
- "BridgeIfname", "s",
- (WPADBusPropertyAccessor)
- wpas_dbus_getter_bridge_ifname, NULL,
- wpa_s, NULL, R);
- wpa_dbus_property_register(obj_desc, WPAS_DBUS_NEW_IFACE_INTERFACE,
- "CurrentBSS", "o",
- (WPADBusPropertyAccessor)
- wpas_dbus_getter_current_bss, NULL,
- wpa_s, NULL, R);
- wpa_dbus_property_register(obj_desc, WPAS_DBUS_NEW_IFACE_INTERFACE,
- "CurrentNetwork", "o",
- (WPADBusPropertyAccessor)
- wpas_dbus_getter_current_network, NULL,
- wpa_s, NULL, R);
- wpa_dbus_property_register(obj_desc, WPAS_DBUS_NEW_IFACE_INTERFACE,
- "Blobs", "a{say}",
- (WPADBusPropertyAccessor)
- wpas_dbus_getter_blobs, NULL,
- wpa_s, NULL, R);
- wpa_dbus_property_register(obj_desc, WPAS_DBUS_NEW_IFACE_INTERFACE,
- "BSSs", "ao",
- (WPADBusPropertyAccessor)
- wpas_dbus_getter_bsss, NULL,
- wpa_s, NULL, R);
- wpa_dbus_property_register(obj_desc, WPAS_DBUS_NEW_IFACE_INTERFACE,
- "Networks", "ao",
- (WPADBusPropertyAccessor)
- wpas_dbus_getter_networks, NULL,
- wpa_s, NULL, R);
-
- wpa_dbus_signal_register(obj_desc, WPAS_DBUS_NEW_IFACE_INTERFACE,
- "ScanDone", sargs1);
- wpa_dbus_signal_register(obj_desc, WPAS_DBUS_NEW_IFACE_INTERFACE,
- "StateChanged", sargs2);
- wpa_dbus_signal_register(obj_desc, WPAS_DBUS_NEW_IFACE_INTERFACE,
- "BSSAdded", sargs3);
- wpa_dbus_signal_register(obj_desc, WPAS_DBUS_NEW_IFACE_INTERFACE,
- "BSSRemoved", sargs4);
- wpa_dbus_signal_register(obj_desc, WPAS_DBUS_NEW_IFACE_INTERFACE,
- "BlobAdded", sargs5);
- wpa_dbus_signal_register(obj_desc, WPAS_DBUS_NEW_IFACE_INTERFACE,
- "BlobRemoved", sargs6);
- wpa_dbus_signal_register(obj_desc, WPAS_DBUS_NEW_IFACE_INTERFACE,
- "NetworkAdded", sargs7);
- wpa_dbus_signal_register(obj_desc, WPAS_DBUS_NEW_IFACE_INTERFACE,
- "NetworkRemoved", sargs8);
- wpa_dbus_signal_register(obj_desc, WPAS_DBUS_NEW_IFACE_INTERFACE,
- "NetworkSelected", sargs9);
- wpa_dbus_signal_register(obj_desc, WPAS_DBUS_NEW_IFACE_INTERFACE,
- "PropertiesChanged", sargs10);
-
-#ifdef CONFIG_WPS
- wpa_dbus_method_register(obj_desc, WPAS_DBUS_NEW_IFACE_WPS,
- "Start",
- (WPADBusMethodHandler)
- &wpas_dbus_handler_wps_start,
- wpa_s, NULL, args9);
- wpa_dbus_property_register(obj_desc, WPAS_DBUS_NEW_IFACE_WPS,
- "ProcessCredentials", "b",
- (WPADBusPropertyAccessor)
- wpas_dbus_getter_process_credentials,
- (WPADBusPropertyAccessor)
- wpas_dbus_setter_process_credentials,
- wpa_s, NULL, RW);
-
- wpa_dbus_signal_register(obj_desc, WPAS_DBUS_NEW_IFACE_WPS,
- "Event", sargs11);
- wpa_dbus_signal_register(obj_desc, WPAS_DBUS_NEW_IFACE_WPS,
- "Credentials", sargs12);
- wpa_dbus_signal_register(obj_desc, WPAS_DBUS_NEW_IFACE_WPS,
- "PropertiesChanged", sargs13);
-#endif /* CONFIG_WPS */
+ wpas_dbus_register(obj_desc, wpa_s, wpas_dbus_interface_methods,
+ wpas_dbus_interface_properties,
+ wpas_dbus_interface_signals);
if (wpa_dbus_register_object_per_iface(ctrl_iface, path, wpa_s->ifname,
obj_desc))
diff --git a/wpa_supplicant/ctrl_iface_dbus_new_helpers.c b/wpa_supplicant/ctrl_iface_dbus_new_helpers.c
index d0fc275..0273872 100644
--- a/wpa_supplicant/ctrl_iface_dbus_new_helpers.c
+++ b/wpa_supplicant/ctrl_iface_dbus_new_helpers.c
@@ -1496,7 +1496,7 @@ int wpa_dbus_method_register(struct wpa_dbus_object_desc *obj_dsc,
WPADBusMethodHandler method_handler,
void *handler_argument,
WPADBusArgumentFreeFunction argument_free_func,
- struct wpa_dbus_argument args[])
+ const struct wpa_dbus_argument args[])
{
struct wpa_dbus_method_desc *method_dsc = obj_dsc->methods;
struct wpa_dbus_method_desc *prev_desc;
@@ -1611,7 +1611,7 @@ err:
int wpa_dbus_signal_register(struct wpa_dbus_object_desc *obj_dsc,
const char *dbus_interface,
const char *dbus_signal,
- struct wpa_dbus_argument args[])
+ const struct wpa_dbus_argument args[])
{
struct wpa_dbus_signal_desc *signal_dsc = obj_dsc->signals;
diff --git a/wpa_supplicant/ctrl_iface_dbus_new_helpers.h b/wpa_supplicant/ctrl_iface_dbus_new_helpers.h
index 69fafc4..ad3f50f 100644
--- a/wpa_supplicant/ctrl_iface_dbus_new_helpers.h
+++ b/wpa_supplicant/ctrl_iface_dbus_new_helpers.h
@@ -99,12 +99,12 @@ int wpa_dbus_method_register(struct wpa_dbus_object_desc *obj_dsc,
WPADBusMethodHandler method_handler,
void *handler_argument,
WPADBusArgumentFreeFunction argument_free_func,
- struct wpa_dbus_argument args[]);
+ const struct wpa_dbus_argument args[]);
int wpa_dbus_signal_register(struct wpa_dbus_object_desc *obj_dsc,
const char *dbus_interface,
const char *dbus_signal,
- struct wpa_dbus_argument args[]);
+ const struct wpa_dbus_argument args[]);
int wpa_dbus_property_register(
struct wpa_dbus_object_desc *obj_dsc,