- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个卡住操作系统的设备驱动程序。鼠标甚至不会移动。我正在尝试调试这个问题,我相信一个好的方法是将 gdb 与 qemu 一起使用,这是我以前从未使用过的两件事。有没有更好的方法?
所以首先我需要使用我已经完成的调试符号编译内核。
现在,生成了一个名为 vmlinux 的新文件,它位于与源相同的文件夹中。看来我还需要一个bzImage文件according to this所以我可以使用以下命令运行新编译的内核:
qemu-system-i386 -kernel bzImage
或处于 Debug模式
qemu-system-i386 -s -S -kernel bzImage
我找不到 bzImage 文件。我在哪里可以找到它或这里缺少什么? bzImage 是指我使用 qemu-img create 创建的操作系统镜像吗?
此外,我不明白的是现在内核已经编译(vmlinux),我如何用 qemu 运行它?所以我的问题是,当我使用 qemu 运行它时,或者调试器是在我的主操作系统中作为应用程序运行的内核吗?
还有我如何安装我的设备驱动程序?我的理解是内核不是 Ubuntu,所以没有 UI?
此外,我安装了 qemu,当我输入 qemu 时,我得到命令未找到。我猜我必须选择一个特定的处理器模拟器,如 qemu-system-i386、qemu-system-x86_64 或 qemu-x86_64?
qemu 与 kvm 命令有何不同或相似之处?
谢谢。
最佳答案
所以,如果我理解正确的话,你有一个不需要特定硬件的内核模块。当您使用该模块时,系统会卡住,但内核日志不包含任何特殊内容。
以下内容可能会有所帮助。
您描述的症状可能仍然是内核 oops 或 panic 的结果。日志记录工具有时会在将有关错误的信息输出到日志文件之前就死掉。你可以尝试通过串口输出日志,这样应该更可靠。
由于您的内核模块不需要任何特定硬件,最简单的方法可能是安装与虚拟机相同的 Linux 发行版,并将该机器的虚拟串行端口 (COM) 连接到主机上的管道系统。
这通常很容易做到。例如,this blog post如果主机操作系统和 guest 操作系统是 Ubuntu 11.10,则包含详细说明。
VirtualBox用于管理虚拟机。如果您更喜欢 QEMU,这也应该是可能的。我想虽然使用 VirtualBox 会更容易一些,但这是个人喜好的问题。
基本上,您需要执行以下步骤。
/tmp/vbox_serial
.console=ttyS0,115200
或类似内容添加到启动加载程序菜单中的内核选项。minicom
、socat
或任何其他要从 /tmp/vbox_serial
读取的内容。/tmp/vbox_serial
将客户操作系统的内核日志注入(inject)您的主机系统。如果访客系统随后崩溃,您将获得日志,即使它没有保存到访客本身的文件中。为了使事情更简单,您可以在您的主机系统上使用 socat
而不是该博文作者建议的 minicom
。此处可能不需要 minicom
的强大功能。
这样,您可以使用 socat
和 tee
将日志保存到 guest.log
文件,同时仍将其输出到控制台:
socat /tmp/vbox_serial - | tee guest.log
如果出现内核 oops 或 panic,日志中的回溯通常有助于找出是什么出错了。
如果您通过串行连接或其他方式获得了完整的日志,但仍然没有任何可疑之处,并且您怀疑内核中存在死锁,lockdep
工具可能会有所帮助。它包含在内核中(但您可能需要使用 CONFIG_LOCKDEP_SUPPORT=y
重建内核)。
Lockdep 检测潜在的死锁并将结果输出到内核日志。 This presentation可以帮助您分析其输出。
如果您需要跟踪内核中的某些事件来调试您的系统,可以使用一些工具。
关于linux-kernel - qemu 和 gdb 的问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14944229/
我需要从 kernel/system/do_kill.c (Minix) 将一些信息写入我的特殊日志文件(例如,/home/log.txt) . 我已经尝试过: int filedesc; filed
我正在经历 Uboot 和内核启动过程。 FDT(平面设备树)到底有什么用? 我读过的许多链接都指出,uboot 以 FDT 的形式将板和 SOC 配置信息传递给内核 https://wiki.fre
我的操作系统是Fedora 17。最近,出现内核污染警告“kernel bug at kernel/auditsc.c:1772!-abrt”:不应报告此问题(这可能是一个已知问题)。发生内核问题,但
为 Linux 编译内核模块的教程,使用不同的 Makefile 语法。 Example 1 obj-m += rpi-pwm.o Example 2 obj-m := nothing.o 有什么区别
我正在浏览 Linux 网络设备驱动程序代码,想知道是否可以从驱动程序代码中调用设备层代码。 --- a/drivers/net/ethernet/realtek/8139too.c +++ b/dr
出于工具目的,我尝试附加到 kprobe 事件,但我对 kprobe 事件不太熟悉。我读到注册的 kprobes 列表可以在 /sys/kernel/debug/kprobes/list 中找到,但是
我在其他地方使用 LinK+ 来开发 linux 内核模块。我的开发机器安装了 Linux Mint 18 操作系统,内核版本为 4.4.xx。为了进行测试,我想将内核模块部署到内核版本为 3.16.
我正在玩弄 Android Linux 内核。内核是P970 V30B内核。可用here .我想找出特定的 cmdline 参数到底做了什么。 我知道它是命令行参数,其中有一个参数我找不到它到底做了什
是否可以将 PTE 指向不同的物理页面? 假设我目前在某个进程 A 的上下文中处于内核模式,该进程当前将地址 400k 映射到物理页号。 5. 我可以将该地址 (400k) 映射到物理页号吗? 6 ?
我正在开发一个要在路由器上运行的内核模块。路由器型号为 Netgear 的 DGN2200v2。它在 MIPS 上运行 Linux 2.6.30。我的问题是,当我加载我的模块时,似乎我的 module
关闭。这个问题不符合 Stack Overflow guidelines 。它目前不接受答案。 想改进这个问题?更新问题,使其成为 Stack Overflow 的 on-topic。 6年前关闭。
在大型网格中执行的任务调用两个内核有区别吗 1. for(int i=0;i>>(MatrixA,MatrixB) } 2. dim3 dimBlock(16, 16); dim3 dimGrid(1
在 Linux 中,我生成了一个猜测 VM 并加载了另一个 Linux 实例。 VM 是通过 KVM/libvirt/qemu 生成的。 guest VM 被主机内核视为一个进程。让我们说由于某种原因
我想知道如何设置正确 MACH_TYPE或 arch_id对于内核。我搜索并找到了至少 2 个引用,其中内核会卡在“启动内核...”处。这些都给出了相同的答案。正确设置您的机器类型。但后来都没有提到如
kernel data inpage error蓝屏是一个不常见的问题,一般都是更新失败或者第三方软件冲突导致的,解决方法也非常简单,需要先安全模式进入系统,下面来看看详细的教程吧。 kern
当我用 app/console cache:clear 清除缓存时我收到错误: [Symfony\Component\DependencyInjection\Exception\ParameterNo
我正在玩 Raspberry 3,并尝试使用 U-Boot 启动 Linux 内核。 我构建了一个 Linux 内核(来自 github.com/raspberrypi)和 Busbox-Userla
关闭。这个问题是not reproducible or was caused by typos .它目前不接受答案。 这个问题是由于错别字或无法再重现的问题引起的。虽然类似的问题可能是on-topi
长话短说,我一直在做一个项目,当我使用时我注意到: 1.9.3p392 :001 > `gzip` IRB::Abort: abort then interrupt! from (irb):1
我有一个服务,我在其中注入(inject) TokenStorage 并想要获取当前用户。 /** * * @Service("liip_theme.theme_request_listener"
我是一名优秀的程序员,十分优秀!