X-Git-Url: https://git.ucc.asn.au/?a=blobdiff_plain;f=server%2Fsensor.h;h=6c7abaaa39c543df369dfce3dcf9dbb6eea56ae8;hb=5799ff15b85e78018f2e1800dde82c9aec43f382;hp=3f833d174965dc48d34dd5606c04ec43a3dcf8d8;hpb=ba944d765e2c72b3b83225934021b62b16e8037c;p=matches%2FMCTX3420.git diff --git a/server/sensor.h b/server/sensor.h index 3f833d1..6c7abaa 100644 --- a/server/sensor.h +++ b/server/sensor.h @@ -11,6 +11,7 @@ /** Number of sensors **/ #define NUMSENSORS 6 +/** Sensor ids - there should be correspondence with the names in g_sensor_names **/ typedef enum SensorId { ANALOG_TEST0, @@ -21,12 +22,9 @@ typedef enum SensorId DIGITAL_FAIL0 } SensorId; - - /** Human readable names for the sensors **/ extern const char * g_sensor_names[NUMSENSORS]; - /** Structure to represent a sensor **/ typedef struct { @@ -34,13 +32,12 @@ typedef struct SensorId id; /** DataFile to store sensor values in **/ DataFile data_file; - /** Indicates whether the Sensor should record data **/ - bool record_data; + /** Indicates whether the Sensor is active or not **/ + bool activated; /** Thread the Sensor is running in **/ pthread_t thread; /** Most recently recorded data **/ DataPoint newest_data; - } Sensor; // Structure to define the warning and error thresholds of the sensors @@ -54,11 +51,8 @@ typedef struct extern void Sensor_Init(); // One off initialisation of *all* sensors -extern void Sensor_StartAll(const char * experiment_name); // Start all Sensors recording data -extern void Sensor_StopAll(); // Stop all Sensors recording data -extern void Sensor_Start(Sensor * s, const char * experiment_name); // Start a sensor recording datas -extern void Sensor_Stop(Sensor * s); // Stop a Sensor from recording data - +extern void Sensor_SetModeAll(ControlModes mode, void * arg); +extern void Sensor_SetMode(Sensor * s, ControlModes mode, void * arg); extern void * Sensor_Loop(void * args); // Main loop for a thread that handles a Sensor extern bool Sensor_Read(Sensor * s, DataPoint * d); // Read a single DataPoint, indicating if it has changed since the last one