|
@@ -93,8 +93,13 @@ static inline void arch_counter_set_user_access(void)
|
|
|
|
|
|
asm volatile("mrc p15, 0, %0, c14, c1, 0" : "=r" (cntkctl));
|
|
|
|
|
|
- /* disable user access to everything */
|
|
|
- cntkctl &= ~((3 << 8) | (7 << 0));
|
|
|
+ /* Disable user access to both physical/virtual counters/timers */
|
|
|
+ /* Also disable virtual event stream */
|
|
|
+ cntkctl &= ~(ARCH_TIMER_USR_PT_ACCESS_EN
|
|
|
+ | ARCH_TIMER_USR_VT_ACCESS_EN
|
|
|
+ | ARCH_TIMER_VIRT_EVT_EN
|
|
|
+ | ARCH_TIMER_USR_VCT_ACCESS_EN
|
|
|
+ | ARCH_TIMER_USR_PCT_ACCESS_EN);
|
|
|
|
|
|
asm volatile("mcr p15, 0, %0, c14, c1, 0" : : "r" (cntkctl));
|
|
|
}
|