ipro1000: Always use DELAY() for microsecond pauses (on Haiku.)
pause() has granularity of "hz", which on FreeBSD and in our compat layer is defined to be 1000 (so, 1ms.) As "safe_pause_us" is used copoiously throughout startup code, this meant that (1) startup takes 100-1000x longer than it needed to (this driver seems to most commonly delay for 10us), and (2) this could in theory block the boot for multiple minutes if one got particularly unlucky with the scheduler. Probably helps with or even outright fixes #14795.
This commit is contained in:
parent
046ae71e48
commit
a381a48f86
@ -83,11 +83,15 @@ ms_scale(int x) {
|
|||||||
|
|
||||||
static inline void
|
static inline void
|
||||||
safe_pause_us(int x) {
|
safe_pause_us(int x) {
|
||||||
|
#ifndef __HAIKU__
|
||||||
if (cold) {
|
if (cold) {
|
||||||
DELAY(x);
|
DELAY(x);
|
||||||
} else {
|
} else {
|
||||||
pause("e1000_delay", max(1, x/(1000000/hz)));
|
pause("e1000_delay", max(1, x/(1000000/hz)));
|
||||||
}
|
}
|
||||||
|
#else
|
||||||
|
DELAY(x);
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline void
|
static inline void
|
||||||
|
Loading…
Reference in New Issue
Block a user