|
|
|
#![no_main]
|
|
|
|
#![no_std]
|
|
|
|
|
|
|
|
use panic_halt as _;
|
|
|
|
|
|
|
|
use stm32f0xx_hal as hal;
|
|
|
|
|
|
|
|
use crate::hal::{i2c::I2c, pac, prelude::*};
|
|
|
|
|
|
|
|
use cortex_m_rt::entry;
|
|
|
|
|
|
|
|
/* Example meant for stm32f030xc MCUs with i2c devices connected on PB7 and PB8 */
|
|
|
|
|
|
|
|
#[entry]
|
|
|
|
fn main() -> ! {
|
|
|
|
if let Some(p) = pac::Peripherals::take() {
|
|
|
|
cortex_m::interrupt::free(move |cs| {
|
|
|
|
let mut flash = p.FLASH;
|
|
|
|
let mut rcc = p.RCC.configure().freeze(&mut flash);
|
|
|
|
|
|
|
|
let gpiob = p.GPIOB.split(&mut rcc);
|
|
|
|
|
|
|
|
// Configure pins for I2C
|
|
|
|
let sda = gpiob.pb7.into_alternate_af1(cs);
|
|
|
|
let scl = gpiob.pb8.into_alternate_af1(cs);
|
|
|
|
|
|
|
|
// Configure I2C with 100kHz rate
|
|
|
|
let mut i2c = I2c::i2c1(p.I2C1, (scl, sda), 100.khz(), &mut rcc);
|
|
|
|
|
|
|
|
let mut _devices = 0;
|
|
|
|
// I2C addresses are 7-bit wide, covering the 0-127 range
|
|
|
|
for add in 0..=127 {
|
|
|
|
// The write method sends the specified address and checks for acknowledgement;
|
|
|
|
// if no ack is given by the slave device the result is Err(), otherwise Ok()
|
|
|
|
// Since we only care for an acknowledgement the data sent can be empty
|
|
|
|
if i2c.write(add, &[]).is_ok() {
|
|
|
|
_devices += 1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Here the variable "_devices" counts how many i2c addresses were a hit
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
loop {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
}
|