BIOS备忘录之ASL code常用知识点
_HID:device唯一
_STA:决定device在不在(在DM下面能不能看到)
_CRS:描述分配给device的资源
_INI:在OSPM加载描述表的时候运行一次(比如,如果要根据不同情况给device赋值不同的_HID,可以把代码加在这里)
BIOS code与ASL code之间传递数据
通过ASL code定义的OperationRegion,OperationRegion实例:

1. BIOS code里面定义了一个结构体,ASL code里面定义了一个OperationRegion,两者的数据元素定义是一一对应的;

2. BIOS初始化的时候会初始化结构体(初值的来源:通过PCD设置 / 在code里面设置 / 在setup page里面设置)并把它存放到EfiACPIMemoryNVS 空间:

3. ASL code访问对应的数据元素就能获取BIOS code里面传过来的数据
EC与EC ASL code之间传递数据
1. EC ASL code里面定义OperationRegion:

EC ASL code的OperationRegion的数据元素定义与EC code(EC RAM Space)里面的定义要一一对应(如下:在OS下通过EC tool查看EC RAM 400的空间与用RW查看EC空间(62/66)看到的内容是一样的)

2. EC的ASL code申请资源:

通过上面的资源申请,OSPM就知道要通过62/66来访问EC RAM SPACE的数据(port66就是EC_SC,port62就是EC_DATA):
下面的code获取EC RAM SPACE offset02的值(OSPM实际上也就是通过如下的操作来获取整个EC RAM SPACE的):

 offset A9的位置写0x01


Q event
首先硬件上EC_SCI# 信号要连接到PCH(下图初始化代码表示使用的是PCH的GPP_E16)

当有Q event的事件发生时,EC通过WriteSCI_Buffer(QValue)把事件对应的Q event值汇报给OSPM,然后由OSPM调用对应的Method(_Qxx)
device与driver
下图定义了一个最简单的device,driver通过匹配"ZHUH1000"就能安装

如何判断driver是否被加载?
在device的_DSM里面写某个值,EC看到这个值就知道这个device的driver被安装了。
ASL code的debug
安装Windows SDK,debug工具位于:/C/program files(x86)/windows kits/10/debugger/平台/windbg.exe
具体操作参考:BIOS之通过Windbg来追踪ASL code的运行
WMI
参考BIOS大神的文章:[原创]BIOS知识点滴Follow Bini系列之---WMI ACPI :http://www.ufoit.com/thread-420-1-1.html
_HID:PNP0C14
_WDG:包含对xx的定义
_WQxx:MOF data,包含class的定义,这些二进制数据一般是build的时候生成的
_WMxx:Method
OS下调用WMI method的脚本:.vbs 下图显示的脚本会调用method WMGF,参数为196863(通常来说method会通过触发SMI来调用BIOS)

G Event
The ACPI event programming mode is based on the SCI interrupt and General-Purpose Event(GPE) register.
比如定义USB20/USB30 port支持唤醒系统:定义_PRW;下图定义了USB20/USB30 port对应的L Event number以及支持唤醒的sleep state


下图显示的是在Scope(\_GPE)里面定义的处理L Event的method(2表示唤醒系统)

关于Notify通知值的说明:

D3

设置device支持在S0 idle时进D3(前提是device支持D3)

USB Setting(_UPC _PLD)
...待...
UCSI



ASL code里面定义的Operation Region:(EC里面也定义了相同的数据结构)

调节LCD亮度 _BCL _BCM
_BCL:支持的亮度控制等级
_BCM:设置亮度等级,如果实现了_BCL,那么_BCM必须也要实现
问题举例:OS下切换最亮与次亮的时候闪屏(其他亮度之间切换没问题)
验证:切到最亮的时候不让level达到100(把_BCL的最高值100改成99),没复制到闪屏
BIOS备忘录之ASL code常用知识点的更多相关文章
- 装机备忘录:VS Code 常用插件
		
VS Code 常用插件推荐 1.基本的代码补全 2.git 扩展工具,可以看到代码的每一行 是谁修改?什么时候修改? 修改的版本号? 修改的注释? 非常好的一个工具 3.括号颜色改变工具,可以改变括 ...
 - BIOS备忘录之IIC(touchpad)设备
		
