diff options
| author | Marti Bolivar <mbolivar@leaflabs.com> | 2012-06-21 17:04:32 -0400 | 
|---|---|---|
| committer | Marti Bolivar <mbolivar@leaflabs.com> | 2012-06-22 14:06:10 -0400 | 
| commit | 001997b815e70f6a7707e765982b6f321afb961a (patch) | |
| tree | 7a6fc846bbfaaf18350dffa334adf9e0ad6f91dd /libmaple/i2c_private.h | |
| parent | 9ba028ef647bc033e5ec078acd7de9d5c28432a9 (diff) | |
| download | librambutan-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.h | 37 | 
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(). */ | 
