【openwrt学习笔记】Dying Gasp功能和pstore功能的配置(高通 ipq95xx)

news2024/11/8 3:17:18

目录

    • 一、Dying Gasp信号
      • 1.1 概念
      • 1.2 实现原理
    • 二、pstore 功能
      • 2.1 概念
      • 2.2 实现原理
    • 三、openwrt中开启pstore功能
      • 3.1 软硬件参数
      • 3.2 各文件修改
        • 3.2.1 defconfig
        • 3.2.2 dts(ipq9574-default-memory.dtsi)
        • 3.2.3 fs/pstore/ram.c
    • 四、测试
      • 4.1 挂载
      • 4.2 触发命令和效果

参考资料:
ADSL的Dying gasp作用
Linux pstore 实现自动“抓捕”内核崩溃日志
Android7.1 RK3399 使用 ramoops 机制查看开机 Kernel Log
Pstore 的一些记录
pstore 工具配置及使用
pstore
The test I have done to pstore/blk

一、Dying Gasp信号

1.1 概念

Dying Gasp(临终之息)是一种通信技术术语,主要用于宽带通信(如DSL,数字用户线路)中。当通信设备(如DSL调制解调器)遇到电源中断或故障时,Dying Gasp信号被发送出去,以通知服务提供商关于这个问题。这个信号可以视为设备的最后一次尝试,表明其即将失去连接或停止工作。

Dying Gasp信号的目的是允许网络运营商和服务提供商快速识别问题,从而更有效地处理故障和提高用户满意度。这个信号有助于避免长时间的故障检测和定位过程,加速恢复服务。

通常,Dying Gasp信号在以下情况下触发:
电源中断:例如,在电力故障、设备过热或设备故障等情况下,设备可能会突然关闭,发送Dying Gasp信号。
硬件故障:例如,当设备内部硬件出现故障,如电源供应器或其他关键组件损坏时,设备可能会发送Dying Gasp信号。

1.2 实现原理

芯片厂商在设计芯片的时候会设计一个Dying gasp 性能模块在芯片内。此模块通过监测外部输入电压来实现Dying gasp功能。
因为为使得此功能能正常使用的前提是芯片必须还能正常工作,并且要向头端发送一定时间长度的信号,所以在论坛定义的Dying gasp信号有效时间内,供芯片正常工作的各种电源的电压不能小于此芯片规格书所描述的最小工作电压。
也就是说,监测点开始启动的电压与芯片各工作电压之差不能小于法定Dying gasp信号时间长度。
Dying Gasp顾名思义 - “死前喘口气”,利用最后存储的一点电能让CPE把最后的状态信息发送出去。 包括两个部分的电路:
1、 大电容储能,当外部输入电源掉电时,存储在大电容中的电能释放能量供整个核心电路再工作需要的喘口气的时间,一般几个ms。电路很简单 - 二极管 大电容(电解的,容量取决于电路板的功耗以及能够正常整流稳压的电压范围) 电压比较器。
2 、ADSL的主芯片有一个输入管脚检测电压比较器的输出电平,一旦触发就可以发出中断信号让系统进入“留遗嘱”状态。

二、pstore 功能

2.1 概念

pstore是persistent storage的缩写。内核发生异常时如果能将日志等信息保存下来不丢失,那么就可以通过这些信息来定位问题。
不同的平台可以提供的存储位置不同,例如有些平台支持硬盘,有些不支持。除了平台差异,异常类型也决定了在发生异常时该存储位置是否还可用。
pstore 的目标是提供一套通用的接口用来存储异常信息。pstore以文件系统的形式提供用户空间接口,可以通过mount命令挂载到指定目录下边,如xxx\pstore,那么保存的信息将以文件的形式出现在该目录下,可以使用文件读操作获取调试信息,通过删除操作清除调试信息。

pstore 在内核中的开关是 CONFIG_PSTORE,pstore 提供的是一套可扩展的机制,提供如下类型:

PSTORE_TYPE_DMESG, 表示内核日志
PSTORE_TYPE_MCE, 表示硬件错误
PSTORE_TYPE_CONSOLE, 表示控制台输出,所有内核信息。
PSTORE_TYPE_FTRACE, 表示函数调用序列, ftrace 信息。

ramoops 指的是采用 ram 保存 oops 信息的一个功能,这个功能从 3.10.40 开始采用 pstore 机制来实现,内核中的开关控制:

PSTORE_PMSG,用户空间信息,/dev/pmsg0,pmsg-ramoops-
PSTORE_CONSOLE,控制台输出,所有内核信息,console-ramoops-
PSTORE_FTRACE,函数调用序列, ftrace 信息。
PSTORE_RAM, panic/oops 信息

2.2 实现原理

pstore是Linux内核中的一个功能,它允许在系统崩溃、重启或关机后,保存和检查内核日志和其他相关信息。以下是pstore功能的一些基本实现原理:

  1. 持久存储:pstore使用持久存储(例如NVRAM,非易失性随机存取内存)或者保留区域(例如RAM的特定区域)来存储信息。这些存储区域在系统重启或关机后不会被清除。

  2. 日志和崩溃转储:当系统崩溃,或者由于某些原因,内核需要保存状态信息时,会将这些信息(例如panic信息,oops信息,console日志等)保存到pstore中。

  3. 内核接口:内核提供了一套接口(pstore API),允许内核的其他部分将信息写入到pstore中。

  4. 用户空间访问:在系统重启后,用户空间的程序(例如systemd-journald,kdump等)可以通过文件系统接口(例如/sys/fs/pstore)来访问pstore中的信息,以进行进一步的分析和处理。

三、openwrt中开启pstore功能

3.1 软硬件参数

openwrt版本19.07,但是很多软件包都进行了升级,这个影响不大。芯片是高通ipq9574,比较新的芯片,内核版本5.4。大致了解一下,开整。

root@405BE:/# ubus call system board
{
        "kernel": "5.4.164",
        "hostname": "*******",
        "model": "****/REV0",
        "board_name": "qcom,ipq9574*****",
        "release": {
                "distribution": "OpenWrt",
                "version": "19.07-SNAPSHOT",
                "revision": "r0-6ff4ad7",
                "target": "ipq95xx/generic",
                "description": "OpenWrt 19.07-SNAPSHOT r0-6ff4ad7"
        }
}

3.2 各文件修改

3.2.1 defconfig

新增下列config配置:

CONFIG_PSTORE=y
# CONFIG_PSTORE_DEFLATE_COMPRESS is not set
# CONFIG_PSTORE_LZO_COMPRESS is not set
# CONFIG_PSTORE_LZ4_COMPRESS is not set
# CONFIG_PSTORE_LZ4HC_COMPRESS is not set
# CONFIG_PSTORE_842_COMPRESS is not set
# CONFIG_PSTORE_ZSTD_COMPRESS is not set
CONFIG_PSTORE_CONSOLE=y
CONFIG_PSTORE_PMSG=y
CONFIG_PSTORE_RAM=y

注释:若存储空间比较有限,可以将pstore的内容压缩后再保存到backend设备上,相应的压缩算法可以通过配置选项CONFIG_PSTORE_COMPRESS_DEFAULT或模块参数compress指定。上述注释掉的内容就是相关压缩算法,这里暂时不用。

3.2.2 dts(ipq9574-default-memory.dtsi)

高通提供此文件,直接新增就行,文件中有内存信息。

	/*		  Default Profile
	 * +=========+==============+========================+
	 * |        |              |                         |
	 * | Region | Start Offset |          Size           |
	 * |        |              |                         |
	 * +--------+--------------+-------------------------+
	 * |        |              |                         |
	 * |        |              |                         |
	 * |        |              |                         |
	 * |        |              |                         |
	 * | Linux  |  0x42000000  |         123MB           |
	 * |        |              |                         |
	 * |        |              |                         |
	 * |        |              |                         |
	 * +--------+--------------+-------------------------+
	 * |        |              |                         |
	 * |        |              |                         |
	 * | TZ App |  0x49B00000  |           6MB           |
	 * |        |              |                         |
	 * |        |              |                         |
	 * +--------+--------------+-------------------------+
	 * |        |              |                         |
	 * | uboot  |  0x4A100000  |           4MB           |
	 * |        |              |                         |
	 * +--------+--------------+-------------------------+
	 * |  SBL   |  0x4A500000  |           1MB           |
	 * +--------+--------------+-------------------------+
	 * |        |              |                         |
	 * | TZ+HYP |  0x4A600000  |           4MB           |
	 * |        |              |                         |
	 * +--------+--------------+-------------------------+
	 * |  smem  |  0x4AA00000  |           1MB           |
	 * +--------+--------------+-------------------------+
	 * |        |              |                         |
	 * |        |              |                         |
	 * | WLAN   |              |                         |
	 * |   Q6   |  0x4AB00000  |          43MB           |
	 * |        |              |                         |
	 * |        |              |                         |
	 * +--------+--------------+-------------------------+
	 * | M3 Dump|  0x4D600000  |           1MB           |
	 * +--------+--------------+-------------------------+
	 * | WLAN   |              |                         |
	 * | Q6 ETR |  0x4D700000  |           1MB           |
	 * | Region |              |                         |
	 * +--------+--------------+-------------------------+
	 * | caldb  |  0x4D800000  |           5MB           |
	 * +--------+--------------+-------------------------+
	 * |        |              |                         |
	 * |  Pine0 |  0x4DD00000  |          53MB           |
	 * |        |              |                         |
	 * +--------+--------------+-------------------------+
	 * |        |              |                         |
	 * |  Pine1 |  0x51200000  |          53MB           |
	 * |        |              |                         |
	 * +--------+--------------+-------------------------+
	 * |        |              |                         |
	 * |  MHI0  |  0x54700000  |           9MB           |
	 * |        |              |                         |
	 * +--------+--------------+-------------------------+
	 * |        |              |                         |
	 * |  MHI1  |  0x55000000  |           9MB           |
	 * |        |              |                         |
	 * +=================================================+
	 * |                                                 |
	 * |                                                 |
	 * |                                                 |
	 * |            Rest of memory for Linux             |
	 * |                                                 |
	 * |                                                 |
	 * |                                                 |
	 * +=================================================+
	 */

使用此命令查看到板子里内存情况

# cat proc/iomem

在这里插入图片描述
查看上述dtsi文件,55000000 ~ 55900000 已经使用。 55900000-7fffffff可以使用,所以可以从55900000开始配置一段内存进行使用。

	rampoos_ram: ramoops_ram@55900000  {
		compatible = "ramoops_ram";
		reg = <0x0 0x55900000 0x0 0x00140000>;
	};
	
/*这是一个名为 ramoops_ram@55900000的节点,
这个节点相关的硬件设备是一个RAM-based Oops/Panic logger,它记录内核panic和oops的消息。
名称中的@55900000表示这个设备在物理地址空间中的起始地址。

下面是字段的详细解释:
compatible = "ramoops_ram";: 这个属性描述了硬件设备的类型或模型。
在这里,它的值是 ramoops_ram,表示这是一个RAM-based Oops/Panic logger。

reg = <0x0 0x55900000 0x0 0x00140000>;: reg属性通常用于描述设备在物理内存中的位置和大小。
在这里,这个设备的起始地址是0x55900000,大小为0x00140000(1.3125MB)。
第一个0x0和第三个0x0通常表示地址空间或者偏移量,在这个例子中,
它们表示该设备是在主地址空间中定义的,没有偏移。
*/
3.2.3 fs/pstore/ram.c
-static ulong ramoops_console_size = MIN_MEM_SIZE;
+static ulong ramoops_console_size = 256*1024UL;

-static unsigned long long mem_address;
+static unsigned long long mem_address = 0x55900000;

- static ulong mem_size;
+ static ulong mem_size=0x100000;

四、测试

4.1 挂载

上述修改完成后,可以进行编译固件,烧录成功后,直接使用以下命令进行挂载。

mount -t pstore pstore /sys/fs/pstore

4.2 触发命令和效果

# echo c > /proc/sysrq-trigger 

使用此命令可以触发崩溃,重启,生成console-ramoops-0和dmesg-ramoops-0两个文件。
内容大致如下,dmesg-ramoops-0,保存了崩溃时的一些打印。
在这里插入图片描述
console-ramoops-0中书崩溃重启之前,控制台的打印信息。
在这里插入图片描述

注意:只有触发内核崩溃才会有两个文件生成,如果是输入命令重启、开门狗重启、poweroff或者kill触发的重启都只会生成
console-ramoops-0的重启文件。当然,如果是直接断电重启,那么就没有文件生成。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1114704.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

cocos creator 在网页中调试的时候直接代码调试方法

cocos creator 在网页中调试的时候直接代码调试方法

数据结构───顺序表(梦开始的地方)

从一个编程小白到入门&#xff0c;大学选的软件工程&#xff0c;从大一开始就没有真正的了解这个专业&#xff0c;更别说以后的发展方向。活了几十年&#xff0c;也不知道自己究竟要成为一个什么样的人。似乎在大二的某一天&#xff0c;忽然意识到我不该如此庸碌下去&#xff0…

对话 L2 潜力新星 Mantle:模块化理念推动生态可持续建设

作为一个由 DAO 主导实现快速增长&#xff0c;致⼒推动⼤众应⽤与数字虚拟资产治理技术—— Mantle 如何凭借模块化设计理念、可扩展性技术优势、高效能数据处理机制在 Layer2 版图中成长为新晋潜力项目&#xff1f;从测试网到主网上线&#xff0c;Mantle 经历了数个技术更新阶…

【(数据结构)— 双向链表的实现】

&#xff08;数据结构&#xff09;— 双向链表的实现 一.双向链表的结构二. 双向链表的实现2.1 头文件 ——双向链表的创建及功能函数的定义2.2 源文件 ——双向链表的功能函数的实现2.3 源文件 ——双向链表功能的测试2.4 双向链表各项功能测试运行展示2.4.1 双向链表的初始化…

发现一不错的编程助手 Amazon CodeWhisperer

Amazon CodeWhisperer 是一款 AI 编程助手&#xff0c;旨在为开发人员提供智能化的编程辅助工具。作为一款基于人工智能的编程助手&#xff0c;CodeWhisperer 的目标是提高开发人员的生产效率、降低开发成本&#xff0c;并提供高质量的编程解决方案。 1.安装过程参考官网 htt…

C++11函数适配器bind() --- C++11新语法bind() 你了解多少?什么是适配器???

文章目录 1.介绍头文件定义原型 2.引入2.1现有语法无法解决2.2bind的文档阅读2.3bind()绑定函数对于2.1问题的解决 1.介绍 头文件 #include <functional> 定义 bind函数定义在头文件中&#xff0c;是一个函数模板&#xff0c;它就像一个函数包装器(适配器)&#xff0c…

苹果 AirPods Pro 2 耳机新固件(6A305)

苹果公司对采用 Lightning 端口和 USB-C 端口的 AirPods Pro 2 耳机&#xff0c;推出了内部编号为 6A305 的全新固件&#xff0c;高于 10 月 10 日发布的 6A303 更新。用户无需手动更新&#xff0c;只需将 AirPods 通过蓝牙连接到 iPhone &#xff0c;此时便会自动安装新的固件…

甄知科技张礼军:数智化转型助企业破茧成蝶!

数智化浪潮滚滚向前&#xff0c;正席卷各行各业&#xff0c;带领企业从数字化时代跨入数智化时代。可什么是数智化&#xff1f;如何实现数智化转型&#xff1f;已经成为横亘在无数企业面前的大难题&#xff01; 事实上&#xff0c;数智化是数字化、AI和业务三个要素的交集&…

SQLServe联合主键、联合索引、唯一索引,聚集索引,和非聚集索引、主键、唯一约束和外键约束、索引运算总结

联合主键 SQL server 中给表增加联合主键的两种方法 第一种方法&#xff0c;新建表时增加联合主键&#xff1a; create table t_students(id int not null,name varchar(10) not null Primary Key (id, name),age int,dept_id int )注&#xff1a;联合主键的列需要限制非空约…

操作系统【OS】系统调用

