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

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

citgpt 2024-08-10 15:18 10 浏览 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) 转至安装目录,运行批处理文件作为您的英特尔平台

相关推荐

js中arguments详解

一、简介了解arguments这个对象之前先来认识一下javascript的一些功能:其实Javascript并没有重载函数的功能,但是Arguments对象能够模拟重载。Javascrip中每个函数...

firewall-cmd 常用命令

目录firewalldzone说明firewallzone内容说明firewall-cmd常用参数firewall-cmd常用命令常用命令 回到顶部firewalldzone...

epel-release 是什么

EPEL-release(ExtraPackagesforEnterpriseLinux)是一个软件仓库,它为企业级Linux发行版(如CentOS、RHEL等)提供额外的软件包。以下是关于E...

FullGC详解  什么是 JVM 的 GC
FullGC详解 什么是 JVM 的 GC

前言:背景:一、什么是JVM的GC?JVM(JavaVirtualMachine)。JVM是Java程序的虚拟机,是一种实现Java语言的解...

2024-10-26 08:50 citgpt

使用Spire.Doc组件利用模板导出Word文档
  • 使用Spire.Doc组件利用模板导出Word文档
  • 使用Spire.Doc组件利用模板导出Word文档
  • 使用Spire.Doc组件利用模板导出Word文档
  • 使用Spire.Doc组件利用模板导出Word文档
跨域(CrossOrigin)

1.介绍  1)跨域问题:跨域问题是在网络中,当一个网络的运行脚本(通常时JavaScript)试图访问另一个网络的资源时,如果这两个网络的端口、协议和域名不一致时就会出现跨域问题。    通俗讲...

微服务架构和分布式架构的区别

1、含义不同微服务架构:微服务架构风格是一种将一个单一应用程序开发为一组小型服务的方法,每个服务运行在自己的进程中,服务间通信采用轻量级通信机制(通常用HTTP资源API)。这些服务围绕业务能力构建并...

深入理解与应用CSS clip-path 属性
深入理解与应用CSS clip-path 属性

clip-pathclip-path是什么clip-path 是一个CSS属性,允许开发者创建一个剪切区域,从而决定元素的哪些部分可见,哪些部分会被隐...

2024-10-25 11:51 citgpt

HCNP Routing&Switching之OSPF LSA类型(二)
  • HCNP Routing&Switching之OSPF LSA类型(二)
  • HCNP Routing&Switching之OSPF LSA类型(二)
  • HCNP Routing&Switching之OSPF LSA类型(二)
  • HCNP Routing&Switching之OSPF LSA类型(二)
Redis和Memcached的区别详解
  • Redis和Memcached的区别详解
  • Redis和Memcached的区别详解
  • Redis和Memcached的区别详解
  • Redis和Memcached的区别详解
Request.ServerVariables 大全

Request.ServerVariables("Url")返回服务器地址Request.ServerVariables("Path_Info")客户端提供的路...

python操作Kafka

目录一、python操作kafka1.python使用kafka生产者2.python使用kafka消费者3.使用docker中的kafka二、python操作kafka细...

Runtime.getRuntime().exec详解

Runtime.getRuntime().exec详解概述Runtime.getRuntime().exec用于调用外部可执行程序或系统命令,并重定向外部程序的标准输入、标准输出和标准错误到缓冲池。...

promise.all详解 promise.all是干什么的
promise.all详解 promise.all是干什么的

promise.all详解promise.all中所有的请求成功了,走.then(),在.then()中能得到一个数组,数组中是每个请求resolve抛出的结果...

2024-10-24 16:21 citgpt

Content-Length和Transfer-Encoding详解
  • Content-Length和Transfer-Encoding详解
  • Content-Length和Transfer-Encoding详解
  • Content-Length和Transfer-Encoding详解
  • Content-Length和Transfer-Encoding详解

取消回复欢迎 发表评论: