Назад | Перейти на главную страницу

Невозможно распечатать сообщение, отправленное из приложения C пользовательского пространства в модуль ядра Linux

Я разработал простой модуль ядра Linux:

#include <linux/init.h>
#include <linux/module.h>
#include <linux/fs.h>


ssize_t exer_open(struct inode *pinode, struct file *pfile) {

    return 0;
}



ssize_t exer_read(struct file *pfile, char __user *buffer, size_t length, loff_t *offset) {

    return 0;
}



ssize_t exer_write(struct file *pfile, const char __user *buffer, size_t length, loff_t *offset) {

    return length;
}



ssize_t exer_close(struct inode *pinode, struct file *pfile) {

    return 0;
}




struct file_operations exer_file_operations = { 
    .owner = THIS_MODULE,
    .open = exer_open,
    .read = exer_read,
    .write = exer_write,
    .release = exer_close,
};




int exer_simple_module_init(void) {

    printk(KERN_ALERT "Inside the %s function\n", __FUNCTION__);
    register_chrdev(240, "Simple Char Drv", &exer_file_operations);
    return 0;
}



void exer_simple_module_exit(void) {

    unregister_chrdev(240, "Simple Char Drv");
}

module_init(exer_simple_module_init);
module_exit(exer_simple_module_exit);

Я вставляю этот модуль в ядро, используя insmod команда без проблем.

Я хочу использовать этот модуль для печати сообщения, отправленного ему программой пользовательского пространства, которую я тоже разработал:

#include<stdio.h>
#include<stdlib.h>
#include<errno.h>
#include<fcntl.h>
#include<string.h>
#include<unistd.h>


int main()

{

int ret, fd;
char stringToSend[] = "Hello World !";


fd = open("/dev/char_device", O_RDWR);             // Open the device with read/write access

if (fd < 0)
    {
            perror("Failed to open the device...");
            return errno;
    }


ret = write(fd, stringToSend, strlen(stringToSend)); // Send the string to the LKM

if (ret < 0)
    {
            perror("Failed to write the message to the device.");
            return errno;
    }

return 0;

}

Когда я запускаю программу и просматриваю журналы ядра, используя tail -f /var/log/messages команда, которую я вижу: user.alert kernel: Inside the exer_read функция Но я не вижу сообщение " Hello World !"

Я не знаю, что мне здесь не хватает. Я новичок в разработке модулей и их использовании.

Вам необходимо использовать концепцию copy_to_user и copy_from_user для чтения данных записи из пользовательского пространства.