Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/dev/usb Match an additional `SHT1x' signature when attac...
details: https://anonhg.NetBSD.org/src/rev/58e3e20dd0b1
branches: trunk
changeset: 752940:58e3e20dd0b1
user: jdc <jdc%NetBSD.org@localhost>
date: Fri Mar 12 09:02:15 2010 +0000
description:
Match an additional `SHT1x' signature when attaching.
Handle different temperature calculations for `SHT1x' and for `TEMPer' types.
Display signature and data when UTHUM_DEBUG is defined.
Tested on `SHT1x' (TEMPerHUM) and `TEMPer' (TEMPer and TEMPer1) devices.
Also tested by Antoine Reilles on an `SHT1x' device.
diffstat:
sys/dev/usb/uthum.c | 56 +++++++++++++++++++++++++++++++++++++++++-----------
1 files changed, 44 insertions(+), 12 deletions(-)
diffs (119 lines):
diff -r 7bc2f9ddaa86 -r 58e3e20dd0b1 sys/dev/usb/uthum.c
--- a/sys/dev/usb/uthum.c Fri Mar 12 08:40:50 2010 +0000
+++ b/sys/dev/usb/uthum.c Fri Mar 12 09:02:15 2010 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: uthum.c,v 1.4 2010/03/07 11:28:46 jdc Exp $ */
+/* $NetBSD: uthum.c,v 1.5 2010/03/12 09:02:15 jdc Exp $ */
/* $OpenBSD: uthum.c,v 1.6 2010/01/03 18:43:02 deraadt Exp $ */
/*
@@ -103,7 +103,8 @@
int uthum_read_data(struct uthum_softc *, uint8_t, uint8_t *, size_t, int);
int uthum_check_sensortype(struct uthum_softc *);
-int uthum_sht1x_temp(unsigned int);
+int uthum_temper_temp(uint8_t, uint8_t);
+int uthum_sht1x_temp(uint8_t, uint8_t);
int uthum_sht1x_rh(unsigned int, int);
void uthum_intr(struct uhidev *, void *, u_int);
@@ -297,8 +298,10 @@
uthum_check_sensortype(struct uthum_softc *sc)
{
uint8_t buf[8];
- static uint8_t sht1x_sig[] =
+ static uint8_t sht1x_sig0[] =
{ 0x57, 0x5a, 0x13, 0x00, 0x14, 0x00, 0x53, 0x00 };
+ static uint8_t sht1x_sig1[] =
+ { 0x57, 0x5a, 0x14, 0x00, 0x14, 0x00, 0x53, 0x00 };
static uint8_t temper_sig[] =
{ 0x57, 0x58, 0x14, 0x00, 0x14, 0x00, 0x53, 0x00 };
@@ -312,10 +315,16 @@
* therefore, compare full bytes.
* TEMPerHUM HID (SHT1x version) will return:
* { 0x57, 0x5a, 0x13, 0x00, 0x14, 0x00, 0x53, 0x00 }
- * TEMPer HID (SHT1x version) will return:
+ * { 0x57, 0x5a, 0x14, 0x00, 0x14, 0x00, 0x53, 0x00 }
+ * TEMPer HID (TEMPer version) will return:
* { 0x57, 0x58, 0x14, 0x00, 0x14, 0x00, 0x53, 0x00 }
*/
- if (0 == memcmp(buf, sht1x_sig, sizeof(sht1x_sig)))
+ DPRINTF(("uthum: device signature: "
+ "0x%0x 0x%0x 0x%0x 0x%0x 0x%0x 0x%0x 0x%0x 0x%0x\n",
+ buf[0], buf[1], buf[2], buf[3], buf[4], buf[5], buf[6], buf[7]));
+ if (0 == memcmp(buf, sht1x_sig0, sizeof(sht1x_sig0)))
+ return UTHUM_TYPE_SHT1x;
+ if (0 == memcmp(buf, sht1x_sig1, sizeof(sht1x_sig1)))
return UTHUM_TYPE_SHT1x;
if (0 == memcmp(buf, temper_sig, sizeof(temper_sig)))
return UTHUM_TYPE_TEMPER;
@@ -329,7 +338,7 @@
{
struct uthum_softc *sc = sme->sme_cookie;
uint8_t buf[8];
- unsigned int temp_tick, humidity_tick;
+ unsigned int humidity_tick;
int temp, rh;
switch (sc->sc_sensortype) {
@@ -340,11 +349,14 @@
sc->sc_sensor[UTHUM_HUMIDITY].state = ENVSYS_SINVALID;
return;
}
+ DPRINTF(("%s: read SHT1x data "
+ "0x%0x 0x%0x 0x%0x 0x%0x 0x%0x 0x%0x 0x%0x 0x%0x\n",
+ sc->sc_sme->sme_name, buf[0], buf[1], buf[2], buf[3],
+ buf[4], buf[5], buf[6], buf[7]));
- temp_tick = (buf[0] * 256 + buf[1]) & 0x3fff;
humidity_tick = (buf[2] * 256 + buf[3]) & 0x0fff;
- temp = uthum_sht1x_temp(temp_tick);
+ temp = uthum_sht1x_temp(buf[0], buf[1]);
rh = uthum_sht1x_rh(humidity_tick, temp);
sc->sc_sensor[UTHUM_HUMIDITY].value_cur = rh / 1000;
@@ -356,8 +368,11 @@
sc->sc_sensor[UTHUM_TEMP].state = ENVSYS_SINVALID;
return;
}
- temp_tick = (buf[0] * 256 + buf[1]) & 0xffff;
- temp = uthum_sht1x_temp(temp_tick);
+ DPRINTF(("%s: read TEMPER data "
+ "0x%0x 0x%0x 0x%0x 0x%0x 0x%0x 0x%0x 0x%0x 0x%0x\n",
+ sc->sc_sme->sme_name, buf[0], buf[1], buf[2], buf[3],
+ buf[4], buf[5], buf[6], buf[7]));
+ temp = uthum_temper_temp(buf[0], buf[1]);
break;
default:
/* do nothing */
@@ -370,9 +385,26 @@
/* return C-degree * 100 value */
int
-uthum_sht1x_temp(unsigned int ticks)
+uthum_temper_temp(uint8_t msb, uint8_t lsb)
{
- return (ticks - 4010);
+ int val;
+
+ val = (msb << 8) | lsb;
+ if (val >= 32768) {
+ val = val - 65536;
+ }
+ val = (val * 100) >> 8;
+ return val;
+}
+
+/* return C-degree * 100 value */
+int
+uthum_sht1x_temp(uint8_t msb, uint8_t lsb)
+{
+ int val;
+
+ val = ((msb << 8) + lsb) - 4096;
+ return val;
}
/* return %RH * 1000 */
Home |
Main Index |
Thread Index |
Old Index