0

我正在开发设备驱动程序,需要使用 IOCTL。不幸的是,我无法从用户空间复制结构。这是代码(简化,删除了错误处理):

结构

struct secvault_createoptions {
    int secvaultId;
    long dataSize;
    char key[SECVAULT_KEYSIZE];
};

应用

void createSecvault(int secvaultId)
{
    struct secvault_createoptions creationOptions;
    /* fill with data */
    sendIoctlCommand(SECVAULT_IOCTL_CREATE, &creationOptions);
}

void sendIoctlCommand(int command, void *arg)
{
    FILE *stream;
    int fd, err;

    stream = fopen(SECVAULT_DEV_CONTROL, "r");
    fd = fileno(stream);
    ioctl(fd, command, arg);
    fclose(stream);
}

内核模块

int control_device_ioctl(struct inode *node, struct file *filp, unsigned int cmd, unsigned long arg)
{
    struct secvault_createoptions creationOptions;
    int returnCode;

    switch (cmd)
    {
        case SECVAULT_IOCTL_CREATE:
            if (copy_from_user(&creationOptions, (void*)arg, sizeof(struct secvault_createoptions)) != sizeof(struct secvault_createoptions))
            {
                /* Always this branch gets executed */
                printk(KERN_ALERT "Copying secure vault creation options from user space failed.\n");
                returnCode = -EFAULT;
                break;
            }
            printk(KERN_ALERT "2 IOCTL create request on control device received: secvaultId = %d, dataSize = %ld.\n",
                creationOptions.secvaultId, creationOptions.dataSize);

            returnCode = createDataDevice(&creationOptions);
            break;
    }
    return returnCode;
}

最好的问候,
奥利弗·哈纳皮

4

3 回答 3

4

你的copy_from_user电话是错误的。它不返回复制的字节数,而是未复制的字节数。你想要的是

if (copy_from_user(...) != 0)
        return -EFAULT;

(您可以ret在代码段中跳过作业。)

于 2011-01-08T17:01:08.467 回答
3

copy_from_user()返回无法复制的字节数。所以你应该期待0成功,而不是sizeof(struct secvault_createoptions)

于 2011-01-08T17:01:17.323 回答
0

您应该将语句修改为 ,

  if (copy_from_user(&creationOptions, (void*)arg, sizeof(struct secvault_createoptions)) != 0)
            {
                /* Always this branch gets executed */
                printk(KERN_ALERT "Copying secure vault creation options from user space failed.\n");
                returnCode = -EFAULT;
                break;
            }

因为copy_from_user成功完成后总是返回 0。

请参阅了解更多详细信息。

于 2014-09-02T06:27:37.663 回答