From: Antoni Pokusinski <apokusinski01@gmail.com>
To: jdelvare@suse.com, linux@roeck-us.net, corbet@lwn.net
Cc: linux-hwmon@vger.kernel.org, linux-doc@vger.kernel.org,
linux-kernel@vger.kernel.org,
Antoni Pokusinski <apokusinski01@gmail.com>
Subject: [PATCH] hwmon: (sht3x) add support for SHT85
Date: Tue, 9 Dec 2025 18:58:49 +0100 [thread overview]
Message-ID: <20251209175848.5739-1-apokusinski01@gmail.com> (raw)
SHT85 is a temperature and humidity sensor with an interface very
similar to SHT3x. However, it does not feature alerts (and therefore
limits).
Signed-off-by: Antoni Pokusinski <apokusinski01@gmail.com>
---
Documentation/hwmon/sht3x.rst | 11 ++++++++++-
drivers/hwmon/sht3x.c | 26 +++++++++++++++++---------
2 files changed, 27 insertions(+), 10 deletions(-)
diff --git a/Documentation/hwmon/sht3x.rst b/Documentation/hwmon/sht3x.rst
index 9585fa7c5a5d..25c7428f0a77 100644
--- a/Documentation/hwmon/sht3x.rst
+++ b/Documentation/hwmon/sht3x.rst
@@ -23,6 +23,15 @@ Supported chips:
- https://sensirion.com/media/documents/1DA31AFD/61641F76/Sensirion_Temperature_Sensors_STS3x_Datasheet.pdf
- https://sensirion.com/media/documents/292A335C/65537BAF/Sensirion_Datasheet_STS32_STS33.pdf
+ * Sensirion SHT85
+
+ Prefix: 'sht85'
+
+ Addresses scanned: none
+
+ Datasheets:
+ - https://sensirion.com/media/documents/4B40CEF3/640B2346/Sensirion_Humidity_Sensors_SHT85_Datasheet.pdf
+
Author:
- David Frey <david.frey@sensirion.com>
@@ -31,7 +40,7 @@ Author:
Description
-----------
-This driver implements support for the Sensirion SHT3x-DIS and STS3x-DIS
+This driver implements support for the Sensirion SHT3x-DIS, STS3x-DIS and SHT85
series of humidity and temperature sensors. Temperature is measured in degrees
celsius, relative humidity is expressed as a percentage. In the sysfs interface,
all values are scaled by 1000, i.e. the value for 31.5 degrees celsius is 31500.
diff --git a/drivers/hwmon/sht3x.c b/drivers/hwmon/sht3x.c
index f36c0229328f..eff915d31452 100644
--- a/drivers/hwmon/sht3x.c
+++ b/drivers/hwmon/sht3x.c
@@ -63,6 +63,7 @@ static const unsigned char sht3x_cmd_read_serial_number[] = { 0x37, 0x80 };
enum sht3x_chips {
sht3x,
sts3x,
+ sht85,
};
enum sht3x_limits {
@@ -668,6 +669,8 @@ static umode_t sht3x_is_visible(const void *data, enum hwmon_sensor_types type,
}
break;
case hwmon_temp:
+ if (chip_data->chip_id == sht85 && attr != hwmon_temp_input)
+ break;
switch (attr) {
case hwmon_temp_input:
case hwmon_temp_alarm:
@@ -684,6 +687,8 @@ static umode_t sht3x_is_visible(const void *data, enum hwmon_sensor_types type,
case hwmon_humidity:
if (chip_data->chip_id == sts3x)
break;
+ if (chip_data->chip_id == sht85 && attr != hwmon_humidity_input)
+ break;
switch (attr) {
case hwmon_humidity_input:
case hwmon_humidity_alarm:
@@ -908,16 +913,18 @@ static int sht3x_probe(struct i2c_client *client)
mutex_init(&data->i2c_lock);
mutex_init(&data->data_lock);
- /*
- * An attempt to read limits register too early
- * causes a NACK response from the chip.
- * Waiting for an empirical delay of 500 us solves the issue.
- */
- usleep_range(500, 600);
+ if (data->chip_id == sht3x || data->chip_id == sts3x) {
+ /*
+ * An attempt to read limits register too early
+ * causes a NACK response from the chip.
+ * Waiting for an empirical delay of 500 us solves the issue.
+ */
+ usleep_range(500, 600);
- ret = limits_update(data);
- if (ret)
- return ret;
+ ret = limits_update(data);
+ if (ret)
+ return ret;
+ }
hwmon_dev = devm_hwmon_device_register_with_info(dev, client->name, data,
&sht3x_chip_info, sht3x_groups);
@@ -933,6 +940,7 @@ static int sht3x_probe(struct i2c_client *client)
static const struct i2c_device_id sht3x_ids[] = {
{"sht3x", sht3x},
{"sts3x", sts3x},
+ {"sht85", sht85},
{}
};
--
2.25.1
next reply other threads:[~2025-12-09 17:59 UTC|newest]
Thread overview: 5+ messages / expand[flat|nested] mbox.gz Atom feed top
2025-12-09 17:58 Antoni Pokusinski [this message]
2025-12-09 21:19 ` [PATCH] hwmon: (sht3x) add support for SHT85 Guenter Roeck
2025-12-10 3:09 ` Guenter Roeck
2025-12-10 21:44 ` Antoni Pokusinski
2025-12-10 21:56 ` Guenter Roeck
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20251209175848.5739-1-apokusinski01@gmail.com \
--to=apokusinski01@gmail.com \
--cc=corbet@lwn.net \
--cc=jdelvare@suse.com \
--cc=linux-doc@vger.kernel.org \
--cc=linux-hwmon@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=linux@roeck-us.net \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).