Commit 1b75ce65 authored by Ludovic Tancerel's avatar Ludovic Tancerel Committed by Jonathan Cameron

Add ms8607 meas-spec driver support

Support for MS8607 temperature, pressure & humidity sensor.
This part is using functions from MS5637 for temperature and pressure
and HTU21 for humidity
Signed-off-by: default avatarLudovic Tancerel <ludovic.tancerel@maplehightech.com>
Signed-off-by: default avatarJonathan Cameron <jic23@kernel.org>
parent 64a70c65
...@@ -5,3 +5,4 @@ Description: ...@@ -5,3 +5,4 @@ Description:
Reading returns either '1' or '0'. '1' means that the Reading returns either '1' or '0'. '1' means that the
battery level supplied to sensor is below 2.25V. battery level supplied to sensor is below 2.25V.
This ABI is available for tsys02d, htu21, ms8607 This ABI is available for tsys02d, htu21, ms8607
This ABI is available for htu21, ms8607
...@@ -29,6 +29,8 @@ config HTU21 ...@@ -29,6 +29,8 @@ config HTU21
help help
If you say yes here you get support for the Measurement Specialties If you say yes here you get support for the Measurement Specialties
HTU21 humidity and temperature sensor. HTU21 humidity and temperature sensor.
This driver is also used for MS8607 temperature, pressure & humidity
sensor
This driver can also be built as a module. If so, the module will This driver can also be built as a module. If so, the module will
be called htu21. be called htu21.
......
/* /*
* htu21.c - Support for Measurement-Specialties * htu21.c - Support for Measurement-Specialties
* htu21 temperature & humidity sensor * htu21 temperature & humidity sensor
* and humidity part of MS8607 sensor
* *
* Copyright (c) 2014 Measurement-Specialties * Copyright (c) 2014 Measurement-Specialties
* *
...@@ -10,6 +11,8 @@ ...@@ -10,6 +11,8 @@
* *
* Datasheet: * Datasheet:
* http://www.meas-spec.com/downloads/HTU21D.pdf * http://www.meas-spec.com/downloads/HTU21D.pdf
* Datasheet:
* http://www.meas-spec.com/downloads/MS8607-02BA01.pdf
*/ */
#include <linux/init.h> #include <linux/init.h>
...@@ -24,6 +27,11 @@ ...@@ -24,6 +27,11 @@
#define HTU21_RESET 0xFE #define HTU21_RESET 0xFE
enum {
HTU21,
MS8607
};
static const int htu21_samp_freq[4] = { 20, 40, 70, 120 }; static const int htu21_samp_freq[4] = { 20, 40, 70, 120 };
/* String copy of the above const for readability purpose */ /* String copy of the above const for readability purpose */
static const char htu21_show_samp_freq[] = "20 40 70 120"; static const char htu21_show_samp_freq[] = "20 40 70 120";
...@@ -106,6 +114,18 @@ static const struct iio_chan_spec htu21_channels[] = { ...@@ -106,6 +114,18 @@ static const struct iio_chan_spec htu21_channels[] = {
} }
}; };
/*
* Meas Spec recommendation is to not read temperature
* on this driver part for MS8607
*/
static const struct iio_chan_spec ms8607_channels[] = {
{
.type = IIO_HUMIDITYRELATIVE,
.info_mask_shared_by_type = BIT(IIO_CHAN_INFO_PROCESSED),
.info_mask_shared_by_all = BIT(IIO_CHAN_INFO_SAMP_FREQ),
}
};
static ssize_t htu21_show_battery_low(struct device *dev, static ssize_t htu21_show_battery_low(struct device *dev,
struct device_attribute *attr, char *buf) struct device_attribute *attr, char *buf)
{ {
...@@ -188,8 +208,14 @@ static int htu21_probe(struct i2c_client *client, ...@@ -188,8 +208,14 @@ static int htu21_probe(struct i2c_client *client,
indio_dev->name = id->name; indio_dev->name = id->name;
indio_dev->dev.parent = &client->dev; indio_dev->dev.parent = &client->dev;
indio_dev->modes = INDIO_DIRECT_MODE; indio_dev->modes = INDIO_DIRECT_MODE;
if (id->driver_data == MS8607) {
indio_dev->channels = ms8607_channels;
indio_dev->num_channels = ARRAY_SIZE(ms8607_channels);
} else {
indio_dev->channels = htu21_channels; indio_dev->channels = htu21_channels;
indio_dev->num_channels = ARRAY_SIZE(htu21_channels); indio_dev->num_channels = ARRAY_SIZE(htu21_channels);
}
i2c_set_clientdata(client, indio_dev); i2c_set_clientdata(client, indio_dev);
...@@ -206,7 +232,8 @@ static int htu21_probe(struct i2c_client *client, ...@@ -206,7 +232,8 @@ static int htu21_probe(struct i2c_client *client,
} }
static const struct i2c_device_id htu21_id[] = { static const struct i2c_device_id htu21_id[] = {
{"htu21", 0}, {"htu21", HTU21},
{"ms8607-humidity", MS8607},
{} {}
}; };
......
...@@ -86,6 +86,8 @@ config MS5637 ...@@ -86,6 +86,8 @@ config MS5637
help help
If you say yes here you get support for the Measurement Specialties If you say yes here you get support for the Measurement Specialties
MS5637 pressure and temperature sensor. MS5637 pressure and temperature sensor.
This driver is also used for MS8607 temperature, pressure & humidity
sensor
This driver can also be built as a module. If so, the module will This driver can also be built as a module. If so, the module will
be called ms5637. be called ms5637.
......
/* /*
* ms5637.c - Support for Measurement-Specialties ms5637 * ms5637.c - Support for Measurement-Specialties ms5637 and ms8607
* pressure & temperature sensor * pressure & temperature sensor
* *
* Copyright (c) 2015 Measurement-Specialties * Copyright (c) 2015 Measurement-Specialties
...@@ -10,7 +10,10 @@ ...@@ -10,7 +10,10 @@
* *
* Datasheet: * Datasheet:
* http://www.meas-spec.com/downloads/MS5637-02BA03.pdf * http://www.meas-spec.com/downloads/MS5637-02BA03.pdf
* Datasheet:
* http://www.meas-spec.com/downloads/MS8607-02BA01.pdf
*/ */
#include <linux/init.h> #include <linux/init.h>
#include <linux/device.h> #include <linux/device.h>
#include <linux/kernel.h> #include <linux/kernel.h>
...@@ -167,6 +170,7 @@ static int ms5637_probe(struct i2c_client *client, ...@@ -167,6 +170,7 @@ static int ms5637_probe(struct i2c_client *client,
static const struct i2c_device_id ms5637_id[] = { static const struct i2c_device_id ms5637_id[] = {
{"ms5637", 0}, {"ms5637", 0},
{"ms8607-temppressure", 1},
{} {}
}; };
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment