为什么ioctl会返回“糟糕的地址”

前端之家收集整理的这篇文章主要介绍了为什么ioctl会返回“糟糕的地址”前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

我使用下面的代码从嵌入式电路板的SPI端口输出数据(olimex imx233-micro – 它不是特定于电路板的问题).当我运行代码ioctl返回“坏地址”.我正在修改http://twilight.ponies.cz/spi-test.c上的代码,工作正常.谁能告诉我我做错了什么?

root@ubuntu:/home# gcc test.c -o test
test.c:20: warning: conflicting types for ‘msg_send’
test.c:16: note: prevIoUs implicit declaration of ‘msg_send’ was here
root@ubuntu:/home# ./test
errno:Bad address - cannot send SPI message
root@ubuntu:/home# uname -a
Linux ubuntu 3.7.1 #2 Sun Mar 17 03:49:39 CET 2013 armv5tejl GNU/Linux

码:

//test.c
#include dio.h>
#include 

谢谢!

最佳答案
错误消息“错误地址”来自错误代码EFAULT,当您将地址传递给内核时会发生这种情况,该内核不是进程虚拟地址空间中的有效虚拟地址. tr结构的地址显然是有效的,因此问题必须与其中一个成员有关.

根据definition of struct spi_ioc_transfer,.tx_buf和.rx_buf成员必须是指向用户空间缓冲区的指针,或者为null.您将.tx_buf设置为整数254,它不是有效的用户空间指针,因此这是坏地址的来源.

我不熟悉这个IOCTL,所以我最好的猜测是你需要用二进制来对数据进行低音.一种方法是这样做:

struct spi_ioc_transfer tr = {
    .len = sizeof(msg),// Length of rx and tx buffers
     ...
    .tx_buf = (u64)&msg,// Pointer to tx buffer
    ...
};

如果您需要将其作为ASCII发送,那么您应该使用诸如snprintf(3)之类的函数将整数转换为ASCII字符串,然后将TX缓冲区指向该字符串并相应地设置长度.

猜你在找的Linux相关文章