免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 16941 | 回复: 1
打印 上一主题 下一主题

[操作系统] telnet登陆目标板无法接收printf打印信息 [复制链接]

论坛徽章:
0
1 [报告]
发表于 2012-01-31 15:45 |显示全部楼层
这是不可能达到的:
1. 内核的printk把信息打到哪里去呢?这是在内核的命令行参数console=ttyXXX里指定死了,比如console=ttySAC0表示printk的信息输出到串口0
2. telnet上去之后,printf的输出信息是输出到一个“虚拟的终端”去的,你可以用ps命令看一下这个telnet对应的/bin/sh进程ID,ls  /proc/进程ID/fd -l 就可以知道这个虚拟的终端对应什么文件。
  你可以看到0、1、2这3个文件都是对应一个“临时生成的虚拟的文件”
3. 所以,内核的信息不可能在telnet界面显示出来,你想看的话,可以为dmesg命令查看

论坛徽章:
0
2 [报告]
发表于 2012-01-31 17:38 |显示全部楼层
每次telnet上去,就会生成一个/dev/pts/x文件,每次都不会相同的;
你telnet上去后,会有一个/bin/sh,在这个/bin/sh里启动应用程序,那么这个/bin/sh就是这个应用程序的父进程;当你把这个telne连接关闭后,/bin/sh会退出,它的子进程也会退出。
所以你说的“再次telnet到目标板,就无法收到应用程序的打印信息”,原因是这个应用程序早就死掉了。


应用程序的打印信息,与它的父进程的0、1、2三个文件相关。在telnet界面,这3个文件对应虚拟的设备。
根据这个原理,你可以在应用程序里close(0),close(1),close(2),然后再打开3个文件,这样printf就可以输出到这些文件去了。
通常的做法是:不直接用printf,而是自己实现打印,打到文件去、或是发到服务器去。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP