[riscv] Add missing volatile qualifiers on timer and seed CSR accesses

The timer and entropy seed CSRs will, by design, return different
values each time they are read.

Add the missing volatile qualifiers on the inline assembly to prevent
gcc from assuming that repeated invocations may be elided.

Signed-off-by: Michael Brown <mcb30@ipxe.org>
This commit is contained in:
Michael Brown 2024-10-28 16:40:44 +00:00
parent be0c9788a1
commit 06a9330004
2 changed files with 11 additions and 9 deletions

View File

@ -64,7 +64,7 @@ rdtime_low ( void ) {
unsigned long time;
/* Read low XLEN bits of current time */
__asm__ ( "rdtime %0" : "=r" ( time ) );
__asm__ __volatile__ ( "rdtime %0" : "=r" ( time ) );
return time;
}
@ -86,14 +86,15 @@ rdtime_scaled ( void ) {
/* Read full current time */
#if __riscv_xlen >= 64
__asm__ ( "rdtime %0" : "=r" ( u.time ) );
__asm__ __volatile__ ( "rdtime %0" : "=r" ( u.time ) );
#else
__asm__ ( "1:\n\t"
"rdtimeh %1\n\t"
"rdtime %0\n\t"
"rdtimeh %2\n\t"
"bne %1, %2, 1b\n\t"
: "=r" ( u.low ), "=r" ( u.high ), "=r" ( tmp ) );
__asm__ __volatile__ ( "1:\n\t"
"rdtimeh %1\n\t"
"rdtime %0\n\t"
"rdtimeh %2\n\t"
"bne %1, %2, 1b\n\t"
: "=r" ( u.low ), "=r" ( u.high ),
"=r" ( tmp ) );
#endif
/* Scale time to avoid XLEN-bit rollover */

View File

@ -85,7 +85,8 @@ static int zkr_get_noise ( noise_sample_t *noise ) {
for ( i = 0 ; i < ZKR_SEED_MAX_RETRY ; i++ ) {
/* Read seed CSR */
__asm__ ( "csrrw %0, seed, zero" : "=r" ( seed ) );
__asm__ __volatile__ ( "csrrw %0, seed, zero" :
"=r" ( seed ) );
/* Check operationsl state */
if ( ( seed & ZKR_SEED_OPST_MASK ) == ZKR_SEED_OPST_ES16 ) {