-
Notifications
You must be signed in to change notification settings - Fork 34
/
Copy pathSoftwareWire.cpp
872 lines (716 loc) · 22 KB
/
SoftwareWire.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
// Signal differences
// ------------------
// When the AVR microcontroller is set into hardware I2C mode,
// the pins follow the I2C specifications for voltage levels and current.
// For example the current to pull SDA or SCL low is maximum 3mA.
//
// With the Software I2C, a normal pin is used which can sink/source 40mA for a ATmega328P.
// That could increase the voltage spikes and could increase interference between sda and scl.
// The voltage levels are different.
// The timing of the software I2C is also different.
//
// In most cases the software I2C should work.
// With longer wires or with non-matching voltage levels, the result is unpredictable.
//
//
//
// Clock pulse stretching
// ----------------------
// An I2C Slave could stretch the clock signal by keeping the SCL low.
// This happens for example when a Slave is an Arduino which can be
// busy doing other things like handling other interrupts.
// Adding a check for the clock stretching should make the transmission
// completely reliable without any loss.
// Only an Arduino as Slave would do clock stretching, normal devices
// like sensors and I2C EEPROM don't use clock stretching.
// The extra check for clock stretching slows down the transfer rate.
//
// Using millis() instead of micros() is faster.
// That is why millis() is used for the timeout of the clock pulse stretching.
//
//
//
// Arduino Stream class
// --------------------
// The Arduino Stream class is used by many Arduino objects.
// For the I2C bus, the benefits are less obvious.
// For example the parseInt() function is not used with I2C.
// At this moment the Stream class is not used.
//
//
// Multiple Slaves with the same I2C address
// -----------------------------------------
// The SoftwareWire can be declared more than once,
// to create a number of software i2c busses.
// That makes it possible to use a number of I2C devices,
// which have the same I2C address.
// Every software i2c bus requires 2 pins,
// and every SoftwareWire object requires 59 bytes at the moment.
//
// added code to i2c_stop(), since a problem was reported here:
// http://forum.arduino.cc/index.php?topic=348337.0
// Added lines have keyword "ADDED1".
// Use the next define to run a i2c_scanner inside the printStatus() function.
// #define ENABLE_I2C_SCANNER
#include "SoftwareWire.h"
// Sets SDA low and drives output.
// The SDA may not be HIGH output, so first the output register is cleared
// (clearing internal pullup resistor), after that the SDA is set as output.
#define i2c_sda_lo() \
*_sdaPortReg &= ~_sdaBitMask; \
*_sdaDirReg |= _sdaBitMask;
// sets SCL low and drives output.
// The SCL may not be HIGH output, so first the output register is cleared
// (clearing internal pullup resistor), after that the SCL is set as output.
#define i2c_scl_lo() \
*_sclPortReg &= ~_sclBitMask; \
*_sclDirReg |= _sclBitMask;
// Set SDA high and to input (releases pin) (i.e. change to input, turn on pullup).
// The SDA may not become HIGH output. Therefore the pin is first set to input,
// after that, a pullup resistor is switched on if needed.
#define i2c_sda_hi() \
*_sdaDirReg &= ~_sdaBitMask; \
if(_pullups) { *_sdaPortReg |= _sdaBitMask; }
// set SCL high and to input (releases pin) (i.e. change to input, turn on pullup)
// The SCL may not become HIGH output. Therefore the pin is first set to input,
// after that, a pullup resistor is switched on if needed.
#define i2c_scl_hi() \
*_sclDirReg &= ~_sclBitMask; \
if(_pullups) { *_sclPortReg |= _sclBitMask; }
// Read the bit value of the pin
// Note that is the pin can also be read when it is an output.
#define i2c_sda_read() ((uint8_t) (*_sdaPinReg & _sdaBitMask) ? 1 : 0)
#define i2c_scl_read() ((uint8_t) (*_sclPinReg & _sclBitMask) ? 1 : 0)
//
// Constructor
//
// The pins are not activated until begin() is called.
//
SoftwareWire::SoftwareWire()
{
}
SoftwareWire::SoftwareWire(uint8_t sdaPin, uint8_t sclPin, boolean pullups, boolean detectClockStretch)
{
_sdaPin = sdaPin;
_sclPin = sclPin;
_pullups = pullups;
_stretch = detectClockStretch;
setClock( 100000UL); // set default 100kHz
// Set default timeout to 1000 ms.
// 1 second is very long, 10ms would be more appropriate.
// However, the Arduino libraries use often a default timeout of 1 second.
setTimeout( 1000L);
// Turn Arduino pin numbers into PORTx, DDRx, and PINx
uint8_t port;
port = digitalPinToPort(_sdaPin);
_sdaBitMask = digitalPinToBitMask(_sdaPin);
_sdaPortReg = portOutputRegister(port);
_sdaDirReg = portModeRegister(port);
_sdaPinReg = portInputRegister(port); // PinReg is the input register, not the Arduino pin.
port = digitalPinToPort(_sclPin);
_sclBitMask = digitalPinToBitMask(_sclPin);
_sclPortReg = portOutputRegister(port);
_sclDirReg = portModeRegister(port);
_sclPinReg = portInputRegister(port);
}
//
// The destructor releases the pins Software I2C bus for other use.
//
SoftwareWire::~SoftwareWire()
{
end();
}
//
// Release the pins of the Software I2C bus for other use.
// Also the internal pullup resistors are removed.
//
void SoftwareWire::end()
{
// Remember the pullups variable.
// They will be used again when begin() is called.
boolean pullupsCopy = _pullups;
_pullups = false;
i2c_sda_hi(); // release sda, remove any pullup
i2c_scl_hi(); // release scl, remove any pullup
_pullups = pullupsCopy;
}
// begin(void) - enter master mode
// The pins are not changed until begin() is called.
void SoftwareWire::begin(void)
{
rxBufPut = 0; // nothing in the rxBuf
rxBufGet = 0;
i2c_init(); // release the sda and scl (the pullup resistors pull them high)
// Some tests could be added here, to check if the SDA and SCL are really turning high.
// Even some tests for shortcuts could be done here.
// When a I2C transmission would start immediate, it could fail when only the internal pullup resistors
// are used, and the signals were just now turned high with i2c_init().
if( _pullups)
delay(2); // 1ms didn't always work.
}
//
// beginTransmission starts the I2C transmission immediate.
//
void SoftwareWire::beginTransmission(uint8_t address)
{
// Reset error returned by endTransmission.
_transmission = SOFTWAREWIRE_NO_ERROR;
// check return value of the start condition.
// It indicates if the i2c bus is okay.
if(i2c_start())
{
uint8_t rc = i2c_write((address << 1) | 0); // The r/w bit is zero for write
if( rc == 0) // a sda zero from Slave for the 9th bit is ack
{
_transmission = SOFTWAREWIRE_NO_ERROR;
}
else
{
_transmission = SOFTWAREWIRE_ADDRESS_NACK;
}
}
else
{
// If the bus was not okay, the scl or sda didn't work.
_transmission = SOFTWAREWIRE_OTHER;
}
}
//
void SoftwareWire::beginTransmission(int address)
{
beginTransmission((uint8_t)address);
}
//
uint8_t SoftwareWire::endTransmission(boolean sendStop)
{
if(sendStop)
i2c_stop();
else
i2c_repstart();
return(_transmission); // return the transmission status that was set during writing address and data
}
//
// The requestFrom() read the data from the I2C bus and stores it in a buffer.
//
uint8_t SoftwareWire::requestFrom(uint8_t address, uint8_t size, boolean sendStop)
{
uint8_t n=0; // number of valid received bytes. Start with 0 bytes.
// The transmission status is set, although it is not returned.
// Start with the status : no error
_transmission = SOFTWAREWIRE_NO_ERROR;
// Clear the RX buffer
rxBufPut = 0;
rxBufGet = 0;
boolean bus_okay = i2c_start();
if(bus_okay)
{
uint8_t rc = i2c_write((address << 1) | 1); // The r/w bit is '1' to read
if( rc == 0) // a sda zero from Slave for the 9th bit is ack
{
_transmission = SOFTWAREWIRE_NO_ERROR;
// TODO: check if the Slave returns less bytes than requested.
for(; n<size; n++)
{
if( n < (size - 1))
rxBuf[n] = i2c_read(true); // read with ack
else
rxBuf[n] = i2c_read(false); // last byte, read with nack
}
rxBufPut = n;
}
else
{
_transmission = SOFTWAREWIRE_ADDRESS_NACK;
}
}
else
{
// There was a bus error.
_transmission = SOFTWAREWIRE_OTHER;
}
if(sendStop || _transmission != SOFTWAREWIRE_NO_ERROR)
i2c_stop();
else
i2c_repstart();
return( n);
}
//
uint8_t SoftwareWire::requestFrom(int address, int size, boolean sendStop)
{
return requestFrom( (uint8_t) address, (uint8_t) size, sendStop);
}
// must be called in:
// slave tx event callback
// or after beginTransmission(address)
size_t SoftwareWire::write(uint8_t data)
{
// When there was an error during the transmission, no more bytes are transmitted.
if( _transmission == SOFTWAREWIRE_NO_ERROR)
{
if( i2c_write(data) == 0) // a sda zero from Slave for the 9th bit is ack
{
_transmission = SOFTWAREWIRE_NO_ERROR;
}
else
{
_transmission = SOFTWAREWIRE_ADDRESS_NACK;
}
}
return(1); // ignore any errors, return the number of bytes that are written.
}
//
size_t SoftwareWire::write(const uint8_t* data, size_t quantity)
{
for (size_t i=0; i<quantity; i++)
{
write(data[i]);
}
return(quantity); // ignore any errors, return the number of bytes that are written.
}
//
int SoftwareWire::available(void)
{
return(rxBufPut - rxBufGet);
}
//
int SoftwareWire::peek(void)
{
int data;
if( rxBufPut > rxBufGet)
{
data = rxBuf[rxBufGet];
}
else
{
data = -1;
}
return(data);
}
//
// The read() reads the buffer, not the I2C bus.
//
int SoftwareWire::read(void)
{
int data;
if( rxBufPut > rxBufGet)
{
data = rxBuf[rxBufGet];
rxBufGet++;
}
else
{
data = -1;
}
return(data);
}
int SoftwareWire::readBytes(uint8_t* buf, uint8_t size)
{
int data;
int n;
for( n=0; n<size; n++)
{
data = read();
if( data == -1)
break;
else
buf[n] = (uint8_t) data;
}
return(n);
}
//
int SoftwareWire::readBytes(char * buf, uint8_t size)
{
return readBytes( (uint8_t *) buf, size);
}
//
int SoftwareWire::readBytes(char * buf, int size)
{
return readBytes( (uint8_t *) buf, (uint8_t) size);
}
//
// Set the clock speed for the I2C bus.
// Default is 100000 (100kHz).
// A speed of 1Hz is possible with this software I2C library (but not with the Arduino Wire library).
// A speed of 200kHz or higher will remove the delay on an Arduino Uno.
// Without the delay, the functions are free running, using the execution timing of the code.
//
void SoftwareWire::setClock(uint32_t clock)
{
// Tested values with an earlier version of this library.
// Value 0 is without delay, the result depends on the microcontroller and the cpu clock.
// 0=maxspeed=140kHz (tested on 328P@16MHz)
// 1=120kHz
// 2=100kHz (default)
// 7=50kHz
// 47=10kHz
// 97=5kHz
// 500=1kHz
// 5000=100Hz
// 16383=minspeed=30Hz - delayMicroseconds() max value reference arduino
//
// The _i2cdelay is an uint16_t
_i2cdelay = ( (F_CPU / 32L) / clock ); // The delay in microseconds, '32' is for this code.
unsigned int delayByCode = (F_CPU / 5000000L); // Add some delay for the code, just a guess
if( _i2cdelay > delayByCode)
_i2cdelay -= delayByCode;
else
_i2cdelay = 0;
}
//
// Set the timeout in milliseconds.
// At this moment, it is only used for timeout when the Slave is stretching the clock pulse.
//
void SoftwareWire::setTimeout(long timeout)
{
// 2017, fix issue #6.
// A signed long as parameter to be compatible with Arduino libraries.
// A unsigned long internal to avoid compiler warnings.
_timeout = (unsigned long) timeout;
}
// printStatus
// -----------
// Print information to the Serial port
// Used during developing and debugging.
// Call it with the Serial port as parameter:
// myWire.printStatus(Serial);
// This function is not compatible with the Wire library.
// When this function is not called, it does not use any memory.
//
void SoftwareWire::printStatus( Print& Ser)
{
Ser.println(F("-------------------"));
Ser.println(F("SoftwareWire Status"));
Ser.println(F("-------------------"));
Ser.print(F(" F_CPU = "));
Ser.println(F_CPU);
Ser.print(F(" sizeof(SoftwareWire) = "));
Ser.println(sizeof(SoftwareWire));
Ser.print(F(" _transmission status = "));
Ser.println(_transmission);
Ser.print(F(" _i2cdelay = "));
Ser.print(_i2cdelay);
if( _i2cdelay == 0)
Ser.print(F(" (free running)"));
Ser.println();
Ser.print(F(" _pullups = "));
Ser.print(_pullups);
if( _pullups)
Ser.print(F(" (enabled)"));
Ser.println();
Ser.print(F(" _timeout = "));
Ser.print(_timeout);
Ser.println(F(" ms"));
Ser.print(F(" SOFTWAREWIRE_BUFSIZE = "));
Ser.println(SOFTWAREWIRE_BUFSIZE);
Ser.print(F(" rxBufPut = "));
Ser.println(rxBufPut);
Ser.print(F(" rxBufGet = "));
Ser.println(rxBufGet);
Ser.print(F(" available() = "));
Ser.println(available());
Ser.print(F(" rxBuf (hex) = "));
for(int ii=0; ii<SOFTWAREWIRE_BUFSIZE; ii++)
{
if(rxBuf[ii] < 16)
Ser.print(F("0"));
Ser.print(rxBuf[ii],HEX);
Ser.print(F(" "));
}
Ser.println();
Ser.print(F(" _sdaPin = "));
Ser.println(_sdaPin);
Ser.print(F(" _sclPin = "));
Ser.println(_sclPin);
Ser.print(F(" _sdaBitMask = 0x"));
Ser.println(_sdaBitMask, HEX);
Ser.print(F(" _sclBitMask = 0x"));
Ser.println(_sclBitMask, HEX);
Ser.print(F(" _sdaPortReg = "));
Ser.println( (uint16_t) _sdaPortReg, HEX);
Ser.print(F(" _sclPortReg = "));
Ser.println( (uint16_t) _sclPortReg, HEX);
Ser.print(F(" _sdaDirReg = "));
Ser.println( (uint16_t) _sdaDirReg, HEX);
Ser.print(F(" _sclDirReg = "));
Ser.println( (uint16_t) _sclDirReg, HEX);
Ser.print(F(" _sdaPinReg = "));
Ser.println( (uint16_t) _sdaPinReg, HEX);
Ser.print(F(" _sclPinReg = "));
Ser.println( (uint16_t) _sclPinReg, HEX);
Ser.print(F(" line state sda = "));
Ser.println(i2c_sda_read());
Ser.print(F(" line state scl = "));
Ser.println(i2c_scl_read());
#ifdef ENABLE_I2C_SCANNER
// i2c_scanner
// Taken from : http://playground.arduino.cc/Main/I2cScanner
// At April 2015, it was version 5
Ser.println("\n I2C Scanner");
byte error, address;
int nDevices;
Ser.println(" Scanning...");
nDevices = 0;
for(address=1; address<127; address++ )
{
// The i2c_scanner uses the return value of
// the Write.endTransmisstion to see if
// a device did acknowledge to the address.
beginTransmission(address);
error = endTransmission();
if (error == 0)
{
Ser.print(" I2C device found at address 0x");
if (address<16)
Ser.print("0");
Ser.print(address,HEX);
Ser.println(" !");
nDevices++;
}
else if (error==4)
{
Ser.print(" Unknow error at address 0x");
if (address<16)
Ser.print("0");
Ser.println(address,HEX);
}
}
if (nDevices == 0)
Ser.println(" No I2C devices found\n");
else
Ser.println(" done\n");
#endif
}
//--------------------------------------------------------------------
//
// The i2c_writebit and i2c_readbit could be make "inline", but that
// didn't increase the speed, and the code size increases.
//
// The sda is low after the start condition.
// Therefore the sda is low for the first bit.
//
void SoftwareWire::i2c_writebit(uint8_t c)
{
if(c==0)
{
i2c_sda_lo();
}
else
{
i2c_sda_hi();
}
if (_i2cdelay != 0) // This delay is not needed, but it makes it safer
delayMicroseconds(_i2cdelay); // This delay is not needed, but it makes it safer
i2c_scl_hi(); // clock high: the Slave will read the sda signal
// Check if clock stretching by the Slave should be detected.
if( _stretch)
{
// If the Slave was stretching the clock pulse, the clock would not go high immediately.
// For example if the Slave is an Arduino, that has other interrupts running (for example Serial data).
unsigned long prevMillis = millis();
while( i2c_scl_read() == 0)
{
if( millis() - prevMillis >= _timeout)
break;
};
}
// After the clock stretching, the clock must be high for the normal duration.
// That is why this delay has still to be done.
if (_i2cdelay != 0)
delayMicroseconds(_i2cdelay);
i2c_scl_lo();
if (_i2cdelay != 0)
delayMicroseconds(_i2cdelay);
}
//
uint8_t SoftwareWire::i2c_readbit(void)
{
i2c_sda_hi(); // 'hi' is the same as releasing the line
i2c_scl_hi();
// Check if clock stretching by the Slave should be detected.
if( _stretch)
{
// Wait until the clock is high, the Slave could keep it low for clock stretching.
unsigned long prevMillis = millis();
while( i2c_scl_read() == 0)
{
if( millis() - prevMillis >= _timeout)
break;
};
}
// After the clock stretching, this delay has still be done before reading sda.
if (_i2cdelay != 0)
delayMicroseconds(_i2cdelay);
uint8_t c = i2c_sda_read();
i2c_scl_lo();
if (_i2cdelay != 0)
delayMicroseconds(_i2cdelay);
return(c);
}
//
// Initializes the Software I2C.
//
// The original i2c_init sets the SDA and SCL high at the same time.
//
// The code has been changed, since the first data to the software i2c did fail sometimes.
// Changed into SCL high first, with a delay.
// That would send a STOP if the SDA happens to be low.
// Any Slave that was busy, will detect the STOP.
//
// After both lines are high, the delay is changed into 4 times the normal delay.
// That did reduce the error with the first transmission.
// It was tested with Arduino Uno with clock of 100kHz (_i2cdelay=2).
//
void SoftwareWire::i2c_init(void)
{
i2c_scl_hi();
if (_i2cdelay != 0)
delayMicroseconds(_i2cdelay);
i2c_sda_hi();
for( uint8_t i=0; i<4; i++) // 4 times the normal delay, to claim the bus.
{
if (_i2cdelay != 0)
delayMicroseconds(_i2cdelay);
}
}
//
// Send a START Condition
//
// The SDA and SCL should already be high.
//
// The SDA and SCL will both be low after this function.
// When writing the address, the Master makes them high.
//
// Return value:
// true : software i2c bus is okay.
// false : failed, some kind of hardware bus error.
//
boolean SoftwareWire::i2c_start(void)
{
i2c_sda_hi(); // can perhaps be removed some day ? if the rest of the code is okay
i2c_scl_hi(); // can perhaps be removed some day ? if the rest of the code is okay
if (_i2cdelay != 0)
delayMicroseconds(_i2cdelay);
// Both the sda and scl should be high.
// If not, there might be a hardware problem with the i2c bus signal lines.
// This check was added to prevent that a shortcut of sda would be seen as a valid ACK
// from a i2c Slave.
uint8_t sda_status = i2c_sda_read();
uint8_t scl_status = i2c_scl_read();
if(sda_status == 0 || scl_status == 0)
{
return(false);
}
else
{
i2c_sda_lo();
if (_i2cdelay != 0)
delayMicroseconds(_i2cdelay);
i2c_scl_lo();
if (_i2cdelay != 0)
delayMicroseconds(_i2cdelay);
}
return(true);
}
//
// Repeated START instead of a STOP
//
// TODO: check if the repeated start actually works.
//
void SoftwareWire::i2c_repstart(void)
{
i2c_sda_hi();
// i2c_scl_hi(); // ??????
i2c_scl_lo(); // force SCL low
if (_i2cdelay != 0)
delayMicroseconds(_i2cdelay);
i2c_sda_hi(); // release SDA
if (_i2cdelay != 0)
delayMicroseconds(_i2cdelay);
i2c_scl_hi(); // release SCL
// Check if clock stretching by the Slave should be detected.
if( _stretch)
{
// If the Slave was stretching the clock pulse, the clock would not go high immediately.
// For example if the Slave is an Arduino, that has other interrupts running (for example Serial data).
unsigned long prevMillis = millis();
while( i2c_scl_read() == 0)
{
if( millis() - prevMillis >= _timeout)
break;
};
}
if (_i2cdelay != 0)
delayMicroseconds(_i2cdelay);
}
// Send a STOP Condition
//
// The stop was not recognized by every chip.
// Some code has been added (with comment "ADDED1"),
// to be sure that the levels are okay with delays in between.
void SoftwareWire::i2c_stop(void)
{
i2c_scl_lo(); // ADDED1, it should already be low.
i2c_sda_lo();
// ADDED1, wait to be sure that the slave knows that both are low
if (_i2cdelay != 0) // ADDED1
delayMicroseconds(_i2cdelay); // ADDED1
// For a stop, make SCL high wile SDA is still low
i2c_scl_hi();
// Check if clock stretching by the Slave should be detected.
if( _stretch)
{
// Wait until the clock is high, the Slave could keep it low for clock stretching.
// Clock pulse stretching during a stop condition seems odd, but when
// the Slave is an Arduino, it might happen.
unsigned long prevMillis = millis();
while( i2c_scl_read() == 0)
{
if( millis() - prevMillis >= _timeout)
break;
};
}
if (_i2cdelay != 0)
delayMicroseconds(_i2cdelay);
// complete the STOP by setting SDA high
i2c_sda_hi();
// A delay after the STOP for safety.
// It is not known how fast the next START will happen.
if (_i2cdelay != 0)
delayMicroseconds(_i2cdelay);
}
//
// Write a byte to the I2C slave device
// The returned bit is 0 for ACK and 1 for NACK
//
uint8_t SoftwareWire::i2c_write( uint8_t c )
{
for ( uint8_t i=0; i<8; i++)
{
i2c_writebit(c & 0x80); // highest bit first
c <<= 1;
}
return(i2c_readbit());
}
//
// read a byte from the I2C slave device
//
uint8_t SoftwareWire::i2c_read(boolean ack)
{
uint8_t res = 0;
for(uint8_t i=0; i<8; i++)
{
res <<= 1;
res |= i2c_readbit();
}
if(ack)
{
i2c_writebit(0);
}
else
{
i2c_writebit(1);
}
if(_i2cdelay != 0)
delayMicroseconds(_i2cdelay);
return(res);
}