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+ ...
随机推荐
- Golang 笔记 4 defer、error、panic
一.defer语句 defer语句仅能被放置在函数或方法中.它由关键字defer和一个调用表达式组成.这里的表达式所表示的既不能是对Go语言内建函数的调用也不能是对Go语言标准库代码包unsafe中的 ...
- 【Zookeeper系列】ZooKeeper安装配置(转)
原文链接:https://www.cnblogs.com/sunddenly/p/4018459.html 一.Zookeeper的搭建方式 Zookeeper安装方式有三种,单机模式和集群模式以及伪 ...
- 关于JAVA项目中的常用的异常处理
一.简介(摘自百度百科) 异常处理,是编程语言或计算机硬件里的一种机制,用于处理软件或信息系统中出现的异常状况(即超出程序正常执行流程的某些特殊条件). 异常有以下的一些特点: (1)偶然性.程序运行 ...
- Express中间件的原理及实现
在Node开发中免不了要使用框架,比如express.koa.koa2拿使用的最多的express来举例子开发中肯定会用到很多类似于下面的这种代码 var express = require('exp ...
- 微信小程序时间戳的转换及调用
13位 的时间戳,如下图: 效果图: 1.(utils.js里面的代码): function formatTime(timestamp, format) { const formateArr = [' ...
- vue2.0 vs vue
vue2.0相比vue1.0 有哪些改变,今天总结了一下 vue2.0组件中 template 不在支持代码片段 //vue1.0组件中template写法 <template> < ...
- Java 实现 AES 加解密
毕业课题中需要使用加解密算法,要求加解密前后的数据长度不会变化,查了一些资料,发现可以采用AES加密的CFB跟OFB模式是无填充的模式,可以保持加解密前后数据的长度相等.下面上代码: import j ...
- Android开发入门经典【申明:来源于网络】
Android开发入门经典[申明:来源于网络] 地址:http://wenku.baidu.com/view/6e7634050740be1e650e9a7b.html?re=view
- svn和NetBeans一起使用造成svn老是死锁, database is locked
其实我一直没发现,又一次我以为需要写些前端吧NetBeans关了,使用HBuilder写vue,因为内存只有8G,乱七八糟的一些东西一开,只剩20%左右,我就把 NetBeans关了,发现更新svn的 ...
- [httpd] httpd server 在低负载的情况下对SYN无响应
如题: 两台client通过load balance访问httpd server.两个client交互访问.load balance处于fullnat模式. server在低负载情况下,常常对某一个c ...