forked from Imagelibrary/rtems
timecounter: Initialize tc_lock earlier
Hyper-V wants to register its MSR-based timecounter during SI_SUB_HYPERVISOR, before SI_SUB_LOCK, since an emulated 8254 may not be available for DELAY(). So we cannot use MTX_SYSINIT to initialize the timecounter lock. PR: 259878 Reviewed by: kib MFC after: 3 days Sponsored by: The FreeBSD Foundation Differential Revision: https://reviews.freebsd.org/D33014
This commit is contained in:
committed by
Sebastian Huber
parent
d69acf87dc
commit
ede2278d8d
@@ -219,7 +219,6 @@ static struct timecounter *timecounters = &dummy_timecounter;
|
||||
|
||||
/* Mutex to protect the timecounter list. */
|
||||
static struct mtx tc_lock;
|
||||
MTX_SYSINIT(tc_lock, &tc_lock, "tc", MTX_DEF);
|
||||
|
||||
int tc_min_ticktock_freq = 1;
|
||||
#else /* __rtems__ */
|
||||
@@ -2378,6 +2377,8 @@ inittimehands(void *dummy)
|
||||
|
||||
TUNABLE_STR_FETCH("kern.timecounter.hardware", tc_from_tunable,
|
||||
sizeof(tc_from_tunable));
|
||||
|
||||
mtx_init(&tc_lock, "tc", NULL, MTX_DEF);
|
||||
}
|
||||
SYSINIT(timehands, SI_SUB_TUNABLES, SI_ORDER_ANY, inittimehands, NULL);
|
||||
|
||||
|
||||
Reference in New Issue
Block a user