sys v从内核模块到用户空间进程共享内存

时间:2016-06-07 14:35:07

标签: linux-kernel ipc shared-memory kernel-module sysv-ipc

我是Linux内核模块开发的新手,我正在寻找从内核模块到用户空间进程共享内存段以避免复制数据的延迟。

我正在使用sys v共享内存api,当我在两个进程之间共享内存它工作正常,但我无法在进程和内核模块之间共享内存。

bellow是我的内核模块代码和用户空间应用程序

服务器端:模块

#include <linux/module.h> // init_module, cleanup_module //
#include <linux/kernel.h> // KERN_INFO //
#include <linux/types.h> // uint64_t //
#include <linux/kthread.h> // kthread_run, kthread_stop //
#include <linux/delay.h> // msleep_interruptible //
#include <linux/syscalls.h> // sys_shmget //

#define BUFSIZE 100
#define SHMSZ BUFSIZE*sizeof(char)
key_t KEY = 5678;

static struct task_struct *shm_task = NULL;


static char *shm = NULL;
static int shmid;

static int run_thread( void *data )
{
    char strAux[BUFSIZE];
    shmid = sys_shmget(KEY, SHMSZ, IPC_CREAT | 0666);
    if( shmid < 0 )
    {
        printk( KERN_INFO "SERVER : Unable to obtain shmid\n" );
        return -1;
    }
    shm = sys_shmat(shmid, NULL, 0);
    if( !shm )
    {
        printk( KERN_INFO "SERVER : Unable to attach to memory\n" );
        return -1;
    }
    strncpy( strAux, "hello world from kernel module", BUFSIZE );
    memcpy(shm, strAux, BUFSIZE);
    return 0;
}

int init_module()
{
    printk( KERN_INFO "SERVER : Initializing shm_server\n" );
    shm_task = kthread_run( run_thread, NULL, "shm_server" );
    return 0;
}

void cleanup_module()
{
    int result;
    printk( KERN_INFO "SERVER : Cleaning up shm_server\n" );
    result = kthread_stop( shm_task );
    if( result < 0 )
    {
        printk( KERN_INFO "SERVER : Unable to stop shm_task\n" );
    }
    result = sys_shmctl( shmid, IPC_RMID, NULL );
    if( result < 0 )
    {
        printk( KERN_INFO
        "SERVER : Unable to remove shared memory from system\n" );
    }

}


MODULE_LICENSE( "GPL" );
MODULE_AUTHOR( " MBA" );
MODULE_DESCRIPTION( "Shared memory  server" );

客户端:流程

#include <sys/ipc.h> // IPC_CREAT, ftok //
#include <sys/shm.h> // shmget, ... //
#include <sys/sem.h> // semget, semop //
#include <stdio.h> // printf //
#include <string.h> // strcpy //
#include <stdint.h> // uint64_t //

#define BUFSIZE 4096
key_t KEY = 5678;

int main(int argc, char *argv[]) {
    int shmid, result;
    char *shm = NULL;

    shmid = shmget(KEY, BUFSIZE, 0666);
    if (shmid == -1) {
        perror("shmget");
        exit(-1);
    }
    shm = shmat(shmid, NULL, 0);
    if (!shm) {
        perror("shmat");
        exit(-1);
    }

    printf("%s\n", shm);
    result = shmdt(shm);
    if (result < 0) {
        perror("shmdt");
        exit(-1);
    }
}

任何建议或文件都可以提供帮助。

1 个答案:

答案 0 :(得分:0)

系统调用不适合内核使用:它们仅用于用户程序。此外,sys v内存共享不太可能适用于内核线程。

内核和内核模块有自己的机制来与用户交互 空间。对于共享内存,您的内核模块可以为它实现字符设备和mmap方法,它将内核的已分配内存映射到用户。请参阅 Linux设备驱动程序(3d版)中的此类# Data Structures ## Article (object) Represents an article ## Properties + id: 1 (number, optional) + name: My first article (string) ## Articles [/articles] ### Get all articles [GET] Get all articles available on this website. + Response 200 (application/json) + Attributes (array[Article]) ### Create an article [POST] Create new article. + Request (application/json) + Attributes (Article) 实现示例,第15章。