1、uboot跳转到内核启动的时候通过环境变量 console设置控制台

(console = ttySAC0表示输出到串口,并从串口结束输入,也可以设置console=tty1,表示输出到LCD,从inputevent接受输入事件)

2、内核用printk打印,printk肯定要调用硬件函数,其通过console参数来确定具体硬件,调用对应的硬件处理函数

  在内核中搜索“console=”,可以看到__setup("console=",console_setup),__setup是个宏

以console为例,在/kernel/printk.c中,如下:

  1. static int __init console_setup(char *str)
  2. {
  3. .......
  4. }
  5. __setup("console=", console_setup);

__setup宏定义展开,如下:

  1. Static struct obs_kernel_param __setup_console_setup
  2. __used_section(.init.setup) __attribute__((aligned((sizeof(long)))) = {
  3. .name = “console=”,
  4. .setup_func = console_setup,
  5. .early = 0
  6. }

__setup_console_setup编译时就会链接到.init.setup段中,kernel运行时就会根据cmdline中的参数名与.init.setup段中obs_kernel_param的name对比。

匹配则调用console-setup来解析该参数,console_setup的参数就是cmdline中console的值

1. 内核处理UBOOT传入的参数
console_setup
  add_preferred_console // 我想用名为"ttySAC0"的控制台,先保存在console_cmdline中,可以有多个console,会在register_console中被使用来比较

2. 硬件驱动的入口函数里:
drivers/serial/s3c2410.c
  register_console(&s3c24xx_serial_console);//注册console,其有个名字,内核会把这个名字和uboot中传过来的被保存的那个名字链表比较,s3c24xx_serial_console结构体有write函数,会被prinkt调用;register_console会把s3c24xx_serial_console放在console_drivers的尾部

(3.4.2的内核如下

drivers/tty/serial/samsung.c

s3c24xx_serial_probe

  uart_add_one_port(&s3c24xx_uart_drv, &ourport->port);//s3c24xx_uart_drv的cons成员就是提供串口写操作的函数

    uart_configure_port

      register_console(port->cons);//同上面其他内核分析的,会把cons保存在console_drivers这个console链表上,其就是个链表头,根据它可以找到多个cons,这里的cons就是上面s3c24xx_uart_drv的cons,在uart_add_one_port中赋的值

3.printk
    vprintk
        /* Emit the output into the temporary buffer */
        // 先把输出信息放入临时BUFFER
        vscnprintf

        // Copy the output into log_buf.
        // 把临时BUFFER里的数据稍作处理,再写入log_buf(处理打印级别,给无打印级别的添加默认打印级别 )
        // 比如printk("abc")会得到"<4>abc", 再写入log_buf
        // 可以用dmesg命令把log_buf里的数据打印出来重现内核的输出信息

        // 调用硬件的write函数输出,3.4.2内核是console_unlock函数
        release_console_sem();或者console_unlock
            call_console_drivers(_con_start, _log_end);
                // 从log_buf得到数据,算出打印级别
                _call_console_drivers(start_print, cur_index, msg_level); //通过drivers的“s”看出可以打印到多个设备,在uboot环境变量中设置多个console=
                    // 如果可以级别够格打印
                    if ((msg_log_level < console_loglevel
                          __call_console_drivers
                              con->write(con, &LOG_BUF(start), end - start);

cat  /proc/sys/kernel/printk

7  4  1  7

console_loglevel  default_message_loglevel  minimum_console_loglevel  defaule_console_loglevel

通过“echo  "8 4 1 7"  >  /proc/sys/kernel/printk”来设置

内核文档kernel-parameters.txt有介绍这些环境变量参数,可以设置loglevel=这些环境变量,在uboot的环境变量中设置

24、驱动调试之printk的更多相关文章

  1. 驱动调试(一)-printk

    目录 驱动调试(一)-printk 引入 框架 入口console_setup add_preferred_console register_console s3c24xx_serial_initco ...

  2. printk 驱动调试

    驱动的调试,printk()添加调试信息 printk相当于printf的孪生姐妹,它们一个运行在用户态,另一个则在内核态. 需要包含<linux/device.h>或者<linux ...

  3. Linux驱动设计—— 驱动调试技术

    参考博客与书籍: <Linux设备驱动开发详解> <Linux设备驱动程序> http://blog.chinaunix.net/uid-24219701-id-2884942 ...

  4. 【转】android 电容屏(三):驱动调试之驱动程序分析篇

    关键词:android  电容屏 tp 工作队列 中断 坐点计算  电容屏主要参数平台信息:内核:linux2.6/linux3.0系统:android/android4.0  平台:S5PV310( ...

  5. 【转】Android LCD(四):LCD驱动调试篇

    关键词:android LCD TFTSN75LVDS83B  TTL-LVDS LCD电压背光电压 平台信息:内核:linux2.6/linux3.0系统:android/android4.0 平台 ...

  6. 驱动调试(三)oops确定函数PC

    目录 驱动调试(三)oops确定函数PC 什么是oops 流程简述 代码仓库 模块例子分析 找到PC值 判断是否属于模块 查看符号表 找到模块 反汇编模块 内核例子分析 找到PC值 判断是否属于模块 ...

  7. linux驱动调试--修改系统时钟终端来定位僵死问题【转】

    本文转载自:http://blog.chinaunix.net/uid-20671208-id-4940381.html 原文地址:linux驱动调试--修改系统时钟终端来定位僵死问题 作者:枫露清愁 ...

  8. tiny4412 串口驱动分析二 --- printk的实现

    作者:彭东林 邮箱:pengdonglin137@163.com 开发板:tiny4412ADK+S700 4GB Flash 主机:Wind7 64位 虚拟机:Vmware+Ubuntu12_04 ...

  9. Android驱动调试利器Busybox之初体验

    工欲善其事必先利其器,之前做WinCE开发时,经常写一些小工具以提高开发调试的效率,如WinCE驱动调试助手.WinCE串口调试助手.WinCE6.0寄存器访问工具.WinCE远程桌面助手和S3C24 ...

随机推荐

  1. Kinect 开发 —— 骨骼数据与彩色影像和深度影像的对齐

    在显示彩色影像和深度影像时最好使用WriteableBitmap对象: 要想将骨骼数据影像和深度影像,或者彩色影像叠加到一起,首先要确定深度影像的分辨率和大小,为了方便,这里将深度影像数据和彩色影像数 ...

  2. 阿里云 CentOS7.4 环境安装mysql5.7

    1. 删除默认安装的数据库,无所谓的请略过 据说CentOS7.x版本会默认安装mariadb数据库,我有点强迫症,故卸载之: rpm -qa|grep mariadb yum remove mari ...

  3. 使用SqlBulkCopy进行批量数据插入

    Dim dt As DataTable = New DataTable() dt.Columns.Add("DtCostProductRuleGUID", GetType(Guid ...

  4. enq: TX - row lock contention故障处理一则

    一个非常easy的问题,之所以让我对这个问题进行总结.一是由于没我想象的简单,在处理的过程中遇到了一些磕磕碰碰,甚至绕了一些弯路.二是引发了我对故障处理时的一些思考. 6月19日,下午5点左右.数据库 ...

  5. hiho 1182 : 欧拉路&#183;三

    1182 : 欧拉路·三 这时题目中给的提示: 小Ho:是这种.每次转动一个区域不是相当于原来数字去掉最左边一位,并在最后加上1或者0么. 于是我考虑对于"XYYY",它转动之后能 ...

  6. CentOS6 安装中文包和变更系统默认语言

    CentOS6 安装中文包和变更系统默认语言   用 yum 安装语言包的命令是 yum groupinstall <language>-support    ,其中 <langua ...

  7. 不安装谷歌市场,下载谷歌市场中的APK

    不安装谷歌市场,下载谷歌市场中的APK GooglePlayStore 是谷歌官方的的应用市场,有的时候还是需要从谷歌市场下载APK文件.国内的安卓手机厂商都不自带GooglePlay,甚至一些手机& ...

  8. 【Expression 序列化】WCF的简单使用及其Expression Lambada的序列化问题初步解决方案

    地址:http://www.cnblogs.com/guomingfeng/tag/Expression%E5%BA%8F%E5%88%97%E5%8C%96/

  9. 使用ILMerge将所有引用的DLL和exe文件打成一个exe文件

    今天做了一个IM自动更新的软件,里面牵扯到了文件的解压和接口签名加密,使用了2个第三方的dll,想发布的时候才发现调用的类没几个,就像把它们都跟EXE文件打包在一起,以后复制去别的地方用也方便,于是上 ...

  10. 关于CSDN2013博客之星的一些看法

    最近一个周,最火的话题当然要数CSDN2013博客之星拉票了. 实话实说,从12月14日开始,我连续5天拉票. 通过QQ群.QQ好友.CSDN文章.给CSDN粉丝发私信等多种方式拉票,真是累死我了. ...