aboutsummaryrefslogtreecommitdiffstats
path: root/libmaple/i2c.c
diff options
context:
space:
mode:
authorMarti Bolivar <mbolivar@leaflabs.com>2011-04-25 16:12:57 -0400
committerMarti Bolivar <mbolivar@leaflabs.com>2011-04-25 16:12:57 -0400
commitfb6cf96a4657e4d7ba462f457d9e8e4258b604bb (patch)
treebf80e742ce0f5b4a90eac36b8b2c76b06f419409 /libmaple/i2c.c
parentd6bb86b9e458bbf4f5a376caf05b2bc796a53aea (diff)
downloadlibrambutan-fb6cf96a4657e4d7ba462f457d9e8e4258b604bb.tar.gz
librambutan-fb6cf96a4657e4d7ba462f457d9e8e4258b604bb.zip
I2C fixup.
Added i2c_init() for consistency with rest of libmaple.
Diffstat (limited to 'libmaple/i2c.c')
-rw-r--r--libmaple/i2c.c17
1 files changed, 13 insertions, 4 deletions
diff --git a/libmaple/i2c.c b/libmaple/i2c.c
index 3a1082a..f4cb522 100644
--- a/libmaple/i2c.c
+++ b/libmaple/i2c.c
@@ -321,9 +321,19 @@ static void i2c_bus_reset(const i2c_dev *dev) {
}
/**
+ * @brief Initialize an I2C device and reset its registers to their
+ * default values.
+ * @param dev Device to enable.
+ */
+void i2c_init(i2c_dev *dev) {
+ rcc_reset_dev(dev->clk_line);
+ rcc_clk_enable(dev->clk_line);
+}
+
+/**
* @brief Initialize an i2c device as bus master
- * @param device to enable
- * @param flags bitwise or of the following I2C options:
+ * @param dev Device to enable
+ * @param flags Bitwise or of the following I2C options:
* I2C_FAST_MODE: 400 khz operation
* I2C_10BIT_ADDRESSING: Enable 10-bit addressing
*/
@@ -337,8 +347,7 @@ void i2c_master_enable(i2c_dev *dev, uint32 flags) {
i2c_bus_reset(dev);
/* Turn on clock and set GPIO modes */
- rcc_reset_dev(dev->clk_line);
- rcc_clk_enable(dev->clk_line);
+ i2c_init(dev);
gpio_set_mode(dev->gpio_port, dev->sda_pin, GPIO_AF_OUTPUT_OD);
gpio_set_mode(dev->gpio_port, dev->scl_pin, GPIO_AF_OUTPUT_OD);