Module Name:    src
Committed By:   kardel
Date:           Sun May 18 11:46:24 UTC 2014

Modified Files:
        src/doc: CHANGES
        src/share/man/man4: Makefile
        src/sys/dev/i2c: files.i2c
        src/sys/dev/sysmon: sysmon_envsys_tables.c
        src/sys/modules: Makefile
        src/sys/sys: envsys.h
        src/usr.sbin/envstat: envstat.8 envstat.c
Added Files:
        src/share/man/man4: hythygtemp.4
        src/sys/dev/i2c: hytp14.c hytp14reg.h hytp14var.h
        src/sys/modules/hythygtemp: Makefile hythygtemp.ioconf

Log Message:
add HYT-221/271/939 humidity/temperature I2C sensor
extend envsys(4) framework by %rH (relative humidity)


To generate a diff of this commit:
cvs rdiff -u -r1.1925 -r1.1926 src/doc/CHANGES
cvs rdiff -u -r1.613 -r1.614 src/share/man/man4/Makefile
cvs rdiff -u -r0 -r1.1 src/share/man/man4/hythygtemp.4
cvs rdiff -u -r1.53 -r1.54 src/sys/dev/i2c/files.i2c
cvs rdiff -u -r0 -r1.1 src/sys/dev/i2c/hytp14.c src/sys/dev/i2c/hytp14reg.h \
    src/sys/dev/i2c/hytp14var.h
cvs rdiff -u -r1.11 -r1.12 src/sys/dev/sysmon/sysmon_envsys_tables.c
cvs rdiff -u -r1.135 -r1.136 src/sys/modules/Makefile
cvs rdiff -u -r0 -r1.1 src/sys/modules/hythygtemp/Makefile \
    src/sys/modules/hythygtemp/hythygtemp.ioconf
cvs rdiff -u -r1.33 -r1.34 src/sys/sys/envsys.h
cvs rdiff -u -r1.61 -r1.62 src/usr.sbin/envstat/envstat.8
cvs rdiff -u -r1.94 -r1.95 src/usr.sbin/envstat/envstat.c

Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.

Modified files:

Index: src/doc/CHANGES
diff -u src/doc/CHANGES:1.1925 src/doc/CHANGES:1.1926
--- src/doc/CHANGES:1.1925	Fri May 16 06:25:22 2014
+++ src/doc/CHANGES	Sun May 18 11:46:23 2014
@@ -1,4 +1,4 @@
-# LIST OF CHANGES FROM LAST RELEASE:			<$Revision: 1.1925 $>
+# LIST OF CHANGES FROM LAST RELEASE:			<$Revision: 1.1926 $>
 #
 #
 # [Note: This file does not mention every change made to the NetBSD source tree.
@@ -417,3 +417,7 @@ Changes from NetBSD 6.0 to NetBSD 7.0:
 		[pettai 20140424]
 	libc: Update to tzcode2014c. [christos 20140513]
 	zoneinfo: Import tzdata2014c. [apb 20140515]
+	hythygtemp(4): Add HYT-221/271/939 humidity/temperature iic sensor
+		driver.	[kardel 20140518]
+	envsys(4): Add %rH (relative Humidity) to sensor framework. 
+		[kardel 20140518]
\ No newline at end of file

Index: src/share/man/man4/Makefile
diff -u src/share/man/man4/Makefile:1.613 src/share/man/man4/Makefile:1.614
--- src/share/man/man4/Makefile:1.613	Wed Apr 23 06:53:14 2014
+++ src/share/man/man4/Makefile	Sun May 18 11:46:23 2014
@@ -1,4 +1,4 @@
-#	$NetBSD: Makefile,v 1.613 2014/04/23 06:53:14 kardel Exp $
+#	$NetBSD: Makefile,v 1.614 2014/05/18 11:46:23 kardel Exp $
 #	@(#)Makefile	8.1 (Berkeley) 6/18/93
 
 MAN=	aac.4 ac97.4 acardide.4 aceride.4 acphy.4 \
@@ -28,7 +28,7 @@ MAN=	aac.4 ac97.4 acardide.4 aceride.4 a
 	gcscaudio.4 gem.4 genfb.4 gentbi.4 geodeide.4 \
 	glxtphy.4 gpib.4 gpio.4 gpiolock.4 gpiopwm.4 gpiosim.4 gre.4 \
 	gphyter.4 gsip.4 \
