百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程网 > 正文

如何使用英特尔 系统调试器在早期启动阶段检查并读取开机自检编码

yuyutoo 2025-01-14 18:39 2 浏览 0 评论

1. 背景

在借助英特尔平台开发系统过程中,您可能会面临系统甚至在启动的初始阶段也无法启动的问题。 为了确定问题,您连接 JTAG 并使用英特尔系统调试器 (R) 进行源代码行调试。 不过,如果没有源代码或 BIOS 或固件的符号文件,那么你不能做源代码行调试。 在这种情况下,您可以在遇到困难时获得开机自检编码,您将开机自检编码发送到 BIOS/固件团队。 其次,如果问题只在运行时发生,这意味着当您运行时,没有发生任何问题或只是偶发性问题,那么您需要在问题发生之前,检查开机自检编码作为软件的检查点,然后就可以猜问题点了。 最后,如果您有关于开机自检编码的信息,但没有 BIOS/固件的源代码,那么您可以通过检查开机自检编码来猜引起问题的位置。

当系统 BIOS 或固件的早期启动阶段中有任何问题时,邮政代码非常有用。 但许多嵌入式系统或封闭机箱没有开机自检编码 LED。 但不要担心;您可以通过 JTAG 和英特尔系统调试器 (R) 来检查开机自检编码。 在文本中,我将解释如何检查英特尔系统调试器 (R) 内的开机自检编码。

2. 开机自检编码

开机自检编码是一个用于调试的传统单元。 在加电自检 (POST) 过程中,当它们将代码发送至 I/O 80h 时,开机自检编码在 BIOS/固件中提供进度指示。

(1) 可以从开机自检编码中获得什么信息

  • 开机自检编码告知 BIOS/固件中启用和传递哪个主要特性。
  • 开机自检编码可用于在初始化系统时指示设备或特性错误。

(2) 在硬件 (LED) 中哪里可以找到开机自检编码(如有)

POST 卡

(PCI 附加卡)

POST 卡解码端口并在 LED 显示屏上显示内容。

POST 卡必须安装在 PCI 总线连接器 1 上。

机载 POST 代码

LED 显示屏

一些英特尔? 台式机主板包括用于显示 POST 代码的板载 LED

(3) 每个开机自检编码描述的示例(典型用法)

范围类别/子系统
00 – 0F调试代码: 可供任何 PEIM/驱动程序用于调试
10 – 1F主机处理器
20 – 2F内存/芯片组
30 – 3F恢复
40 – 4F留作未来使用
50 – 5FI/O 总线: PCI、USB、ISA、ATA 等
60 – 6F当前未使用
70 – 7F输出设备: 所有输出控制台
80 – 8F留作未来使用(新的输出控制台代码)
90 – 9F输入设备: 键盘/鼠标
A0 – AF留作未来使用(新的输入控制台代码)
B0 – BF启动设备: 包含固定介质和可移动介质。
C0 ? CF留作未来使用
D0 – DF启动设备选择
E0 – FFE0 - EE: 其他代码
F0 – FF: FF 处理器异常

3. 使用英特尔系统调试器 (R) 检查开机自检编码

(1) 下载和安装英特尔 System Studio (R) 旗舰版或英特尔系统调试器 NDA 版本(R)(您可能需要与英特尔签订保密协议。)

https://software.intel.com/en-us/intel-system-studio

(2) 转至安装目录,运行批处理文件作为您的英特尔平台

相关推荐

.NET Core 中推荐使用的10大优秀库,你用到过几个?

概述:Microsoft的.NETCore生态系统中的中间件已经发生了重大变化,包括无缝集成到应用程序管道中的内置和第三方组件,协调客户端和服务器之间的数据流。它通过身份验证、日志记录和路由等...

机器学习中英文对照表

10-1LossFunction0-1损失函数2Accept-RejectSamplingMethod接受-拒绝抽样法/接受-拒绝采样法3AccumulatedErrorBa...

反应式编程之Spring Web-Flux/Project Reactor

介绍反应式编程代表了我们对应用程序执行模型的看法的改变。在响应式应用程序中,执行不遵循一个请求由一个线程处理的线性模型,而是以事件驱动和非阻塞的方式处理多个请求。...

Spider详解

简介Spider的功能主要使用于大型的应用系统测试,它能在很短的时间内帮助我们快速地对一个应用程序的内容、功能、系统的结构和分布情况进行了解。Control右键进行爬取数据使用spider功能。在Sp...

WebUI 如何高效进行测试

1.选择合适的浏览器驱动ChromeDriver:对于大多数情况,推荐使用ChromeDriver,因为它与Chrome浏览器的兼容性好,并且性能较好。...

《成为Rust专家》五、单元测试 (2)

6.3测试框架Rust的单元测试不包括其他单元测试框架中可能找到的辅助函数、夹具、测试框架或参数化测试功能。对于这些功能,你需要自己编写代码或者尝试一些库。对于基本的参数化测试,parameteri...

JUnit5学习之一:基本操作

欢迎访问我的GitHubhttps://github.com/zq2599/blog_demos内容:所有原创文章分类和汇总,及配套源码,涉及Java、Docker、Kubernetes、DevOPS...

511基于C# Thread类的大漠多线程模板游戏实战

如果你的游戏检测易语言,或者,客户反馈你的脚本被频繁报毒,加入黑名单,那么我们选择微软的C#来写一个大漠的多线程模板是最好的选择。...

如何深度理解mybatis?

深度自定义mybatis回顾mybatis的操作的核心步骤...

.NET 6 多线程的几种打开方式

前言多线程无处不在,平常的开发过程中,应该算是最常用的基础技术之一了。以下通过Thread、ThreadPool、再到Task、Parallel、线程锁、线程取消等方面,一步步进行演示多线程的一些基础...

C# 多 线 程。

一、基本概念1、进程...

C#多线程

1.概念进程,线程,应用程序的定义网上有很多资料,但是有些抽象。通俗的来讲,进程就是一旦一个应用程序开始运行,那么这个应用程序就会存在一个属于这个应用程序的进程。线程就是进程中的基本执行单元,每个进...

多线程在C# (.NET) 中的应用

在实际项目应用中我们难免会用到多线程、多进程编程方式,C#中的多线程允许你在同一时间内执行多个线程,每个线程都可以独立地执行不同的任务或者处理不同的部分。这可以帮助提高应用程序的响应性和性能。通过这...

如何使?C#创建?个线程?

在C#中,可以通过多种方式创建和启动一个线程。以下是常用的方式及其具体实现。1.使用Thread类创建线程...

在C#中,如何创建并启动?个新的线程?请举例说明

在C#中,可以使用System.Threading.Thread类创建并启动一个新的线程。以下是创建和启动线程的方式以及示例代码:创建并启动线程的步骤...

取消回复欢迎 发表评论: