NetBSD/sys/dev/onewire/onewire_bitbang.c
riz 637bfc29f9 Dallas Semiconductor 1-Wire bus support, from OpenBSD. Currently includes
gpioow(4), attaching a bit-banging driver via a GPIO pin.  Also,
owtemp(4) which supports some of the 1-Wire temperature sensors, including
the DS18b20 and DS1920 - temperatures are returned via the envsys(4)
framework.

Original drivers by Alexander Yurchenko (grange@openbsd), with envsys(4)
support and a fix to the 1-wire search algorithm (for discovering
devices on the bus) by me.

As discussed on tech-kern earlier this week.
2006-04-07 18:55:21 +00:00

82 lines
1.9 KiB
C

/* $NetBSD: onewire_bitbang.c,v 1.1 2006/04/07 18:55:22 riz Exp $ */
/* $OpenBSD: onewire_bitbang.c,v 1.1 2006/03/04 16:27:03 grange Exp $ */
/*
* Copyright (c) 2006 Alexander Yurchenko <grange@openbsd.org>
*
* Permission to use, copy, modify, and distribute this software for any
* purpose with or without fee is hereby granted, provided that the above
* copyright notice and this permission notice appear in all copies.
*
* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
* WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
* MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
* ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
*/
#include <sys/cdefs.h>
__KERNEL_RCSID(0, "$NetBSD: onewire_bitbang.c,v 1.1 2006/04/07 18:55:22 riz Exp $");
/*
* 1-Wire bus bit-banging routines.
*/
#include <sys/param.h>
#include <sys/systm.h>
#include <sys/device.h>
#include <dev/onewire/onewirevar.h>
int
onewire_bb_reset(const struct onewire_bbops *ops, void *arg)
{
int s, rv = 0, i;
s = splhigh();
ops->bb_tx(arg);
ops->bb_set(arg, 0);
DELAY(480);
ops->bb_set(arg, 1);
ops->bb_rx(arg);
DELAY(30);
for (i = 0; i < 6; i++) {
if ((rv = ops->bb_get(arg)) == 0)
break;
DELAY(20);
}
DELAY(450);
splx(s);
return (rv);
}
int
onewire_bb_bit(const struct onewire_bbops *ops, void *arg, int value)
{
int s, rv = 0, i;
s = splhigh();
ops->bb_tx(arg);
ops->bb_set(arg, 0);
DELAY(2);
if (value) {
ops->bb_set(arg, 1);
ops->bb_rx(arg);
for (i = 0; i < 15; i++) {
if ((rv = ops->bb_get(arg)) == 0)
break;
DELAY(2);
}
ops->bb_tx(arg);
}
DELAY(60);
ops->bb_set(arg, 1);
DELAY(5);
splx(s);
return (rv);
}