新手求教!!hello world模块,但是想在insmod和remod的时候从/dev/ttyS1输出信息。
如题。应该需要在模块中编写open,write的吧,可是不知道怎么写,有什么可参考的吗???? ldd3没看过吗或看看这个同志的
http://bbs.chinaunix.net/thread-2021361-1-1.html
回复 2# wwxxxxll
看过ldd3了,可是效果不大。还是不知道怎么在内核层打开串口并输出。 我不知道你是在pc还是某嵌入时平台上
先说你的问题,怎么在内核层打开串口并输出
你的问题是不是uart怎么做console?
如果是,我随便打开一个驱动serial_txx9.c
就这句
static int __init serial_txx9_console_init(void)
{
register_console(&serial_txx9_console);
return 0;
}
console_initcall(serial_txx9_console_init);
启动时会调用,这个函数应该可以回答你的问题
假设你有几个串口
你要在应用层用一个输出
我给你个例子
#include <fcntl.h>
#include <sys/stat.h>
#include <unistd.h>
#include <termios.h>
static int open_port(void)
{
long vdisable;
int fd;
fd = open("/dev/ttyWXL1", O_RDWR|O_NOCTTY|O_NDELAY);//注意你的设备名
if (-1 == fd)
{
perror("Can't Open Serial Port %s");
return(-1);
}
return fd;
}
static int set_opt(int fd,int nSpeed, int nBits, char nEvent, int nStop)
{
struct termios newtio, oldtio;
if ( tcgetattr( fd,&oldtio) != 0)
{
printf("SetupSerial 1");
return -1;
}
bzero( &newtio, sizeof( newtio ) );
newtio.c_cflag |= CLOCAL | CREAD;
newtio.c_cflag &= ~CSIZE;
switch( nBits )
{
case 7:
newtio.c_cflag |= CS7;
break;
case 8:
newtio.c_cflag |= CS8;
break;
}
switch( nEvent )
{
case 'O':
newtio.c_cflag |= PARENB;
newtio.c_cflag |= PARODD;
newtio.c_iflag |= (INPCK | ISTRIP);
break;
case 'E':
newtio.c_iflag |= (INPCK | ISTRIP);
newtio.c_cflag |= PARENB;
newtio.c_cflag &= ~PARODD;
break;
case 'N':
newtio.c_cflag &= ~PARENB;
break;
}
switch( nSpeed )
{
case 2400:
cfsetispeed(&newtio, B2400);
cfsetospeed(&newtio, B2400);
break;
case 4800:
cfsetispeed(&newtio, B4800);
cfsetospeed(&newtio, B4800);
break;
case 9600:
cfsetispeed(&newtio, B9600);
cfsetospeed(&newtio, B9600);
break;
case 115200:
cfsetispeed(&newtio, B115200);
cfsetospeed(&newtio, B115200);
break;
default:
cfsetispeed(&newtio, B9600);
cfsetospeed(&newtio, B9600);
break;
}
if ( nStop == 1 )
{
newtio.c_cflag &= ~CSTOPB;
}
else if ( nStop == 2 )
{
newtio.c_cflag |= CSTOPB;
}
newtio.c_cc = 0;
newtio.c_cc= 0;
tcflush(fd,TCIFLUSH);
if ((tcsetattr(fd,TCSANOW,&newtio))!=0)
{
printf("com set error");
return -1;
}
return 0;
}
int main(void)
{
int fd;
fd = open_port();
char buffer;
memset(buffer, 0, 256);
set_opt(fd,115200,8,'N',1);
//write(fd, "wxl", 3);
while (read(fd,buffer,sizeof(buffer)) == 0);
//printf("%s\n", buffer);
close(fd);
return 0;
}
这是之前测试我的一个uart_tty驱动
这只是应用层的调用方法
回复 4# wwxxxxll
先谢谢您的回答,我是在pc上做的,说白了就是做一个在被加载时能从UART输出一串文字的驱动程序。 如果在应用层,就是我的例子
如果是内核,我不知道内核有提供什么可以调用串口的,按我的理解除非uart驱动提供EXPORT_SYMBOL(...)
让你在内核调用。
我不知道你对硬件寄存器多了解,如果我是在我的板子做这个功能,简单的处理,我直接去操作uart的寄存器。 回复 6# wwxxxxll
在用户层的话你那个例子的确可行,之前我也写过一个差不多的。可是现在师傅说要写一个在被加载时能从UART输出一串文字的驱动程序,摸不着头脑啊。我再摸索摸索吧,谢谢了。 我想起来来了,你知道内核可以通过uevent和mdev或udev去调用应用层,当然还有如call_usermodehelper
http://www.cnblogs.com/hoys/archive/2012/03/13/2395232.html
linux直接运行用户空间程序
这都是研究热插拔时看到的
你只要在用户态做个C程序调用system("echo "abc" > /dev/ttyS1");就查不多了。
考虑一下call_usermodehelper,我没具体用过,看看贴子,自己研究吧!
插个广告:有兴趣加入里面,相信群众的力量
qq: 2379374402
群:163617970
页:
[1]