linux开机去掉内核打印信息,屏蔽内核启动打印信息

最近做的4412板子终于经过测试形成产品,在这之前需要把内核启动过程中的打印信息去掉,并且更换启动LOGO,下面讲讲自己去掉打印信息的过程。

去掉打印信息方法很多,我使用一个相对比较简单的,就是将下面选项的[*]去掉

Device Drivers  --->

Character devices  --->

[*]   Support for console on virtual terminal

这样printk的打印信息就不会输出在显示器或LCD上。

将打印信息去掉后,莫名其妙的会出现因为读取文件系统失败而启动不了的情况,报错:Kernel panic - not syncing: VFS。根据网上查找到的资料,因为系统启动过程中,磁盘EMMC的初始化和读取文件系统是在两个不同的线程中进行的,屏蔽掉打印信息后,主线程,及挂在文件系统的线程执行时间缩短,以至于当主线程准备挂载文件系统的时候,EMMC的初始化还没有完成,所以启动会失败。这个时候我们可以再uboot的启动参数中加入rootdelay=1,延迟系统挂在文件系统的时间,从而使系统顺利启动。

接下来创建自己的启动LOGO,方法如下

创建logo图片:1、内核默认的logo图片为drivers/video/logo/logo_linux_clut224.ppmfile logo_linux_clut224.ppm先得到图片的大小,然后再用gimp等工具创建一个同样大小的png图片2、把自己创建的png图片转换为只有224色的ppm图片pngtopnm logo.png | ppmquant -fs 224 | pnmtoplainpnm > logo_linux_clut224.ppm如果没有以上的转换命令请安装netpbm工具包3、覆盖原来的logo_linux_clut224.ppm文件,若有logo_linux_clut224.o和logo_linux_clut224.c文件则删除内核配置:Device Drivers ->Graphics Support ->[*] Support for frame buffer devices[*] VESA VGA graphics supportConsole display driver support ->[*] Video mode selection support[*] Framebuffer Console support[*]Select compiled-in fonts[*]VGA 8x16 fontLogo configuration->[*]Bootup logo[*] Standard 224-color Linux logo重新编译内核logo居中:1、设置logo图片在屏幕中的位置vi drivers/video/fbmem.c找到"fb_show_logo_line"函数,把image.dx = 0;image.dy = y;改为image.dx = (info->var.xres/2) - (610/2);image.dy = (info->var.yres/2) - (206/2);[注:info->var.xres和info->var.yres是分辨率大小610和206是logo图片的大小]2、vi drivers/video/console/fbcon.c找到"fbcon_prepare_logo"函数,在logo_height = fb_prepare_logo(info, ops->rotate);后面加上logo_height += (info->var.yres/2) - (206/2);添加新图片:在Makefile中有这么一句:extra-y += $(call logo-cfiles,_clut224,ppm)它的意思是在当前找到以"_clut224"结尾的ppm图片,然后根据它生成.c文件,所以添加新的图片名可以类似这样:logo_linux_sullg_clut224.ppm1.Makefile,加入一行obj-$(CONFIG_LOGO_LINUX_SULLG_CLUT224) += logo_linux_sullg_clut224.o2.Kconfig,加入config LOGO_LINUX_SULLG_CLUT224bool "Standard 224-color Linux logo for sullg"default y3.logo.c,加入extern const struct linux_logo logo_linux_sullg_clut224;在"fb_find_logo"中找到"#ifdef CONFIG_LOGO_LINUX_CLUT224",在其后加入:#ifdef CONFIG_LOGO_LINUX_SULLG_CLUT224logo = &logo_linux_sullg_clut224;#endif

原文:http://blog.csdn.net/qq405180763/article/details/39118497

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值