gpt4 book ai didi

linux - 从 linux 内核模块中读出大数组

转载 作者:塔克拉玛干 更新时间:2023-11-02 23:11:45 25 4
gpt4 key购买 nike

我已经搜索了很多,虽然我肯定可能错过了一些东西,而且我来自阅读 http://tldp.org/LDP/lkmpg/2.6/html/lkmpg.html还有这个http://www.amazon.com/Essential-Device-Drivers-Sreekrishnan-Venkateswaran/dp/0132396556 ,但我在读取我在我的 linux 内核模块中创建的大数组时遇到了问题 ~200kB。我正在开发基于 ARM 的 ti-omap3530。我这样分配数组:

static unsigned int* captured_params;
static unsigned int* time_params;

captured_params=vmalloc(3500*7*sizeof(unsigned int));
time_params=vmalloc(3500*7*sizeof(unsigned int));

我的读取函数看起来像这样(我意识到我这样做可能不是最好的方法):

ssize_t tgdev_read(struct file *file, char *buf, size_t count, loff_t *ppos){
/*This file will expect reads in 8-byte chunks, 4 for the data parameter
and 4 for the time parameter*/

struct tg_dev *tg_devp = file->private_data;
unsigned int num_pairs=sample_counter;
static unsigned int pairs_out=0;
static unsigned int sent_successfully=0;
unsigned int* param_ptr;
unsigned int* time_ptr;
pairs_out=(tg_devp->current_pointer)/8;
num_pairs=sample_counter;

if(pairs_out==num_pairs){//all returned end of file
return 0; //EOF
}
while((pairs_out*8)<count){
//update data pointers
time_ptr=&time_params[pairs_out];
param_ptr=&captured_params[pairs_out];
//send user time first
sent_successfully=copy_to_user(&buf[tg_devp->current_pointer],time_ptr,4);
//send param value for that time
sent_successfully=copy_to_user(&buf[tg_devp->current_pointer+4],param_ptr,4);
//update number of pairs sent to user
pairs_out+=1;
//update file_pointer
tg_devp->current_pointer +=8;
}
return pairs_out*8;
}

我用这样的用户空间程序读取它:

int fp;
char* mode="r";
char* fname="/dev/my_device";
unsigned int param[3500*7]={0};
unsigned int time[3500*7]={0};
unsigned int* param_ptr;
unsigned int* time_ptr;
char buff[3500*7*4*2];
int i=0;
int rc=0;
int completed_reads;

fp=open(fname,O_RDONLY);

if(fp<0){
printf("failed to open file EXITING\n");
return 1;
}

rc=read(fp,buff,3500*7*4*2);
completed_reads=(rc-rc%8)/8;
printf("rc=%i cr=%i\n",rc,completed_reads);

for(i=0;i<completed_reads;i++){
param_ptr=&param[i];
time_ptr=&time[i];
memcpy(param_ptr,&buff[i*8],4);
memcpy(time_ptr,&buff[i*8+4],4);
printf("[%i]%u,%u\n",i,param[i],time[i]);
}
close(fp);

用户空间读取总是报告读取了正确的字节数,但我没有得到正确的数据。

如果我用更小的东西替换上面的 3500s(最多 1000 表现得很好),这个解决方案似乎工作正常,但在上面我得到奇怪的行为,我读出的数组零填充每个数组的最后一个 N(相同2 个数组中每个数组中同一点的元素数)并且在系列中较晚开始,例如time/param[0]= 一些值比我想读出的原始数组更远。

我想这是因为我不太了解内存处理,但我不知道如何让它做我想做的事情,即将这些数据数组存储在模块中直到我想将它们读出到用户空间。如果我有任何错误的建议或想法,我们将不胜感激。

预先感谢您为我付出的时间、努力和耐心。

最佳答案

您可以(应该)避免通过使用 mmap 将数组映射到用户空间进程的地址空间来进行读取。请参阅以下示例:

http://people.ee.ethz.ch/~arkeller/linux/multi/kernel_user_space_howto-8.html

关于linux - 从 linux 内核模块中读出大数组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9798401/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com