2228
- 收藏
- 点赞
- 分享
- 举报
hi3516a spi连续写数据出错
通过hi3516a的SPI接口,连续写数据,10个数据的时候正常,超过10个数据就失败,代码如下:
int i, retval = 0;
unsigned char buf[4098];
struct spi_ioc_transfer mesg[1];
unsigned char dev_addr=0x7e, reg_addr=0x22;
memset(mesg, 0, sizeof mesg);
if (length > 4094) length = 4094;
mesg[0].tx_buf = (__u32)buf;
mesg[0].rx_buf = (__u32)buf;
mesg[0].len = 2 + length;
mesg[0].cs_change = 1;
mesg[0].bits_per_word = 8;
mesg[0].speed_hz = 2000000;
printf("mesg.len=%d, speed=%dhz\n", mesg[0].len, mesg[0].speed_hz);
memset(buf, 0, sizeof buf);
buf[0] = dev_addr & 0x7f;
buf[1] = reg_addr & 0xff;
memcpy(buf+2, packet, length);
for(i=0; i
printf("%02X ", buf);
printf("\n");
retval = ioctl(gs_SpiFd, SPI_IOC_MESSAGE(length), mesg);
if (retval != mesg[0].len)
{
printf("ERR: SPI_IOC_MESSAGE error \n");
retval = -1;
}
运行结果如下:
/mnt # ./myvenc
ready write length=10
mesg.len=12, speed=2000000hz
7E 22 00 01 02 03 04 05 06 07 08 09
write2 10, return 12
/mnt # ./myvenc
ready write length=12
mesg.len=14, speed=2000000hz
7E 22 00 01 02 03 04 05 06 07 08 09 0A 0B
ERR: SPI_IOC_MESSAGE error
write2 12, return -1
/mnt #
这是咋回事呢?资料上说最大可以写4KB一次,为什么超过10都不行了呢?
int i, retval = 0;
unsigned char buf[4098];
struct spi_ioc_transfer mesg[1];
unsigned char dev_addr=0x7e, reg_addr=0x22;
memset(mesg, 0, sizeof mesg);
if (length > 4094) length = 4094;
mesg[0].tx_buf = (__u32)buf;
mesg[0].rx_buf = (__u32)buf;
mesg[0].len = 2 + length;
mesg[0].cs_change = 1;
mesg[0].bits_per_word = 8;
mesg[0].speed_hz = 2000000;
printf("mesg.len=%d, speed=%dhz\n", mesg[0].len, mesg[0].speed_hz);
memset(buf, 0, sizeof buf);
buf[0] = dev_addr & 0x7f;
buf[1] = reg_addr & 0xff;
memcpy(buf+2, packet, length);
for(i=0; i
printf("\n");
retval = ioctl(gs_SpiFd, SPI_IOC_MESSAGE(length), mesg);
if (retval != mesg[0].len)
{
printf("ERR: SPI_IOC_MESSAGE error \n");
retval = -1;
}
运行结果如下:
/mnt # ./myvenc
ready write length=10
mesg.len=12, speed=2000000hz
7E 22 00 01 02 03 04 05 06 07 08 09
write2 10, return 12
/mnt # ./myvenc
ready write length=12
mesg.len=14, speed=2000000hz
7E 22 00 01 02 03 04 05 06 07 08 09 0A 0B
ERR: SPI_IOC_MESSAGE error
write2 12, return -1
/mnt #
这是咋回事呢?资料上说最大可以写4KB一次,为什么超过10都不行了呢?
我来回答
回答1个
时间排序
认可量排序
认可0
或将文件直接拖到这里
悬赏:
E币
网盘
* 网盘链接:
* 提取码:
悬赏:
E币
Markdown 语法
- 加粗**内容**
- 斜体*内容*
- 删除线~~内容~~
- 引用> 引用内容
- 代码`代码`
- 代码块```编程语言↵代码```
- 链接[链接标题](url)
- 无序列表- 内容
- 有序列表1. 内容
- 缩进内容
- 图片
相关问答
-
2015-06-23 09:39:53
-
2016-10-08 19:26:04
-
2017-11-08 15:13:55
-
2015-06-22 16:00:33
-
2016-04-25 13:53:04
-
2015-09-24 15:46:05
-
2017-09-19 15:00:41
-
2017-03-07 10:03:09
-
2014-11-25 14:58:09
-
2015-10-16 11:23:34
-
2017-07-11 00:49:28
-
2015-04-22 09:36:40
-
2019-10-17 13:54:21
-
2017-03-21 18:31:50
-
2015-09-28 10:55:08
-
2018-04-13 16:01:38
-
2015-01-20 17:16:14
-
2023-09-25 15:57:56
-
2020-01-16 20:24:15
无更多相似问答 去提问
点击登录
-- 积分
-- E币
提问
—
收益
—
被采纳
—
我要提问
切换马甲
上一页
下一页
悬赏问答
-
10hi35169dv500平台使用http协议推拉流UVC摄像头,帧率问题
-
10hi3516cv610关于YOLO优化和调优问题
-
10hi_mpi_vpss_get_chn_frame err:0xa0078016报错
-
5gk7205v200(hisi3516ev200)如何接入b656?
-
30pipe管道创建失败
-
10atc转换模型失败
-
20拍摄静止画面显示正常,拍摄运动的画面出现马赛克显示
-
100hi3516cv610 通过易百纳官方SDK中编译出的uboot env kernel,移植到自己的工程中,MPP初始化时出现内核拷贝数据到用户端时出现错误导致内核进入pain模式进而时内核重启
-
5hisi3519 gs2972 bt1120 转sdi 无法正常显示问题
-
5hisi3516cv610 + gc4336p 夜晚很模糊
举报反馈
举报类型
- 内容涉黄/赌/毒
- 内容侵权/抄袭
- 政治相关
- 涉嫌广告
- 侮辱谩骂
- 其他
详细说明
提醒
你的问题还没有最佳答案,是否结题,结题后将扣除20%的悬赏金
取消
确认
提醒
你的问题还没有最佳答案,是否结题,结题后将根据回答情况扣除相应悬赏金(1回答=1E币)
取消
确认

微信扫码分享
QQ好友