rpmb实际就是emmc中的一个独立分区,写rpmb需要rpmb key对包计算mac值,rpmb硬件内部会校验mac值正确才能正常写入数据,可以防止重要数据被破坏
底层rpmb相关函数:
static TEE_Result tee_rpmb_get_dev_info(uint16_t dev_id, struct rpmb_dev_info *dev_info)
获取硬件rpmb信息,包括cid和rpmb大小
static TEE_Result tee_rpmb_write_key(uint16_t dev_id)
若rpmb第一次使用,会调用该函数写入一把rpmb key,该key只能写一次,后续不能改变
static TEE_Result tee_rpmb_read(uint16_t dev_id, uint32_t addr, uint8_t *data,
uint32_t len, const uint8_t *fek,
const TEE_UUID *uuid)
读取rpmb包数据,校验包的mac值合法,解密数据
static TEE_Result tee_rpmb_write_blk(uint16_t dev_id, uint16_t blk_idx,
const uint8_t *data_blks, uint16_t blkcnt,