mirror of
https://github.com/yaakov-h/scream-driver.git
synced 2024-11-22 01:14:49 +00:00
try register, get -EBUSY?
This commit is contained in:
parent
261aa7269f
commit
d34c97192a
1 changed files with 83 additions and 6 deletions
89
scream.c
89
scream.c
|
@ -1,20 +1,97 @@
|
|||
#include <linux/init.h>
|
||||
#include <linux/module.h>
|
||||
#include <linux/uaccess.h>
|
||||
#include <linux/init.h>
|
||||
#include <linux/fs.h>
|
||||
#include <linux/proc_fs.h>
|
||||
#include <linux/cdev.h>
|
||||
#include <linux/device.h>
|
||||
#include <linux/uaccess.h>
|
||||
|
||||
MODULE_AUTHOR("Yaakov");
|
||||
MODULE_DESCRIPTION("Scream Device");
|
||||
MODULE_LICENSE("GPL");
|
||||
|
||||
#define DEVICE_NAME "scream_device"
|
||||
#define CLASS_NAME "scream_class"
|
||||
|
||||
static int major_number;
|
||||
static struct class* scream_class = NULL;
|
||||
static struct device* scream_device = NULL;
|
||||
static struct cdev scream_cdev;
|
||||
|
||||
static int scream_device_open(struct inode*, struct file*);
|
||||
static int scream_device_release(struct inode*, struct file*);
|
||||
static ssize_t scream_device_read(struct file*, char*, size_t, loff_t*);
|
||||
|
||||
static struct file_operations fops = {
|
||||
.open = scream_device_open,
|
||||
.read = scream_device_read,
|
||||
.release = scream_device_release,
|
||||
};
|
||||
|
||||
static int __init scream_module_init(void) {
|
||||
printk(KERN_INFO "Module init");
|
||||
return 0;
|
||||
printk(KERN_INFO "[scream] loading...\n");
|
||||
|
||||
if (alloc_chrdev_region(&major_number, 0, 1, DEVICE_NAME) < 0) {
|
||||
printk(KERN_ALERT "[scream] Failed to register a major number.\n");
|
||||
return major_number;
|
||||
}
|
||||
|
||||
scream_class = class_create(CLASS_NAME);
|
||||
if (IS_ERR(scream_class)) {
|
||||
unregister_chrdev_region(major_number, 1);
|
||||
printk(KERN_ALERT "[scream] Failed to register device class\n");
|
||||
return PTR_ERR(scream_class);
|
||||
}
|
||||
|
||||
scream_device = device_create(scream_class, NULL, MKDEV(major_number, 0), NULL, DEVICE_NAME);
|
||||
if (IS_ERR(scream_device)) {
|
||||
class_destroy(scream_class);
|
||||
unregister_chrdev_region(major_number, 1);
|
||||
printk(KERN_ALERT "[scream] Failed to create the device\n");
|
||||
return PTR_ERR(scream_device);
|
||||
}
|
||||
|
||||
// Initialize the cdev structure and add it to the kernel
|
||||
cdev_init(&scream_cdev, &fops);
|
||||
int add_result = cdev_add(&scream_cdev, MKDEV(major_number, 0), 1);
|
||||
if (add_result < 0) {
|
||||
device_destroy(scream_class, MKDEV(major_number, 0));
|
||||
class_destroy(scream_class);
|
||||
unregister_chrdev_region(major_number, 1);
|
||||
printk(KERN_ALERT "[scream] Failed to add cdev: %d\n", add_result);
|
||||
return -1;
|
||||
}
|
||||
|
||||
printk(KERN_INFO "[scream] loaded.\n");
|
||||
return 0;
|
||||
}
|
||||
|
||||
static void __exit scream_module_exit(void) {
|
||||
printk(KERN_INFO "Module exit");
|
||||
printk(KERN_INFO "[scream] exiting...\n");
|
||||
|
||||
cdev_del(&scream_cdev);
|
||||
device_destroy(scream_class, MKDEV(major_number, 0));
|
||||
class_destroy(scream_class);
|
||||
unregister_chrdev_region(major_number, 1);
|
||||
|
||||
printk(KERN_INFO "[scream] done.\n");
|
||||
}
|
||||
|
||||
static int scream_device_open(struct inode* node, struct file* file)
|
||||
{
|
||||
printk(KERN_INFO "[scream] opening device.\n");
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int scream_device_release(struct inode* node, struct file* file)
|
||||
{
|
||||
printk(KERN_INFO "[scream] releasing device.\n");
|
||||
return 0;
|
||||
}
|
||||
|
||||
static ssize_t scream_device_read(struct file* file, char* __user user_buffer, size_t size, loff_t* offset)
|
||||
{
|
||||
printk(KERN_INFO "[scream] reading from device.\n");
|
||||
return 0;
|
||||
}
|
||||
|
||||
module_init(scream_module_init);
|
||||
|
|
Loading…
Reference in a new issue