ubuntu + gdb + ovmf + qemu 虚拟机调试UEFI

2023-10-10 19:59

本文主要是介绍ubuntu + gdb + ovmf + qemu 虚拟机调试UEFI,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

调试BIOS 大部分情况都是在真实的板子上面, 就是build 之后, 烧录到rom 里面, 整个流程非常耗时间,下面讲解如何在qemu 上面调试uefi driver.

 

 

 

 

环境: ubuntu 18.04

1. 编译:1. source edksetup.sh        // 这一步,是设置环境变量

               2.build -p OvmfPkg/OvmfPkgIa32.dsc -t GCC5 -D SOURCE_DEBUG_ENABLE

2. 执行qemu

qemu-system-i386 -s -pflash OVMF.fd  -net none -debugcon file:-debug.log -global isa-debugcon.iobase=0x402 -hda fat:rw:hda-contents/

$ qemu-system-i386 -s -pflash OVMF_CODE.fd -pflash OVMF_VARS.fd -net none -debugcon file:-debug.log -global isa-debugcon.iobase=0x402 -hda fat:rw:hda-contents -global e1000.romfile="E1000Fmp.rom" -device e1000

 

3. 启动gdb

 

gdb 基础:

info register: 列出当前寄存器的值

info breakpoint: 列出所有的断点

info files:

从串口输出来的文件读出相应driver load 进内存起始地址:

结合上面图中的信息算出代码段和数据段的位置:

7d2a000+240 = 7d2a240

7d2a000+240+58c0 = 7D2FB00

 

加载符号表并设置断点:

 

让GDB 连上 qemu;

Caption

 

在QEMU 里面重启:

这时候,可以看到GDB 停在了刚刚下的断点处:

key 入list ,可以列出最近的10 行:

接下来,就是gdb 常规操作了。

 

x/10i  显示程序当前位置开始往后的10条汇编指令。 它可以看到call 指令相关内容 ,就是能知道会调用哪个函数,方便你知道load 哪个符号表。

n 显示下一条代码

 

 

 

linux 环境安装:

chmod +x UDK_Debugger_Tool_v1_5_1.bin

Desktop$ ./UDK_Debugger_Tool_v1_5_1.bin

 

这篇关于ubuntu + gdb + ovmf + qemu 虚拟机调试UEFI的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/182753

相关文章

新特性抢先看! Ubuntu 25.04 Beta 发布:Linux 6.14 内核

《新特性抢先看!Ubuntu25.04Beta发布:Linux6.14内核》Canonical公司近日发布了Ubuntu25.04Beta版,这一版本被赋予了一个活泼的代号——“Plu... Canonical 昨日(3 月 27 日)放出了 Beta 版 Ubuntu 25.04 系统镜像,代号“Pluc

Ubuntu中Nginx虚拟主机设置的项目实践

《Ubuntu中Nginx虚拟主机设置的项目实践》通过配置虚拟主机,可以在同一台服务器上运行多个独立的网站,本文主要介绍了Ubuntu中Nginx虚拟主机设置的项目实践,具有一定的参考价值,感兴趣的可... 目录简介安装 Nginx创建虚拟主机1. 创建网站目录2. 创建默认索引文件3. 配置 Nginx4

Linux虚拟机不显示IP地址的解决方法(亲测有效)

《Linux虚拟机不显示IP地址的解决方法(亲测有效)》本文主要介绍了通过VMware新装的Linux系统没有IP地址的解决方法,主要步骤包括:关闭虚拟机、打开VM虚拟网络编辑器、还原VMnet8或修... 目录前言步骤0.问题情况1.关闭虚拟机2.China编程打开VM虚拟网络编辑器3.1 方法一:点击还原VM

JAVA虚拟机中 -D, -X, -XX ,-server参数使用

《JAVA虚拟机中-D,-X,-XX,-server参数使用》本文主要介绍了JAVA虚拟机中-D,-X,-XX,-server参数使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有... 目录一、-D参数二、-X参数三、-XX参数总结:在Java开发过程中,对Java虚拟机(JVM)的启动参数进

前端bug调试的方法技巧及常见错误

《前端bug调试的方法技巧及常见错误》:本文主要介绍编程中常见的报错和Bug,以及调试的重要性,调试的基本流程是通过缩小范围来定位问题,并给出了推测法、删除代码法、console调试和debugg... 目录调试基本流程调试方法排查bug的两大技巧如何看控制台报错前端常见错误取值调用报错资源引入错误解析错误

Ubuntu 22.04 服务器安装部署(nginx+postgresql)

《Ubuntu22.04服务器安装部署(nginx+postgresql)》Ubuntu22.04LTS是迄今为止最好的Ubuntu版本之一,很多linux的应用服务器都是选择的这个版本... 目录是什么让 Ubuntu 22.04 LTS 变得安全?更新了安全包linux 内核改进一、部署环境二、安装系统

Ubuntu固定虚拟机ip地址的方法教程

《Ubuntu固定虚拟机ip地址的方法教程》本文详细介绍了如何在Ubuntu虚拟机中固定IP地址,包括检查和编辑`/etc/apt/sources.list`文件、更新网络配置文件以及使用Networ... 1、由于虚拟机网络是桥接,所以ip地址会不停地变化,接下来我们就讲述ip如何固定 2、如果apt安

使用C/C++调用libcurl调试消息的方式

《使用C/C++调用libcurl调试消息的方式》在使用C/C++调用libcurl进行HTTP请求时,有时我们需要查看请求的/应答消息的内容(包括请求头和请求体)以方便调试,libcurl提供了多种... 目录1. libcurl 调试工具简介2. 输出请求消息使用 CURLOPT_VERBOSE使用 C

虚拟机与物理机的文件共享方式

《虚拟机与物理机的文件共享方式》文章介绍了如何在KaliLinux虚拟机中实现物理机文件夹的直接挂载,以便在虚拟机中方便地读取和使用物理机上的文件,通过设置和配置,可以实现临时挂载和永久挂载,并提供... 目录虚拟机与物理机的文件共享1 虚拟机设置2 验证Kali下分享文件夹功能是否启用3 创建挂载目录4

怎么关闭Ubuntu无人值守升级? Ubuntu禁止自动更新的技巧

《怎么关闭Ubuntu无人值守升级?Ubuntu禁止自动更新的技巧》UbuntuLinux系统禁止自动更新的时候,提示“无人值守升级在关机期间,请不要关闭计算机进程”,该怎么解决这个问题?详细请看... 本教程教你如何处理无人值守的升级,即 Ubuntu linux 的自动系统更新。来源:https://