_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常用知识点的更多相关文章

  1. 装机备忘录:VS Code 常用插件

    VS Code 常用插件推荐 1.基本的代码补全 2.git 扩展工具,可以看到代码的每一行 是谁修改?什么时候修改? 修改的版本号? 修改的注释? 非常好的一个工具 3.括号颜色改变工具,可以改变括 ...

  2. BIOS备忘录之IIC(touchpad)设备

    简述BIOS中对IIC device的支持,以touchpad为例. 信息收集 收集平台的硬件信息: 1. IIC controller number(PCH一般包含多个controller,我们使用 ...

  3. BIOS备忘录之EC常用知识点

    BIOS工程师眼中常用的EC知识点汇总: EC的硬件架构 EC硬件结构上主要分为两部分:Host Domain和EC Domain Host Domain就是通过LPC与CPU通信的部分(LPC部分需 ...

  4. BIOS备忘录之通过Windbg来追踪ASL code的运行

    通过Windbg来追踪ASL code的运行: 目标机的配置: 第一步: 在BIOS Setup下面 disable secure boot(不然下面debug on 命令会失败):关闭防火墙. 第二 ...

  5. HTML常用知识点代码演示

    1 HTML部分常用知识点 <!-- 版本声明 --> <!DOCTYPE html> <!-- 唯一根元素 --> <html> <!-- 对网 ...

  6. javaScript常用知识点有哪些

    javaScript常用知识点有哪些 一.总结 一句话总结:int = ~~myVar, // to integer | 是二进制或, x|0 永远等于x:^为异或,同0异1,所以 x^0 还是永远等 ...

  7. DB2_SQL_常用知识点&实践

    DB2_SQL_常用知识点&实践 一.删除表中的数据(delete或truncate) 1 truncate table T_USER immediate; 说明:Truncate是一个能够快 ...

  8. vscode: Visual Studio Code 常用快捷键

    vscode: Visual Studio Code 常用快捷键 主命令框 F1 或 Ctrl+Shift+P: 打开命令面板.在打开的输入框内,可以输入任何命令,例如: 按一下 Backspace ...

  9. 【转】vscode: Visual Studio Code 常用快捷键

    原文链接:https://www.cnblogs.com/bindong/p/6045957.html vscode: Visual Studio Code 常用快捷键 主命令框 F1 或 Ctrl+ ...

随机推荐

  1. [Vue warn]: Attribute "id" is ignored on component <div> because the component is a fragment instanc

    今天在使用vue框架搭建环境时,遇到这个错误提示: [Vue warn]: Attribute "id" is ignored on component <div> b ...

  2. linux 使用不安全的sprintf函数,存储字符越界导致程序莫名崩溃问题

    linux c++编程 问题背景: 在处理一个公共模块的代码中,其中有以下代码片段 //代码片段-组合一组字符串并存放到szSignKey数组中 ] = {}; sprintf(szSignKey, ...

  3. C# windows GDI+仿画图 绘图程序设计

    C# windows GDI+仿画图 绘图程序设计 1.介绍 这里分享一个简单的画图程序 原作者:author: ping3108@163.com 2.程序主窗体设计 3.程序设计 本程序工程使用VS ...

  4. 2018年总结&2019年计划

    今天加了来自博客园的好友,才意识到博客已经荒废了许久.其实自己最近也是考虑了总结一下这个繁忙的2018. 2019计划: . 多给家里通电话: . 关心照顾好小奶糖: . 多读书,非小说: . 坚持吃 ...

  5. 深度学习入门之Mnist

    参看Deep learning from scratch,学习到反向传播网络后,把网络调通了,但是训练后损失函数减小,准确率没有变化,和瞎猜一样,是为什么呢?只有在看看各层缺少什么,关键是我的参数和书 ...

  6. python和计算机的交互

    网易邮箱都2万+满了,但是只有手动删除.实在太多,于是想使用python脚本实现,python有很多现成的库可以使用,这就是python的好处,而不是c++或者java,python的库说明网站:ht ...

  7. oracle ORA-01991错误--重建密码文件问题

    问题现象描述: 统计服务器测试没问题,刚好上次配置系统的时候有点问题,故重装一次,配置好安全策略(最近在研究如何新配置一台服务器的时候,第一时间配置好相关的安全设置,有空再写下来). 为了省事,直接冷 ...

  8. Radar Installation---(贪心)

    Radar Installation Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 115873   Accepted: 2 ...

  9. Spring-Boot之Redis基础

    Spring-Boot之Redis基础 准备 Redis下载地址:github.com/MSOpenTech/redis/releases Redis数据库的默认端口号是 6379 开启Redis服务 ...

  10. mui 窗口管理及窗口之间的数据传递

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta name ...