ae1f3df434
only gpiobus configured via FDT is supported. Bus enumeration is supported. Devices are created for each device found. 1-Wire temperature controllers are supported, but other drivers could be written. Temperatures are polled and reported via a sysctl. Errors are reported via sysctl counters. Mis-wired bus detection is included for more trouble shooting. See ow(4), owc(4) and ow_temp(4) for details of what's supported and known issues. This has been tested on Raspberry Pi-B, Pi2 and Beagle Bone Black with up to 7 devices. Differential Revision: https://reviews.freebsd.org/D2956 Relnotes: yes MFC after: 2 weeks Reviewed by: loos@ (with many insightful comments)
78 lines
2.8 KiB
C
78 lines
2.8 KiB
C
/*-
|
|
* Copyright (c) 2015 M. Warner Losh <imp@freebsd.org>
|
|
* 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 unmodified, 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 ``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 AUTHOR 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.
|
|
*
|
|
* $FreeBSD$
|
|
*/
|
|
|
|
#ifndef DEV_OW_OW_H
|
|
#define DEV_OW_OW_H 1
|
|
|
|
enum ow_device_ivars {
|
|
OW_IVAR_FAMILY,
|
|
OW_IVAR_ROMID
|
|
};
|
|
|
|
#define OW_ACCESSOR(var, ivar, type) \
|
|
__BUS_ACCESSOR(ow, var, OW, ivar, type);
|
|
|
|
OW_ACCESSOR(family, FAMILY, uint8_t)
|
|
OW_ACCESSOR(romid, ROMID, uint8_t *)
|
|
|
|
#undef OW_ACCSSOR
|
|
|
|
/*
|
|
* The following likely should be in the own.h file, but needs to be here to
|
|
* avoid recursive issues when defining the own_if.m interface.
|
|
*/
|
|
|
|
/*
|
|
* Generalized command structure for a 1wire bus transaction. Not all possible
|
|
* transactions on the 1wire bus can be represented here (a notable exception
|
|
* being both the search ROM commands), but most of them can be, allowing for
|
|
* general transactions from userland. A lower-level interface to the link
|
|
* layer is also provided.
|
|
*/
|
|
#define MAX_ROM 10
|
|
#define MAX_XPT 32
|
|
#define MAX_READ 32
|
|
struct ow_cmd
|
|
{
|
|
uint32_t flags; /* Various flags */
|
|
#define OW_FLAG_OVERDRIVE 1 /* Send xpt stuff overdrive speed */
|
|
#define OW_FLAG_READ_BIT 2 /* Read a single bit after xpt_cmd */
|
|
uint8_t rom_len; /* Number of ROM bytes to send */
|
|
uint8_t rom_cmd[MAX_ROM]; /* Rom command to send */
|
|
uint8_t rom_read_len; /* Number of bytes to read */
|
|
uint8_t rom_read[MAX_ROM]; /* Extra bytes read */
|
|
uint8_t xpt_len; /* Total transport bytes to send */
|
|
uint8_t xpt_cmd[MAX_XPT]; /* Device specific command to send, if flagged */
|
|
uint8_t xpt_read_len; /* Number of bytes to read after */
|
|
uint8_t xpt_read[MAX_READ]; /* Buffer for read bytes */
|
|
};
|
|
|
|
typedef uint64_t romid_t;
|
|
|
|
#endif /* DEV_OW_OW_H */
|