[经验] 嵌入式linux 串口console注册

[复制链接]

助理工程师

发表于 2018-3-5 13:53:06   387 查看 0 回复 显示全部楼层 倒序浏览
分享
printk打印的信息要在console注册之后才能打印出来,但是在start_kernel中,还没有注册console之前
已经有printk的动作.这些信息会保存在printk的buf里边,这个buf大小可以配置:
General setup
(14) Kernel log buffer size (16 => 64KB, 17 => 128KB)
14=2^14=16KB, 16=2^16=64KB......

printk->vprintk_emit->
->log_store 将打印信息保存到printk的buf中
->console_unlock->call_console_drivers->console->write打印信息


console 的注册:
static struct console cdns_uart_console = {
.name = CDNS_UART_TTY_NAME,
.write = cdns_uart_console_write,
.device = uart_console_device,
.setup = cdns_uart_console_setup,
.flags = CON_PRINTBUFFER, // 打印出buf的printk信息
.index = -1, /* Specified on the cmdline (e.g. console=ttyPS ) */
.data = &cdns_uart_uart_driver,
};

static int __init cdns_uart_console_init(void)
{
register_console(&cdns_uart_console);
return 0;
}
console_initcall(cdns_uart_console_init);

#define console_initcall(fn) \
static initcall_t __initcall_##fn \
__used __section(.con_initcall.init) = fn


console_initcall宏定义把cdns_uart_console_init放到.con_initcall.init段中,该段可从vmlinux.lds中找到.
__con_initcall_start = .; *(.con_initcall.init) __con_initcall_end = .;
该段的起始地址是__con_initcall_start,该段中的所有函数在driver\tty\tty_io.c\console_init函数中调用,
console_init在start_kernel函数中被调用. console的注册和driver是不相关的,它有自己的setup,write函数,
register_console之后,console就可以输出信息.

for (i = 0, c = console_cmdline;
    i < MAX_CMDLINECONSOLES && c->name[0];
    i++, c++) {
if (strcmp(c->name, newcon->name) != 0)/* 驱动中定义的console->name要与命令行中的一致 */
continue;
if (newcon->index >= 0 &&
   newcon->index != c->index)
continue;
if (newcon->index < 0)
newcon->index = c->index;


if (_braille_register_console(newcon, c))
return;


if (newcon->setup &&
   newcon->setup(newcon, console_cmdline.options) != 0) /* 调用console->setup函数,options就是 115200n81之类的参数 */
break;
newcon->flags |= CON_ENABLED;
newcon->index = c->index;
if (i == selected_console) {
newcon->flags |= CON_CONSDEV;
preferred_console = selected_console;
}
break;
}

if (newcon->flags & CON_PRINTBUFFER) { // 只有设置了CON_PRINTBUFFER,才会打印被buf的信息
/*
* console_unlock(); will print out the buffered messages
* for us.
*/
raw_spin_lock_irqsave(&logbuf_lock, flags);
console_seq = syslog_seq;
console_idx = syslog_idx;
console_prev = syslog_prev;
raw_spin_unlock_irqrestore(&logbuf_lock, flags);
/*
* We're about to replay the log buffer.  Only do this to the
* just-registered console to avoid excessive message spam to
* the already-registered consoles.
*/
exclusive_console = newcon;}
console_unlock(); // 该函数打印信息到uart中.



嵌入式学习交流群:561213221
标签:嵌入式 linux 串口 注册
高级模式
您需要登录后才可以回帖 登录 | 注册

关闭

站长推荐 上一条 /9 下一条

快速回复 返回顶部 返回列表
-

推荐专区

技术干货集中营

专家问答

方案交易

用户帮助┃咨询与建议┃版主议事

工程师杂谈

项目|工程师创意

招聘|求职}工程师职场

论坛电子赛事

社区活动专版

发烧友活动

-

嵌入式论坛

ARM技术论坛

Android论坛

Linux论坛

单片机/MCU论坛

MSP430技术论坛

FPGA|CPLD|ASIC论坛

STM32/STM8技术论坛

NXP MCU 技术论坛

PIC单片机论坛

DSP论坛

瑞萨单片机论坛

嵌入式系统论坛

-

电源技术论坛

电源技术论坛

无线充电技术

-

硬件设计论坛

PCB设计论坛

电路设计论坛

电子元器件论坛

控制|传感

总线技术|接口技术

-

测试测量论坛

LabVIEW论坛

Matlab论坛

测试测量技术专区

仪器仪表技术专区

-

EDA设计论坛

multisim论坛

PADS技术论坛

Protel|AD|DXP论坛

Allegro论坛

proteus论坛|仿真论坛

EasyEDA-中国人自已的EDA工具

Orcad论坛

-

综合技术与应用

电机控制

智能电网

光电及显示

工程资源中心

汽车电子技术论坛

医疗电子论坛

-

开源硬件

-

无线通信论坛

无线通信技术专区

天线|RF射频|微波|雷达技术

-

IC设计论坛

芯片测试与失效分析

Mixed Signal/SOC[数模混合芯片设计]

Analog/RF IC设计

设计与制造封装测试

-

厂商专区

TI论坛

TI Deyisupport社区

-

检测技术与质量

电磁兼容(EMC)设计与整改

安规知识论坛

检测与认证

-

消费电子论坛

手机技术论坛

平板电脑/mid论坛

音视/视频/机顶盒论坛

-

电子论坛综合区

聚丰众筹官方社区

新人报道区

聚丰供应链

-

论坛服务区

-

供求信息发布

供需广告

电子展览展会专区

芯片求购|供应发布区