diff options
Diffstat (limited to 'platforms/chibios/drivers/i2c_master.h')
-rw-r--r-- | platforms/chibios/drivers/i2c_master.h | 113 |
1 files changed, 113 insertions, 0 deletions
diff --git a/platforms/chibios/drivers/i2c_master.h b/platforms/chibios/drivers/i2c_master.h new file mode 100644 index 000000000..c68109acb --- /dev/null +++ b/platforms/chibios/drivers/i2c_master.h | |||
@@ -0,0 +1,113 @@ | |||
1 | /* Copyright 2018 Jack Humbert | ||
2 | * Copyright 2018 Yiancar | ||
3 | * | ||
4 | * This program is free software: you can redistribute it and/or modify | ||
5 | * it under the terms of the GNU General Public License as published by | ||
6 | * the Free Software Foundation, either version 2 of the License, or | ||
7 | * (at your option) any later version. | ||
8 | * | ||
9 | * This program is distributed in the hope that it will be useful, | ||
10 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
11 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
12 | * GNU General Public License for more details. | ||
13 | * | ||
14 | * You should have received a copy of the GNU General Public License | ||
15 | * along with this program. If not, see <http://www.gnu.org/licenses/>. | ||
16 | */ | ||
17 | |||
18 | /* This library follows the convention of the AVR i2c_master library. | ||
19 | * As a result addresses are expected to be already shifted (addr << 1). | ||
20 | * I2CD1 is the default driver which corresponds to pins B6 and B7. This | ||
21 | * can be changed. | ||
22 | * Please ensure that HAL_USE_I2C is TRUE in the halconf.h file and that | ||
23 | * STM32_I2C_USE_I2C1 is TRUE in the mcuconf.h file. | ||
24 | */ | ||
25 | #pragma once | ||
26 | |||
27 | #include <ch.h> | ||
28 | #include <hal.h> | ||
29 | |||
30 | #ifdef I2C1_BANK | ||
31 | # define I2C1_SCL_BANK I2C1_BANK | ||
32 | # define I2C1_SDA_BANK I2C1_BANK | ||
33 | #endif | ||
34 | |||
35 | #ifndef I2C1_SCL_BANK | ||
36 | # define I2C1_SCL_BANK GPIOB | ||
37 | #endif | ||
38 | |||
39 | #ifndef I2C1_SDA_BANK | ||
40 | # define I2C1_SDA_BANK GPIOB | ||
41 | #endif | ||
42 | |||
43 | #ifndef I2C1_SCL | ||
44 | # define I2C1_SCL 6 | ||
45 | #endif | ||
46 | #ifndef I2C1_SDA | ||
47 | # define I2C1_SDA 7 | ||
48 | #endif | ||
49 | |||
50 | #ifdef USE_I2CV1 | ||
51 | # ifndef I2C1_OPMODE | ||
52 | # define I2C1_OPMODE OPMODE_I2C | ||
53 | # endif | ||
54 | # ifndef I2C1_CLOCK_SPEED | ||
55 | # define I2C1_CLOCK_SPEED 100000 /* 400000 */ | ||
56 | # endif | ||
57 | # ifndef I2C1_DUTY_CYCLE | ||
58 | # define I2C1_DUTY_CYCLE STD_DUTY_CYCLE /* FAST_DUTY_CYCLE_2 */ | ||
59 | # endif | ||
60 | #else | ||
61 | // The default timing values below configures the I2C clock to 400khz assuming a 72Mhz clock | ||
62 | // For more info : https://www.st.com/en/embedded-software/stsw-stm32126.html | ||
63 | # ifndef I2C1_TIMINGR_PRESC | ||
64 | # define I2C1_TIMINGR_PRESC 0U | ||
65 | # endif | ||
66 | # ifndef I2C1_TIMINGR_SCLDEL | ||
67 | # define I2C1_TIMINGR_SCLDEL 7U | ||
68 | # endif | ||
69 | # ifndef I2C1_TIMINGR_SDADEL | ||
70 | # define I2C1_TIMINGR_SDADEL 0U | ||
71 | # endif | ||
72 | # ifndef I2C1_TIMINGR_SCLH | ||
73 | # define I2C1_TIMINGR_SCLH 38U | ||
74 | # endif | ||
75 | # ifndef I2C1_TIMINGR_SCLL | ||
76 | # define I2C1_TIMINGR_SCLL 129U | ||
77 | # endif | ||
78 | #endif | ||
79 | |||
80 | #ifndef I2C_DRIVER | ||
81 | # define I2C_DRIVER I2CD1 | ||
82 | #endif | ||
83 | |||
84 | #ifdef USE_GPIOV1 | ||
85 | # ifndef I2C1_SCL_PAL_MODE | ||
86 | # define I2C1_SCL_PAL_MODE PAL_MODE_STM32_ALTERNATE_OPENDRAIN | ||
87 | # endif | ||
88 | # ifndef I2C1_SDA_PAL_MODE | ||
89 | # define I2C1_SDA_PAL_MODE PAL_MODE_STM32_ALTERNATE_OPENDRAIN | ||
90 | # endif | ||
91 | #else | ||
92 | // The default PAL alternate modes are used to signal that the pins are used for I2C | ||
93 | # ifndef I2C1_SCL_PAL_MODE | ||
94 | # define I2C1_SCL_PAL_MODE 4 | ||
95 | # endif | ||
96 | # ifndef I2C1_SDA_PAL_MODE | ||
97 | # define I2C1_SDA_PAL_MODE 4 | ||
98 | # endif | ||
99 | #endif | ||
100 | |||
101 | typedef int16_t i2c_status_t; | ||
102 | |||
103 | #define I2C_STATUS_SUCCESS (0) | ||
104 | #define I2C_STATUS_ERROR (-1) | ||
105 | #define I2C_STATUS_TIMEOUT (-2) | ||
106 | |||
107 | void i2c_init(void); | ||
108 | i2c_status_t i2c_start(uint8_t address); | ||
109 | i2c_status_t i2c_transmit(uint8_t address, const uint8_t* data, uint16_t length, uint16_t timeout); | ||
110 | i2c_status_t i2c_receive(uint8_t address, uint8_t* data, uint16_t length, uint16_t timeout); | ||
111 | i2c_status_t i2c_writeReg(uint8_t devaddr, uint8_t regaddr, const uint8_t* data, uint16_t length, uint16_t timeout); | ||
112 | i2c_status_t i2c_readReg(uint8_t devaddr, uint8_t regaddr, uint8_t* data, uint16_t length, uint16_t timeout); | ||
113 | void i2c_stop(void); | ||