Commit 82c54f86 authored by David Brownell's avatar David Brownell Committed by Haavard Skinnemoen

[AVR32] ngw100 i2c-gpio tweaks

Make the NGW100 bitbang i2c use open drain signaling.

Also, speed it up, so it's closer to 100 kHz ... the code paths seem
to be long enough that the udelay isn't dominating bit times.  The
peak bit rate I observed was around 125 kHz, but that's with large
delays (usually before ACK/NAK) which hold the overall rate down to
around 80 kHz (call it 100 usec/byte on average).
Signed-off-by: default avatarDavid Brownell <dbrownell@users.sourceforge.net>
Signed-off-by: default avatarHaavard Skinnemoen <hskinnemoen@atmel.com>
parent a7ff43b8
...@@ -125,8 +125,11 @@ static struct platform_device ngw_gpio_leds = { ...@@ -125,8 +125,11 @@ static struct platform_device ngw_gpio_leds = {
}; };
static struct i2c_gpio_platform_data i2c_gpio_data = { static struct i2c_gpio_platform_data i2c_gpio_data = {
.sda_pin = GPIO_PIN_PA(6), .sda_pin = GPIO_PIN_PA(6),
.scl_pin = GPIO_PIN_PA(7), .scl_pin = GPIO_PIN_PA(7),
.sda_is_open_drain = 1,
.scl_is_open_drain = 1,
.udelay = 2, /* close to 100 kHz */
}; };
static struct platform_device i2c_gpio_device = { static struct platform_device i2c_gpio_device = {
...@@ -162,8 +165,10 @@ static int __init atngw100_init(void) ...@@ -162,8 +165,10 @@ static int __init atngw100_init(void)
} }
platform_device_register(&ngw_gpio_leds); platform_device_register(&ngw_gpio_leds);
at32_select_gpio(i2c_gpio_data.sda_pin, 0); at32_select_gpio(i2c_gpio_data.sda_pin,
at32_select_gpio(i2c_gpio_data.scl_pin, 0); AT32_GPIOF_MULTIDRV | AT32_GPIOF_OUTPUT | AT32_GPIOF_HIGH);
at32_select_gpio(i2c_gpio_data.scl_pin,
AT32_GPIOF_MULTIDRV | AT32_GPIOF_OUTPUT | AT32_GPIOF_HIGH);
platform_device_register(&i2c_gpio_device); platform_device_register(&i2c_gpio_device);
return 0; return 0;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment