arm64: arm_generic: prevent reading stale time
Currently arch_counter_get_cnt{p,v}ct can be speculated, allowing for stale time values to be read. This could be problematic for the delay loop and other sensitive functions, as the time delta could jump around unexpectedly. This patch adds isbs to arch_counter_get_cnt{p,v}ct, preventing this possibility. Signed-off-by: Mark Rutland <mark.rutland@arm.com> Acked-by: Catalin Marinas <catalin.marinas@arm.com>
This commit is contained in:
parent
8a4da6e36c
commit
1dac0dd71c
|
@ -83,6 +83,7 @@ static inline cycle_t arch_counter_get_cntpct(void)
|
|||
{
|
||||
cycle_t cval;
|
||||
|
||||
isb();
|
||||
asm volatile("mrs %0, cntpct_el0" : "=r" (cval));
|
||||
|
||||
return cval;
|
||||
|
@ -92,6 +93,7 @@ static inline cycle_t arch_counter_get_cntvct(void)
|
|||
{
|
||||
cycle_t cval;
|
||||
|
||||
isb();
|
||||
asm volatile("mrs %0, cntvct_el0" : "=r" (cval));
|
||||
|
||||
return cval;
|
||||
|
|
Loading…
Reference in New Issue
Block a user