MAV'RIC
i2c_driver_dma.h
1 /*******************************************************************************
2  * Copyright (c) 2009-2014, MAV'RIC Development Team
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 are met:
7  *
8  * 1. Redistributions of source code must retain the above copyright notice,
9  * this list of conditions and the following disclaimer.
10  *
11  * 2. Redistributions in binary form must reproduce the above copyright notice,
12  * this list of conditions and the following disclaimer in the documentation
13  * and/or other materials provided with the distribution.
14  *
15  * 3. Neither the name of the copyright holder nor the names of its contributors
16  * may be used to endorse or promote products derived from this software without
17  * specific prior written permission.
18  *
19  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
20  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
21  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
22  * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
23  * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
24  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
25  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
26  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
27  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
28  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
29  * POSSIBILITY OF SUCH DAMAGE.
30  ******************************************************************************/
31 
32 /*******************************************************************************
33  * \file i2c_driver_dma.h
34  *
35  * \author MAV'RIC Team
36  * \author Felix Schill
37  *
38  * \brief The i2c driver
39  *
40  ******************************************************************************/
41 
42 
43 #ifndef I2C_DRIVER_H_
44 #define I2C_DRIVER_H_
45 
46 
47 #include "twim.h"
48 #include <stdint.h>
49 #include "dma_channel_config.h"
50 
51 #define I2C_DEVICES 2
52 #define I2C_SCHEDULE_SLOTS 10
53 
54 #define I2C_READ 0
55 #define I2C_WRITE 1
56 #define I2C_WRITE1_THEN_READ 2
57 
58 
61 typedef struct
62 {
63  uint8_t slave_address;
64  uint16_t i2c_speed;
65  int8_t direction;
66  int8_t write_then_read_preamble;
67  uint8_t* write_data;
68  uint32_t write_count;
69  uint8_t* read_data;
70  uint32_t read_count;
72 
73 typedef void (i2c_callback_t)(i2c_packet_conf_t* data);
74 
78 typedef struct
79 {
80  i2c_packet_conf_t config;
81  uint8_t schedule_slot;
82  int32_t repetition_rate_ms;
83  uint8_t trigger_next_event;
84  int8_t active;
85  int8_t transfer_in_progress;
86  i2c_callback_t* callback;
88 
96 int32_t i2c_driver_init(uint8_t i2c_device);
97 
105 int8_t i2c_driver_reset(uint8_t i2c_device);
106 
115 int8_t i2c_driver_add_request(uint8_t i2c_device, i2c_schedule_event_t* new_event);
116 
125 int8_t i2c_driver_change_request(uint8_t i2c_device, i2c_schedule_event_t* new_event);
126 
135 int8_t i2c_driver_enable_request(uint8_t i2c_device, uint8_t schedule_slot);
136 
146 int8_t i2c_driver_pause_request(uint8_t i2c_device, uint8_t schedule_slot);
147 
156 int8_t i2c_driver_remove_request(uint8_t i2c_device, uint8_t schedule_slot); // if the slot is currently processing, this blocks until it's finished
157 
166 int8_t i2c_driver_trigger_request(uint8_t i2c_device, uint8_t schedule_slot);
167 #endif /* I2C_DRIVER_H_ */
i2c event scheduler packet
Definition: i2c_driver.h:78
i2c configuration packet
Definition: i2c_driver.h:61