blob: 8137fe6f6c3d11534458457ade422d8a84fd8dac [file] [log] [blame]
Scott Alfter948593082014-06-17 20:42:05 +00001w1_ds2406 kernel driver
2=======================
3
4Supported chips:
5 * Maxim DS2406 (and other family 0x12) addressable switches
6
7Author: Scott Alfter <scott@alfter.us>
8
9Description
10-----------
11
12The w1_ds2406 driver allows connected devices to be switched on and off.
13These chips also provide 128 bytes of OTP EPROM, but reading/writing it is
14not supported. In TSOC-6 form, the DS2406 provides two switch outputs and
15can be provided with power on a dedicated input. In TO-92 form, it provides
16one output and uses parasitic power only.
17
18The driver provides two sysfs files. state is readable; it gives the
19current state of each switch, with PIO A in bit 0 and PIO B in bit 1. The
20driver ORs this state with 0x30, so shell scripts get an ASCII 0/1/2/3 to
21work with. output is writable; bits 0 and 1 control PIO A and B,
22respectively. Bits 2-7 are ignored, so it's safe to write ASCII data.
23
24CRCs are checked on read and write. Failed checks cause an I/O error to be
25returned. On a failed write, the switch status is not changed.