${PROJECT_ROOT_DIR}/src/resource/resource_rain_sensor.c
${PROJECT_ROOT_DIR}/src/resource/resource_sound_detection_sensor.c
${PROJECT_ROOT_DIR}/src/resource/resource_tilt_sensor.c
+ ${PROJECT_ROOT_DIR}/src/resource/resource_gas_detection_sensor.c
)
TARGET_LINK_LIBRARIES(${PROJECT_NAME} ${pkgs_LDFLAGS} -lm)
extern void connectivity_unset_resource(connectivity_resource_s *resource);
/**
- * @brief Notifies specific clients that resource's attributes have changed with boolean vaule.
+ * @brief Notifies specific clients that resource's attributes have changed with boolean value.
* @param[in] resource_info A structure containing information about connectivity resource
* @param[in] key A new key to be added into attributes
* @param[in] value A boolean value to be added into attributes
extern int connectivity_notify_bool(connectivity_resource_s *resource_info, const char *key, bool value);
/**
- * @brief Notifies specific clients that resource's attributes have changed with int vaule.
+ * @brief Notifies specific clients that resource's attributes have changed with int value.
* @param[in] resource_info A structure containing information about connectivity resource
* @param[in] key A new key to be added into attributes
* @param[in] value A int value to be added into attributes
extern int connectivity_notify_int(connectivity_resource_s *resource_info, const char *key, int value);
/**
- * @brief Notifies specific clients that resource's attributes have changed with double vaule.
+ * @brief Notifies specific clients that resource's attributes have changed with double value.
* @param[in] resource_info A structure containing information about connectivity resource
* @param[in] key A new key to be added into attributes
* @param[in] value A double value to be added into attributes
#include "resource/resource_rain_sensor.h"
#include "resource/resource_sound_detection_sensor.h"
#include "resource/resource_tilt_sensor.h"
+#include "resource/resource_gas_detection_sensor.h"
#endif /* __POSITION_FINDER_RESOURCE_H__ */
--- /dev/null
+/*
+ * Copyright (c) 2017 Samsung Electronics Co., Ltd.
+ *
+ * Contact: Jin Yoon <jinny.yoon@samsung.com>
+ * Geunsun Lee <gs86.lee@samsung.com>
+ * Eunyoung Lee <ey928.lee@samsung.com>
+ * Junkyu Han <junkyu.han@samsung.com>
+ *
+ * Licensed under the Flora License, Version 1.1 (the License);
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://floralicense.org/license/
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an AS IS BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+#ifndef __POSITION_FINDER_RESOURCE_GAS_DETECTION_SENSOR_H__
+#define __POSITION_FINDER_RESOURCE_GAS_DETECTION_SENSOR_H__
+
+/**
+ * @brief Reads the value of gpio connected to the gas detection sensor(fc-22).
+ * @param[in] pin_num The number of the gpio pin connected to the digital pin of gas detection sensor
+ * @param[out] out_value The value of the gpio (zero or non-zero)
+ * @return 0 on success, otherwise a negative error value
+ * @see If the gpio pin is not open, creates gpio handle before reading the value of gpio.
+ */
+extern int resource_read_gas_detection_sensor(int pin_num, int *out_value);
+
+#endif /* __POSITION_FINDER_RESOURCE_GAS_DETECTION_SENSOR_H__ */
--- /dev/null
+/*
+ * Copyright (c) 2017 Samsung Electronics Co., Ltd.
+ *
+ * Contact: Jin Yoon <jinny.yoon@samsung.com>
+ * Geunsun Lee <gs86.lee@samsung.com>
+ * Eunyoung Lee <ey928.lee@samsung.com>
+ * Junkyu Han <junkyu.han@samsung.com>
+ *
+ * Licensed under the Flora License, Version 1.1 (the License);
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://floralicense.org/license/
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an AS IS BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+#ifndef __POSITION_FINDER_RESOURCE_GAS_DETECTION_SENSOR_INTERNAL_H__
+#define __POSITION_FINDER_RESOURCE_GAS_DETECTION_SENSOR_INTERNAL_H__
+
+/**
+ * @brief Releases the gpio handle and changes the gpio pin state to the close(0).
+ * @param[in] pin_num The number of the gpio pin connected to the gas detection sensor
+ */
+extern void resource_close_gas_detection_sensor(int pin_num);
+
+#endif /* __POSITION_FINDER_RESOURCE_GAS_DETECTION_SENSOR_INTERNAL_H__ */
/**
* @brief Reads the value of i2c bus connected illuminance sensor.
* @param[in] i2c_bus The i2c bus number that the slave device is connected
- * @param[out] out_value The vaule read by the illuminance sensor
+ * @param[out] out_value The value read by the illuminance sensor
* @return 0 on success, otherwise a negative error value
* @see If the i2c bus is not open, creates i2c handle before reading data from the i2c slave device.
*/
/**
* @brief Reads the value of gpio connected infrared motion sensor(HC-SR501).
* @param[in] pin_num The number of the gpio pin connected to the infrared motion sensor
- * @param[out] out_value The vaule of the gpio (zero or non-zero)
+ * @param[out] out_value The value of the gpio (zero or non-zero)
* @return 0 on success, otherwise a negative error value
* @see If the gpio pin is not open, creates gpio handle before reading the value of gpio.
*/
/**
* @brief Reads the value of gpio connected infrared obstacle avoidance sensor.
* @param[in] pin_num The number of the gpio pin connected to the infrared obstacle avoidance sensor
- * @param[out] out_value The vaule of the gpio (zero or non-zero)
+ * @param[out] out_value The value of the gpio (zero or non-zero)
* @return 0 on success, otherwise a negative error value
* @see If the gpio pin is not open, creates gpio handle before reading the value of gpio.
*/
/**
* @brief Reads the value of gpio connected touch sensor.
* @param[in] pin_num The number of the gpio pin connected to the touch sensor
- * @param[out] out_value The vaule of the gpio (zero or non-zero)
+ * @param[out] out_value The value of the gpio (zero or non-zero)
* @return 0 on success, otherwise a negative error value
* @see If the gpio pin is not open, creates gpio handle before reading the value of gpio.
*/
#include "resource/resource_rain_sensor_internal.h"
#include "resource/resource_sound_detection_sensor_internal.h"
#include "resource/resource_tilt_sensor_internal.h"
+#include "resource/resource_gas_detection_sensor_internal.h"
#define PIN_MAX 40
#include <stdbool.h>
#include <glib.h>
#include <Eina.h>
+#include <app_common.h>
#include "log.h"
#include "connectivity.h"
--- /dev/null
+/*
+ * Copyright (c) 2017 Samsung Electronics Co., Ltd.
+ *
+ * Contact: Jin Yoon <jinny.yoon@samsung.com>
+ * Geunsun Lee <gs86.lee@samsung.com>
+ * Eunyoung Lee <ey928.lee@samsung.com>
+ * Junkyu Han <junkyu.han@samsung.com>
+ *
+ * Licensed under the Flora License, Version 1.1 (the License);
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://floralicense.org/license/
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an AS IS BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+#include <stdlib.h>
+#include <unistd.h>
+#include <peripheral_io.h>
+#include <sys/time.h>
+
+#include "log.h"
+#include "resource_internal.h"
+
+void resource_close_gas_detection_sensor(int pin_num)
+{
+ if (!resource_get_info(pin_num)->opened) return;
+
+ _I("Gas Detection Sensor is finishing...");
+ peripheral_gpio_close(resource_get_info(pin_num)->sensor_h);
+ resource_get_info(pin_num)->opened = 0;
+}
+
+int resource_read_gas_detection_sensor(int pin_num, int *out_value)
+{
+ int ret = PERIPHERAL_ERROR_NONE;
+
+ if (!resource_get_info(pin_num)->opened) {
+ ret = peripheral_gpio_open(pin_num, &resource_get_info(pin_num)->sensor_h);
+ retv_if(!resource_get_info(pin_num)->sensor_h, -1);
+
+ ret = peripheral_gpio_set_direction(resource_get_info(pin_num)->sensor_h, PERIPHERAL_GPIO_DIRECTION_IN);
+ retv_if(ret != 0, -1);
+
+ resource_get_info(pin_num)->opened = 1;
+ resource_get_info(pin_num)->close = resource_close_gas_detection_sensor;
+ }
+
+ ret = peripheral_gpio_read(resource_get_info(pin_num)->sensor_h, out_value);
+ retv_if(ret < 0, -1);
+
+ return 0;
+}