FreeBSD manual
download PDF document: owc.4.pdf
OWC(4) FreeBSD Kernel Interfaces Manual OWC(4)
NAME
owc - Dallas Semiconductor 1-Wire Controller
SYNOPSIS
device owc
DESCRIPTION
The owc module implements Dallas Semiconductor 1-Wire signaling. It
attaches the ow(4) driver 1-Wire bus protocol. The owc device implements
the Link Layer of the 1-Wire bus protocol stack.
Bit banging a pin on a gpiobus(4) is the only supported controller. Both
standard and overdrive transfer timings are implemented. Strong pull-up
functionality needed to support parasitic mode is not implemented.
To enable 1-Wire for FDT systems requires modifying the DTS for your
board to add something like:
/ {
...
onewire {
compatible = "w1-gpio";
gpios = <&gpio 4 1>;
};
...
};
The gpios property describes the GPIO pin the 1-Wire bus is connected to.
For more details about the gpios property, please consult
/usr/src/sys/dts/bindings-gpio.txt.
On a device.hints(5) based system these values are required for the owc:
hint.owc.%d.at The gpiobus you are attaching to.
hint.owc.%d.pins This is a bitmask that defines a pin on the gpiobus
that is to be used for the 1-Wire bus. For instance,
to configure pin 10, use the bitmask of 0x400. Please
note that this mask should have only one bit set (any
other bits - i.e., pins - will be ignored).
SEE ALSO
gpiobus(4), ow(4), ow_temp(4), owll(9), own(9)
LEGAL
1-Wire is a registered trademark of Maxim Integrated Products, Inc.
HISTORY
The owc driver first appeared in FreeBSD 11.0.
AUTHORS
The owc device driver and this manual page were written by Warner Losh.
CAVEATS
The gpio driver implements timing by busy waiting, which can cause a high
load on slower systems.