转载地址:http://blog.youkuaiyun.com/zmc1216/article/details/34473197
项目中用到串口通信,但是这个串口也用于控制台。为了保证串口通信时不能有控制台发出的消息,需要关闭打印。
在测试过程中发现,有三种类型的打印,一是uboot的打印,在Starting kernel ...之前的打印都是;二是prink的打印,linux kernel不能用printf,对应的输出函数是printk,它的实现在kernel/printk.c中;三是应用层的printf。
1、去掉printk打印
在linux内核中的/kernel目录下printk.c文件中有一个函数:
static void __call_console_drivers(unsigned long start, unsigned long end)
{
struct console *con;
for (con = console_drivers; con; con = con->next) {
if ((con->flags & CON_ENABLED) && con->write)
con->write(con, &LOG_BUF(start), end - start);
}
}
去掉如下两行重新编译内核即可:
if ((con->flags & CON_ENABLED) && con->write)
con->write(con, &LOG_BUF(start), end - start);
2、标准输出、标准错误输出重定向
int main() { int pid = 0; // fork a worker process if (pid = fork()) { // wait for completion of the child process int status; waitpid(pid, &status, 0); } else { // open /dev/null int fd_null = open("/dev/null",
O_RDWR
); if(dup2(fd_null, 1) == -1) return 1; if(dup2(fd_null, 2) == -1) return 1; XX_run(); } return 0; }
我将标准输出和错误输出重定向到/dev/null中
如果我没有将输出重定向,只是关闭输出,close(1) close(2),程序经常出现错误,这个还需要继续研究。