BIOS备忘录之IIC(touchpad)设备
简述BIOS中对IIC device的支持,以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是如何传递数据的)


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

ASL code初始化
1. 根据GNVS的参数,赋值正确的_HID, HID2等;
2. 修改_CRS,配置device使用的系统资源,这里一般会把INT引脚的int number传进来(体现了GPIO的显式使用)



问题举例
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;

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


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配合)
BIOS备忘录之IIC(touchpad)设备的更多相关文章
- BIOS备忘录之SPI(fingerprint)设备
Reset和INT信号使用的是GPIO功能,需要显式的使用(INT信号使用了GPIO的int number,RST信号使用了GPIO的absolute number): 问题举例 漏电导致功能异常:在 ...
- RT-thread 设备驱动组件之IIC总线设备
本文主要介绍RT-thread中IIC总线设备驱动,涉及到的主要文件有:驱动框架文件(i2c_core.c,i2c_dev.c,i2c-bit-ops.c,i2c_dev.h,i2c.h):底层硬件驱 ...
- BIOS备忘录之x86硬件编程(寄存器与IO)
SOC固件(BIOS)开发: 1.熟悉硬件原理图:要弄清楚pin脚的功能: 2.配置GPIO引脚,配置成Native功能还是GPIO功能(如果是配置成GPIO,需要在code里面显式的使用): 3.硬 ...
- BIOS备忘录之EC常用知识点
BIOS工程师眼中常用的EC知识点汇总: EC的硬件架构 EC硬件结构上主要分为两部分:Host Domain和EC Domain Host Domain就是通过LPC与CPU通信的部分(LPC部分需 ...
- Arduino IIC 主从设备连接通信
目的: 实现Arduino主从设备之间的互相IIC通信,掌握IIC通信协议的使用方法. 器材: Arduino UNO R3 一块 Arduino Nano 三块 面包板 导线 3K ...
- BIOS启动项中的设备都有哪些
Floppy 软式磁盘驱动器,简称FDD,也就是我们平时所说的软驱. CD-ROM 不用多说了,大家都知道,这是光盘驱动器,也就是我们平时说得光驱. SCSI SCSI的全名是:Small Compu ...
- BIOS备忘录之ASL code常用知识点
_HID:device唯一 _STA:决定device在不在(在DM下面能不能看到) _CRS:描述分配给device的资源 _INI:在OSPM加载描述表的时候运行一次(比如,如果要根据不同情况给d ...
- BIOS备忘录之通过Windbg来追踪ASL code的运行
通过Windbg来追踪ASL code的运行: 目标机的配置: 第一步: 在BIOS Setup下面 disable secure boot(不然下面debug on 命令会失败):关闭防火墙. 第二 ...
- IIC设备驱动程序
IIC设备是一种通过IIC总线连接的设备,由于其简单性,被广泛引用于电子系统中.在现代电子系统中,有很多的IIC设备需要进行相互之间通信 IIC总线是由PHILIPS公司开发的两线式串行总线,用于连接 ...
随机推荐
- Linux下的搜索查找命令的详解(which)
我们经常在linux要查找某个文件,但不知道放在哪里了,可以使用下面的一些命令来搜索: which 查看可执行文件的位置. whereis 查看文件的位置. locate 配合数据库查看文件 ...
- Twig---for循环
如何使用twig做for循环. Twig中文文档: https://www.kancloud.cn/yunye/twig-cn/159620 {% for item in list %} <li ...
- 【2】static 、construct
[面向对象] 两个概念: 什么是类 具有一批相同属性的集合 什么是对象 特指的某一个具体的事物 [面向对象的三大特征] 1.封装 public 公共的 protected 受保护的 private 私 ...
- Educational Codeforces Round 1
598A - Tricky Sum 20171103$$ans=\frac{n(n+1)}{2} - 2\sum_{k=0}^{\left \lfloor \log_2 n \right \rf ...
- Vue.js中滚动条加载更多数据
本文章参考:http://www.cnblogs.com/ssrsblogs/p/6108423.html 分析:1.需要判断滚动条是否到底部: 需要用到DOM的三个属性值,即scrollTop.cl ...
- mysql提权常用方法。 hack某某
一般是root权限,知道mysql root权限,root账号密码 启动项提权:原理:利用高权限的root写入一个vbs脚本到启动项,再通过一些方法如ddos,社工管理员之类的方法来让服务器重启,运行 ...
- F#周报2019年第2期
新闻 Rider上的拼写助手,对未使用引用的代码分析及更多F#相关特性的更新 .NET开源革命开始 ML.NET 0.9发布记录 测试驱动的集成开发环境 Giraffe在GitHub上超过了1000个 ...
- ADB命令(全)
当熟悉Shell命令的人使用adb是没有任何难度的,因为adb中绝大多少命令都是引用的shell命令 以下命令进行归类,红色部分字体是测试人员常用的adb命令 基础命令 1.启动adb服务 adb s ...
- RoR- Database setup& SQLite ... Migrations
*rails uses SQLite for database by default *Built-in command-line DB viewer *Self-contained,server-l ...
- ext.js的mvc开发模式详解
ext.js的mvc开发模式详解和环境配置 在JS的开发过程中,大规模的JS脚本难以组织和维护,这一直是困扰前端开发人员的头等问题.Extjs为了解决这种问题,在Extjs 4.x版本中引入了MVC开 ...