EC热键问题

ec

问题描述

系统无触摸板打开和关闭的提示

已知热键功能

快捷键 功能
Fn+F1 亮度-
Fn+F2 亮度+
Fn+F3 显示模式切换(扩展、复制等)
Fn+F4 静音
Fn+F5 音量-
Fn+F6 音量+
Fn+F7 触摸板开关

ACPI事件监控

 sudo apt-get install acpid
sudo systemctl start acpid
sudo acpi_listen

Fn+F1\F2\F4\F5\F6可以监控到acpi事件,Fn+F3\F7不行,其中F3 GUI正常F7功能正常


acpi_listen

按键监控

sudo showkey

Fn+F1\F2\F3\F4\F5\F6可以监控到按键事件,Fn+F7不行


showkey

UDEV事件监控

sudo udevadm monitor --environment --udev

Fn+F1\F2可以监控到UDEV事件,显示器属于udev设备?


udevadm

kprobe探测


初步总结热键功能流程

这里面还有很多疑问,但不管怎样Fn+F7未监控到按键事件是不正常的。

目前EC BIOS ACPI 之间的传递关系还比较模糊.

EC热键是指在笔记本电脑中通过按下特定的键组合来触发某些特殊操作的功能。在Linux系统中,EC热键事件的通知和处理涉及多个组件之间的交互。下面是这些组件之间的传递过程:

EC芯片:当按下EC热键时,电路会将响应的信号发送到嵌在主板上的EC芯片。

BIOS:EC芯片已按下的EC热键信号将会被传递给BIOS,BIOS会将EC热键转换为ACPI事件。

ACPI:在Linux系统中,BIOS已转换的ACPI事件将由ACPI守护进程读取并通知内核,以保证它们被正常捕获。

事件生成器:一旦收到ACPI事件,事件生成器将生成input_event(输入事件)并将其传递给内核。

内核输入子系统:接下来,Linux内核将将input_event发送到输入子系统,该子系统负责跟踪和处理所有输入事件。

输入设备驱动程序:当ACPI事件进入输入子系统时,输入设备驱动程序将使用内核标准input_event接口处理输入操作。

udev:udev是一个动态设备管理器,为所有新发现的输入设备生成单个设备节点。其他进程可以使用此节点上的数据来检测输入事件并采取适当的操作。

综上所述,EC热键事件在Linux系统中的处理涉及多个组件之间的协作和传递,包括EC芯片、BIOS、ACPI、事件生成器、内核输入子系统、输入设备驱动程序和udev。这些组件通过一系列传递步骤来捕获和处理EC热键事件,并使其可供Linux系统中的其他进程使用。

ACPI BIOS、CPU和其他系统硬件之间的连接关系可以以下方式进行物理描述:

  1. ACPI BIOS和CPU:ACPI BIOS是位于计机主板上一个集成电路,它将作为计算机主要处理器的CPU通过北芯片(North chip)连接到主板上。ACPI BIOS作为集成电路上的一部分负责在系统启动时检测、配置和管理所有硬件资源。
  2. Northbridge和:Northbridge芯片是连接CPU和系统内存及其他硬件的中介芯片。它提供了一些与CPU通信的基本功能,例如数据和控制信号的传递、扩展内存寻址等。
  3. Southbridge和Northbridge:Southbridge芯片通常与Northbridge芯片一起安装在计算机主板上,并通过高速总线连接。南桥芯片通常负责与所有其他系统组件交互,例如硬盘驱动器、光驱、USB、PCI等输入/输出接口。
  4. Southbridge和BIOS:Southbridge芯片还将与BIOS进行通信,使BIOS能够监测和管理设备资源并接收ACPI事件通知。同时,它还处理与系统内存、磁盘存储器、网络连接、声音和视频资源相关的数据传输。

    总之,ACPI BIOS、CPU、Northbridge和Southbridge芯片之间具有物理连接关系。ACPI BIOS作为主板上的电路板负责管理和协调CPU和其他系统资源。Northbridge芯片负责连接CPU和系统内存及其他硬件,而南桥芯片则负责与所有其他系统组件交互,例如硬盘驱动器、光驱和输入/输出接口。同时,Southbridge还将与BIOS和其他硬件设备进行通信,使计算机系统能够平稳运转。

调试记录


Fn+F6

F7

Fn+F7无任何输出.

Fn+F7时kprobe发现 atkbd_interrupt和i8042_interrupt函数并未被调用。

观察i8042中断计数,Fn+F7中断计数未增加。

Fn+F6则有中断计数的增加以及中断处理函数的调用.


i8042中断信息

lpc物理中断号

i8042物理中断号为37属于LPC中断,因此该问题本质是EC未上报中断.

目前怀疑EC固件直接处理了Fn+F7功能,因此并未上报中断给CPU,导致系统层未收到相关信号(值得说明的是飞腾EC描述手册中写到EC不做按键的功能处理)


