【Linux】【驱动】应用层和驱动层传输数据
- 绪论
- 1.如果我在应用层使用系统0 对设备节点进行打开,关闭,读写等操作会发生什么呢?
- 2 我们的应用层和内核层是不能直接进行数据传输的
- 3 驱动部分的代码
- 4 应用代码
- 5 编译以及运行代码
绪论
Linux一切皆文件!
文件对应的操作有打开,关闭,读写设备节点对应的操作有打开,关闭,读写
1.如果我在应用层使用系统0 对设备节点进行打开,关闭,读写等操作会发生什么呢?
当我们在应用层 read 设备节点的时候,就会触发我们驱动里面read 这个函数
ssize t (*read) (struct file *, char user *, size t, loff t *);
当我们在应用层 write 设备节点的时候,就会触发我们驱动里面 write 这个函数
ssize t (*write) (struct file *, const char user *, size t, loff t *);
unsigned int (*poll) (struct file *, struct poll table struct *);
long (*unlocked ioctl) (struct file *, unsigned int, unsigned long);
int (*open) (struct inode *, struct file *);
int (*release) (struct inode *, struct file *);
2 我们的应用层和内核层是不能直接进行数据传输的
如下两个代码实现了数据的交互
static inline long copy from user(void *to, const void user * from, unsigned long n)
static inline long copy to user(voiduser *to, const void *from, unsigned long n)
3 驱动部分的代码
#include <linux/init.h>
#include <linux/module.h>
#include <linux/miscdevice.h>
#include <linux/fs.h>
#include <linux/uaccess.h>
int misc_open(struct inode *inode, struct file *file)
{
printk("misc_open\n");
return 0;
}
int misc_release(struct inode *inode, struct file *file)
{
printk("misc_release\n");
return 0;
}
ssize_t misc_read(struct file *file,char __user *ubuf,size_t size,loff_t *loff_t)
{
char kbuf[512] = "haha";
if(copy_to_user(ubuf,kbuf,strlen(kbuf))!=0)
{
printk("error copying\n");
return -1;
}
return 0;
}
ssize_t misc_write(struct file *file,const char __user *ubuf,size_t size,loff_t *loff_t)
{
char kbuf[512] = {0};
if(copy_from_user(kbuf,ubuf,size)!= 0)
{
printk("misc_write error\n");
return -1;
}
printk("kbuf = %s\n",kbuf);
return 0;
}
struct file_operations misc_fops = {
.owner = THIS_MODULE,
.open = misc_open,
.release = misc_release,
.read = misc_read,
.write = misc_write
};
struct miscdevice misc_dev =
{
.minor = MISC_DYNAMIC_MINOR,
.name = "hello_misc",
.fops = &misc_fops
};
//drivers for init
static int misc_init(void)
{
int ret = 0;
ret = misc_register(&misc_dev);
if(ret<0)
{
printk("misc_register is failed\n");
return -1;
}
printk("misc registe is succeed \n");
return 0;
}
//drivers for exit
static void misc_exit(void)
{
//
misc_deregister(&misc_dev);
printk("misc exit \n");
}
module_init(misc_init);
module_exit(misc_exit);
MODULE_LICENSE("GPL");
4 应用代码
write就是实现了write的功能
read 函数就是实现了read的功能
#include "stdio.h"
#include "unistd.h"
#include "sys/types.h"
#include "sys/stat.h"
#include "fcntl.h"
#include "stdlib.h"
#include "string.h"
/*
* @description : main主程序
* @param - argc : argv数组元素个数
* @param - argv : 具体参数
* @return : 0 成功;其他 失败
*/
int main(int argc, char *argv[])
{
int fd;
char buf[64] = "12345";
//fd = open(argv[1], O_RDONLY);
fd = open("/dev/hello_misc", O_RDWR);
if(fd < 0)
{
perror("open error");
return fd;
}
//write(fd,buf,sizeof(buf));
//printf("buf is %s\n",buf);
write(fd,buf,sizeof(buf));
close(fd);
return 0;
}
5 编译以及运行代码
编译app代码
arm-buildroot-linux-gnueabihf-gcc -o miscApp miscApp.c
挂载nfs盘
mount -t nfs -o nolock,vers=3 192.168.5.15:/home/book/nfs_rootfs /mnt
移动到mnt目录
cd /mnt
删除文件
rm -f + chrdevbase.ko
移动代码
cp miscApp /home/book/nfs_rootfs/
允许printk输出
echo "7 4 1 7"> /proc/sys/kernel/printk
安装驱动
insmod chrdevbase.ko
列出驱动
lsmod
删除驱动
remmod
运行代码
./miscApp