Better logging
This commit is contained in:
@@ -38,7 +38,6 @@ fn command<I: I2CDevice>(dev: &mut I, cmd: u32) -> Result<u32, I::Error> {
|
|||||||
write(dev, IECS_CMD, cmd)?;
|
write(dev, IECS_CMD, cmd)?;
|
||||||
loop {
|
loop {
|
||||||
let status = read(dev, IECS_CMD)?;
|
let status = read(dev, IECS_CMD)?;
|
||||||
println!("Status: {:X}", status);
|
|
||||||
if status != cmd {
|
if status != cmd {
|
||||||
//TODO: perform error checking here
|
//TODO: perform error checking here
|
||||||
return Ok(status);
|
return Ok(status);
|
||||||
@@ -47,20 +46,21 @@ fn command<I: I2CDevice>(dev: &mut I, cmd: u32) -> Result<u32, I::Error> {
|
|||||||
}
|
}
|
||||||
|
|
||||||
fn main() {
|
fn main() {
|
||||||
|
//TODO: force power and sleep 40ms
|
||||||
|
|
||||||
let mut dev = LinuxI2CDevice::new("/dev/i2c-11", 0x40).unwrap();
|
let mut dev = LinuxI2CDevice::new("/dev/i2c-11", 0x40).unwrap();
|
||||||
println!("Vendor: {:X}", read(&mut dev, 0).unwrap());
|
println!("Vendor: {:X}", read(&mut dev, 0).unwrap());
|
||||||
println!("Device: {:X}", read(&mut dev, 1).unwrap());
|
println!("Device: {:X}", read(&mut dev, 1).unwrap());
|
||||||
|
|
||||||
let image = fs::read("../models/galp5/usb4-retimer.rom").unwrap();
|
let image = fs::read("../models/galp5/usb4-retimer.rom").unwrap();
|
||||||
|
|
||||||
// Set offset to 0
|
println!("Set offset to 0");
|
||||||
write(&mut dev, IECS_DATA, 0).unwrap();
|
write(&mut dev, IECS_DATA, 0).unwrap();
|
||||||
let status = command(&mut dev, CMD_BOPS).unwrap();
|
let status = command(&mut dev, CMD_BOPS).unwrap();
|
||||||
if status != 0 {
|
if status != 0 {
|
||||||
panic!("Failed to set offset: {:X}", status);
|
panic!("Failed to set offset: {:X}", status);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Write data
|
|
||||||
let mut i = 0;
|
let mut i = 0;
|
||||||
while i < image.len() {
|
while i < image.len() {
|
||||||
// Write 64 byte block
|
// Write 64 byte block
|
||||||
@@ -77,19 +77,21 @@ fn main() {
|
|||||||
i += 4;
|
i += 4;
|
||||||
j += 4;
|
j += 4;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
println!("Write {}/{}", i, image.len());
|
||||||
let status = command(&mut dev, CMD_BLKW).unwrap();
|
let status = command(&mut dev, CMD_BLKW).unwrap();
|
||||||
if status != 0 {
|
if status != 0 {
|
||||||
panic!("Failed to write block at {:X}:{:X}: {:X}", start, i, status);
|
panic!("Failed to write block at {:X}:{:X}: {:X}", start, i, status);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Authenticate written data
|
println!("Authenticate");
|
||||||
let status = command(&mut dev, CMD_AUTH).unwrap();
|
let status = command(&mut dev, CMD_AUTH).unwrap();
|
||||||
if status != 0 {
|
if status != 0 {
|
||||||
panic!("Failed to authenticate: {:X}", status);
|
panic!("Failed to authenticate: {:X}", status);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Power cycle
|
println!("Power cycle");
|
||||||
let status = command(&mut dev, CMD_PCYC).unwrap();
|
let status = command(&mut dev, CMD_PCYC).unwrap();
|
||||||
if status != 0 {
|
if status != 0 {
|
||||||
panic!("Failed to power cycle: {:X}", status);
|
panic!("Failed to power cycle: {:X}", status);
|
||||||
|
Reference in New Issue
Block a user