飞腾EC接口规范

PS2

1、PS2协议:

PS2有两个控制线,时钟线和数据线。 当按键按下或抬起,设备会向主机发送键码。 时钟由设备产生,主机需要在下降沿去数据线采集一位数据。 按键码由多个11位数据组成:0 (起始)+ 8位(数据)+1/0(奇偶校验位)+1(结束位)。 数据位是先发的低位!

PS2接口是以前台式电脑后边留的圆形接口,6个引脚,主要用VCC,GND,clk,data。 与AT(5脚)一样

2、键码:

PS2键码大致分为两类:

第1类按键 通码为一个字节,断码为0xF0+通码形式。 如A键,其通码为0x1C; 断码为0xF0 0x1C。

第2类按键 通码为两字节0xE0+0xXX形式,断码为0xE0+0xF0+0xXX形式。 如Right Ctrl键,其通码为0xE0 0x14; 断码为0xE0 0xF0 0x14。

通码为按下,段码为抬起

3、input 子系统下的PS2键盘驱动(因为没有驱动器,没有使用这个框架):

1,Linux X86 PS/2 键盘驱动框架流程(以下均已Intel 8042键盘控制器为例):

1.1 设备初始化注册流程:

键盘控制器硬件驱动(i8042.c) -> 串口驱动核心(serio.c) -> 串口驱动(atkbd.c)

-> 输入驱动核心(input.c) -> 输入事件驱动程序(keyboard.c) -> 虚拟控制台驱动模块;

注册流程:

1.1.1,键盘控制器硬件驱动(i8042.c):

1)、首先键盘硬件驱动程序读写键盘硬件控制器寄存器,配置寄存器并获取相控制器硬件信息(PS/2键盘控制器一共有三个寄存器加一个命令端口,命令数量也不多,下载地址:https://download.csdn.net/download/a372048518/9835565)

注意:Intel8042键盘控制器内部已经实现了PS/2时序协议,硬件驱动程序只需要读写相关寄存器即可;

2)、将8042键盘控制器作为平台设备(struct platform_device)挂接在平台总线(struct bus_type)上,并将获取到的硬件信息及相关软件数据结构信息保存在平台设备实例中;

3)、将8042键盘硬件控制器驱动(struct platform_driver)注册到平台总线上,平台总线匹配平台设备和平台驱动,并调用平台驱动的probe方法,在probe方法中分配并初始化串口数据结构实例(struct serio),将平台设备信息放入串口数据结构实例中; 最后将串口结构实例注册进入串口驱动核心(serio_register_port);

1.1.2,串口驱动核心(serio.c)

串口驱动核心负责匹配串口和串口驱动,匹配之后,调用串口驱动的atkbd_connect方法;

1.1.2,PS/2键盘串口驱动(atkbd.c)

将串口驱动(struct serio_driver)注册到串口核心并匹配到串口设备之后,调用串口驱动的atkbd_connect方法,在atkbd_connect方法中分配并初始化输入设备(struct input_ dev),最后将输入设备注册到输入子系统核心;

1.1.3, 输入驱动核心(input.c)

输入子系统请移步:输入子系统介绍https://blog.csdn.net/a372048518/article/details/71055147

1.1.4,输入事件驱动程序( keyboard.c)

键盘输入事件驱动程序负责处理键盘输入设备上报的键盘输入事件信息,并将信息传递给虚拟控制台模块;

1.2 设备中断流程:

8042硬件中断(i8042_interrupt) -> 串口核心中断(serio_interrupt) -> 串口驱动中断(atkbd_interrupt) -> 输入子系统核心中断(input_event) -> 输入时间驱动程序中断(kbd_event)

资料来源:gpio模拟ps2

