blob: 70787dd9f80b21c0f4db906ab0994730cea82339 [file] [log] [blame]
#include "interfaces/sensor.h"
#include "openbmc.h"
#include "sensor_threshold.h"
/* ---------------------------------------------------------------------------------------------------- */
static const gchar* dbus_object_path = "/org/openbmc/sensors/Temperature/Ambient";
static const gchar* dbus_name = "org.openbmc.sensors.Temperature.Ambient";
static const guint poll_interval = 3000;
static guint heartbeat = 0;
static GDBusObjectManagerServer *manager = NULL;
static gboolean inited = FALSE;
static gboolean
poll_sensor(gpointer user_data)
{
if (!inited)
{
return TRUE;
}
SensorValue *sensor = object_get_sensor_value((Object*)user_data);
SensorThreshold *threshold = object_get_sensor_threshold((Object*)user_data);
SensorI2c *i2c = object_get_sensor_i2c((Object*)user_data);
GVariant* v_value = sensor_value_get_value(sensor);
//TODO: Change to actually read sensor
double value = GET_VARIANT_D(v_value);
g_print("Reading I2C = %s; Address = %s; %f\n",
sensor_i2c_get_dev_path(i2c),sensor_i2c_get_address(i2c),value);
value = value+1;
if (heartbeat > 10000)
{
heartbeat = 0;
sensor_value_emit_heartbeat(sensor,dbus_name);
}
else
{
heartbeat = heartbeat+poll_interval;
}
// End actually reading sensor
//if changed, set property and emit signal
// if (value != sensor_value_get_value(sensor)
if (value != GET_VARIANT_D(v_value))
{
// they don't appear to provide a function to modify float value in varait
// so it seems I have to create a new one
GVariant* v_new_value = NEW_VARIANT_D(value);
sensor_value_set_value(sensor,v_new_value);
sensor_value_set_value(sensor,v_new_value);
//sensor_value_emit_changed(sensor,v_new_value,sensor_value_get_units(sensor));
check_thresholds(threshold,v_new_value);
}
return TRUE;
}
static gboolean
on_init (SensorValue *sen,
GDBusMethodInvocation *invocation,
gpointer user_data)
{
inited = TRUE;
sensor_value_complete_init(sen,invocation);
return TRUE;
}
static void
on_bus_acquired (GDBusConnection *connection,
const gchar *name,
gpointer user_data)
{
g_print ("Acquired a message bus connection: %s\n",name);
cmdline *cmd = user_data;
if (cmd->argc < 2)
{
g_print("No objects created. Put object name(s) on command line\n");
return;
}
manager = g_dbus_object_manager_server_new (dbus_object_path);
int i=0;
for (i=1;i<cmd->argc;i++)
{
gchar *s;
s = g_strdup_printf ("%s/%s",dbus_object_path,cmd->argv[i]);
ObjectSkeleton *object = object_skeleton_new (s);
g_free (s);
SensorValue *sensor = sensor_value_skeleton_new ();
object_skeleton_set_sensor_value (object, sensor);
g_object_unref (sensor);
SensorThreshold *threshold = sensor_threshold_skeleton_new();
object_skeleton_set_sensor_threshold (object,threshold);
g_object_unref (threshold);
SensorI2c *i2c = sensor_i2c_skeleton_new();
object_skeleton_set_sensor_i2c (object,i2c);
g_object_unref (i2c);
// set properties
GVariant* value = g_variant_new_variant(g_variant_new_double(1.0));
sensor_value_set_value(sensor,value);
sensor_value_set_units(sensor,"C");
sensor_threshold_set_state(threshold,NOT_SET);
sensor_threshold_set_upper_critical(threshold,
g_variant_new_variant(g_variant_new_double(0.0)));
sensor_threshold_set_upper_warning(threshold,
g_variant_new_variant(g_variant_new_double(0.0)));
sensor_threshold_set_lower_warning(threshold,
g_variant_new_variant(g_variant_new_double(0.0)));
sensor_threshold_set_lower_critical(threshold,
g_variant_new_variant(g_variant_new_double(0.0)));
//define method callbacks here
g_signal_connect (sensor,
"handle-init",
G_CALLBACK (on_init),
NULL); /* user_data */
g_signal_connect (threshold,
"handle-get-state",
G_CALLBACK (get_threshold_state),
NULL); /* user_data */
g_timeout_add(poll_interval, poll_sensor, object);
/* 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);
}
gint
main (gint argc, gchar *argv[])
{
GMainLoop *loop;
cmdline cmd;
cmd.argc = argc;
cmd.argv = argv;
guint id;
loop = g_main_loop_new (NULL, FALSE);
id = g_bus_own_name (G_BUS_TYPE_SESSION,
dbus_name,
G_BUS_NAME_OWNER_FLAGS_ALLOW_REPLACEMENT |
G_BUS_NAME_OWNER_FLAGS_REPLACE,
on_bus_acquired,
on_name_acquired,
on_name_lost,
&cmd,
NULL);
g_main_loop_run (loop);
g_bus_unown_name (id);
g_main_loop_unref (loop);
return 0;
}