编写字符设备驱动遇到的问题

 

这是一个简单的字符驱动程序,在初始化和退出的时候显示一段话

 

 

#ifndef __KERNEL__

#define __KERNEL__

#endif

#ifndef MODULE

#define MODULE

#endif

 

#include <linux/module.h>

#include <linux/kernel.h>

#include <linux/init.h>

 

static int __init hello_init(void)

{

printk("hello world!/n");

return 0;

}

 

void __exit hello_exit(void)

{

printk("bye!/n");

}

 

module_init(hello_init);

module_exit(hello_exit);

 

MODULE_LICENSE("GPL");

 

 

 

//

以下是我写的Makefile

 

 

ifneq ($(KERNELRELEASE),)

 

obj-m:=test.o

 

else

KERNELDIR=/lib/modules/$(shell uname -r)/build

 

PWD:=$(shell pwd)

 

default:

 

$(MAKE) -C $(KERNELDIR) M=$(PWD) modules

 

clean:

 

rm -rf *.o *.mod.c *.mod.o *.ko

endif

 

 

/

我make出test.ko文件 然后sudo insmod test.ko 加载驱动,之后在/dev文件下面用sudo mknod test c 254 0   ,来创建节点,这样驱动就加载好了,但后写一个简单到不能再简单的测试程序

 

 

#include <stdio.h>

#include <stdlib.h>

#include <time.h>

#include <linux/i2c.h>

#include <linux/fcntl.h>

 

int main()

{

        int fd;

        if((fd=open("/dev/test",O_RDWR))==-1)

 

{

printf("opened!/n");

}

        else

        {

                printf("Fail!/n");

 

        }

}

但是最后执行的结果却是这样
dickens@ubuntu:~/123$ ./tmp
opened!
就是说只打印出了测试程序中的话,按道理设备已经打开了,也就应该执行初始化程序中的那个printk但是实际没有,这是怎么回事?!
===================================给力的分割线======================================
问题解决了,是这样的
驱动打印了。只有在字符模式下才能看到这个。进入图形界面,是看不到这个打印语句的
要用dmesg看才行,printk不能输出到用户空间,如果要的话应该是copy_to_user

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值