Contiki 3.x
onewire.h
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2014, Eistec AB.
3  * All rights reserved.
4  *
5  * Redistribution and use in source and binary forms, with or without
6  * modification, are permitted provided that the following conditions
7  * are met:
8  * 1. Redistributions of source code must retain the above copyright
9  * notice, this list of conditions and the following disclaimer.
10  * 2. Redistributions in binary form must reproduce the above copyright
11  * notice, this list of conditions and the following disclaimer in the
12  * documentation and/or other materials provided with the distribution.
13  * 3. Neither the name of the copyright holder nor the names of its contributors
14  * may be used to endorse or promote products derived from this software
15  * without specific prior written permission.
16  *
17  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
18  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
19  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
20  * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
21  * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
22  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
23  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
24  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
25  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
26  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
27  * POSSIBILITY OF SUCH DAMAGE.
28  *
29  * This file is part of the Mulle platform port of the Contiki operating system.
30  *
31  */
32 
33 /**
34  * \file
35  * One wire driver using hardware UART as a bus master.
36  *
37  * \author
38  * Joakim Gebart <joakim.gebart@eistec.se>
39  *
40  * \note
41  * This is heavily based on Maxim document TUTORIAL 214
42  * "Using a UART to Implement a 1-Wire Bus Master"
43  */
44 
45 #ifndef ONEWIRE_H_
46 #define ONEWIRE_H_
47 
48 #include <stdint.h>
49 
50 #ifdef __cplusplus
51 extern "C" {
52 #endif
53 
54 #define ONEWIRE_UART_BAUD_SLOW 9600
55 #define ONEWIRE_UART_BAUD_FAST 115200
56 
57 /* common 1-wire ROM commands */
58 typedef enum {
59  ONEWIRE_CMD_SEARCH_ROM = 0xF0,
60  ONEWIRE_CMD_READ_ROM = 0x33,
61  ONEWIRE_CMD_MATCH_ROM = 0x55,
62  ONEWIRE_CMD_SKIP_ROM = 0xCC,
63  ONEWIRE_CMD_ALARM_SEARCH = 0xEC
64 } ow_rom_cmd_t;
65 
66 /* Set ONEWIRE_ALWAYS_SKIP_ROM to 1 to always ignore ROM codes and only use the
67  * SKIP ROM command when communicating with the bus */
68 #define ONEWIRE_ALWAYS_SKIP_ROM 0
69 
70 #define ONEWIRE_ROM_CODE_LENGTH 8
71 typedef uint64_t ow_rom_code_t;
72 
73 void ow_init(void);
74 void ow_reset(void);
75 void ow_write_bytes(const uint8_t *src, const uint8_t count);
76 void ow_write_byte(const uint8_t data);
77 void ow_read_bytes(uint8_t *dest, const uint8_t count);
78 uint8_t ow_compute_crc(const uint8_t *data, const uint8_t count);
79 ow_rom_code_t ow_read_rom(void);
80 void ow_skip_rom(void);
81 void ow_match_rom(const ow_rom_code_t id);
82 void ow_skip_or_match_rom(const ow_rom_code_t id);
83 
84 #ifdef __cplusplus
85 } /* extern "C" */
86 #endif
87 
88 #endif
void ow_init(void)
Initialize the 1-wire driver.
Definition: onewire.c:220
void ow_match_rom(const ow_rom_code_t id)
Issue a 1-wire MATCH ROM command.
Definition: onewire.c:482
void ow_skip_or_match_rom(const ow_rom_code_t id)
Shorthand function for MATCH ROM or SKIP ROM if id is zero.
Definition: onewire.c:500
void ow_read_bytes(uint8_t *dest, const uint8_t count)
Read a sequence of bytes from the 1-wire bus.
Definition: onewire.c:365
void ow_reset(void)
Reset the 1-wire bus.
Definition: onewire.c:269
void ow_write_byte(const uint8_t data)
Shorthand function to write a single byte to the 1-wire bus.
Definition: onewire.c:348
void ow_skip_rom(void)
Issue a 1-wire SKIP ROM command.
Definition: onewire.c:466
ow_rom_code_t ow_read_rom(void)
Issue a 1-wire READ ROM command.
Definition: onewire.c:428
void ow_write_bytes(const uint8_t *src, const uint8_t count)
Write a sequence of bytes to the 1-wire bus.
Definition: onewire.c:329
uint8_t ow_compute_crc(const uint8_t *data, const uint8_t count)
Compute a 1-wire 8-bit CRC.
Definition: onewire.c:401