xref: /freebsd/sys/dev/ow/owll_if.m (revision c697fb7f)
1#-
2# Copyright (c) 2015 M. Warner Losh <imp@FreeBSD.org>
3#
4# Redistribution and use in source and binary forms, with or without
5# modification, are permitted provided that the following conditions
6# are met:
7# 1. Redistributions of source code must retain the above copyright
8#    notice, this list of conditions and the following disclaimer.
9# 2. Redistributions in binary form must reproduce the above copyright
10#    notice, this list of conditions and the following disclaimer in the
11#    documentation and/or other materials provided with the distribution.
12#
13# THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
14# ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
15# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
16# ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
17# FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
18# DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
19# OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
20# HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
21# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
22# OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
23# SUCH DAMAGE.
24#
25# $FreeBSD$
26#
27
28#include <sys/bus.h>
29#include <dev/ow/owll.h>
30
31INTERFACE owll;
32
33#
34# Dallas Semiconductor 1-Wire bus Link Layer (owll)
35#
36# See Maxim Application Note AN937: Book of iButton Standards for the
37# 1-Wire protocol specification.
38# http://pdfserv.maximintegrated.com/en/an/AN937.pdf
39#
40# Note: 1-Wire is a registered trademark of Maxim Integrated Products, Inc.
41#
42# This file provides an interface to the logical layer of the protocol.
43# Although the first implementation is done with GPIO bit banging, some
44# SoCs have a 1-Wire controller with more smarts or hardware offload.
45# Maxim datasheets also describe how to use UARTs to generate timing,
46# as well as both usb and i2c 1-Wire controllers.
47#
48# Chapter 4 has all the electrical timing diagrams that make up the link
49# layer of this protocol.
50#
51# Two speed classes are defined: Regular speed and Overdrive speed.
52# It is the responsibility of a device implementing the owll(9) interface
53# to ensure that the timings are met:
54#
55# 	Regular				Overdrive
56#
57#	60us <= tSLOT < 120us		6us <= tSLOT <= 16us
58#	60us <= tLOW0 < tSLOT < 120us	6us <= tLOW0 < tSLOT < 16us
59#	1us <= tLOW1 < 15us		1us <= tLOW < 2us
60#	1us < tLOWR < 15us		1us <= tLOWR < 2us
61#	0 <= tRELEASE < 45us		0 <= tRELEASE < 4us
62#	1us <= tREC < inf		1us <= tREC < inf
63#	tRDV = 15us			tRDV = 2us
64#	480us <= tRSTL < inf		48us <= tRSTL < 80us
65#	480us <= tRSTH < inf		48us <= tRSTH < inf
66#	15us < tPDH < 60us		2us <= tPDH < 6us
67#	60us < tPDL < 240us		8us <= tPDL < 24us
68#
69# In the diagrams below, R is driven by the resistor pullup, M is driven by
70# the master, and S is driven by the slave / target.
71#
72# All of these methods are expected to be called from the "network"/bus layer
73# for doing its operations. See 1wn_if.m for those.
74#
75# Note: This is the polling / busy-wait interface. An interrupt-based interface
76# may be different. But an interrupt-based, non-blocking interface can be tricky.
77#
78# Only the owbus should talk to this interface.
79#
80
81# WRITE-ONE (see above for timings) From Figure 4-1 AN-937
82#
83#		       |<---------tSLOT---->|<-tREC->|
84#	High	RRRRM  | 	RRRRRRRRRRRR|RRRRRRRRM
85#		     M |       R |     |  |	      M
86#		      M|      R	 |     |  |	       M
87#	Low	       MMMMMMM	 |     |  |    	        MMMMMM...
88#      	       	       |<-tLOW1->|     |  |
89#    		       |<------15us--->|  |
90#                      |<--------60us---->|
91#
92#
93METHOD int write_one {
94	device_t	lldev;		/* Link Level device (eg bridge) */
95	struct ow_timing *timing;	/* timing values */
96};
97
98
99# WRITE-ZERO (see above for timings) From Figure 4-2 AN-937
100#
101#		       |<---------tSLOT------>|<-tREC->|
102#	High	RRRRM  | 	            | |RRRRRRRM
103#		     M |                    | R	       M
104#		      M|       	 |     |    |R 	        M
105#	Low	       MMMMMMMMMMMMMMMMMMMMMR  	         MMMMMM...
106#      	       	       |<--15us->|     |    |
107#      	       	       |<------60us--->|    |
108#                      |<-------tLOW0------>|
109#
110#
111METHOD int write_zero {
112	device_t	lldev;		/* Link Level device (eg bridge) */
113	struct ow_timing *timing;	/* timing values */
114};
115
116# READ-DATA (see above for timings) From Figure 4-3 AN-937
117#
118#		       |<---------tSLOT------>|<-tREC->|
119#	High	RRRRM  |        rrrrrrrrrrrrrrrRRRRRRRM
120#		     M |       r            | R	       M
121#		      M|      r	        |   |R 	        M
122#	Low	       MMMMMMMSSSSSSSSSSSSSSR  	         MMMMMM...
123#      	       	       |<tLOWR>< sample	>   |
124#      	       	       |<------tRDV---->|   |
125#                                     ->|   |<-tRELEASE
126#
127# r -- allowed to pull high via the resistor when slave writes a 1-bit
128#
129METHOD int read_data {
130	device_t	lldev;		/* Link Level device (eg bridge) */
131	struct ow_timing *timing;	/* timing values */
132	int		*bit;		/* Bit we sampled */
133};
134
135# RESET AND PRESENCE PULSE (see above for timings) From Figure 4-4 AN-937
136#
137#				    |<---------tRSTH------------>|
138#	High RRRM  |		  | RRRRRRRS	       |  RRRR RRM
139#		 M |		  |R|  	   |S  	       | R	  M
140#		  M|		  R |	   | S	       |R	   M
141#	Low	   MMMMMMMM MMMMMM| |	   |  SSSSSSSSSS	    MMMMMM
142#      	       	   |<----tRSTL--->| |  	   |<-tPDL---->|
143#		   |   	       	->| |<-tR  |	       |
144#				    |<tPDH>|
145#
146# Note: for Regular Speed operations, tRSTL + tR should be less than 960us to
147# avoid interfering with other devives on the bus.
148#
149# Returns errors associating with acquiring the bus, or EIO to indicate
150# that the bus was low during the RRRR time where it should have been
151# pulled high. The present field is always updated, even on error.
152#
153METHOD int reset_and_presence {
154	device_t	lldev;		/* Link level device (eg bridge) */
155	struct ow_timing *timing;	/* timing values */
156	int		*present;	/* 0 = slave 1 = no slave -1 = bus error */
157};
158