- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
This是我试图通过放置 printf/printk 语句来调试的文件。
代码是汇编。
79 __HEAD
80 ENTRY(stext)
81 ARM_BE8(setend be ) @ ensure we are in BE8 mode
82
83 THUMB( adr r9, BSYM(1f) ) @ Kernel is always entered in ARM.
84 THUMB( bx r9 ) @ If this is a Thumb-2 kernel,
85 THUMB( .thumb ) @ switch to Thumb now.
86 THUMB(1: )
87
88 #ifdef CONFIG_ARM_VIRT_EXT
89 bl __hyp_stub_install
90 #endif
91 @ ensure svc mode and all interrupts masked
92 safe_svcmode_maskall r9
93
94 mrc p15, 0, r9, c0, c0 @ get processor id
95 bl __lookup_processor_type @ r5=procinfo r9=cpuid
96 movs r10, r5 @ invalid processor (r5=0)?
97 THUMB( it eq ) @ force fixup-able long branch encoding
98 beq __error_p @ yes, error 'p'
99
100 #ifdef CONFIG_ARM_LPAE
101 mrc p15, 0, r3, c0, c1, 4 @ read ID_MMFR0
102 and r3, r3, #0xf @ extract VMSA support
103 cmp r3, #5 @ long-descriptor translation table format?
104 THUMB( it lo ) @ force fixup-able long branch encoding
105 blo __error_lpae @ only classic page table format
106 #endif
107
108 #ifndef CONFIG_XIP_KERNEL
109 adr r3,
我只是想将一些消息从这个文件中发送到控制台。此代码适用于 ARM。
我尝试在此类代码块中使用 printk,但无法编译。
有什么建议吗?
最佳答案
答案在ARM booting FAQ中给出.您需要启用配置菜单项Kernel Hacking|Kernel low-level debugging functions。例如,代码 __error_p
然后将在您的控制台 UART 上显示一些内容。例如,elinux.org's Debugging by printing当内核无法匹配您的机器 ID 时显示错误消息。 参见:ARM booting documentation
DEBUG_LL 创建函数 extern void printascii(char *);
,您还可以使用它来检测 vprintk_emit()
。
--- a/kernel/printk/printk.c
+++ b/kernel/printk/printk.c
@@ -1483,6 +1483,8 @@ static size_t cont_print_text(char *text, size_t size)
return textlen;
}
+extern void printascii(char*);
+
asmlinkage int vprintk_emit(int facility, int level,
const char *dict, size_t dictlen,
const char *fmt, va_list args)
@@ -1541,6 +1543,7 @@ asmlinkage int vprintk_emit(int facility, int level,
* prefix which might be passed-in as a parameter.
*/
text_len = vscnprintf(text, sizeof(textbuf), fmt, args);
+ printascii(text);
/* mark and strip a trailing newline */
if (text_len && text[text_len-1] == '\n') {
这和内核命令行 initcall_debug 将有助于诊断引导问题。
如果您的平台不支持 DEBUG_LL,则很容易实现支持它所需的轮询 UART 例程。
通常,printk()
在早期引导期间被缓冲并且在控制台驱动程序处于事件状态之前不会实际打印出来。因此,如果不修补 vprintk_emit()
,您可以在 UART 驱动程序运行之前的任何地方崩溃/暂停,并且在正常配置下什么也看不到。
对于 head.S 等的调试,您需要在汇编程序中执行此操作。 error_p
实现有一些示例代码,这里是另一个,
#ifdef CONFIG_DEBUG_LL
/* Save some registers? */
adr r0, prefix
bl printascii
mov r0, r9
bl printhex8
adr r0, tail
bl printascii
b 1f
prefix: .asciz "\nTrace 1 gives "
tail: .asciz "\n"
1: /* Perhaps halt here, due to register clobbers */
#endif
根据 head.S 中的上下文,您在使用寄存器方面受到限制。通常此代码的唯一问题是您没有执行 ARM booting documentation 中描述的操作.
您也可以直接使用定义在arch/arm/include/debug 中的宏。 .宏是,
addruart
- 获取参数 1 (phys)、2 (virt) 的 uart 地址,(第三个是宏的 tmp)。senduart
- 将字符参数 1 写入地址(虚拟或物理地址)。waituart
- 参数 1 (tmp),参数 2 地址(virt 或 phys)。准备好了吗?busyuart
- 参数 1 (tmp),参数 2 地址(virt 或 phys)。空的?您可以在 printasii()
的实现中看到正在使用的 API .
ENTRY(printascii)
addruart_current r3, r1, r2 @ phys address to r3
b 2f
1: waituart r2, r3 @ ready (r2 is tmp, r3 is phys address)
senduart r1, r3 @ transmit r1 character
busyuart r2, r3 @ wait for character to finish tx.
teq r1, #'\n'
moveq r1, #'\r' @ insert carriage return if new line.
beq 1b
2: teq r0, #0 @ NULL pointer?
ldrneb r1, [r0], #1 @ next char
teqne r1, #0 @ end of string?
bne 1b @ send another.
mov pc, lr
ENDPROC(printascii)
在 head.S 和其他程序的汇编程序中,您可以使用带有各种寄存器参数的宏来避免破坏正在使用的寄存器,例如 r0-r3
。它们通常可供使用,并且可以直接调用 printascii()
。
关于c - 如何使用printf调试linux内核的汇编代码,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24302830/
我想知道以下语句在 C 中会打印什么? printf("hello\n") || (printf("goodbye\n") || printf("world\n")); 我通常习惯于使用“cout”在
这是我目前正在学习的系统编程类(class)的幻灯片: catch_child 是 SIGCHLD 处理程序。输出与代码如何对应?为什么没有打印一些“Child #x started”消息? 最佳答案
这有点像拼图……我刚刚又回到了C,打算这次掌握它。所以我一直在阅读 The C Programming Language ,我得到了这个声明: Among others, printf also re
如何使用 printf 在字符串末尾附加空格? 我找不到任何在右侧附加空格的示例。 A similar question我发现使用 printf改为在字符串的左侧添加空格。 最佳答案 使用负数左对齐(
我想通过 usart 从 stm32f405 注销。 在我的 syscall.c 文件中,我实现了通过 usart 打印的功能: int _write(int file, char *ptr, int
我想定义一个记录器函数,比如 myPutStrLn = putStrLn . (++) "log: " main = do myPutStrLn "hello" 这很好。现在我想用 printf 格式
Printf module API详细介绍了类型转换标志,其中: %B: convert a boolean argument to the string true or false %b: conv
@H2CO3 这是我的主要代码: #pragma OPENCL EXTENSION cl_ amd_ printf : enable #define PROGRAM_FILE "matvec.cl"
Printf module API详细介绍了类型转换标志,其中: %B: convert a boolean argument to the string true or false %b: conv
您可以使用 printf 字段宽度说明符截断字符串: printf("%.5s", "abcdefgh"); > abcde 不幸的是,它不适用于数字(将 d 替换为 x 是相同的): printf(
关闭。此题需要details or clarity 。目前不接受答案。 想要改进这个问题吗?通过 editing this post 添加详细信息并澄清问题. 已关闭 4 年前。 Improve th
我遇到了我见过的最奇怪的错误之一。 我有一个简单的程序,可以打印多个整数数组。 对数组进行排序,然后打印...... place_in_buf(n100, 100); insertion(10
我的程序是每隔一段时间获取文件大小并显示它以记录任何更改。由于某种原因,执行下面的代码挂起,只为我提供了一个光标。没有打印或显示任何内容。 代码: #include #include #inclu
printf("It is currently %s's turn.\n", current->name); 我想知道为什么在 %s 之后打印出额外的换行符。我知道C 中的字符串总是以\0 结尾。没有
这个问题已经有答案了: printf anomaly after "fork()" (3 个回答) fork() in c using printf [duplicate] (2 个回答) 已关闭 9
我对编程很陌生。 我正在尝试编写一个程序,从数组中调用水果的价格。但我希望代码在写价格之前也写水果的名称。如果我键入 2,如何使输出为“Orange price : 10”而不仅仅是 price :
这个问题在这里已经有了答案: How do I print a non-null-terminated string using printf? (2 个答案) 关闭 7 年前。 例如,我有一个字符
我有一个 atmel UC3-L0 和罗盘传感器。现在我安装 AtmelStudio 并将一些演示代码下载到电路板中。但是我不知道演示代码中的函数 printf 会在哪里出现数据。我应该如何获取数据?
我有一个 atmel UC3-L0 和罗盘传感器。现在我安装 AtmelStudio 并将一些演示代码下载到电路板中。但是我不知道演示代码中的函数 printf 会在哪里出现数据。我应该如何获取数据?
嗨,我是 C 世界的新手,我的代码确实有些奇怪。目标是创建一个函数,可以在开头和结尾处用空格和/或制表符修剪字符串。我无法使用字符串库。 问题是我的代码中有一个 printf 只是用于测试,它的工作非
我是一名优秀的程序员,十分优秀!