-	hdaudio.4 hifn.4 hme.4 hpacel.4 hpqlb.4 hptide.4 \
+	hdaudio.4 hifn.4 hme.4 hpacel.4 hpqlb.4 hptide.4 hythygtemp.4 \
 	ibmcd.4 ibmhawk.4 ichsmb.4 icmp.4 icp.4 icsphy.4 iee.4 ieee80211.4 \
 	ifmedia.4 igmafb.4 igphy.4 igsfb.4 iha.4 ihphy.4 iic.4 inet.4 ikphy.4 \
 	inphy.4 intersil7170.4 \

Index: src/sys/dev/i2c/files.i2c
diff -u src/sys/dev/i2c/files.i2c:1.53 src/sys/dev/i2c/files.i2c:1.54
--- src/sys/dev/i2c/files.i2c:1.53	Tue Oct 15 19:13:32 2013
+++ src/sys/dev/i2c/files.i2c	Sun May 18 11:46:23 2014
@@ -1,4 +1,4 @@
-#	$NetBSD: files.i2c,v 1.53 2013/10/15 19:13:32 jdc Exp $
+#	$NetBSD: files.i2c,v 1.54 2014/05/18 11:46:23 kardel Exp $
 
 obsolete defflag	opt_i2cbus.h		I2C_SCAN
 define	i2cbus { }
@@ -103,6 +103,11 @@ device	lmtemp: sysmon_envsys
 attach	lmtemp at iic
 file	dev/i2c/lm75.c				lmtemp
 
+# IST-AG Humidity and Teperature sensor (P14)
+device	hythygtemp: sysmon_envsys
+attach	hythygtemp at iic
+file	dev/i2c/hytp14.c			hythygtemp
+
 # National Semiconductor LM78 temp sensor/fan controller
 attach	lm at iic with lm_iic
 file	dev/i2c/lm_i2c.c			lm_iic

Index: src/sys/dev/sysmon/sysmon_envsys_tables.c
diff -u src/sys/dev/sysmon/sysmon_envsys_tables.c:1.11 src/sys/dev/sysmon/sysmon_envsys_tables.c:1.12
--- src/sys/dev/sysmon/sysmon_envsys_tables.c:1.11	Mon Aug 27 21:42:04 2012
+++ src/sys/dev/sysmon/sysmon_envsys_tables.c	Sun May 18 11:46:23 2014
@@ -1,4 +1,4 @@
-/* $NetBSD: sysmon_envsys_tables.c,v 1.11 2012/08/27 21:42:04 pgoyette Exp $ */
+/* $NetBSD: sysmon_envsys_tables.c,v 1.12 2014/05/18 11:46:23 kardel Exp $ */
 
 /*-
  * Copyright (c) 2007 Juan Romero Pardines.
@@ -26,7 +26,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: sysmon_envsys_tables.c,v 1.11 2012/08/27 21:42:04 pgoyette Exp $");
+__KERNEL_RCSID(0, "$NetBSD: sysmon_envsys_tables.c,v 1.12 2014/05/18 11:46:23 kardel Exp $");
 
 #include <sys/types.h>
 
@@ -51,6 +51,7 @@ static const struct sme_descr_entry sme_
 	{ ENVSYS_DRIVE,		PENVSYS_TYPE_DRIVE,	"Drive" },
 	{ ENVSYS_BATTERY_CAPACITY, PENVSYS_TYPE_BATTERY,"Battery capacity" },
 	{ ENVSYS_BATTERY_CHARGE, -1,			"Battery charge" },
+	{ ENVSYS_SRELHUMIDITY,	-1,			"relative Humidity" },
 	{ -1,			-1,			"unknown" }
 };
 

Index: src/sys/modules/Makefile
diff -u src/sys/modules/Makefile:1.135 src/sys/modules/Makefile:1.136
--- src/sys/modules/Makefile:1.135	Fri Jan  3 16:16:10 2014
+++ src/sys/modules/Makefile	Sun May 18 11:46:23 2014
@@ -1,4 +1,4 @@
-#	$NetBSD: Makefile,v 1.135 2014/01/03 16:16:10 pgoyette Exp $
+#	$NetBSD: Makefile,v 1.136 2014/05/18 11:46:23 kardel Exp $
 
 .include <bsd.own.mk>
 
@@ -39,6 +39,7 @@ SUBDIR+=	gpioiic
 SUBDIR+=	gpioow
 SUBDIR+=	gpiosim
 SUBDIR+=	hfs
+SUBDIR+=	hythygtemp
 SUBDIR+=	if_axe
 SUBDIR+=	if_axen
 SUBDIR+=	if_npflog

Index: src/sys/sys/envsys.h
diff -u src/sys/sys/envsys.h:1.33 src/sys/sys/envsys.h:1.34
--- src/sys/sys/envsys.h:1.33	Wed Dec  5 04:21:30 2012
+++ src/sys/sys/envsys.h	Sun May 18 11:46:24 2014
@@ -1,7 +1,7 @@
-/* $NetBSD: envsys.h,v 1.33 2012/12/05 04:21:30 riastradh Exp $ */
+/* $NetBSD: envsys.h,v 1.34 2014/05/18 11:46:24 kardel Exp $ */
 
 /*-
- * Copyright (c) 1999, 2007 The NetBSD Foundation, Inc.
+ * Copyright (c) 1999, 2007, 2014 The NetBSD Foundation, Inc.
  * All rights reserved.
  *
  * This code is derived from software contributed to The NetBSD Foundation
@@ -63,6 +63,7 @@ enum envsys_units {
 	ENVSYS_DRIVE,			/* Drive */
 	ENVSYS_BATTERY_CAPACITY,	/* Battery capacity */
 	ENVSYS_BATTERY_CHARGE,		/* Battery charging/discharging */
+	ENVSYS_SRELHUMIDITY,		/* relative humidity */
 	ENVSYS_NSENSORS
 };
 
@@ -161,7 +162,7 @@ typedef struct envsys_tre_data envsys_tr
 #ifdef ENVSYSUNITNAMES
 static const char * const envsysunitnames[] = {
     "degC", "RPM", "VAC", "V", "Ohms", "W",
-    "A", "Wh", "Ah", "bool", "integer", "drive", "Unk"
+    "A", "Wh", "Ah", "bool", "integer", "drive", "%rH", "Unk"
 };
 static const char * const envsysdrivestatus[] = {
     "unknown", "empty", "ready", "powering up", "online", "idle", "active",

Index: src/usr.sbin/envstat/envstat.8
diff -u src/usr.sbin/envstat/envstat.8:1.61 src/usr.sbin/envstat/envstat.8:1.62
--- src/usr.sbin/envstat/envstat.8:1.61	Thu Feb  9 18:10:26 2012
+++ src/usr.sbin/envstat/envstat.8	Sun May 18 11:46:24 2014
@@ -1,6 +1,6 @@
-.\"	$NetBSD: envstat.8,v 1.61 2012/02/09 18:10:26 riz Exp $
+.\"	$NetBSD: envstat.8,v 1.62 2014/05/18 11:46:24 kardel Exp $
 .\"
-.\" Copyright (c) 2000, 2007, 2008, 2009 The NetBSD Foundation, Inc.
+.\" Copyright (c) 2000, 2007, 2008, 2009, 2014 The NetBSD Foundation, Inc.
 .\" All rights reserved.
 .\"
 .\" This code is derived from software contributed to The NetBSD Foundation
@@ -27,7 +27,7 @@
 .\" ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
 .\" POSSIBILITY OF SUCH DAMAGE.
 .\"
-.Dd June 7, 2011
+.Dd May 18, 2014
 .Dt ENVSTAT 8
 .Os
 .Sh NAME
@@ -166,6 +166,8 @@ Volts AC
 Watts
 .It Wh
 Watt-hours
+.It %rH
+relative Humidity
 .El
 .Sh EXAMPLES
 To display the
@@ -217,6 +219,7 @@ invalid states every second:
 .Xr envctrl 4 ,
 .Xr envsys 4 ,
 .Xr finsio 4 ,
+.Xr hythygtemp 4 ,
 .Xr ipmi 4 ,
 .Xr itesio 4 ,
 .Xr lm 4 ,

Index: src/usr.sbin/envstat/envstat.c
diff -u src/usr.sbin/envstat/envstat.c:1.94 src/usr.sbin/envstat/envstat.c:1.95
--- src/usr.sbin/envstat/envstat.c:1.94	Fri Dec 14 05:29:28 2012
+++ src/usr.sbin/envstat/envstat.c	Sun May 18 11:46:24 2014
@@ -1,4 +1,4 @@
-/* $NetBSD: envstat.c,v 1.94 2012/12/14 05:29:28 pgoyette Exp $ */
+/* $NetBSD: envstat.c,v 1.95 2014/05/18 11:46:24 kardel Exp $ */
 
 /*-
  * Copyright (c) 2007, 2008 Juan Romero Pardines.
@@ -27,7 +27,7 @@
 
 #include <sys/cdefs.h>
 #ifndef lint
-__RCSID("$NetBSD: envstat.c,v 1.94 2012/12/14 05:29:28 pgoyette Exp $");
+__RCSID("$NetBSD: envstat.c,v 1.95 2014/05/18 11:46:24 kardel Exp $");
 #endif /* not lint */
 
 #include <stdio.h>
@@ -975,6 +975,8 @@ do {									\
 				stype = "Wh";
 			else if (strcmp(sensor->type, "Ampere hour") == 0)
 				stype = "Ah";
+			else if (strcmp(sensor->type, "relative Humidity") == 0)
+				stype = "%rH";
 			else
 				stype = "?";
 

Added files:

Index: src/share/man/man4/hythygtemp.4
diff -u /dev/null src/share/man/man4/hythygtemp.4:1.1
--- /dev/null	Sun May 18 11:46:24 2014
+++ src/share/man/man4/hythygtemp.4	Sun May 18 11:46:23 2014
@@ -0,0 +1,63 @@
+.\"	$NetBSD: hythygtemp.4,v 1.1 2014/05/18 11:46:23 kardel Exp $
+.\"
+.\"Copyright (c) 2014 Frank Kardel
+.\"All rights reserved.
+.\"
+.\"Redistribution and use in source and binary forms, with or without
+.\"modification, are permitted provided that the following conditions
+.\"are met:
+.\"1. Redistributions of source code must retain the above copyright
+.\"   notice, this list of conditions and the following disclaimer.
+.\"2. Redistributions in binary form must reproduce the above copyright
+.\"   notice, this list of conditions and the following disclaimer in the
+.\"   documentation and/or other materials provided with the distribution.
+.\"
+.\"THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS
+.\"``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
+.\"TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
+.\"PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
+.\"BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+.\"CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
+.\"SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
+.\"INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
+.\"CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
+.\"ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
+.\"POSSIBILITY OF SUCH DAMAGE.
+.\"
+.Dd May 18, 2014
+.Dt HYTHYGTEMP 4
+.Os
+.Sh NAME
+.Nm hythygtemp
+.Nd Driver for IST-AG HYT-221/271/939 sensor chip via I2C bus
+.Sh SYNOPSIS
+.Cd "hythygtemp* at iic? addr 0x28"
+.Sh DESCRIPTION
+The
+.Nm
+driver provides measurements from the HYT-221/271/939 humidity/temperature
+sensors via the
+.Xr envsys 4
+framework.
+The
+.Nm
+.Ar addr
+argument selects the address at the 
+.Xr iic 4
+bus. The sensor chips can be reconfigured to respond to other addresses than the
+default value of 0x28.
+.Sh SEE ALSO
+.Xr envstat 8 ,
+.Xr envsys 4 ,
+.Xr iic 4
+.Sh HISTORY
+The
+.Nm
+driver first appeared in
+.Nx 7.0 .
+.Sh AUTHORS
+.An -nosplit
+The
+.Nm
+driver was written by
+.An Frank Kardel Aq Mt kar...@netbsd.org .

Index: src/sys/dev/i2c/hytp14.c
diff -u /dev/null src/sys/dev/i2c/hytp14.c:1.1
--- /dev/null	Sun May 18 11:46:24 2014
+++ src/sys/dev/i2c/hytp14.c	Sun May 18 11:46:23 2014
@@ -0,0 +1,312 @@
+/*-
+ * Copyright (c) 2014 The NetBSD Foundation, Inc.
+ * All rights reserved.
+ *
+ * This code is derived from software contributed to The NetBSD Foundation
+ * by Frank Kardel.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ *    notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ *    notice, this list of conditions and the following disclaimer in the
+ *    documentation and/or other materials provided with the distribution.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
+ * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
+ * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
+ * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
+ * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+ * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
+ * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
+ * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
+ * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
+ * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
+ * POSSIBILITY OF SUCH DAMAGE.
+ */
+
+/*
+ * IST-AG P14 calibrated Hygro-/Temperature sensor module
+ * Devices: HYT-271, HYT-221 and HYT-939 
+ *
+ * see:
+ * http://www.ist-ag.com/eh/ist-ag/resource.nsf/imgref/Download_AHHYTM_E2.1.pdf/
+ *      $FILE/AHHYTM_E2.1.pdf
+ */ 
+
+#include <sys/cdefs.h>
+__KERNEL_RCSID(0, "$NetBSD: hytp14.c,v 1.1 2014/05/18 11:46:23 kardel Exp $");
+
+#include <sys/param.h>
+#include <sys/systm.h>
+#include <sys/kernel.h>
+#include <sys/device.h>
+#include <sys/module.h>
+
+#include <dev/sysmon/sysmonvar.h>
+
+#include <dev/i2c/i2cvar.h>
+#include <dev/i2c/hytp14reg.h>
+#include <dev/i2c/hytp14var.h>
+
+static int hytp14_match(device_t, cfdata_t, void *);
+static void hytp14_attach(device_t, device_t, void *);
+static int hytp14_detach(device_t, int);
+static int hytp14_refresh_sensor(struct hytp14_sc *sc);
+static void hytp14_refresh(struct sysmon_envsys *, envsys_data_t *);
+static void hytp14_refresh_humidity(struct hytp14_sc *, envsys_data_t *);
+static void hytp14_refresh_temp(struct hytp14_sc *, envsys_data_t *);
+
+/* #define HYT_DEBUG 3 */
+#ifdef HYT_DEBUG
+volatile int hythygtemp_debug = HYT_DEBUG;
+
+#define DPRINTF(_L_, _X_) do {			\
+	  if ((_L_) <= hythygtemp_debug) {	\
+	    printf _X_;				\
+	  }                                     \
+        } while (0)
+#else
+#define DPRINTF(_L_, _X_)
+#endif
+
+CFATTACH_DECL_NEW(hythygtemp, sizeof(struct hytp14_sc),
+    hytp14_match, hytp14_attach, hytp14_detach, NULL);
+
+static struct hytp14_sensor hytp14_sensors[] = {
+	{
+		.desc = "humidity",
+		.type = ENVSYS_SRELHUMIDITY,
+		.refresh = hytp14_refresh_humidity
+	},
+	{
+		.desc = "temperature",
+		.type = ENVSYS_STEMP,
+		.refresh = hytp14_refresh_temp
+	}
+};
+
+static int
+hytp14_match(device_t parent, cfdata_t match, void *aux)
+{
+	struct i2c_attach_args *ia = aux;
+
+	if (ia->ia_name) {
+		/* direct config - check name */
+		if (strcmp(ia->ia_name, "hythygtemp") == 0)
+			return 1;
+	} else {
+		/* indirect config - check typical address */
+		if (ia->ia_addr == HYTP14_DEFAULT_ADDR)
+			return 1;
+	}
+	return 0;
+}
+
+static void
+hytp14_attach(device_t parent, device_t self, void *aux)
+{
+	struct hytp14_sc *sc = device_private(self);
+	struct i2c_attach_args *ia = aux;
+	int i;
+
+	sc->sc_dev = self;
+	sc->sc_tag = ia->ia_tag;
+	sc->sc_addr = ia->ia_addr;
+	sc->sc_refresh = 0;
+	sc->sc_valid = ENVSYS_SINVALID;
+	sc->sc_numsensors = __arraycount(hytp14_sensors);
+
+	if ((sc->sc_sme = sysmon_envsys_create()) == NULL) {
+		aprint_error_dev(sc->sc_dev,
+		    "unable to create sysmon structure\n");
+		return;
+	}
+	
+	for (i = 0; i < sc->sc_numsensors; i++) {
+		strlcpy(sc->sc_sensors[i].desc,
+			hytp14_sensors[i].desc,
+			sizeof sc->sc_sensors[i].desc);
+		
+		sc->sc_sensors[i].units = hytp14_sensors[i].type;
+		sc->sc_sensors[i].state = ENVSYS_SINVALID;
+		
+		DPRINTF(2, ("hytp14_attach: registering sensor %d (%s)\n", i,
+			    sc->sc_sensors[i].desc));
+		
+		if (sysmon_envsys_sensor_attach(sc->sc_sme, &sc->sc_sensors[i])) {
+			aprint_error_dev(sc->sc_dev,
+			    "unable to attach sensor\n");
+			sysmon_envsys_destroy(sc->sc_sme);
+			return;
+		}
+	}
+
+	sc->sc_sme->sme_name = device_xname(sc->sc_dev);
+	sc->sc_sme->sme_cookie = sc;
+	sc->sc_sme->sme_refresh = hytp14_refresh;
+
+	DPRINTF(2, ("hytp14_attach: registering with envsys\n"));
+
+	if (sysmon_envsys_register(sc->sc_sme)) {
+		aprint_error_dev(sc->sc_dev,
+		    "unable to register with sysmon\n");
+		sysmon_envsys_destroy(sc->sc_sme);
+		return;
+	}
+
+	aprint_normal(": HYT-221/271/939 humidity and temperature sensor\n");
+}
+
+static int hytp14_detach(device_t self, int flags)
+{
+	struct hytp14_sc *sc = device_private(self);
+
+	if (sc->sc_sme != NULL) {
+		sysmon_envsys_unregister(sc->sc_sme);
+		sc->sc_sme = NULL;
+	}
+	
+	return 0;
+}
+
+static int
+hytp14_refresh_sensor(struct hytp14_sc *sc)
+{
+	int error = 0;
+	uint8_t buf[I2C_EXEC_MAX_BUFLEN];
+
+	/* no more than once per second */
+	if (hardclock_ticks - sc->sc_refresh < hz)
+		return sc->sc_valid;
+	
+	DPRINTF(2, ("hytp14_refresh_sensor(%s)\n", device_xname(sc->sc_dev)));
+
+	if ((error = iic_acquire_bus(sc->sc_tag, 0)) == 0) {
+		DPRINTF(3, ("hytp14_refresh_sensor(%s): bus locked\n", device_xname(sc->sc_dev)));
+
+		/* send MR command */
+                /* avoid quick read/write by providing a result buffer */
+		if ((error = iic_exec(sc->sc_tag, I2C_OP_WRITE_WITH_STOP,
+				      sc->sc_addr, NULL, 0, buf, sizeof buf, 0)) == 0) {
+			DPRINTF(3, ("hytp14_refresh_sensor(%s): MR sent\n",
+				    device_xname(sc->sc_dev)));
+
+			/* send DF command - read data from sensor */
+			if ((error = iic_exec(sc->sc_tag, I2C_OP_READ_WITH_STOP,
+					      sc->sc_addr, NULL, 0, sc->sc_data,
+					      sizeof sc->sc_data, 0)) != 0) {
+				DPRINTF(2, ("%s: %s: failed read from 0x%02x - error %d\n",
+					    device_xname(sc->sc_dev),
+					    __func__, sc->sc_addr, error));
+			} else {
+				DPRINTF(2, ("hytp14_refresh_sensor(%s): DF success : 0x%02x%02x%02x%02x\n",
+					    device_xname(sc->sc_dev),
+					    sc->sc_data[0],
+					    sc->sc_data[1],
+					    sc->sc_data[2],
+					    sc->sc_data[3]));
+			}
+		} else {
+			DPRINTF(2, ("%s: %s: failed read from 0x%02x - error %d\n",
+				    device_xname(sc->sc_dev), __func__,
+				    sc->sc_addr, error));
+		}
+
+		iic_release_bus(sc->sc_tag, 0);	
+		DPRINTF(3, ("hytp14_refresh_sensor(%s): bus released\n", device_xname(sc->sc_dev)));
+	} else {
+		DPRINTF(2, ("%s: %s: failed read from 0x%02x - error %d\n",
+			    device_xname(sc->sc_dev), __func__, sc->sc_addr, error));
+	}
+			
+	sc->sc_refresh = hardclock_ticks;
+	
+	if (error == 0) {
+		sc->sc_valid = ENVSYS_SVALID;
+	} else {
+		sc->sc_valid = ENVSYS_SINVALID;
+	}
+	
+	return sc->sc_valid;
+}
+
+
+static void
+hytp14_refresh_humidity(struct hytp14_sc *sc, envsys_data_t *edata)
+{
+	uint16_t hyg;
+	int status;
+	
+	status = hytp14_refresh_sensor(sc);
+	
+	if (status == ENVSYS_SVALID) {
+		hyg = (sc->sc_data[0] << 8) | sc->sc_data[1];
+		
+		edata->value_cur = (1000000000 / HYTP14_HYG_SCALE) * (int32_t)HYTP14_HYG_RAWVAL(hyg);
+		edata->value_cur /= 10;
+	}
+
+	edata->state = status;
+}
+
+static void
+hytp14_refresh_temp(struct hytp14_sc *sc, envsys_data_t *edata)
+{
+	uint16_t temp;
+	int status;
+	
+	status = hytp14_refresh_sensor(sc);
+	
+	if (status == ENVSYS_SVALID) {
+		temp = HYTP14_TEMP_RAWVAL((sc->sc_data[2] << 8) | sc->sc_data[3]);
+
+		edata->value_cur = (HYTP14_TEMP_FACTOR * 1000000) / HYTP14_TEMP_SCALE;
+		edata->value_cur *= (int32_t)temp;
+		edata->value_cur += HYTP14_TEMP_OFFSET * 1000000 + 273150000;
+	}
+
+	edata->state = status;
+}
+
+static void
+hytp14_refresh(struct sysmon_envsys *sme, envsys_data_t *edata)
+{
+	struct hytp14_sc *sc = sme->sme_cookie;
+	
+	hytp14_sensors[edata->sensor].refresh(sc, edata);
+}
+
+
+MODULE(MODULE_CLASS_DRIVER, hythygtemp, "iic");
+
+#ifdef _MODULE
+#include "ioconf.c"
+#endif
+
+static int
+hythygtemp_modcmd(modcmd_t cmd, void *opaque)
+{
+	int error = 0;
+
+	switch (cmd) {
+	case MODULE_CMD_INIT:
+#ifdef _MODULE
+		error = config_init_component(cfdriver_ioconf_hythygtemp,
+		    cfattach_ioconf_hythygtemp, cfdata_ioconf_hythygtemp);
+#endif
+		return error;
+
+	case MODULE_CMD_FINI:
+#ifdef _MODULE
+		error = config_fini_component(cfdriver_ioconf_hythygtemp,
+		    cfattach_ioconf_hythygtemp, cfdata_ioconf_hythygtemp);
+#endif
+		return error;
+
+	default:
+		return ENOTTY;
+	}
+}
Index: src/sys/dev/i2c/hytp14reg.h
diff -u /dev/null src/sys/dev/i2c/hytp14reg.h:1.1
--- /dev/null	Sun May 18 11:46:24 2014
+++ src/sys/dev/i2c/hytp14reg.h	Sun May 18 11:46:23 2014
@@ -0,0 +1,90 @@
+/* $NetBSD: hytp14reg.h,v 1.1 2014/05/18 11:46:23 kardel Exp $ */
+
+/*-
+ * Copyright (c) 2014 The NetBSD Foundation, Inc.
+ * All rights reserved.
+ *
+ * This code is derived from software contributed to The NetBSD Foundation
+ * by Frank Kardel.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ *    notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ *    notice, this list of conditions and the following disclaimer in the
+ *    documentation and/or other materials provided with the distribution.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
+ * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
+ * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
+ * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
+ * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+ * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
+ * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
+ * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
+ * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
+ * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
+ * POSSIBILITY OF SUCH DAMAGE.
+ */
+
+/*
+ * IST-AG P14 calibrated Hygro-/Temperature sensor module
+ * Devices: HYT-271, HYT-221 and HYT-939 
+ *
+ * see:
+ * http://www.ist-ag.com/eh/ist-ag/resource.nsf/imgref/Download_AHHYTM_E2.1.pdf/
+ *      $FILE/AHHYTM_E2.1.pdf
+ */ 
+#ifndef _DEV_I2C_HYTP14REG_H_
+#define _DEV_I2C_HYTP14REG_H_
+
+#define HYTP14_DEFAULT_ADDR	0x28
+
+#define HYTP14_CMD_SEND		0x50 /* send command */
+#define HYTP14_CMD_RESP		0x51 /* receive response */
+
+#define HYTP14_CMD_START_NOM	0x80 /* end command mode (or power-off)  */
+#define HYTP14_CMD_START_CM	0xA0 /* start command mode (within 10ms after power-up) */
+#define HYTP14_CMD_GET_REV	0xB0 /* get revison */
+
+#define HYTP14_NUM_WORDS	32
+#define HYTP14_READ_OFFSET	0x00 /* command offset to read EEPROM words */
+#define HYTP14_WRITE_OFFSET	0x40 /* command offset to write EEPROM words */
+
+#define HYTP14_READ_EEPROM(_X_)	(HYTP14_READ_OFFSET + (_X_) & (HYTP14_NUM_WORDS - 1))
+#define HYTP14_WRITE_EEPROM(_X_) (HYTP14_WRITE_OFFSET + (_X_) & (HYTP14_NUM_WORDS - 1))
+
+#define HYTP14_EEADDR_I2CADDR	0x1C /* I2C address EEPROD word address */
+
+#define HYTP14_RESP_CMDMODE	0x80 /* command mode response */
+#define HYTP14_RESP_STALE	0y40 /* stale measurement data */
+
+#define HYTP14_DIAG_ERR_CFG	0x20 /* configuration error */
+#define HYTP14_DIAG_ERR_RAMPRTY	0x10 /* RAM parity error */
+#define HYTP14_DIAG_ERR_UNCEEP	0x08 /* uncorrectable EEPROM error */
+#define HYTP14_DIAG_ERR_COREEP	0x04 /* correctable EEPROM error */
+
+#define HYTP14_RESP_MASK	0x03
+#define HYTP14_RESP_BUSY	0x00 /* device is busy */
+#define HYTP14_RESP_ACK		0x01 /* positive acknowlege */
+#define HYTP14_RESP_NACK	0x02 /* negative acknowlege */
+
+#define HYTP14_ST_CMDMODE	0x8000 /* command mode */
+#define HYTP14_ST_STALE		0x4000 /* stale measurement data */
+#define HYTP14_HYG_RAWVAL(_X_)	((_X_) & 0x3FFF)
+#define HYTP14_HYG_SCALE	(1<<14)
+#define HYTP14_TEMP_RAWVAL(_X_)	(((_X_) >> 2) & 0x3FFF)
+#define HYTP14_TEMP_SCALE	(1<<14)
+#define HYTP14_TEMP_FACTOR	165
+#define HYTP14_TEMP_OFFSET	(-40)
+
+#endif
+/*
+ * $Log: hytp14reg.h,v $
+ * Revision 1.1  2014/05/18 11:46:23  kardel
+ * add HYT-221/271/939 humidity/temperature I2C sensor
+ * extend envsys(4) framework by %rH (relative humidity)
+ *
+ */
Index: src/sys/dev/i2c/hytp14var.h
diff -u /dev/null src/sys/dev/i2c/hytp14var.h:1.1
--- /dev/null	Sun May 18 11:46:24 2014
+++ src/sys/dev/i2c/hytp14var.h	Sun May 18 11:46:23 2014
@@ -0,0 +1,75 @@
+/* $NetBSD: hytp14var.h,v 1.1 2014/05/18 11:46:23 kardel Exp $ */
+
+/*-
+ * Copyright (c) 2014 The NetBSD Foundation, Inc.
+ * All rights reserved.
+ *
+ * This code is derived from software contributed to The NetBSD Foundation
+ * by Frank Kardel.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ *    notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ *    notice, this list of conditions and the following disclaimer in the
+ *    documentation and/or other materials provided with the distribution.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
+ * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
+ * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
+ * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
+ * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+ * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
+ * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
+ * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
+ * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
+ * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
+ * POSSIBILITY OF SUCH DAMAGE.
+ */
+
+/*
+ * IST-AG P14 calibrated Hygro-/Temperature sensor module
+ * Devices: HYT-271, HYT-221 and HYT-939 
+ *
+ * see:
+ * http://www.ist-ag.com/eh/ist-ag/resource.nsf/imgref/Download_AHHYTM_E2.1.pdf/
+ *      $FILE/AHHYTM_E2.1.pdf
+ */ 
+#ifndef _DEV_I2C_HYTP14VAR_H_
+#define _DEV_I2C_HYTP14VAR_H_
+
+#define HYTP14_DEFAULT_ADDR	0x28
+
+#define HYTP14_NUM_SENSORS	2
+
+struct hytp14_sc {
+	device_t	sc_dev;
+	i2c_tag_t	sc_tag;
+	i2c_addr_t	sc_addr;
+
+	int		sc_refresh; /* last refresh from hardclock_ticks */
+        int             sc_valid;   /* ENVSYS validity state for this sensor */
+        uint8_t         sc_data[4]; /* last data read */
+
+	int		sc_numsensors;
+
+	struct sysmon_envsys *sc_sme;
+	envsys_data_t sc_sensors[HYTP14_NUM_SENSORS];
+};
+
+struct hytp14_sensor {
+	const char	  *desc;
+	enum envsys_units  type;
+	void		 (*refresh)(struct hytp14_sc *, envsys_data_t *);
+};
+
+#endif
+/*
+ * $Log: hytp14var.h,v $
+ * Revision 1.1  2014/05/18 11:46:23  kardel
+ * add HYT-221/271/939 humidity/temperature I2C sensor
+ * extend envsys(4) framework by %rH (relative humidity)
+ *
+ */

Index: src/sys/modules/hythygtemp/Makefile
diff -u /dev/null src/sys/modules/hythygtemp/Makefile:1.1
--- /dev/null	Sun May 18 11:46:24 2014
+++ src/sys/modules/hythygtemp/Makefile	Sun May 18 11:46:24 2014
@@ -0,0 +1,11 @@
+# $NetBSD: Makefile,v 1.1 2014/05/18 11:46:24 kardel Exp $
+
+.include "../Makefile.inc"
+
+.PATH:	${S}/dev/i2c
+
+KMOD=	hythygtemp
+IOCONF=	hythygtemp.ioconf
+SRCS=	hytp14.c
+
+.include <bsd.kmodule.mk>
Index: src/sys/modules/hythygtemp/hythygtemp.ioconf
diff -u /dev/null src/sys/modules/hythygtemp/hythygtemp.ioconf:1.1
--- /dev/null	Sun May 18 11:46:24 2014
+++ src/sys/modules/hythygtemp/hythygtemp.ioconf	Sun May 18 11:46:24 2014
@@ -0,0 +1,9 @@
+# $NetBSD: hythygtemp.ioconf,v 1.1 2014/05/18 11:46:24 kardel Exp $
+
+ioconf hythygtemp
+
+include "conf/files"
+
+pseudo-root iic*
+
+hythygtemp* at iic? addr 0x28

Reply via email to