Compare commits

..

No commits in common. "dacc816eb44c9c9904a4b1a251578f5a9dd1b49d" and "14b0247716fe19a9bb2b028e86553a83dc76e8e5" have entirely different histories.

2 changed files with 18 additions and 21 deletions

View File

@ -278,7 +278,6 @@
openocd gdb openocd gdb
openssh rsync openssh rsync
llvmPackages_9.clang-unwrapped llvmPackages_9.clang-unwrapped
(python3.withPackages(ps: [ ps.pyftdi ]))
mkbootimage ]; mkbootimage ];
}; };
}; };

View File

@ -7,7 +7,7 @@ use super::time::Microseconds;
use embedded_hal::timer::CountDown; use embedded_hal::timer::CountDown;
use libregister::{RegisterR, RegisterRW, RegisterW}; use libregister::{RegisterR, RegisterRW, RegisterW};
pub enum I2cMultiplexer { enum PCA954X {
PCA9548 = 0, PCA9548 = 0,
#[cfg(feature = "target_kasli_soc")] #[cfg(feature = "target_kasli_soc")]
PCA9547 = 1, PCA9547 = 1,
@ -16,7 +16,7 @@ pub enum I2cMultiplexer {
pub struct I2c { pub struct I2c {
regs: regs::RegisterBlock, regs: regs::RegisterBlock,
count_down: super::timer::global::CountDown<Microseconds>, count_down: super::timer::global::CountDown<Microseconds>,
pca_type: I2cMultiplexer pca_type: PCA954X
} }
impl I2c { impl I2c {
@ -63,7 +63,7 @@ impl I2c {
let self_ = Self { let self_ = Self {
regs: regs::RegisterBlock::i2c(), regs: regs::RegisterBlock::i2c(),
count_down: unsafe { super::timer::GlobalTimer::get() }.countdown(), count_down: unsafe { super::timer::GlobalTimer::get() }.countdown(),
pca_type: I2cMultiplexer::PCA9548 //default for zc706 pca_type: PCA954X::PCA9548
}; };
// Setup GPIO output mask // Setup GPIO output mask
@ -75,7 +75,7 @@ impl I2c {
w.scl(true).sda(true) w.scl(true).sda(true)
}); });
//Kasli-SoC only: I2C_SW_RESET configuration //Kasli-SoC exclusive: I2C_SW_RESET configuration
#[cfg(feature = "target_kasli_soc")] #[cfg(feature = "target_kasli_soc")]
{ {
self_.regs.gpio_output_mask_lower.modify(|_, w| { self_.regs.gpio_output_mask_lower.modify(|_, w| {
@ -144,15 +144,13 @@ impl I2c {
} }
#[cfg(feature = "target_kasli_soc")] #[cfg(feature = "target_kasli_soc")]
fn pca_autodetect(&mut self) -> Result<I2cMultiplexer, &'static str> { pub fn pca_autodetect(&mut self) -> Result<PCA954X, &'static str> {
// start with resetting the PCA954X // start with resetting the PCA954X
// SDA must be clear (before start)
// reset time is 500ns, unit_delay (100us) to account for propagation /*self.i2cswr_oe(false);
self.i2cswr_o(true); self.unit_delay();
self.unit_delay(); self.i2cswr_oe(true);*/
self.i2cswr_o(false);
self.unit_delay();
let pca954x_read_addr = (0x71 << 1) | 0x01; let pca954x_read_addr = (0x71 << 1) | 0x01;
self.start()?; self.start()?;
@ -163,8 +161,8 @@ impl I2c {
let config = self.read(false)?; let config = self.read(false)?;
let pca = match config { let pca = match config {
0x00 => I2cMultiplexer::PCA9548, 0x00 => PCA954X::PCA9548,
0x08 => I2cMultiplexer::PCA9547, 0x08 => PCA954X::PCA9547,
_ => { return Err("Unknown response for PCA954X autodetect")}, _ => { return Err("Unknown response for PCA954X autodetect")},
}; };
self.stop()?; self.stop()?;
@ -200,7 +198,7 @@ impl I2c {
#[cfg(feature = "target_kasli_soc")] #[cfg(feature = "target_kasli_soc")]
{ {
self.i2cswr_oe(true); self.unit_delay();
self.pca_type = self.pca_autodetect()?; self.pca_type = self.pca_autodetect()?;
} }
@ -302,18 +300,18 @@ impl I2c {
pub fn pca954x_select(&mut self, address: u8, channel: u8) -> Result<(), &'static str> { pub fn pca954x_select(&mut self, address: u8, channel: u8) -> Result<(), &'static str> {
self.start()?; self.start()?;
// PCA9547 supports only one channel at a time // PCA9547 supports only one channel at a time
// for compatibility, PCA9548 is treated as such too // for compatibility, PCA9548 is treated as such
let setting = match self.pca_type { let setting = match self.pca_type {
I2cMultiplexer::PCA9548 => 1 << channel, PCA954X::PCA9548 => 1 << channel,
#[cfg(feature = "target_kasli_soc")] #[cfg(feature = "target_kasli_soc")]
I2cMultiplexer::PCA9547 => channel | 0x08, PCA954X::PCA9547 => channel | 0x08,
}; };
if !self.write(address << 1)? { if !self.write(address << 1)? {
return Err("PCA954X failed to ack write address") return Err("PCA9548 failed to ack write address")
} }
if !self.write(setting)? { if !self.write(setting)? {
return Err("PCA954X failed to ack control word") return Err("PCA9548 failed to ack control word")
} }
self.stop()?; self.stop()?;
Ok(()) Ok(())