* ESPNOW: now using hardware RNG for radio_new_identity()

This commit is contained in:
Scott Powell 2025-04-24 10:59:01 +10:00
parent 10df19d3a3
commit 00f0bb7471
4 changed files with 15 additions and 5 deletions

View file

@ -11,7 +11,8 @@ ESP32RTCClock rtc_clock;
bool radio_init() {
rtc_clock.begin();
// NOTE: radio_driver.begin() is called by Dispatcher::begin(), so not needed here
radio_driver.init();
return true; // success
}
@ -27,7 +28,16 @@ void radio_set_tx_power(uint8_t dbm) {
radio_driver.setTxPower(dbm);
}
// NOTE: as we are using the WiFi radio, the ESP_IDF will have enabled hardware RNG:
// https://docs.espressif.com/projects/esp-idf/en/stable/esp32/api-reference/system/random.html
class ESP_RNG : public mesh::RNG {
public:
void random(uint8_t* dest, size_t sz) override {
esp_fill_random(dest, sz);
}
};
mesh::LocalIdentity radio_new_identity() {
StdRNG rng; // TODO: need stronger True-RNG here
ESP_RNG rng;
return mesh::LocalIdentity(&rng); // create new random identity
}