以前没接触过加密ic,只知道加密ic是通过i2c和mcu通讯,前段时间做的项目算是第一次用上了。
这个项目的要求是通过加密ic 既要能加密我们的固件 也要能加密配合我们固件使用的app。mcu和ic之间用i2c通讯,mcu和app之间走usb通道
我们的方案是这样的:
由加密ic方往加密ic里面写入数值不同的16个byte长度的id,拿到这个id后发送给app,app再对这个id的真伪进行校验。
如此则涉及到两次校验过程
一:加密ic和固件的校验
这个加密的原理是由我方指定一个16 Byte的key,用ic方提供的库函数通过i2c,将key传递给ic,ic读到正确的key值才能通过校验并将id值返回给我方。
在调试过程中为了达到ic方指定的通讯波形,大意了,在调用这个mcu方案的os提供的i2c读写函数时