Contiki 3.x
i2c.h
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2010, Swedish Institute of Computer Science.
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 Institute 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 INSTITUTE AND CONTRIBUTORS ``AS IS'' AND
18  * 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 INSTITUTE OR CONTRIBUTORS BE LIABLE
21  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
22  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
23  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
24  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
25  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
26  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
27  * SUCH DAMAGE.
28  *
29  */
30 
31 /**
32  * \file
33  * includes for i2c core functions
34  * \author
35  * Robert Olsson <robert@radio-sensors.com>
36  */
37 
38 #include "contiki.h"
39 
40 /* Here we define the i2c address for dev we support */
41 #define I2C_AT24MAC_ADDR 0xB0 /* EUI64 ADDR */
42 #define I2C_SHT2X_ADDR (0x40 << 1) /* SHT2X ADDR */
43 
44 
45 /* Here we define a enumration for devices */
46 #define I2C_AT24MAC (1<<0)
47 #define I2C_SHT2X (1<<1)
48 #define I2C_CO2SA (1<<2) /* Sense-Air CO2 */
49 
50 #define I2C_READ 1
51 #define I2C_WRITE 0
52 
53 void i2c_init(uint32_t speed);
54 uint8_t i2c_start(uint8_t addr);
55 void i2c_start_wait(uint8_t addr);
56 void i2c_stop(void);
57 void i2c_write(uint8_t u8data);
58 uint8_t i2c_readAck(void);
59 uint8_t i2c_readNak(void);
60 uint8_t i2c_getstatus(void);
61 uint16_t i2c_probe(void);
62 void i2c_read_mem(uint8_t addr, uint8_t reg, uint8_t buf[], uint8_t bytes);
63 void i2c_write_mem(uint8_t addr, uint8_t reg, uint8_t value);
64 void i2c_at24mac_read(char *buf, uint8_t eui64);
65 extern uint16_t i2c_probed; /* i2c devices we have probed */
static uip_ds6_addr_t * addr
Pointer to a router list entry.
Definition: uip-nd6.c:124
void i2c_write(uint8_t u8data)
Send a byte to I2C bus.
Definition: i2c.c:139
void i2c_stop(void)
Generate I2C STOP condition.
Definition: i2c.c:132
void i2c_init(uint8_t port_sda, uint8_t pin_sda, uint8_t port_scl, uint8_t pin_scl, uint32_t bus_speed)
Initialize the I2C peripheral and pins.
Definition: i2c.c:49
void i2c_start(void)
Generate I2C START condition.
Definition: i2c.c:85