forked from Imagelibrary/rtems
@@ -10,6 +10,7 @@ include_dev_i2c_HEADERS += include/dev/i2c/eeprom.h
|
|||||||
include_dev_i2c_HEADERS += include/dev/i2c/fpga-i2c-slave.h
|
include_dev_i2c_HEADERS += include/dev/i2c/fpga-i2c-slave.h
|
||||||
include_dev_i2c_HEADERS += include/dev/i2c/gpio-nxp-pca9535.h
|
include_dev_i2c_HEADERS += include/dev/i2c/gpio-nxp-pca9535.h
|
||||||
include_dev_i2c_HEADERS += include/dev/i2c/i2c.h
|
include_dev_i2c_HEADERS += include/dev/i2c/i2c.h
|
||||||
|
include_dev_i2c_HEADERS += include/dev/i2c/sensor-lm75a.h
|
||||||
include_dev_i2c_HEADERS += include/dev/i2c/switch-nxp-pca9548a.h
|
include_dev_i2c_HEADERS += include/dev/i2c/switch-nxp-pca9548a.h
|
||||||
include_dev_i2c_HEADERS += include/dev/i2c/xilinx-axi-i2c.h
|
include_dev_i2c_HEADERS += include/dev/i2c/xilinx-axi-i2c.h
|
||||||
include_dev_i2c_HEADERS += include/dev/i2c/ti-ads-16bit-adc.h
|
include_dev_i2c_HEADERS += include/dev/i2c/ti-ads-16bit-adc.h
|
||||||
@@ -41,6 +42,7 @@ libdev_a_SOURCES += i2c/fpga-i2c-slave.c
|
|||||||
libdev_a_SOURCES += i2c/gpio-nxp-pca9535.c
|
libdev_a_SOURCES += i2c/gpio-nxp-pca9535.c
|
||||||
libdev_a_SOURCES += i2c/i2c-bus.c
|
libdev_a_SOURCES += i2c/i2c-bus.c
|
||||||
libdev_a_SOURCES += i2c/i2c-dev.c
|
libdev_a_SOURCES += i2c/i2c-dev.c
|
||||||
|
libdev_a_SOURCES += i2c/sensor-lm75a.c
|
||||||
libdev_a_SOURCES += i2c/switch-nxp-pca9548a.c
|
libdev_a_SOURCES += i2c/switch-nxp-pca9548a.c
|
||||||
libdev_a_SOURCES += i2c/xilinx-axi-i2c.c
|
libdev_a_SOURCES += i2c/xilinx-axi-i2c.c
|
||||||
libdev_a_SOURCES += i2c/ti-ads-16bit-adc.c
|
libdev_a_SOURCES += i2c/ti-ads-16bit-adc.c
|
||||||
|
|||||||
198
cpukit/dev/i2c/sensor-lm75a.c
Normal file
198
cpukit/dev/i2c/sensor-lm75a.c
Normal file
@@ -0,0 +1,198 @@
|
|||||||
|
/**
|
||||||
|
* @file
|
||||||
|
*
|
||||||
|
* @brief Temperature Sensor LM75A Driver Implementation
|
||||||
|
*
|
||||||
|
* @ingroup I2CSensorLM75A
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2017 embedded brains GmbH. All rights reserved.
|
||||||
|
*
|
||||||
|
* embedded brains GmbH
|
||||||
|
* Dornierstr. 4
|
||||||
|
* 82178 Puchheim
|
||||||
|
* Germany
|
||||||
|
* <rtems@embedded-brains.de>
|
||||||
|
*
|
||||||
|
* The license and distribution terms for this file may be
|
||||||
|
* found in the file LICENSE in this distribution or at
|
||||||
|
* http://www.rtems.org/license/LICENSE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#if HAVE_CONFIG_H
|
||||||
|
#include "config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include <dev/i2c/sensor-lm75a.h>
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
SENSOR_LM75A_PTR_TEMP,
|
||||||
|
SENSOR_LM75A_PTR_CONF,
|
||||||
|
SENSOR_LM75A_PTR_THYST,
|
||||||
|
SENSOR_LM75A_PTR_TOS
|
||||||
|
} sensor_lm75a_ptr;
|
||||||
|
|
||||||
|
static int sensor_lm75a_get_reg_8(
|
||||||
|
i2c_dev *dev,
|
||||||
|
sensor_lm75a_ptr ptr,
|
||||||
|
uint8_t *val
|
||||||
|
)
|
||||||
|
{
|
||||||
|
uint8_t out[1] = { ptr };
|
||||||
|
uint8_t in[sizeof(*val)];
|
||||||
|
i2c_msg msgs[2] = {
|
||||||
|
{
|
||||||
|
.addr = dev->address,
|
||||||
|
.flags = 0,
|
||||||
|
.len = (uint16_t) sizeof(out),
|
||||||
|
.buf = &out[0]
|
||||||
|
}, {
|
||||||
|
.addr = dev->address,
|
||||||
|
.flags = I2C_M_RD,
|
||||||
|
.len = (uint16_t) sizeof(in),
|
||||||
|
.buf = &in[0]
|
||||||
|
}
|
||||||
|
};
|
||||||
|
int err;
|
||||||
|
|
||||||
|
err = i2c_bus_transfer(dev->bus, &msgs[0], RTEMS_ARRAY_SIZE(msgs));
|
||||||
|
*val = in[0];
|
||||||
|
|
||||||
|
return err;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int sensor_lm75a_set_reg_8(
|
||||||
|
i2c_dev *dev,
|
||||||
|
sensor_lm75a_ptr ptr,
|
||||||
|
uint8_t val
|
||||||
|
)
|
||||||
|
{
|
||||||
|
uint8_t out[2] = { ptr, val };
|
||||||
|
i2c_msg msgs[1] = {
|
||||||
|
{
|
||||||
|
.addr = dev->address,
|
||||||
|
.flags = 0,
|
||||||
|
.len = (uint16_t) sizeof(out),
|
||||||
|
.buf = &out[0]
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
return i2c_bus_transfer(dev->bus, &msgs[0], RTEMS_ARRAY_SIZE(msgs));
|
||||||
|
}
|
||||||
|
|
||||||
|
static int sensor_lm75a_get_reg_16(
|
||||||
|
i2c_dev *dev,
|
||||||
|
sensor_lm75a_ptr ptr,
|
||||||
|
uint16_t *val
|
||||||
|
)
|
||||||
|
{
|
||||||
|
uint8_t out[1] = { ptr };
|
||||||
|
uint8_t in[sizeof(*val)];
|
||||||
|
i2c_msg msgs[2] = {
|
||||||
|
{
|
||||||
|
.addr = dev->address,
|
||||||
|
.flags = 0,
|
||||||
|
.len = (uint16_t) sizeof(out),
|
||||||
|
.buf = &out[0]
|
||||||
|
}, {
|
||||||
|
.addr = dev->address,
|
||||||
|
.flags = I2C_M_RD,
|
||||||
|
.len = (uint16_t) sizeof(in),
|
||||||
|
.buf = &in[0]
|
||||||
|
}
|
||||||
|
};
|
||||||
|
int err;
|
||||||
|
|
||||||
|
err = i2c_bus_transfer(dev->bus, &msgs[0], RTEMS_ARRAY_SIZE(msgs));
|
||||||
|
*val = (in[0] << 8) | in[1];
|
||||||
|
|
||||||
|
return err;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int sensor_lm75a_set_reg_16(
|
||||||
|
i2c_dev *dev,
|
||||||
|
sensor_lm75a_ptr ptr,
|
||||||
|
uint16_t val
|
||||||
|
)
|
||||||
|
{
|
||||||
|
uint8_t out[3] = { ptr, (uint8_t) (val >> 8), (uint8_t) val };
|
||||||
|
i2c_msg msgs[1] = {
|
||||||
|
{
|
||||||
|
.addr = dev->address,
|
||||||
|
.flags = 0,
|
||||||
|
.len = (uint16_t) sizeof(out),
|
||||||
|
.buf = &out[0]
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
return i2c_bus_transfer(dev->bus, &msgs[0], RTEMS_ARRAY_SIZE(msgs));
|
||||||
|
}
|
||||||
|
|
||||||
|
static int sensor_lm75a_ioctl(
|
||||||
|
i2c_dev *dev,
|
||||||
|
ioctl_command_t command,
|
||||||
|
void *arg
|
||||||
|
)
|
||||||
|
{
|
||||||
|
uint8_t v8 = (uint8_t) (uintptr_t) arg;
|
||||||
|
uint16_t v16 = (uint16_t) (uintptr_t) arg;
|
||||||
|
int err;
|
||||||
|
|
||||||
|
switch (command) {
|
||||||
|
case SENSOR_LM75A_GET_CONF:
|
||||||
|
err = sensor_lm75a_get_reg_8(dev, SENSOR_LM75A_PTR_CONF, arg);
|
||||||
|
break;
|
||||||
|
case SENSOR_LM75A_SET_CONF:
|
||||||
|
err = sensor_lm75a_set_reg_8(dev, SENSOR_LM75A_PTR_CONF, v8);
|
||||||
|
break;
|
||||||
|
case SENSOR_LM75A_CLEAR_AND_SET_CONF:
|
||||||
|
i2c_bus_obtain(dev->bus);
|
||||||
|
err = sensor_lm75a_get_reg_8(dev, SENSOR_LM75A_PTR_CONF, &v8);
|
||||||
|
if (err == 0) {
|
||||||
|
v8 &= ~((uint8_t) v16);
|
||||||
|
v8 |= (uint8_t) (v16 >> 8);
|
||||||
|
err = sensor_lm75a_set_reg_8(dev, SENSOR_LM75A_PTR_CONF, v8);
|
||||||
|
}
|
||||||
|
i2c_bus_release(dev->bus);
|
||||||
|
break;
|
||||||
|
case SENSOR_LM75A_GET_TEMP:
|
||||||
|
err = sensor_lm75a_get_reg_16(dev, SENSOR_LM75A_PTR_TEMP, arg);
|
||||||
|
break;
|
||||||
|
case SENSOR_LM75A_GET_TOS:
|
||||||
|
err = sensor_lm75a_get_reg_16(dev, SENSOR_LM75A_PTR_TOS, arg);
|
||||||
|
break;
|
||||||
|
case SENSOR_LM75A_SET_TOS:
|
||||||
|
err = sensor_lm75a_set_reg_16(dev, SENSOR_LM75A_PTR_TOS, v16);
|
||||||
|
break;
|
||||||
|
case SENSOR_LM75A_GET_THYST:
|
||||||
|
err = sensor_lm75a_get_reg_16(dev, SENSOR_LM75A_PTR_THYST, arg);
|
||||||
|
break;
|
||||||
|
case SENSOR_LM75A_SET_THYST:
|
||||||
|
err = sensor_lm75a_set_reg_16(dev, SENSOR_LM75A_PTR_THYST, v16);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
err = -ENOTTY;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
return err;
|
||||||
|
}
|
||||||
|
|
||||||
|
int i2c_dev_register_sensor_lm75a(
|
||||||
|
const char *bus_path,
|
||||||
|
const char *dev_path,
|
||||||
|
uint16_t address
|
||||||
|
)
|
||||||
|
{
|
||||||
|
i2c_dev *dev;
|
||||||
|
|
||||||
|
dev = i2c_dev_alloc_and_init(sizeof(*dev), bus_path, address);
|
||||||
|
if (dev == NULL) {
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
dev->ioctl = sensor_lm75a_ioctl;
|
||||||
|
|
||||||
|
return i2c_dev_register(dev, dev_path);
|
||||||
|
}
|
||||||
125
cpukit/dev/include/dev/i2c/sensor-lm75a.h
Normal file
125
cpukit/dev/include/dev/i2c/sensor-lm75a.h
Normal file
@@ -0,0 +1,125 @@
|
|||||||
|
/**
|
||||||
|
* @file
|
||||||
|
*
|
||||||
|
* @brief Temperature Sensor LM75A Driver API
|
||||||
|
*
|
||||||
|
* @ingroup I2CSensorLM75A
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2017 embedded brains GmbH. All rights reserved.
|
||||||
|
*
|
||||||
|
* embedded brains GmbH
|
||||||
|
* Dornierstr. 4
|
||||||
|
* 82178 Puchheim
|
||||||
|
* Germany
|
||||||
|
* <rtems@embedded-brains.de>
|
||||||
|
*
|
||||||
|
* The license and distribution terms for this file may be
|
||||||
|
* found in the file LICENSE in this distribution or at
|
||||||
|
* http://www.rtems.org/license/LICENSE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef _DEV_I2C_SENSOR_LM75A_H
|
||||||
|
#define _DEV_I2C_SENSOR_LM75A_H
|
||||||
|
|
||||||
|
#include <dev/i2c/i2c.h>
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif /* __cplusplus */
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @defgroup I2CSensorLM75A Temperature Sensor LM75A Driver
|
||||||
|
*
|
||||||
|
* @ingroup I2CDevice
|
||||||
|
*
|
||||||
|
* @brief Driver for NXP or Texas Instruments LM75A temperature sensor.
|
||||||
|
*
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
int i2c_dev_register_sensor_lm75a(
|
||||||
|
const char *bus_path,
|
||||||
|
const char *dev_path,
|
||||||
|
uint16_t address
|
||||||
|
);
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
SENSOR_LM75A_GET_CONF = I2C_DEV_IO_CONTROL,
|
||||||
|
SENSOR_LM75A_SET_CONF,
|
||||||
|
SENSOR_LM75A_CLEAR_AND_SET_CONF,
|
||||||
|
SENSOR_LM75A_GET_TEMP,
|
||||||
|
SENSOR_LM75A_GET_TOS,
|
||||||
|
SENSOR_LM75A_SET_TOS,
|
||||||
|
SENSOR_LM75A_GET_THYST,
|
||||||
|
SENSOR_LM75A_SET_THYST
|
||||||
|
} sensor_lm75a_command;
|
||||||
|
|
||||||
|
static inline int sensor_lm75a_get_conf(int fd, uint8_t *val)
|
||||||
|
{
|
||||||
|
return ioctl(fd, SENSOR_LM75A_GET_CONF, val);
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline int sensor_lm75a_set_conf(int fd, uint8_t val)
|
||||||
|
{
|
||||||
|
return ioctl(fd, SENSOR_LM75A_SET_CONF, (void *)(uintptr_t) val);
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline int sensor_lm75a_clear_and_set_conf(
|
||||||
|
int fd,
|
||||||
|
uint8_t clear,
|
||||||
|
uint8_t set
|
||||||
|
)
|
||||||
|
{
|
||||||
|
uint16_t clear_and_set = (uint16_t) (((uint16_t) set << 8) | clear);
|
||||||
|
|
||||||
|
return ioctl(
|
||||||
|
fd,
|
||||||
|
SENSOR_LM75A_CLEAR_AND_SET_CONF,
|
||||||
|
(void *)(uintptr_t) clear_and_set
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline int sensor_lm75a_get_temp(int fd, int16_t *val)
|
||||||
|
{
|
||||||
|
return ioctl(fd, SENSOR_LM75A_GET_TEMP, val);
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline int sensor_lm75a_get_temp_celsius(int fd, double *celsius)
|
||||||
|
{
|
||||||
|
int rv;
|
||||||
|
int16_t val;
|
||||||
|
|
||||||
|
rv = ioctl(fd, SENSOR_LM75A_GET_TEMP, &val);
|
||||||
|
*celsius = (((int) val) >> 5) * 0.125;
|
||||||
|
return rv;
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline int sensor_lm75a_get_tos(int fd, uint16_t *val)
|
||||||
|
{
|
||||||
|
return ioctl(fd, SENSOR_LM75A_GET_TOS, val);
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline int sensor_lm75a_set_tos(int fd, uint16_t val)
|
||||||
|
{
|
||||||
|
return ioctl(fd, SENSOR_LM75A_SET_TOS, (void *)(uintptr_t) val);
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline int sensor_lm75a_get_thyst(int fd, uint16_t *val)
|
||||||
|
{
|
||||||
|
return ioctl(fd, SENSOR_LM75A_GET_THYST, val);
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline int sensor_lm75a_set_thyst(int fd, uint16_t val)
|
||||||
|
{
|
||||||
|
return ioctl(fd, SENSOR_LM75A_SET_THYST, (void *)(uintptr_t) val);
|
||||||
|
}
|
||||||
|
|
||||||
|
/** @} */
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif /* __cplusplus */
|
||||||
|
|
||||||
|
#endif /* _DEV_I2C_SENSOR_LM75A_H */
|
||||||
@@ -39,6 +39,10 @@ $(PROJECT_INCLUDE)/dev/i2c/i2c.h: include/dev/i2c/i2c.h $(PROJECT_INCLUDE)/dev/i
|
|||||||
$(INSTALL_DATA) $< $(PROJECT_INCLUDE)/dev/i2c/i2c.h
|
$(INSTALL_DATA) $< $(PROJECT_INCLUDE)/dev/i2c/i2c.h
|
||||||
PREINSTALL_FILES += $(PROJECT_INCLUDE)/dev/i2c/i2c.h
|
PREINSTALL_FILES += $(PROJECT_INCLUDE)/dev/i2c/i2c.h
|
||||||
|
|
||||||
|
$(PROJECT_INCLUDE)/dev/i2c/sensor-lm75a.h: include/dev/i2c/sensor-lm75a.h $(PROJECT_INCLUDE)/dev/i2c/$(dirstamp)
|
||||||
|
$(INSTALL_DATA) $< $(PROJECT_INCLUDE)/dev/i2c/sensor-lm75a.h
|
||||||
|
PREINSTALL_FILES += $(PROJECT_INCLUDE)/dev/i2c/sensor-lm75a.h
|
||||||
|
|
||||||
$(PROJECT_INCLUDE)/dev/i2c/switch-nxp-pca9548a.h: include/dev/i2c/switch-nxp-pca9548a.h $(PROJECT_INCLUDE)/dev/i2c/$(dirstamp)
|
$(PROJECT_INCLUDE)/dev/i2c/switch-nxp-pca9548a.h: include/dev/i2c/switch-nxp-pca9548a.h $(PROJECT_INCLUDE)/dev/i2c/$(dirstamp)
|
||||||
$(INSTALL_DATA) $< $(PROJECT_INCLUDE)/dev/i2c/switch-nxp-pca9548a.h
|
$(INSTALL_DATA) $< $(PROJECT_INCLUDE)/dev/i2c/switch-nxp-pca9548a.h
|
||||||
PREINSTALL_FILES += $(PROJECT_INCLUDE)/dev/i2c/switch-nxp-pca9548a.h
|
PREINSTALL_FILES += $(PROJECT_INCLUDE)/dev/i2c/switch-nxp-pca9548a.h
|
||||||
|
|||||||
Reference in New Issue
Block a user