我在使用此系统调用时遇到了一些问题,可能还有kmalloc。
好吧,基本上我正在构建一个系统调用,这个系统调用和内核编译没有问题。 但是,当我调用系统调用时,shell会显示大量消息,然后计算机崩溃。
我认为问题出在 kmalloc 上,因为当我删除 kmalloc 以及包含 kmalloc 的其他代码时,系统调用才有效完美。
例如:bloqueados = kmalloc(sizeof(struct bloqueio),GFP_ATOMIC);
添加: 也许这是一个僵局,但我不确切地知道。
谢谢。
这是代码:
#include <linux/linkage.h>
#include <linux/io_block_unblock.h>
//#include <linux/printk.h>
#include <linux/kernel.h>
#include <linux/unistd.h>
#include <linux/stddef.h>
#include <linux/slab.h>
#include <linux/gfp.h>
#include <linux/unistd.h>
#include <linux/uaccess.h>
#include <linux/fs.h>
#include <linux/mount.h>
#include <linux/genhd.h>
#include <linux/device.h>
struct bloqueio *bloqueados;
EXPORT_SYMBOLL(bloqueados);
asmlinkage long sys_io_block(const char __user *particao, const char __user *arquivo){
int id_inode;
struct file *arq;
char *part;
struct bloqueio *tmp;
arq = filp_open(arquivo,O_CREAT, S_IRWXU);
printk(KERN_EMERG "\nstruct file criado para o arquivo %s",arquivo);
id_inode = arq->f_path.dentry->d_inode->i_ino;
printk(KERN_EMERG "\nO inode do arquivo %s e %d",arquivo, id_inode);
//part = arq->f_path.mnt->mnt_sb->s_bdev->bd_part->__dev.init_name;
//printk(KERN_EMERG "\nA particao a qual o arquivo se encontra e %s",part);
if(bloqueados == NULL){
bloqueados = kmalloc(sizeof(struct bloqueio),GFP_ATOMIC);//<--------------
if(!bloqueados){
printk(KERN_EMERG "\n Erro ao alocar memoria");
return 0;
}
bloqueados->inode = id_inode;
bloqueados->tipo = 0;
bloqueados->prox = NULL;
}
else
{
tmp = kmalloc(sizeof(struct bloqueio), GFP_ATOMIC);//<--------------------
if(!bloqueados){
printk(KERN_EMERG "\n Erro ao alocar memoria");
return 0;
}
tmp->inode = id_inode;
tmp->tipo = 0;
tmp->prox = bloqueados->prox;
bloqueados->prox = tmp;
}
return 1;
}
添加,这是struct bloqueio。
extern int contem(const char *arquivo);
struct bloqueio{
int inode;
int tipo; // 0 -> arquivo 1 -> partição
struct bloqueio *prox;
};
extern struct bloqueio *bloqueados;
答案 0 :(得分:0)
显然我还不能评论,所以我会问几个问题作为答案......
我看到“EXPORT_SYMBOLL(bloqueados);” ...这是您的复制/粘贴中的错误类型还是在实际代码中输入错误?这可能是一个问题...
您使用GFP_ATOMIC与GFP_KERNEL的原因是什么?
这可能有所帮助,
http://www.linuxjournal.com/article/6930
如果您不完全需要它,建议不要使用GFP_ATOMIC ...因为它可能会失败。我可能会遗漏一些东西,但我不明白你为什么需要它...你似乎没有使用任何锁。