1.mybinder.c
#include <linux/miscdevice.h> #include <linux/delay.h> #include <linux/kernel.h> #include <linux/module.h> #include <linux/init.h> #include <linux/mm.h> #include <linux/fs.h> #include <linux/types.h> #include <linux/delay.h> #include <linux/moduleparam.h> #include <linux/slab.h> #include <linux/errno.h> #include <linux/ioctl.h> #include <linux/cdev.h> #include <linux/string.h> #include <linux/list.h> #include <linux/pci.h> #include <linux/gpio.h> static int mybinder_open(struct inode *nodp, struct file *filp) { return 0; } static int mybinder_mmap(struct file *filp, struct vm_area_struct *vma) { return 0; } static long mybinder_ioctl(struct file *filp, unsigned int cmd, unsigned long arg) { return 0; } static unsigned int mybinder_poll(struct file *filp,struct poll_table_struct *wait) { return 0; } static int mybinder_flush(struct file *filp, fl_owner_t id) { return 0; } static int mybinder_release(struct inode *nodp, struct file *filp) { return 0; } static const struct file_operations mybinder_fops = { .owner = THIS_MODULE, .poll = mybinder_poll, .unlocked_ioctl = mybinder_ioctl, .mmap = mybinder_mmap, .open = mybinder_open, .flush = mybinder_flush, .release = mybinder_release, }; static struct miscdevice mybinder_miscdev = { .minor = MISC_DYNAMIC_MINOR, .name = "mybinder", .fops = &mybinder_fops }; static int __init mybinder_init(void) { int ret; ret = misc_register(&mybinder_miscdev); return ret; } device_initcall(mybinder_init); MODULE_LICENSE("GPL v2");
2.main.c
#include <unistd.h> #include <stdio.h> #include <stdlib.h> #include <string.h> #include <fcntl.h> #include <linux/fb.h> #include <sys/mman.h> #include <sys/ioctl.h> int main(int argc , char *argv[]) { int fd; fd = open("/dev/mybinder",O_RDWR); if(fd < 0) { printf("open failn"); exit(1); } printf("fd = %d\n",fd); close(fd); return 0; }