1
0
mirror of https://github.com/esp8266/Arduino.git synced 2025-10-25 18:38:07 +03:00

Improve I2C waveforms

This commit is contained in:
Ivan Grokhotkov
2015-05-29 20:40:18 +03:00
parent e8bdd50458
commit d862cdbb5a

View File

@@ -44,16 +44,16 @@ static unsigned char twi_sda, twi_scl;
void twi_setClock(unsigned int freq){ void twi_setClock(unsigned int freq){
#if F_CPU == FCPU80 #if F_CPU == FCPU80
if(freq <= 100000) twi_dcount = 18;//about 100KHz if(freq <= 100000) twi_dcount = 19;//about 100KHz
else if(freq <= 200000) twi_dcount = 8;//about 200KHz else if(freq <= 200000) twi_dcount = 8;//about 200KHz
else if(freq <= 300000) twi_dcount = 4;//about 300KHz else if(freq <= 300000) twi_dcount = 3;//about 300KHz
else if(freq <= 400000) twi_dcount = 2;//about 370KHz else if(freq <= 400000) twi_dcount = 1;//about 370KHz
else twi_dcount = 1;//about 450KHz else twi_dcount = 1;//about 450KHz
#else #else
if(freq <= 100000) twi_dcount = 32;//about 100KHz if(freq <= 100000) twi_dcount = 32;//about 100KHz
else if(freq <= 200000) twi_dcount = 16;//about 200KHz else if(freq <= 200000) twi_dcount = 14;//about 200KHz
else if(freq <= 300000) twi_dcount = 8;//about 300KHz else if(freq <= 300000) twi_dcount = 8;//about 300KHz
else if(freq <= 400000) twi_dcount = 4;//about 370KHz else if(freq <= 400000) twi_dcount = 5;//about 370KHz
else twi_dcount = 2;//about 450KHz else twi_dcount = 2;//about 450KHz
#endif #endif
} }
@@ -109,7 +109,7 @@ static bool twi_write_bit(bool bit) {
twi_delay(twi_dcount+1); twi_delay(twi_dcount+1);
SCL_HIGH(); SCL_HIGH();
while (SCL_READ() == 0 && (i++) < TWI_CLOCK_STRETCH);// Clock stretching (up to 100us) while (SCL_READ() == 0 && (i++) < TWI_CLOCK_STRETCH);// Clock stretching (up to 100us)
twi_delay(twi_dcount+1); twi_delay(twi_dcount);
return true; return true;
} }
@@ -117,7 +117,7 @@ static bool twi_read_bit(void) {
unsigned int i = 0; unsigned int i = 0;
SCL_LOW(); SCL_LOW();
SDA_HIGH(); SDA_HIGH();
twi_delay(twi_dcount+1); twi_delay(twi_dcount+2);
SCL_HIGH(); SCL_HIGH();
while (SCL_READ() == 0 && (i++) < TWI_CLOCK_STRETCH);// Clock stretching (up to 100us) while (SCL_READ() == 0 && (i++) < TWI_CLOCK_STRETCH);// Clock stretching (up to 100us)
bool bit = SDA_READ(); bool bit = SDA_READ();