Platform: RK3399
OS: Android 8.1
现象:
使用LT9611实现MIPI TO HDMI输出功能,使用官方提供驱动后HDMI输出时有时无,并且很不稳定
问题1
1.开机HDMI没有输出,根据打印发现问题是HDMI输出为0,但是系统认为已经输出 ,原因是power on没有对HDMI是否输出进行判断,不论HDMI输出是否成功,bridge_is_o = true;
static int lt9611_poweron(struct lt9611 *lt){int ret;lt->bridge_is_on = true;DRM_ERROR("%s[%d]: lt->bridge_is_on=%d\n", __FUNCTION__, __LINE__, lt->bridge_is_on);ret = lt9611_setup(lt, <->previous_mode);return ret;}
解决方法:
1.对lt9611_setup进行判断,如果输出HDMI失败,lt->bridge_is_on = false;lt->disabled = true;如果输出成功,lt->bridge_is_on = true;lt->disabled = false;
2.增加延时,确保读取mipi信息准确 ,具体延时时间后续优化
static int lt9611_poweron(struct lt9611 *lt){int ret;lt->bridge_is_on = true;//JYXDRM_ERROR("%s[%d]: lt->bridge_is_on=%d\n", __FUNCTION__, __LINE__, lt->bridge_is_on);msleep(200);//jyxret = lt9611_setup(lt, <->previous_mode);lt->disabled = false;if (ret){lt->bridge_is_on = false;//JYXlt->disabled = true;}return ret;}
问题2
1.开机LT9611输出正常,插拔HDMI无图像,查看打印发现中断触发2次。
解决方法:
1.修改LT9611_irq_init,中断初始化函数,由于9611寄存器手册没有这些寄存器的具体信息,所以通过尝试发现RGO_8200_OFFSET_NA 寄存器的值与问题有关,将该寄存器值由0xfe修改为0xff,问题解决
static int lt9611_irq_init(struct lt9611 *lt){int ret;ret = lt9611_write_byte(lt, BANK_SELECT_ADDR, SYSTEM_CTRL0_BLOCK);if (ret)return ret;ret = lt9611_write_byte(lt, RGO_8258_OFFSET_NA, 0x0a); //Det HPDif (ret)return ret;ret = lt9611_write_byte(lt, RGO_8259_OFFSET_NA, 0x80); //HPD debounce widthif (ret)return ret;ret = lt9611_write_byte(lt, RGO_829E_OFFSET_NA, 0xf7); //vid chk clkif (ret)return ret;ret = lt9611_write_byte(lt, RGO_8200_OFFSET_NA, 0xff); //vid_chk_IRQ 0xff JYXif (ret)return ret;ret = lt9611_write_byte(lt, RGO_8203_OFFSET_NA, 0x3f); //Tx_detif (ret)return ret;ret = lt9611_write_byte(lt, RGO_8204_OFFSET_NA, 0xff); //clear0if (ret)return ret;ret = lt9611_write_byte(lt, RGO_8204_OFFSET_NA, 0xfe); //clear0if (ret)return ret;ret = lt9611_write_byte(lt, RGO_8207_OFFSET_NA, 0xff); //clear3if (ret)return ret;ret = lt9611_write_byte(lt, RGO_8207_OFFSET_NA, 0x3f); //clear3if (ret)return ret;return 0;}
问题3
1.HDMI输出画面有 横条状抖动,下图左侧
解决方法:
1.确认不是RK输出MIPI时钟的问题
2.查看LT9611寄存器手册,找到MIPI rx的配置寄存器0X8106,经过一系列尝试,将mipi rx的参考电流由37.5uA修改为12.5uA,并且直接使能mipi rx 的高速模式,最终将0x8106配置为0x3f。图像不再出现横纹。
总结
目前该驱动修改仅处于可以使用的状态,后续需要向原厂提供技术支持,确保产品万无一失。