2018-07-03 16:13:15 +02:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2018 HAW Hamburg
|
|
|
|
*
|
|
|
|
* This file is subject to the terms and conditions of the GNU Lesser
|
|
|
|
* General Public License v2.1. See the file LICENSE in the top level
|
|
|
|
* directory for more details.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @ingroup sys_puf_sram
|
|
|
|
*
|
|
|
|
* @{
|
|
|
|
* @file
|
|
|
|
*
|
|
|
|
* @author Peter Kietzmann <peter.kietzmann@haw-hamburg.de>
|
|
|
|
*
|
|
|
|
* @}
|
|
|
|
*/
|
|
|
|
#include "puf_sram.h"
|
|
|
|
|
|
|
|
/* Allocation of the PUF seed variable */
|
2018-11-15 08:54:51 +01:00
|
|
|
PUF_SRAM_ATTRIBUTES uint32_t puf_sram_seed;
|
2018-07-03 16:13:15 +02:00
|
|
|
|
|
|
|
/* Allocation of the PUF seed state */
|
2018-11-15 08:54:51 +01:00
|
|
|
PUF_SRAM_ATTRIBUTES uint32_t puf_sram_state;
|
2018-07-03 16:13:15 +02:00
|
|
|
|
2022-09-16 13:28:48 +02:00
|
|
|
/* Allocation of the PUF soft reset counter */
|
2020-01-15 17:19:54 +01:00
|
|
|
PUF_SRAM_ATTRIBUTES uint32_t puf_sram_softreset_cnt;
|
|
|
|
|
2018-07-03 16:13:15 +02:00
|
|
|
/* Allocation of the memory marker */
|
2018-11-15 08:54:51 +01:00
|
|
|
PUF_SRAM_ATTRIBUTES uint32_t puf_sram_marker;
|
2018-07-03 16:13:15 +02:00
|
|
|
|
|
|
|
void puf_sram_init(const uint8_t *ram, size_t len)
|
|
|
|
{
|
|
|
|
/* generates a new seed value if power cycle was detected */
|
|
|
|
if (!puf_sram_softreset()) {
|
|
|
|
puf_sram_generate(ram, len);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
void puf_sram_generate(const uint8_t *ram, size_t len)
|
|
|
|
{
|
|
|
|
/* build hash from start-up pattern */
|
|
|
|
puf_sram_seed = dek_hash(ram, len);
|
|
|
|
/* write marker to a defined section for subsequent reset detection */
|
|
|
|
puf_sram_marker = PUF_SRAM_MARKER;
|
2019-10-23 21:16:23 +02:00
|
|
|
/* setting state to 0 means seed was generated from SRAM pattern */
|
2018-07-03 16:13:15 +02:00
|
|
|
puf_sram_state = 0;
|
2020-01-15 17:19:54 +01:00
|
|
|
/* reset counter of detected soft resets */
|
|
|
|
puf_sram_softreset_cnt = 0;
|
2018-07-03 16:13:15 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
bool puf_sram_softreset(void)
|
|
|
|
{
|
|
|
|
if (puf_sram_marker != PUF_SRAM_MARKER) {
|
|
|
|
puf_sram_state = 2;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
puf_sram_state = 1;
|
2020-01-15 17:19:54 +01:00
|
|
|
|
|
|
|
/* increment number of detected soft resets */
|
|
|
|
puf_sram_softreset_cnt++;
|
|
|
|
|
|
|
|
/* generate alterntive seed value */
|
|
|
|
puf_sram_seed ^= puf_sram_softreset_cnt;
|
|
|
|
puf_sram_seed = dek_hash((uint8_t *)&puf_sram_seed, sizeof(puf_sram_seed));
|
2018-07-03 16:13:15 +02:00
|
|
|
return 1;
|
|
|
|
}
|