简述BIOS中对IIC device的支持,以touchpad为例. 信息收集 收集平台的硬件信息: 1. IIC controller number(PCH一般包含多个controller,我们使用 ...
 - BIOS备忘录之EC常用知识点
		
BIOS工程师眼中常用的EC知识点汇总: EC的硬件架构 EC硬件结构上主要分为两部分:Host Domain和EC Domain Host Domain就是通过LPC与CPU通信的部分(LPC部分需 ...
 - BIOS备忘录之通过Windbg来追踪ASL code的运行
		
通过Windbg来追踪ASL code的运行: 目标机的配置: 第一步: 在BIOS Setup下面 disable secure boot(不然下面debug on 命令会失败):关闭防火墙. 第二 ...
 - HTML常用知识点代码演示
		
1 HTML部分常用知识点 <!-- 版本声明 --> <!DOCTYPE html> <!-- 唯一根元素 --> <html> <!-- 对网 ...
 - javaScript常用知识点有哪些
		
javaScript常用知识点有哪些 一.总结 一句话总结:int = ~~myVar, // to integer | 是二进制或, x|0 永远等于x:^为异或,同0异1,所以 x^0 还是永远等 ...
 - DB2_SQL_常用知识点&实践
		
DB2_SQL_常用知识点&实践 一.删除表中的数据(delete或truncate) 1 truncate table T_USER immediate; 说明:Truncate是一个能够快 ...
 - vscode: Visual Studio Code 常用快捷键
		
vscode: Visual Studio Code 常用快捷键 主命令框 F1 或 Ctrl+Shift+P: 打开命令面板.在打开的输入框内,可以输入任何命令,例如: 按一下 Backspace ...
 - 【转】vscode: Visual Studio Code 常用快捷键
		
原文链接:https://www.cnblogs.com/bindong/p/6045957.html vscode: Visual Studio Code 常用快捷键 主命令框 F1 或 Ctrl+ ...
 
随机推荐
- springboot源码解读01
			
package org.springframework.web; @javax.servlet.annotation.HandlesTypes({org.springframework.web.Web ...
 - codechef cook 103  div2
			
第一次打codechef...不太会用这oj. A: #include <bits/stdc++.h> #define mk(a,b) make_pair(a,b) #define pii ...
 - 配置sudo日志审计
			
1.检查sudo与syslog服务 centos [root@xiaoyuer ~]# rpm -qa|grep sudo sudo-1.8.6p3-24.el6.x86_64 [root@xiaoy ...
 - Python学习之旅(二十)
			
Python基础知识(19):面向对象高级编程(Ⅱ) 定制类 形如“__xx__”的变量或函数在Python中是有特殊用途的 1.__str__ 让打印出来的结果更好看 __str__:面向用户:__ ...
 - python全栈开发   *   30知识点汇总   *    180713
			
30 re模块2一.正则表达式在线测试 在线测试工具 http://tool.chinaz.com/regex/(一).*?的用法: . 是任意字符 * 是取 0 至 无限长度 ? 是非贪婪模式.合在 ...
 - linux--python虚拟环境篇
			
python的虚拟环境 首先我们得知道为什么要要用虚拟环境? 在使用python开发过程中,各种业务需求多了,导致工程任务多了,难免会碰到不同的工程依赖不同版本库的问题,;或者是在开发的时候不想让物理 ...
 - EF Unknown column 'Project1.FamilyMembers_ID' in 'field list'
			
产生成的查询语句中有:Project1.FamilyMembers_ID 字段 原因:就是对象主键对象中有一个属性!
 - ASP.NET Core 集成测试中通过 Serilog 向控制台输出日志
			
日志是程序员的雷达,不仅在生产环境中需要,在集成测试环境中也需要,可以在持续集成失败后帮助定位问题.与生产环境不同,在集成测试环境中使用控制台输出日志更方便,这样可以通过持续集成 runner 执行 ...
 - C++ 在继承中虚函数、纯虚函数、普通函数,三者的区别
			
1.虚函数(impure virtual) C++的虚函数主要作用是“运行时多态”,父类中提供虚函数的实现,为子类提供默认的函数实现. 子类可以重写父类的虚函数实现子类的特殊化. 如下就是一个父类中的 ...
 - postman进行接口测试
			
1.添加header 2.入参为json格式 3.添加cookie 4.上传文件