From: Marcel Holtmann Date: Wed, 23 Dec 2009 11:39:00 +0000 (-0800) Subject: Add basic mainloop and D-Bus setup to supplicant test tool X-Git-Tag: accepted/2.0alpha-wayland/20121110.002834~2981 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=b766c33ef02179be43134aaf533a844b93269a64;p=profile%2Fivi%2Fconnman.git Add basic mainloop and D-Bus setup to supplicant test tool --- diff --git a/Makefile.am b/Makefile.am index df54367..1242705 100644 --- a/Makefile.am +++ b/Makefile.am @@ -117,6 +117,8 @@ noinst_PROGRAMS += tools/wifi-scan tools/supplicant-test \ tools_wifi_scan_LDADD = @GLIB_LIBS@ @NETLINK_LIBS@ +tools_supplicant_test_SOURCES = $(gdbus_sources) \ + tools/supplicant-test.c tools_supplicant_test_LDADD = @GLIB_LIBS@ @DBUS_LIBS@ tools_polkit_test_LDADD = @DBUS_LIBS@ diff --git a/tools/supplicant-test.c b/tools/supplicant-test.c index 6f110c1..24fd5d8 100644 --- a/tools/supplicant-test.c +++ b/tools/supplicant-test.c @@ -23,7 +23,74 @@ #include #endif +#include +#include +#include +#include +#include + +#include + +#define DBG(fmt, arg...) do { \ + syslog(LOG_DEBUG, "%s:%s() " fmt, __FILE__, __FUNCTION__ , ## arg); \ +} while (0) + +static GMainLoop *main_loop = NULL; + +static void sig_term(int sig) +{ + syslog(LOG_INFO, "Terminating"); + + g_main_loop_quit(main_loop); +} + +static void disconnect_callback(DBusConnection *conn, void *user_data) +{ + syslog(LOG_ERR, "D-Bus disconnect"); + + g_main_loop_quit(main_loop); +} + int main(int argc, char *argv[]) { + DBusConnection *conn; + DBusError err; + struct sigaction sa; + + main_loop = g_main_loop_new(NULL, FALSE); + + dbus_error_init(&err); + + conn = g_dbus_setup_bus(DBUS_BUS_SYSTEM, NULL, &err); + if (conn == NULL) { + if (dbus_error_is_set(&err) == TRUE) { + fprintf(stderr, "%s\n", err.message); + dbus_error_free(&err); + } else + fprintf(stderr, "Can't register with system bus\n"); + exit(1); + } + + openlog("supplicant", LOG_NDELAY | LOG_PERROR, LOG_USER); + + g_dbus_set_disconnect_function(conn, disconnect_callback, NULL, NULL); + + memset(&sa, 0, sizeof(sa)); + sa.sa_handler = sig_term; + sigaction(SIGINT, &sa, NULL); + sigaction(SIGTERM, &sa, NULL); + + syslog(LOG_INFO, "Startup"); + + g_main_loop_run(main_loop); + + syslog(LOG_INFO, "Exit"); + + dbus_connection_unref(conn); + + g_main_loop_unref(main_loop); + + closelog(); + return 0; }