在使用gdb或者其他工具调试默认优化选项的内核时,内核的反汇编代码与原来的C语言代码对应很乱。如果切换到C语言模式,使用单步调试时会看到执行顺序在C语言源代码里面跳来跳去,甚是紊乱。


    这一切都是GCC对代码进行了优化造成的,优化后的代码执行顺序与源代码的顺序就有出入了。GCC优化代码,提高运行效率与代码紧凑度,但对于调试学习内核就不友好了。


    通过下面的方法去掉内核编译时的优化。


1,优化级别从-O2改为-O1


修改内核源代码根目录下的Makefile


all: vmlinux


ifdef CONFIG_CC_OPTIMIZE_FOR_SIZE
KBUILD_CFLAGS    += -Os
else
KBUILD_CFLAGS    += -O1
endif


CONFIG_CC_OPTIMIZE_FOR_SIZE默认是不定义的,所以修改红色部分为-O1,优化级别为1级,只做基本的优化。






2,不要将只有一个地方调用的函数自动变为inline函数


变为inline函数之后,对于调试代码极为不便。原来在里面定义的局部变量都没有了,要查看一些局部变量的值时需要从寄存器里面去推导,并且需要手动的做强制类型转换才能看到数据结构的值。


禁止inline后会是一次真正的函数调用,对于通过调试理解代码功能作用很大。


# We trigger additional mismatches with less inlining
ifdef CONFIG_DEBUG_SECTION_MISMATCH
KBUILD_CFLAGS += $(call cc-option, -fno-inline-functions-called-once)
endif


CONFIG_DEBUG_SECTION_MISMATCH这个宏本来是检测代码/数据段类型属性不匹配的,定义后同时有个功能是禁止将只有一个地方调用的函数变为inline函数。




————————————————
版权声明:本文为CSDN博主「nust20」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/nust20/article/details/17720859
09-01 18:21