使用I2C操作AT88加密芯片
2012-06-30 12:30
218 查看
1.上电时序,直接省略
2.waitclock
往I2c总线上发送两个字节的0x00,具体方法为想地址0写一个字节的0x0.
3.命令和数据
遇到"0xb8 00 00 0x0a"命令直接返回。
AT88的规则是每次读写数据之前先发送命令。因此读写数据的时候一定是带命令的。
写数据的操作很简单,使用命令的第一个字节作为地址,剩下的命令部分和数据部分当成一般数据发送。
读操作稍微复杂一点。AT88的时序不是标准I2C,但是大致兼容。I2C没办法实现AT88手册中说的normal read时序,但是可以使用random read操作代替。
具体实现为先先发送写数据指令”0xb4 XX XX N“,其中”XX XX N“代表地址和数据长度。此时应或略NACK。
然后使用”0xb1“作为地址来读。
举个读取数据的例子:
本来要使用命令"0xbX BB CC N"来读取N字节的数据,使用I2C做如下操作:
先以”0xb4“为地址向I2C写三个字节,内容为命令的后三个字节” BB CC N“,应让I2C忽略NACK。
然后以”0xbX“为地址读取N字节的数据。
2.waitclock
往I2c总线上发送两个字节的0x00,具体方法为想地址0写一个字节的0x0.
3.命令和数据
遇到"0xb8 00 00 0x0a"命令直接返回。
AT88的规则是每次读写数据之前先发送命令。因此读写数据的时候一定是带命令的。
写数据的操作很简单,使用命令的第一个字节作为地址,剩下的命令部分和数据部分当成一般数据发送。
读操作稍微复杂一点。AT88的时序不是标准I2C,但是大致兼容。I2C没办法实现AT88手册中说的normal read时序,但是可以使用random read操作代替。
具体实现为先先发送写数据指令”0xb4 XX XX N“,其中”XX XX N“代表地址和数据长度。此时应或略NACK。
然后使用”0xb1“作为地址来读。
举个读取数据的例子:
本来要使用命令"0xbX BB CC N"来读取N字节的数据,使用I2C做如下操作:
先以”0xb4“为地址向I2C写三个字节,内容为命令的后三个字节” BB CC N“,应让I2C忽略NACK。
然后以”0xbX“为地址读取N字节的数据。
相关文章推荐
- STM32F407VE单片机使用I2C接口操作内部控制芯片为RA8816的FYD12864-1001A型的12864液晶
- android mosquitto客户端使用SSL功能的具体操作总结(android mqtt ssl 加密)
- SQLITE3 使用总结(SQL语句操作,加密)
- IIC专题(二)-使用内核原代码提供的at24.c驱动来操作I2C的at24lc04 EEPROM
- LKT4102 8位I2C接口防盗版加密芯片
- LKT4102 8位I2C接口防盗版加密芯片
- 使用Zend Guard来加密PHP代码保护的操作
- C#.NET COOKIE操作 KEY使用MD5加密,Value使用AES加密
- LKT4102 8位I2C接口防盗版加密芯片
- 使用Win32 加密API 来进行加密操作
- Java程序使用HASP加密狗加密保护的操作步骤--手把手包你学会
- Java-web下使用RSA进行加密解密操作
- Python使用MD5加密算法对字符串进行加密操作示例
- 使用AES算法对文件进行加密/解密的操作(JAVA)
- 使用xenocode代码混淆加密的操作步骤
- Java-web下使用RSA进行加密解密操作
- Visual Studio 2017中使用正则修改部分内容 如何使用ILAsm与ILDasm修改.Net exe(dll)文件 C#学习-图解教程(1):格式化数字字符串 小程序开发之图片转Base64(C#、.Net) jquery遍历table为每一个单元格取值及赋值 。net加密解密相关方法 .net关于坐标之间一些简单操作
- I2C接口硬件加密芯片SMEC98SP在STM32F103C8T6系统上的应用
- Java使用基本JDK操作ZIP文件以及zip文件的加密、解密等功能
- atsha204a加密芯片使用攻略——配置篇