4973
- 收藏
- 点赞
- 分享
- 举报
hisi3516 gpio模拟I2C写地址无法接收到ACK
调试AT88SC0104C 加密芯片,采用GPIO模拟实现I2C通信。麻烦大神帮看看如下问题,欢迎交流讨论,先在此谢过,谢谢!
现在问题:
1、写8位数据0xB6后,无法获取到芯片返回的ACK,也就是无法抓到SDA低电平,协议规定第九个SCL,返回SDA低电平作为ACK。不过有一种情况是可以接收到ACK,步骤:
1)、断电重启, insmod 驱动;运行结果:无返回ACK,
2)、rmmod 驱动
3)、重新insmod 驱动; 运行结果,能返回ACK
2、另外,无法写入0x00, 不管怎样操作,写完后都无法获取ACK;
具体写入函数:
static WORD
I2CWRITEA ( WORD a)
{
int TimeOutCount = 0;
int R2;
SDAOUT ( );
for (R2 = 0; R2 < 8; R2++)
{
a <<= 1;
MOVSDAC ( a & 0x100);
a &= 0xFFF;
delay_uS;
SETBSCL ( );
delay_uS;
CLRSCL ( );
delay_uS;
}
// RECV ACK
SETBSDA ( );
delay_uS;
SDAIN ( );
delay_scl_uS;
CLRSCL ( );
delay_uS;
SETBSCL ( );
delay_uS;
/*
* 当8位数据发送完成后,数据接收方需要一个时钟周期以使用SDA发送ACK信号,
* 表明数据是否接收成功。当ACK信号为"0"时,说明接收成功;为"1"时,说明接
* 收失败。
*/
#if 1
while (INSDA() && (TimeOutCount < 0x100))
{
delay_uS;
TimeOutCount++;
}
printk("--TimeOutCount=%x-------------------\n", TimeOutCount);
CLRSCL ( );
delay_uS;
SETBSCL ( );
delay_uS;
#endif
SDAOUT ( );
return TimeOutCount == 0x100;
}
现在问题:
1、写8位数据0xB6后,无法获取到芯片返回的ACK,也就是无法抓到SDA低电平,协议规定第九个SCL,返回SDA低电平作为ACK。不过有一种情况是可以接收到ACK,步骤:
1)、断电重启, insmod 驱动;运行结果:无返回ACK,
2)、rmmod 驱动
3)、重新insmod 驱动; 运行结果,能返回ACK
2、另外,无法写入0x00, 不管怎样操作,写完后都无法获取ACK;
具体写入函数:
static WORD
I2CWRITEA ( WORD a)
{
int TimeOutCount = 0;
int R2;
SDAOUT ( );
for (R2 = 0; R2 < 8; R2++)
{
a <<= 1;
MOVSDAC ( a & 0x100);
a &= 0xFFF;
delay_uS;
SETBSCL ( );
delay_uS;
CLRSCL ( );
delay_uS;
}
// RECV ACK
SETBSDA ( );
delay_uS;
SDAIN ( );
delay_scl_uS;
CLRSCL ( );
delay_uS;
SETBSCL ( );
delay_uS;
/*
* 当8位数据发送完成后,数据接收方需要一个时钟周期以使用SDA发送ACK信号,
* 表明数据是否接收成功。当ACK信号为"0"时,说明接收成功;为"1"时,说明接
* 收失败。
*/
#if 1
while (INSDA() && (TimeOutCount < 0x100))
{
delay_uS;
TimeOutCount++;
}
printk("--TimeOutCount=%x-------------------\n", TimeOutCount);
CLRSCL ( );
delay_uS;
SETBSCL ( );
delay_uS;
#endif
SDAOUT ( );
return TimeOutCount == 0x100;
}
我来回答
回答5个
时间排序
认可量排序
认可0
认可0
认可0
认可0
认可0
或将文件直接拖到这里
悬赏:
E币
网盘
* 网盘链接:
* 提取码:
悬赏:
E币
Markdown 语法
- 加粗**内容**
- 斜体*内容*
- 删除线~~内容~~
- 引用> 引用内容
- 代码`代码`
- 代码块```编程语言↵代码```
- 链接[链接标题](url)
- 无序列表- 内容
- 有序列表1. 内容
- 缩进内容
- 图片![alt](url)
相关问答
-
2016-08-30 20:00:07
-
2018-09-01 11:11:36
-
2014-12-12 15:25:29
-
2019-12-13 15:55:27
-
2024-04-02 17:42:56
-
2019-12-17 16:42:03
-
2017-10-12 20:38:01
-
2016-04-24 00:33:08
-
2016-01-27 09:07:13
-
22020-03-17 11:56:06
-
42019-12-20 09:46:51
-
02018-07-23 08:49:20
-
2021-08-04 11:26:24
-
2017-05-05 09:19:32
-
2016-12-29 10:29:28
-
2019-12-25 11:31:25
-
2020-07-15 12:24:09
-
02019-03-22 09:52:53
-
22019-05-24 18:19:17
无更多相似问答 去提问
点击登录
-- 积分
-- E币
提问
—
收益
—
被采纳
—
我要提问
切换马甲
上一页
下一页
悬赏问答
-
5Hi3516CV610 如何使用SD卡升级固件
-
5cat /dev/logmpp 报错 <3>[ vi] [func]:vi_send_frame_node [line]:99 [info]:vi pic queue is full!
-
50如何获取vpss chn的图像修改后发送至vo
-
5FPGA通过Bt1120传YUV422数据过来,vi接收不到数据——3516dv500
-
50SS928 运行PQtools 拼接 推到设备里有一半画面会异常
-
53536AV100的sample_vdec输出到CVBS显示
-
10海思板子mpp怎么在vi阶段改变视频数据尺寸
-
10HI3559AV100 多摄像头同步模式
-
9海思ss928单路摄像头vio中加入opencv处理并显示
-
10EB-RV1126-BC-191板子运行自己编码的程序
举报反馈
举报类型
- 内容涉黄/赌/毒
- 内容侵权/抄袭
- 政治相关
- 涉嫌广告
- 侮辱谩骂
- 其他
详细说明
提醒
你的问题还没有最佳答案,是否结题,结题后将扣除20%的悬赏金
取消
确认
提醒
你的问题还没有最佳答案,是否结题,结题后将根据回答情况扣除相应悬赏金(1回答=1E币)
取消
确认