From: Lorenzo Bianconi <lorenzo@xxxxxxxxxx> Date: Mon, Mar 09, 2020 at 15:10:35 > > From: Lorenzo Bianconi <lorenzo@xxxxxxxxxx> > > Date: Mon, Mar 09, 2020 at 15:01:01 > > > > > > Hi Lorenzo, > > > > > > > > From: Lorenzo Bianconi <lorenzo@xxxxxxxxxx> > > > > Date: Sun, Mar 08, 2020 at 00:06:03 > > > > > > > > > Disable MIPI I3C during device reset in order to avoid > > > > > possible races on interrupt line 1. If the first interrupt > > > > > line is asserted during hw reset the device will work in > > > > > I3C-only mode > > > > > > > > > > > [...] > > > > > > > > + > > > > > > > > After disable the i3c interface the dynamic address is no more accessible > > > > and fails the initialization. > > > > > > > > > > Hi Vitor, > > > > > > thx for testing it. What do you mean here? > > > Is int1 set to vdd in your test? > > > > > > Regards, > > > Lorenzo > > > > Yes, according with figure 14 of lsm6dso datasheet. > > uhm..probably we should do this configuration if the device is not in I3C-only > mode. Are you able to test it without setting the int1 to vdd? > Unfortunately I have no devices with an I3C controller yet. > > Regards, > Lorenzo > Yes, I can test but I suspect we will have the same issue because it lost the dynamic address. I would say to add a flag during the probe to indicate the interface and bypass this if in I3C mode. This may be useful when address the In-band interrupts. Best regards, Vitor Soares > > > > Is there any way to clear the INT1 before the hw reset? > > > > Best regards, > > Vitor Soares > > > > > > > > > Best regards, > > > > Vitor Soares > > > > > > > > > /* device sw reset */ > > > > > reg = &hw->settings->reset; > > > > > err = regmap_update_bits(hw->regmap, reg->addr, reg->mask, > > > > > @@ -2059,6 +2081,15 @@ static int st_lsm6dsx_init_device(struct st_lsm6dsx_hw *hw) > > > > > > > > > > msleep(50); > > > > > > > > > > + /* enable MIPI I3C */ > > > > > + if (hw->settings->i3c_disable.addr) { > > > > > + reg = &hw->settings->i3c_disable; > > > > > + err = regmap_update_bits(hw->regmap, reg->addr, reg->mask, > > > > > + ST_LSM6DSX_SHIFT_VAL(0, reg->mask)); > > > > > + if (err < 0) > > > > > + return err; > > > > > + } > > > > > + > > > > > /* enable Block Data Update */ > > > > > reg = &hw->settings->bdu; > > > > > err = regmap_update_bits(hw->regmap, reg->addr, reg->mask, > > > > > -- > > > > > 2.24.1 > > > > > > > > > > > >