11个月前
TRNG DA14531
发布的Firefox200540分 6个回答你好,
如何调用trng_acquire函数对吧?
我不知道这个地址在哪里uint8_t * sram_puf。
没有任何演示应用程序或参考实现吗?
/** **************************************************************************************** * @ 短暂的使用未初始化的内存数据获得128个随机位。* * @param[out] trng_bits_ptr指向存储随机数据的缓冲区。* @note它的地址必须对齐到32位。* @param[in] sram_puf指向未初始化SRAM区域的基址。* @note它的地址必须对齐到32位。* @param[in] sram_puf_blocks使用的16字节块的数量(最少28个)。* @return状态代码 **************************************************************************************** */ uint8_t trng_acquire (uint8_t * trng_bits_ptr uint8_t * sram_puf, const uint16_t sram_puf_blocks);
11个月前
你好,
所以我误解了它的功能…
那样的话,我只能init_rand_seed_from_trng ();并使用生成的随机值来初始化将srand (trng_state_val);函数并从中轮询一些随机数rand ();
但我总是得到相同的随机数反复,如果我重新启动相同的固件构建。我认为这是不对的。
什么时候我必须重新初始化init_rand_seed_from_trng ();一遍吗?
为什么trng_aquire(…)函数比不静态如果我没有使用它的trng.c?
到目前为止谢谢你
11个月前
我总是得到相同的输出,如果我重新加载和启动固件。我不应该这么认为。
代码:
Void user_app_init(Void) {arch_printf("\r\n\r\nuser_app_init\r\n");//初始化随机数生成器种子使用随机比特从TRNG init_rand_seed_from_trng();//初始化标准c rand()函数与trng随机数srand(trng_state_val);//测试:循环通过随机数生成器来测试随机数生成器…(uint8_t我= 0;我< 10;i++){//为AES-128密钥获取16字节的随机数(uint8_t i=0;我< ENC_DATA_LEN;i++){generated_challenge[i] = rand()%0xFF;} user_app_format_data("CHALLENGE", generated_challenge, 16); } app_param_update_request_timer_used = EASY_TIMER_INVALID_TIMER; // Initialize Manufacturer Specific Data mnf_data_init(); // Initialize Advertising and Scan Response Data memcpy(stored_adv_data, USER_ADVERTISE_DATA, USER_ADVERTISE_DATA_LEN); stored_adv_data_len = USER_ADVERTISE_DATA_LEN; memcpy(stored_scan_rsp_data, USER_ADVERTISE_SCAN_RESPONSE_DATA, USER_ADVERTISE_SCAN_RESPONSE_DATA_LEN); stored_scan_rsp_data_len = USER_ADVERTISE_SCAN_RESPONSE_DATA_LEN; default_app_on_init(); }
控制台输出:
user_app_init CHALLENGE d816f9d60c6c876abab0a0a11828fae挑战a832652ba76aa59c374db76d6cbcd48a CHALLENGE 2fd232c304c7a631d631d4767e挑战b1740409a2f0c9b945cf4f9a8750e9ea CHALLENGE c694072749e4ce4764ce43001c7d134 CHALLENGE 75679e7a12e6129d5cae5a2d8d0df挑战挑战e3b460feaf935240c3918cd46146de34
11个月前
嗨Firefox2005
请检查init_rand_seed_from_trng(),它调用trng_acquire()。没有这样的例子,但是为什么不使用init_rand_seed_from_trng()来使用从TRNG获得的随机位初始化随机数生成器种子呢?trng_aquire()的目的是生成随机函数。
谢谢,PM_Dialog