From fd0cf1adbe35fb9ab71bec3d818f7ce8f6f27b1e Mon Sep 17 00:00:00 2001 From: asterix Date: Thu, 9 Jun 2011 16:11:41 +0000 Subject: [PATCH] Add hw defines for i2c bitbang. git-svn-id: https://src.develer.com/svnoss/bertos/trunk@4945 38d2e660-2303-0410-9eaa-f027e97ec537 --- boards/sam3x-ek/hw/hw_i2c_bitbang.h | 138 ++++++++++++++++++++++++++++ 1 file changed, 138 insertions(+) create mode 100644 boards/sam3x-ek/hw/hw_i2c_bitbang.h diff --git a/boards/sam3x-ek/hw/hw_i2c_bitbang.h b/boards/sam3x-ek/hw/hw_i2c_bitbang.h new file mode 100644 index 00000000..7a0d8de6 --- /dev/null +++ b/boards/sam3x-ek/hw/hw_i2c_bitbang.h @@ -0,0 +1,138 @@ +/** + * \file + * + * + * \brief Macro for I2C bitbang operation. + * + * + * + * \author Francesco Sacchi + */ + +#ifndef HW_I2C_BITBANG_H +#define HW_I2C_BITBANG_H + +#define SDA_HI do { /* Implement me:Set SDA High by setting SDA pin as input */ } while (0) +#define SDA_LO do { /* Implement me:Set SDA Low by setting SDA pin as open collector output */ } while (0) +#define SCL_HI do { /* Implement me:Set SCL High by setting SCL pin as input */ } while (0) +#define SCL_LO do { /* Implement me:Set SCL Low by setting SCL pin as open collector output */ } while (0) + + +#define SCL_IN (true) /* Implement me: read SDA pin state */ +#define SDA_IN (true) /* Implement me: read SCL pin state */ + +/** + * This macro should set SDA and SCL lines as input. + */ +#define I2C_BITBANG_HW_INIT do { /* Implement me! */ } while (0) + +/** + * Half bit delay routine used to generate the correct timings. + */ +#define I2C_HALFBIT_DELAY() do { /* Implement me! */ } while (0) + + +/* + * New api + */ +#include +#include +#include +#include + +#define SCL 18 +#define SDA 17 + +INLINE void i2c_sdaHi(int dev) +{ + (void)(dev); + /* Implement me:Set SDA High by setting SDA pin as input */ + PIOA_ODR = BV(SDA); +} + +INLINE void i2c_sdaLo(int dev) +{ + (void)(dev); + /* Implement me:Set SDA Low by setting SDA pin as open collector output */ + PIOA_OER = BV(SDA); +} + +INLINE void i2c_sclHi(int dev) +{ + (void)(dev); + /* Implement me:Set SCL High by setting SCL pin as input */ + PIOA_ODR = BV(SCL); +} + +INLINE void i2c_sclLo(int dev) +{ + (void)(dev); + /* Implement me:Set SCL Low by setting SCL pin as open collector output */ + PIOA_OER = BV(SCL); +} + +INLINE bool i2c_sdaIn(int dev) +{ + (void)(dev); + /* Implement me: read SDA pin state */ + return (PIOA_PDSR & BV(SDA)); +} + +INLINE bool i2c_sclIn(int dev) +{ + (void)(dev); + /* Implement me: read SCL pin state */ + return (PIOA_PDSR & BV(SCL)); +} + +/** + * Half bit delay routine used to generate the correct timings. + */ +INLINE void i2c_halfbitDelay(int dev) +{ + (void)(dev); + timer_delay(1); + cpu_relax(); +} + +/** + * This macro should set SDA and SCL lines as input. + */ +INLINE void i2c_bitbangInit(int dev) +{ + (void)(dev); + PIOA_ODR = BV(SDA) | BV (SCL); + PIOA_CODR = BV(SDA) | BV (SCL); + PIOA_PUER = BV(SDA) | BV (SCL); +} + +#endif /* HW_I2C_BITBANG_H */ -- 2.25.1