系统调用 定义 操作系统对应用程序和程序员提供的接口用户程序执行陷入指令&#xff08;Trap或访管指令&#xff09;来发起系统调用&#xff0c;请求操作系统提供服务OS 通过提供系统调用避免用户程序直接访问外设【应用程序通过系统调用使用OS的设备管理服务】操作系统不同, …

弹出框,使用树结构查询数据

效果如下: 描述:希望点击某个按钮,弹出一个窗口,然后通过下拉框,点击下拉框里面的组织信息,然后查询对应组织的成员对象列表,并展示到表格中 HTML代码(最主要的就是树的那个): <el-dialog :visible.sync="TesteePage.showDialog" width="70%&quo…

初出茅庐的小李博客之Windows11运行Linux记录

安装教程 超简单&#xff0c;不安装虚拟机&#xff0c;Windows11运行Linuxhttps://zhuanlan.zhihu.com/p/393484912 注意事项 出现错误有可能是少了驱动 驱动下载地址 https://link.zhihu.com/?targethttps%3A//wslstorestorage.blob.core.windows.net/wslblob/wsl_updat…

bp(back propagation)

文章目录 定义过程前向传播计算过程计算损失函数&#xff08;采用均方误差MSE&#xff09;反向传播误差&#xff08;链式法则&#xff09;计算梯度更新参数 简单实例 定义 反向传播全名是反向传播误差算法&#xff08;Backpropagation&#xff09;&#xff0c;是一种监督学习方…

HZOJ-271: 滑动窗口

题目描述 ​ 给出一个长度为 N&#xfffd; 的数组&#xff0c;一个长为 K&#xfffd; 的滑动窗口从最左移动到最右&#xff0c;每次窗口移动&#xff0c;如下图&#xff1a; 找出窗口在各个位置时的极大值和极小值。 输入 ​ 第一行两个数 N,K&#xfffd;,&#xfffd;。 …

win yolov5.7 tensorRT推理

安装TensorRT 下载tensorrt8.xx版本&#xff0c;适用于Windows的cuda11.x的版本 官方下载地址https://developer.nvidia.com/nvidia-tensorrt-8x-download 把tensorRT里面的bin、include、lib添加到本机CUDA中&#xff0c;CUDA需要加入环境变量中 配置虚拟环境 torch的版本…

Confluence最新版本(8.6)安装

软件获取 Confluence 历史版本下载地址&#xff1a;Confluence Server 下载存档 | Atlassian Atlassian-agent.jar https://github.com/haxqer/confluence/releases/download/v1.3.3/atlassian-agent.jar MySQL 驱动包 MySQL :: Download MySQL Connector/J (Archived Ve…

举个栗子!Alteryx 技巧(6):从 API 中提取数据

你听说过从 API 中提取数据吗&#xff1f;API 是指应用编程接口&#xff0c;是计算机之间或计算机程序之间的连接&#xff0c;它是一种软件接口&#xff0c;让不同的软件进行信息共享。对于很多数据分析师来说&#xff0c;他们常常需要从 API 中提取数据&#xff0c;那么如何快…

ASEMI肖特基二极管MBR10200CT在电子电路中起什么作用

编辑-Z 肖特基二极管MBR10200CT是一种特殊类型的二极管&#xff0c;可以在电子电路中起到多种作用。 首先&#xff0c;MBR10200CT具有非常低的正向电压丢失和快速的开关速度。这使得它非常适合用作整流器。在直流电源中&#xff0c;MBR10200CT可以将交流电转换为直流电&#x…

漏洞复现--蓝凌EIS智慧协同平台任意文件上传

免责声明&#xff1a; 文章中涉及的漏洞均已修复&#xff0c;敏感信息均已做打码处理&#xff0c;文章仅做经验分享用途&#xff0c;切勿当真&#xff0c;未授权的攻击属于非法行为&#xff01;文章中敏感信息均已做多层打马处理。传播、利用本文章所提供的信息而造成的任何直…

【LCR 159. 库存管理 III】

目录 一、题目描述二、算法原理三、代码实现 一、题目描述 二、算法原理 三、代码实现 class Solution { public:int getrandom(int left,int right,vector<int>& stock){return stock[rand()%(right-left1)left];}void qsort(int l,int r,vector<int>& s…