BIOS备忘录之IIC(touchpad)设备

时间:2023-03-09 15:23:55
BIOS备忘录之IIC(touchpad)设备

简述BIOS中对IIC device的支持,以touchpad为例。

信息收集

BIOS备忘录之IIC(touchpad)设备

收集平台的硬件信息:

1. IIC controller number(PCH一般包含多个controller,我们使用的是哪一个);

2. INT / Reset信号用的是哪个GPIO;

3. Enable信号用的是哪个GPIO(Enable信号一般由EC控制,这样可以通过Hotkey来Enable/Disable)

收集device的信息:

1. slave address;

2. hid descriptor address;

3. vendor ID, Product ID;

4. _HID(根据driver确定)

软件初始化

GPIO的配置:

1. SDA,SCL一般直接配置成native function就行了;

2. INT / Reset要配置成GPIO(并且需要在code里面显式的使用:使用GPIO的内存地址或int number)

在BIOS setup下面配置device的相关参数:

设备类型,中断模式,总线地址(controller number),HID地址,速度,SDL Hold Time等,这些参数会通过GNVS传给ASL code(可参考:

BIOS备忘录之ASL code常用知识点 里面的BIOS code与ASL code是如何传递数据的)

BIOS备忘录之IIC(touchpad)设备

BIOS备忘录之IIC(touchpad)设备

我们在系统下通过RW查看寄存器:

BIOS备忘录之IIC(touchpad)设备

ASL code初始化

1. 根据GNVS的参数,赋值正确的_HID, HID2等;

2. 修改_CRS,配置device使用的系统资源,这里一般会把INT引脚的int number传进来(体现了GPIO的显式使用

BIOS备忘录之IIC(touchpad)设备

BIOS备忘录之IIC(touchpad)设备

BIOS备忘录之IIC(touchpad)设备

问题举例

1. device在DM下看不到:

>>> 检查controller是否已经enable;

>>> 检查device在_STA中有没有返回 1。

2. device不能正常工作:

>>> 测量时序,比如配置SDA Hold Time;

>>> 检查EC的使能信号;

>>> 尝试更改clock的频率;

>>> 检查中断信号的设置(中断方式,是否设置了反转等);

>>> 测量是否有漏电(添加code在合适的位置来拉RST/EN)。

support多种device

如果项目支持多种device,比如支持2种touchpad,这时需要BIOS能自动检测不同的device,然后在asl code里面赋值不同的_HID,以便在OS下能安装正确的driver(note:2种touchpad的slave address和hid address要一样)

一般来说,对IIC device,我们会在post过程中去读取IIC device的HID descriptor,从而得到device类型,厂商...,进而在ASL code里面为不同的device赋值不同的_HID,以便安装正确的driver。

BIOS C code IIC driver的作用:

1. 把IIC controller number,slave address,hid address,int(一般为内存地址(体现了GPIO的显式使用),BIOS根据输入判断是否有中断产生),reset传给BIOS;

2. BIOS根据IIC controller number,slave address,hid address获取device的hid descriptor;

BIOS备忘录之IIC(touchpad)设备

3. 把hid descriptor里面的vendorID,productID通过GNVS告诉ASL code给device赋值不同的_HID

BIOS备忘录之IIC(touchpad)设备

BIOS备忘录之IIC(touchpad)设备

Enable/Disable TouchPad

在OS下我们可以通过Hotkey来Enable/Disable touchpad,常用做法:

1. EC 拉GPIO:EC检测到按键按下,直接把device的en信号拉低;

2. EC 发Q Event 告诉Driver:EC检测到按键按下,发Q Event告诉OS,OS调用ASL 来处理(这种方式需要自定义的driver配合)