EC热键问题的更多相关文章

  1. 数字麦克风PDM信号采集与STM32 I2S接口应用(三)

    本文是数字麦克风笔记文章的数据处理篇. 读取数字麦克风的信号,需要嵌入式驱动和PC应用的结合,驱动负责信号采集,应用代码负责声音分析. 一般而言,在完成特征分析和实验之后,把优化过的代码固化到嵌入式端 ...

  2. C# 注册 Windows 热键

    闲扯: 前几日,一个朋友问我如何实现按 F1 键实现粘贴(Ctrl+V)功能,百度了一个方法,发给他,他看不懂(已经是 Boss 的曾经的码农),我就做了个Demo给他参考.今日得空,将 Demo 整 ...

  3. EC笔记:第4部分:22、所有成员都应该是private的

    EC笔记:第4部分:22.所有成员都应该是private的 更简单的访问 用户不用记得什么时候该带上括号,什么时候不用带上括号(因为很确定的就要带上括号) 访问限制 对于public的成员变量,我们可 ...

  4. EC笔记:第二部分:12、复制对象时勿忘其每一个成分

    EC笔记:第二部分:12.复制对象时勿忘其每一个成分 1.场景 某些时候,我们不想使用编译器提供的默认拷贝函数(包括拷贝构造函数和赋值运算符),考虑以下类定义: 代码1: class Point{ p ...

  5. 设计winform自带动态加载工具按钮和实现热键响应

    1.初衷 主要是想设计一个自带添加工具按钮和按钮的快捷键的基窗体.这样以后所设计的窗体只要继承自这个窗体就可以实现热键响应和动态加工具按钮的功能了 写这边文章主要是为了以后使用的时候有个参考,因为这只 ...

  6. <转>MFC注册系统/全局热键。

    <转>MFC注册系统/全局热键. 1. BEGIN_MESSAGE_MAP(CRS232TESTDlg, CDialog) //{{AFX_MSG_MAP(CRS232TESTDlg) O ...

  7. 零配置Socket TCP消息通讯服务容器EC

    EC全称是elastic communication,是基于c#实现的Socket网络通讯服务容器,支持windows .Net和mono.通过EC容器可以让开发人员在不了解Socket网络通讯知识和 ...

  8. Java 上传文件到 SFTP 抛异常 java.lang.NoClassDefFoundError: Could not initialize class sun.security.ec.SunEC 的解决办法

    最近从 Op 那里报来一个问题,说是SFTP上传文件不成功.拿到的 Exception 如下: Caused by: java.lang.NoClassDefFoundError: Could not ...

  9. Linux常用热键(持续更新)

    (这些文章都是从我的个人主页上粘贴过来的,大家也可以访问我的主页 www.iwangzheng.com) --圣诞节怎么过, --略过. 今天装ubuntu的时候把windows覆盖了, 凌乱,TX童 ...

  10. 第三篇T语言热键启动方法

    热键控件 热键控件的使用方法 第一步:选择热键添加到面板上. 第二步:热键控件属性选择热键键值. 第三步:添加热键事件功能. 热键模式的选择 1.普通模式 2.软件模式 3.硬件模式 脚本的基本操作 ...

随机推荐

  1. ABAP CDS 在7.55有比较大的更新

    几年前翻译过CDS的相关文章,部分内容已经过时,比如当时的DDIC CDS在7.55以后已经沦为obsolete,在新版本中,开发者应使用DEFINE VIEW ENTITY而非DEFINE VIEW ...

  2. 关于QQ群炸了的说明

    ABAP 7.5学习群不幸被腾讯封了,想要聊天的群友可以加以下两个群, ABAP 7.5历史研究小组 728466742 ABAP 7.5 备份群 582240105

  3. Linux中的cp命令

    Linux中cp命令用来赋值文件或者目录,其常用的命令选项如下: 下面是cp命令的一些使用示例: 默认情况下,cp命令赋值出来的权限或者属性通常来源自操作者本身.比如上面在root身份在执行cp命令, ...

  4. 暴力破解(Pikachu)

    暴力破解(Pikachu靶场) Burpsuite4种攻击类型 Sinper(狙击手): 可以理解为一个一个爆破,也就是字典只能设置一个,然后用字典替换选择的参数,爆破完一个参数后再爆破另一个参数. ...

  5. 网络性能监测与诊断的专家-AnaTraf

    网络性能问题是困扰许多企业和组织的常见问题.网络速度慢.延迟高.丢包率高.应用卡顿等问题都会严重影响用户体验和工作效率.为了解决这些问题,企业需要对网络流量进行分析和诊断,找出问题根源并采取措施进行优 ...

  6. Python读Excel数据自动化填入日常办公的网页表单

      前言 本篇内容,让你完全掌握Python是如何自动化办公的~ 一.环境准备 1.1  Python 3.7.0 1.2  Pycharm  (Python 开发工具) 1.3 Selenium  ...

  7. 将大量文件的拓展名中大写字母改为小写:Python实现

      本文介绍基于Python语言,基于一个大文件夹,遍历其中的多个子文件夹,对于每一个子文件夹中的大量文件,批量将其文件的名称或后缀名中的字母由大写修改为小写的方法.   本文期望实现的需求为:现有一 ...

  8. vue-cli 中使用 Axios

    安装 axios: 1 npm install axios --save-dev 接着在src目录下创建一个http.js脚本中,导入axios并通过create方法实例化一个http请求对象,这样我 ...

  9. .NET桌面程序混合开发之四:键盘事件的响应

    1. 问题 在生产环境中,有一些场景需要窗体来响应键盘事件(注意,是窗体响应,而不是窗体上的控件响应),如解析扫码枪的扫描结果.但在嵌入WebView2的Form程序,Host Form无法对键盘事件 ...

  10. 基于FPGA的计算器设计---第一版

    欢迎各位朋友关注"郝旭帅电子设计团队",本篇为各位朋友介绍基于FPGA的计算器设计---第一版. 功能说明: 1. 计算器的显示屏幕为数码管. 2. 4x4矩阵键盘作为计算器的输入 ...