first commit
diff --git a/objects/power_control_obj.c b/objects/power_control_obj.c
new file mode 100644
index 0000000..e2560c4
--- /dev/null
+++ b/objects/power_control_obj.c
@@ -0,0 +1,169 @@
+#include "interfaces/power_control.h"

+

+/* ---------------------------------------------------------------------------------------------------- */

+

+static GDBusObjectManagerServer *manager = NULL;

+static PowerControl *power_control = NULL;

+

+static guint gpio_power = 26;

+static guint gpio_fsiclk = 27;

+static guint gpio_fsidat = 28;

+static guint gpio_pgood = 21;

+

+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;

+}