From b766c33ef02179be43134aaf533a844b93269a64 Mon Sep 17 00:00:00 2001 From: Marcel Holtmann Date: Wed, 23 Dec 2009 03:39:00 -0800 Subject: Add basic mainloop and D-Bus setup to supplicant test tool --- tools/supplicant-test.c | 67 +++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 67 insertions(+) (limited to 'tools/supplicant-test.c') diff --git a/tools/supplicant-test.c b/tools/supplicant-test.c index 6f110c17..24fd5d8f 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; } -- cgit v1.2.3