驱动:
#include <linux/init.h> //包含宏定義
#include <linux/module.h>
#include <linux/miscdevice.h>
#include <linux/fs.h>
#include <linux/uaccess.h>
#include <linux/io.h>
#define addr 0x30330380
unsigned int *ioaddr;//無符號指針
//int (*open) (struct inode *, struct file *);
int misc_open(struct inode *inode,struct file *file)
{
printk("hello!\n");
return 0;
}
// ssize_t (*read) (struct file *, char __user *, size_t, loff_t *);
ssize_t misc_read(struct file *file,char __user *buf,size_t count,loff_t *pot)
{
char kbuff[32] = "123456";
if(copy_to_user(buf,kbuff,sizeof(kbuff))!=0)
{
printk("read error\n");
return -1;
}
printk("read is %s\n",kbuff);
return sizeof(kbuff);
}
// ssize_t (*write) (struct file *, const char __user *, size_t, loff_t *);
ssize_t misc_write(struct file *file, const char __user *buf, size_t count, loff_t *pot)
{
char buff[32] = {0};
if(copy_from_user(buff,buf,sizeof(buff))!=0)
{
printk("write error\n");
return -1;
}
if(buff[0]==1)
{
printk("up\n");
printk("%x\n",*ioaddr);
*ioaddr |= (1<<6);
printk("%x\n",*ioaddr);
}else if(buff[0]==0)
{
printk("down\n");
printk("%x\n",*ioaddr);
*ioaddr &= ~(1<<6);
printk("%x\n",*ioaddr);
}
printk("write is %s\n",buff);
return sizeof(buff);
}
//int (*release) (struct inode *, struct file *);
int misc_release(struct inode *inode, struct file *file)
{
printk("byebye");
return 0;
}
struct file_operations misc_fops = {
.owner = THIS_MODULE,
.open = misc_open,
.read = misc_read,
.write = misc_write,
.release = misc_release,
};
struct miscdevice demo={
.minor = MISC_DYNAMIC_MINOR,
.name = "misc",
.fops = &misc_fops,
};
static int misc_init(void)
{
int ret = misc_register(&demo); //注冊雜項設備
if(ret < 0){
printk("error\n");
return -1;
}
ioaddr = ioremap(addr,sizeof(unsigned int));//地址指向映射的地址
if(*ioaddr == NULL){
printk("ioremap is error!\n");
return -1;
}
printk("ioremap is OK!\n");
return 0;
}
static void misc_exit(void)
{
iounmap(ioaddr);
misc_deregister(&demo); //注銷雜項設備
}
module_init(misc_init);
module_exit(misc_exit);
MODULE_LICENSE("GPL");
app代码:
#include <stdio.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <unistd.h>
int main(int argc,char *argv[])
{
int fd;
char buf[32] = {0};
char kbuf[32] = {0};
fd = open("/dev/misc",O_RDWR);
if(fd < 0){
perror("open error\n");
return -1;
};
// read(fd,kbuf,sizeof(kbuf));
buf[0] = atoi(argv[1]);
write(fd,buf,sizeof(buf));
close(fd);
return 0;
}