2021-05-30 14:23:58 +02:00
|
|
|
|
|
|
|
[![Arduino CI](https://github.com/RobTillaart/MultiSpeedI2CScanner/workflows/Arduino%20CI/badge.svg)](https://github.com/marketplace/actions/arduino_ci)
|
2021-12-22 13:02:30 +01:00
|
|
|
[![Arduino-lint](https://github.com/RobTillaart/MultiSpeedI2CScanner/actions/workflows/arduino-lint.yml/badge.svg)](https://github.com/RobTillaart/MultiSpeedI2CScanner/actions/workflows/arduino-lint.yml)
|
|
|
|
[![JSON check](https://github.com/RobTillaart/MultiSpeedI2CScanner/actions/workflows/jsoncheck.yml/badge.svg)](https://github.com/RobTillaart/MultiSpeedI2CScanner/actions/workflows/jsoncheck.yml)
|
2021-05-30 14:23:58 +02:00
|
|
|
[![License: MIT](https://img.shields.io/badge/license-MIT-green.svg)](https://github.com/RobTillaart/MultiSpeedI2CScanner/blob/master/LICENSE)
|
|
|
|
[![GitHub release](https://img.shields.io/github/release/RobTillaart/MultiSpeedI2CScanner.svg?maxAge=3600)](https://github.com/RobTillaart/MultiSpeedI2CScanner/releases)
|
|
|
|
|
|
|
|
|
|
|
|
# Arduino MultiSpeed I2C Scanner
|
|
|
|
|
2021-12-22 13:02:30 +01:00
|
|
|
|
|
|
|
## Version: 0.1.15
|
|
|
|
|
2021-05-30 14:23:58 +02:00
|
|
|
|
|
|
|
## Description
|
|
|
|
|
|
|
|
MultiSpeedI2CScanner is a menu driven I2C scanner, see below.
|
|
|
|
The scanner is tested on an UNO and an ESP32.
|
|
|
|
|
|
|
|
The scanner provides an overview of which addresses can be found
|
|
|
|
at which speed. This allows one to optimize the I2C performance of
|
|
|
|
many devices above the standard 100KHz speed.
|
|
|
|
|
2021-12-22 13:02:30 +01:00
|
|
|
|
2021-05-30 14:23:58 +02:00
|
|
|
## Menu dialog
|
|
|
|
|
|
|
|
```
|
|
|
|
<speeds = 50 100 150 200 250 300 350 400 >
|
|
|
|
|
2021-12-22 13:02:30 +01:00
|
|
|
Arduino MultiSpeed I2C Scanner - 0.1.15
|
2021-05-30 14:23:58 +02:00
|
|
|
|
|
|
|
I2C ports: 1 Current: Wire0
|
|
|
|
@ = toggle Wire - Wire1 - Wire2 [TEENSY 3.5 or Arduino Due]
|
|
|
|
Scan mode:
|
|
|
|
s = single scan
|
|
|
|
c = continuous scan - 1 second delay
|
|
|
|
q = quit continuous scan
|
|
|
|
d = toggle latency delay between successful tests. 0 - 5 ms
|
|
|
|
i = toggle enable/disable interrupts
|
|
|
|
Output:
|
|
|
|
p = toggle printAll - printFound.
|
|
|
|
h = toggle header - noHeader.
|
|
|
|
a = toggle address range, 0..127 - 8..119 (default)
|
|
|
|
Speeds:
|
2021-12-22 13:02:30 +01:00
|
|
|
0 = 100..800 KHz - step 100 (warning - can block!!)
|
2021-05-30 14:23:58 +02:00
|
|
|
1 = 100 KHz
|
|
|
|
2 = 200 KHz
|
|
|
|
4 = 400 KHz
|
2021-12-22 13:02:30 +01:00
|
|
|
9 = 50..400 KHz - step 50 < DEFAULT >
|
2021-05-30 14:23:58 +02:00
|
|
|
|
|
|
|
!! HIGH SPEEDS - WARNING - can block - not applicable for UNO
|
|
|
|
8 = 800 KHz
|
|
|
|
M = 1000 KHz
|
|
|
|
N = 3400 KHz
|
2021-12-22 13:02:30 +01:00
|
|
|
O = 5000 KHz
|
|
|
|
P = 100 400 1000 3400 5000 KHz (standards)
|
2021-05-30 14:23:58 +02:00
|
|
|
|
|
|
|
? = help - this page
|
|
|
|
```
|
|
|
|
|
2021-12-22 13:02:30 +01:00
|
|
|
|
2021-05-30 14:23:58 +02:00
|
|
|
## Functions
|
|
|
|
|
|
|
|
### I2C ports
|
|
|
|
|
|
|
|
**@** selects through the different Wire ports.
|
|
|
|
Note that the current Wire port is given after I2C ports: count
|
|
|
|
Wire0 is just Wire but it was easier to program.
|
|
|
|
|
|
|
|
### Scan mode
|
|
|
|
|
|
|
|
**s** selects single scan mode, think of it as manual.
|
|
|
|
|
|
|
|
**c** selects continuous scanning, think of it as automatic.
|
|
|
|
|
|
|
|
**q** quits the continuous scan mode.
|
|
|
|
|
|
|
|
**d** toggles the latency between successful scans.
|
|
|
|
Only needed sometimes.
|
|
|
|
|
|
|
|
**i** toggles disable/enable interrupts, use with care.
|
|
|
|
|
2021-12-22 13:02:30 +01:00
|
|
|
|
2021-05-30 14:23:58 +02:00
|
|
|
### Output selection
|
|
|
|
|
|
|
|
**p** toggles printAll and printFound.
|
|
|
|
PrintAll will print also the addresses where nothing is found.
|
|
|
|
PrintFound will only generate a line if an I2C device is found on that address.
|
|
|
|
|
|
|
|
**h** toggles the printing of a header.
|
|
|
|
|
|
|
|
**a** toggles the range of addresses scanned, default the range 8 .. 119 is scanned,
|
|
|
|
but one can extend this range to 0 .. 127. **Note:** some addresses are reserved.
|
|
|
|
|
2021-12-22 13:02:30 +01:00
|
|
|
|
2021-05-30 14:23:58 +02:00
|
|
|
### Speeds
|
|
|
|
|
|
|
|
All options here select a single speed or a range of speeds.
|
|
|
|
|
|
|
|
Since 0.1.10 version experimental speeds of 1000, 3400 and 5000 are added as
|
|
|
|
these are part of the I2C standards.
|
|
|
|
http://i2c.info/i2c-bus-specification
|
|
|
|
|
|
|
|
NOTE: not all processors will support these higher speeds.
|
|
|
|
This can show up as blocking or it can even look like it is working.
|
|
|
|
Check your datasheet to see which speeds are applicable for the processor in use.
|
|
|
|
|
2021-12-22 13:02:30 +01:00
|
|
|
|
|
|
|
## Future
|
|
|
|
|
|
|
|
- add watchdog reset (at least AVR - 8 seconds 0.2.0 )
|
|
|
|
- create an I2CScanner class
|
|
|
|
- r = reset (defaults)
|
|
|
|
- non-AVR command behind a ```#ifdef``` ?
|
|
|
|
|