blob: 03eab4063978420c70546567865b27067fdef39f [file] [log] [blame]
#include "interfaces/power_control.h"
/* ---------------------------------------------------------------------------------------------------- */
static GDBusObjectManagerServer *manager = NULL;
static PowerControl *power_control = NULL;
static guint tmp_pgood = 0;
static gboolean
on_set_power_state (PowerControl *pwr,
GDBusMethodInvocation *invocation,
guint state,
gpointer user_data)
{
if (state > 1)
{
g_dbus_method_invocation_return_dbus_error (invocation,
"org.openbmc.PowerControl.Error.Failed",
"Invalid power state");
return TRUE;
}
if (state == power_control_get_state(pwr))
{
g_dbus_method_invocation_return_dbus_error (invocation,
"org.openbmc.PowerControl.Error.Failed",
"Power Control is already at requested state");
return TRUE;
}
// TODO: Implement gpio toggling
g_print("Set power state: %d\n",state);
if (state==1)
{
g_print("Turn on\n");
tmp_pgood=1;
}
else
{
g_print("Turn off\n");
tmp_pgood=0;
}
power_control_set_state(pwr,state);
power_control_complete_set_power_state(pwr,invocation);
return TRUE;
}
static gboolean
on_get_power_state (PowerControl *pwr,
GDBusMethodInvocation *invocation,
gpointer user_data)
{
guint pgood = power_control_get_pgood(pwr);
power_control_complete_get_power_state(pwr,invocation,pgood);
return TRUE;
}
static void
on_bus_acquired (GDBusConnection *connection,
const gchar *name,
gpointer user_data)
{
ObjectSkeleton *object;
guint n;
g_print ("Acquired a message bus connection: %s\n",name);
manager = g_dbus_object_manager_server_new ("/org/openbmc/PowerControl");
gchar *s;
s = g_strdup_printf ("/org/openbmc/PowerControl/0");
object = object_skeleton_new (s);
g_free (s);
power_control = power_control_skeleton_new ();
object_skeleton_set_power_control (object, power_control);
g_object_unref (power_control);
//define method callbacks here
g_signal_connect (power_control,
"handle-set-power-state",
G_CALLBACK (on_set_power_state),
NULL); /* user_data */
g_signal_connect (power_control,
"handle-get-power-state",
G_CALLBACK (on_get_power_state),
NULL); /* user_data */
/* Export the object (@manager takes its own reference to @object) */
g_dbus_object_manager_server_export (manager, G_DBUS_OBJECT_SKELETON (object));
g_object_unref (object);
/* Export all objects */
g_dbus_object_manager_server_set_connection (manager, connection);
}
static void
on_name_acquired (GDBusConnection *connection,
const gchar *name,
gpointer user_data)
{
g_print ("Acquired the name %s\n", name);
}
static void
on_name_lost (GDBusConnection *connection,
const gchar *name,
gpointer user_data)
{
g_print ("Lost the name %s\n", name);
}
static gboolean
poll_pgood()
{
guint pgood = power_control_get_pgood(power_control);
//TOOD: Change to actually read gpio
guint gpio = tmp_pgood;
g_print("Polling pgood: %d\n",gpio);
//if changed, set property and emit signal
if (gpio != power_control_get_pgood(power_control))
{
power_control_set_pgood(power_control,gpio);
if (gpio==0)
{
power_control_emit_power_lost(power_control);
}
else
{
power_control_emit_power_good(power_control);
}
}
return TRUE;
}
gint
main (gint argc, gchar *argv[])
{
GMainLoop *loop;
guint id;
//g_type_init ();
loop = g_main_loop_new (NULL, FALSE);
id = g_bus_own_name (G_BUS_TYPE_SESSION,
"org.openbmc.PowerControl",
G_BUS_NAME_OWNER_FLAGS_ALLOW_REPLACEMENT |
G_BUS_NAME_OWNER_FLAGS_REPLACE,
on_bus_acquired,
on_name_acquired,
on_name_lost,
loop,
NULL);
g_timeout_add(5000, poll_pgood, NULL);
g_main_loop_run (loop);
g_bus_unown_name (id);
g_main_loop_unref (loop);
return 0;
}