tcpci gets error -110 in tcpci_probe on regmap_raw_write

キャンセル
次の結果を表示 
表示  限定  | 次の代わりに検索 
もしかして: 

tcpci gets error -110 in tcpci_probe on regmap_raw_write

5,040件の閲覧回数
dmitry_sidorenkov
Contributor III

board a custom board based on im8qm with 6Gb ram
Android 12.1
kernel 5.15.52

Board can't pass probe of usb-c ptn5110 device which is used for Android adb after shut down and turn on in 2 seconds by SW1 button.
The issue log:
[ 5.463252][ T10] tcpci: probe of 4-0051 failed with error -110

0 件の賞賛
返信
13 返答(返信)

4,393件の閲覧回数
dmitry_sidorenkov
Contributor III

After adding a delay 10s less then 2 times(added usleep_range(6000000, 8000000)) and it didn't help and tcpci was not initialized with the next logs.
So perhaps there is something in kernel code that holds SDA low, but it may be related to HW differences but it is also related to kernel code.

 

[    4.232884][   T10] i2c i2c-3: LPI2C adapter registered
[    4.238689][   T10] imx-lpi2c 5a800000.i2c: use pio mode
[    4.244360][   T10] i2c 4-0051: Fixing up cyclic dependency with 5b130000.usb
[    5.258471][   T10] tcpci 4-0051: Failed to regmap_raw_write (-ETIMEDOUT), attempt:1
[    5.266221][   T10] tcpci 4-0051: Wait the next attempt for 10s
[   14.278486][   T10] tcpci 4-0051: Failed to regmap_raw_write (-ETIMEDOUT), attempt:2
[   14.286236][   T10] tcpci 4-0051: Wait the next attempt for 10s
[   22.290515][   T10] tcpci: probe of 4-0051 failed with error -110
[   22.296819][   T10] i2c i2c-4: LPI2C adapter registered

 


 

0 件の賞賛
返信

4,380件の閲覧回数
dmitry_sidorenkov
Contributor III

But returning EPROBE_DEFER helps, so it means the issue is related to the drivers init order

err = regmap_raw_write(chip->data.regmap, TCPC_ALERT_MASK, &val, sizeof(u16));
if (err < 0)
return -EPROBE_DEFER;
0 件の賞賛
返信

5,007件の閲覧回数
Zhiming_Liu
NXP TechSupport
NXP TechSupport

Hi @dmitry_sidorenkov 

Does this issue occurs only after adb shutdown->turn on? You can't see it during normal bootup, right?

0 件の賞賛
返信

4,998件の閲覧回数
dmitry_sidorenkov
Contributor III

yes, it does, on reboot it doesn't happen.

0 件の賞賛
返信

4,966件の閲覧回数
Zhiming_Liu
NXP TechSupport
NXP TechSupport

From the software side, the i2c communication is timeout. So you may need check the hardware waveforms when use adb shutdown.

0 件の賞賛
返信

4,951件の閲覧回数
dmitry_sidorenkov
Contributor III
For what state of board should I check i2c waveforms?
Do you mean that i2c isn't not ready when tcpci goes probe()?
0 件の賞賛
返信

4,941件の閲覧回数
Zhiming_Liu
NXP TechSupport
NXP TechSupport

For what state of board should I check i2c waveforms?

-->Check all pins status about ptn5110 

Yes, the  -110 means timeout when use regmap framework, so it can't communicate with soc.

 

0 件の賞賛
返信

4,878件の閲覧回数
dmitry_sidorenkov
Contributor III

I disabled the second i2c connected device cs43l21 and noticed a strange behavior about i2c.
Tested with oscilloscope:
- General case: in a cold boot case there is some work on i2c on u-boot stage and kernel probe drivers stage.
- Issue case: there is no i2c actions on u-boot stage and on kernel probe drivers stage.
Also attached a plain from logic analyzer when the ptn5110 is single on i2c
Also if there would the the second i2c device (cs43l21) then it could work fine somehow.
The issue is that SDA is kept down for about 10 seconds

 

analyzer.png

0 件の賞賛
返信

4,833件の閲覧回数
Zhiming_Liu
NXP TechSupport
NXP TechSupport

Hi @dmitry_sidorenkov 

From the oscilloscope test result, the i2c bus SDA stuck in LOW, which we call it has been locked up.

There are two ways to avoid such issue:

1. Connect slave device which has RESET pin(ptn5110 not, but cs43l21 has)

2.Send nine clock pluse when SDA stuck in LOW

Zhiming_Liu_0-1700785145007.png

Zhiming_Liu_1-1700785308640.png

Reference: https://www.nxp.com/docs/en/user-guide/UM10204.pdf

 

 

 

0 件の賞賛
返信

4,813件の閲覧回数
dmitry_sidorenkov
Contributor III

I've added related pins to enable a recovery feature

&i2c0 {
...
pinctrl-names = "default", "gpio";
pinctrl-0 = <&pinctrl_i2c0>;
pinctrl-1 = <&pinctrl_i2c0_gpio>;
scl-gpios = <&lsio_gpio2 2 GPIO_ACTIVE_HIGH>;
sda-gpios = <&lsio_gpio2 3 GPIO_ACTIVE_HIGH>;
...
}
pinctrl_i2c0: i2c0grp {
fsl,pins = <
IMX8QM_HDMI_TX0_TS_SCL_DMA_I2C0_SCL 0x06000021
IMX8QM_HDMI_TX0_TS_SDA_DMA_I2C0_SDA 0x06000021
>;
};
pinctrl_i2c0_gpio: i2c1grp-gpio {
fsl,pins = <
IMX8QM_HDMI_TX0_TS_SCL_LSIO_GPIO2_IO02 0x06000020
IMX8QM_HDMI_TX0_TS_SDA_LSIO_GPIO2_IO03 0x06000020
>;
};


It has caused getting two new lines in logs during the failing line

 /* Disable chip interrupts before requesting irq */
err = regmap_raw_write(chip->data.regmap, TCPC_ALERT_MASK, &val,
sizeof(u16));

 new logs are:

[ 4.775545][ T8] i2c i2c-4: SCL is stuck low, exit recovery
[ 5.283545][ T8] i2c i2c-4: SCL is stuck low, exit recovery

But actually a real SCL level is high for all time, see the previously attached image.

I think as a some workaround I can add usleep_range(1000000, 12000000); into a probing of tcpci device.

0 件の賞賛
返信

4,866件の閲覧回数
Zhiming_Liu
NXP TechSupport
NXP TechSupport

Hi @dmitry_sidorenkov 

Have you tested it on MEK? Please provide test steps and share the log difference you found.

0 件の賞賛
返信

4,801件の閲覧回数
dmitry_sidorenkov
Contributor III

can't reproduce it on mek, but mek works differently i.e. it doesn't turn off power supplies, fan when kernel causes power off

0 件の賞賛
返信

4,989件の閲覧回数
Zhiming_Liu
NXP TechSupport
NXP TechSupport

Can you share your schematic with private message?

0 件の賞賛
返信