linux驱动程序中的分段错误

时间:2014-06-22 13:29:56

标签: c linux-kernel segmentation-fault linux-device-driver

我正在尝试编写一个linux驱动程序。内核版本是2.4.18,发行版是Red Hat linux 8.0。

我的驱动程序的代码是:

#define LINUX

#include <linux/kernel.h> /* We're doing kernel work */
#include <linux/module.h> /* Specifically, a module */
#include <linux/fs.h>
#include <asm-i386/semaphore.h>
#include "rng.h"
#include <linux/random.h>
#include <linux/slab.h>

#define DEVICE_NAME "rng"
#define BUF_LEN 80

static int major;
int init_module();
void cleanup_module();
static int device_open(struct inode *, struct file *);
static int device_release(struct inode *, struct file *);

struct file_operations my_fops = {
  open: device_open,
  release: device_release,
};


/* Init and Cleanup */

int init_module() {
   SET_MODULE_OWNER(&my_fops);
   major = register_chrdev(0, DEVICE_NAME, &my_fops);
   return 0;
}

void cleanup_module() {

   int ret = unregister_chrdev(major, DEVICE_NAME);
   if (ret < 0)
       printk("Error in unregister_chrdev: %d\n", ret);

}

static int device_open(struct inode *inode, struct file *file) {
   file->f_op=&my_fops;
   return 1;
}

static int device_release(struct inode *inode, struct file *file) {
   return 0;
}

我用来测试我的驱动程序的代码是:

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

int openTest() {
    int game1 = open("/dev/game1", O_RDONLY); // SEGMENTATION FAULT
    int retValue=1;

    close(game1);
    return retValue;
}

int main() {
    int res;
    if (openTest() < 1) {
       fprintf(stderr, "open didnt work\n");
    return -1;
    }
    fprintf(stderr, "everything works :)\n");
    return 0;
}

在上面的代码中,当我试图打开设备时,我遇到了分段错误。有人可以向我解释为什么我会出现这种分段错误吗?我真的不明白。

非常感谢!

2 个答案:

答案 0 :(得分:3)

在Linux内核中,通常在没有错误时返回0(零)。您的device_open()例程被硬编码以返回1(一),这可能导致您的段错误。

This Linux Device Drivers本书可能对您有所帮助。链接版本是为内核2.0.x - 2.4.x编写的,因此该信息应该适用于您正在使用的尘土飞扬和古老的内核。

答案 1 :(得分:-1)

这一行似乎有误file->f_op=&my_fops;

基本上,当编写 linux 驱动程序时,会在构建时自行设置操作。