近日在写一个简易的操作系统,经常受到bug的偷袭,由于开发OS的特殊性,一些常规的debug手段用不上,于是打算记录下自己的debug过程,用于交流。
Problem:
在做图层叠加时,引入结构体SHTCTL进行各个图层的管理,但遭遇了黑屏,原因可能来自于图层管理模块、内存管理模块或其他未知原因。
Solution:
恢复到上次不黑屏的版本(即去掉图层管理模块),果然可以进行显示。在此基础上,逐步引入图层管理模块:只让背景图层加入到SHTCTL,鼠标图层暂且不加。发现还是黑屏,于是原因集中在了图层管理模块和内存管理模块,肯定有某个地方code有问题。先分析了图层管理模块中的各个函数,没有问题。再转向内存管理模块,果然在memman_alloc函数中应该return a,却误写成了return 0,相当与内存没有分配成功,于是出现了黑屏。
Summary:
(1)恢复到没有问题的版本
(2)逐步引入,由简到繁
(3)确定与哪些模块有联系,逐个检查
原文地址:http://blog.csdn.net/bluecloudmatrix/article/details/27230659