copy_from_user 的问题

发布于 2022-09-22 10:53:48 字数 1489 浏览 8 评论 0

源程序如下:
驱动部分:
static ssize_t ds18b20_write(struct file *file,const char *buffer, size_t count,loff_t *f_pos)
{
static char *data;
char temp;
int i,dat=0;

kfree(data);

data = (char *)kmalloc(sizeof(char)*(count+1),GFP_KERNEL);

copy_from_user(data,buffer,count+1);

temp=*data;
printk("write temp=%x\n",temp);

........
return count;
}

应用程序如下:
int main (void)
{.....
char *buf1;
......
*buf1=0xCC;
.....
fd=open(ds18b20,O_RDWR);
......
if((len=write(fd,buf1,strlen(buf1)))<0)
{ perror("write:");
exit(1);}
else printf("write:%x\n",*buf1);
......
实际应用中出现的问题是:
# ./ds18b20

the ds18b20 is open now!
open ds18b20 sucess 3
write temp=0 (?????)
pc : [<0200068c>] lr : [<02000660>] Not tainted
sp : bffffe78 ip : 400bff30 fp : bffffeb0
r10: 4010926c r9 : 02000594 r8 : 00000001
r7 : 4001fe94 r6 : 020003e0 r5 : bffffed4 r4 : 00000648
r3 : 000000cc r2 : 00000001 r1 : 000000cc r0 : 00000001
Flags: nzCv IRQs on FIQs on Mode USER_32 Segment user
Control: C000317F Table: 30978000 DAC: 00000015
the ds18b20 is close!
Segmentation fault
请高手指教为什么copy_from_user 没有把CC传入内核驱动中?
copy_from_user(data,buffer,count+1); 函数中传入的数据长度为什么是count+1?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(5

绅士风度i 2022-09-29 10:53:48

一上来就kfree(data);不知道是什么用意?
data = (char *)kmalloc(sizeof(char)*(count+1),GFP_KERNEL); 你申请这么多,所以传那么多。

兮颜 2022-09-29 10:53:48

我要申请的数据长度是count,但是我看到一些例子传参数时都是count+1,所有有些不明白,这是规定的吗?

绿光 2022-09-29 10:53:48

应该不是规定,只是为了防止溢出吧,我觉得这样写没有什么意义。

淡淡離愁欲言轉身 2022-09-29 10:53:48

申请内存应该是多少就多多少把,要多申请一个?

嗳卜坏 2022-09-29 10:53:48

是不是个人习惯啊,要不lz少申请一个单位,运行下看有啥异常没

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文