aboutsummaryrefslogtreecommitdiffstats
path: root/libmaple/i2c_private.h
diff options
context:
space:
mode:
authorMarti Bolivar <mbolivar@leaflabs.com>2012-06-21 17:04:32 -0400
committerMarti Bolivar <mbolivar@leaflabs.com>2012-06-22 14:06:10 -0400
commit001997b815e70f6a7707e765982b6f321afb961a (patch)
tree7a6fc846bbfaaf18350dffa334adf9e0ad6f91dd /libmaple/i2c_private.h
parent9ba028ef647bc033e5ec078acd7de9d5c28432a9 (diff)
downloadlibrambutan-001997b815e70f6a7707e765982b6f321afb961a.tar.gz
librambutan-001997b815e70f6a7707e765982b6f321afb961a.zip
i2c_dev: deprecate .gpio_port.
This won't work on F2, which at times has SDA and SCL on different ports (e.g. I2C3 SDA on PC9, SCL on PA8). Add .sda_port and .scl_port replacements, which are used when the now-deprecated .gpio_port is null. Use them correctly everywhere, with some new i2c_private.h helper functionality. Sigh. The F1 I2C code tries too hard to guess what you wanted; it's not porting well at all. Signed-off-by: Marti Bolivar <mbolivar@leaflabs.com>
Diffstat (limited to 'libmaple/i2c_private.h')
-rw-r--r--libmaple/i2c_private.h37
1 files changed, 33 insertions, 4 deletions
diff --git a/libmaple/i2c_private.h b/libmaple/i2c_private.h
index 05a293c..5b79516 100644
--- a/libmaple/i2c_private.h
+++ b/libmaple/i2c_private.h
@@ -27,10 +27,15 @@
#ifndef _LIBMAPLE_I2C_PRIVATE_H_
#define _LIBMAPLE_I2C_PRIVATE_H_
-#define I2C_DEV(num, port, sda, scl) \
+#include <libmaple/i2c_common.h>
+
+/* For old-style definitions (SDA/SCL on same GPIO device) */
+#define I2C_DEV_OLD(num, port, sda, scl) \
{ \
.regs = I2C##num##_BASE, \
.gpio_port = port, \
+ .scl_port = NULL, \
+ .sda_port = NULL, \
.sda_pin = sda, \
.scl_pin = scl, \
.clk_id = RCC_I2C##num, \
@@ -39,9 +44,33 @@
.state = I2C_STATE_DISABLED, \
}
-struct i2c_dev;
-void _i2c_irq_handler(struct i2c_dev *dev);
-void _i2c_irq_error_handler(struct i2c_dev *dev);
+/* For new-style definitions (SDA/SCL may be on different GPIO devices) */
+#define I2C_DEV_NEW(num, sdaport, sdabit, sclport, sclbit) \
+ { \
+ .regs = I2C##num##_BASE, \
+ .gpio_port = NULL, \
+ .scl_port = sclport, \
+ .scl_pin = sclbit, \
+ .sda_port = sdaport, \
+ .sda_pin = sdabit, \
+ .clk_id = RCC_I2C##num, \
+ .ev_nvic_line = NVIC_I2C##num##_EV, \
+ .er_nvic_line = NVIC_I2C##num##_ER, \
+ .state = I2C_STATE_DISABLED, \
+ }
+
+void _i2c_irq_handler(i2c_dev *dev);
+void _i2c_irq_error_handler(i2c_dev *dev);
+
+struct gpio_dev;
+
+static inline struct gpio_dev* scl_port(const i2c_dev *dev) {
+ return (dev->gpio_port == NULL) ? dev->scl_port : dev->gpio_port;
+}
+
+static inline struct gpio_dev* sda_port(const i2c_dev *dev) {
+ return (dev->gpio_port == NULL) ? dev->sda_port : dev->gpio_port;
+}
/* Auxiliary procedure for enabling an I2C peripheral; `flags' as for
* i2c_master_enable(). */