sync code with last improvements from OpenBSD
This commit is contained in:
parent
ecb53bfacf
commit
f8bbd6dd90
@ -1,4 +1,4 @@
|
|||||||
/* $OpenBSD: kern_sched.c,v 1.87 2023/08/29 16:19:34 claudio Exp $ */
|
/* $OpenBSD: kern_sched.c,v 1.88 2023/08/31 19:29:51 cheloha Exp $ */
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2007, 2008 Artur Grabowski <art@openbsd.org>
|
* Copyright (c) 2007, 2008 Artur Grabowski <art@openbsd.org>
|
||||||
*
|
*
|
||||||
@ -88,26 +88,15 @@ sched_init_cpu(struct cpu_info *ci)
|
|||||||
|
|
||||||
spc->spc_idleproc = NULL;
|
spc->spc_idleproc = NULL;
|
||||||
|
|
||||||
if (spc->spc_itimer == NULL) {
|
spc->spc_itimer = clockintr_establish(&ci->ci_queue, itimer_update);
|
||||||
spc->spc_itimer = clockintr_establish(&ci->ci_queue,
|
if (spc->spc_itimer == NULL)
|
||||||
itimer_update);
|
panic("%s: clockintr_establish itimer_update", __func__);
|
||||||
if (spc->spc_itimer == NULL) {
|
spc->spc_profclock = clockintr_establish(&ci->ci_queue, profclock);
|
||||||
panic("%s: clockintr_establish itimer_update",
|
if (spc->spc_profclock == NULL)
|
||||||
__func__);
|
panic("%s: clockintr_establish profclock", __func__);
|
||||||
}
|
spc->spc_roundrobin = clockintr_establish(&ci->ci_queue, roundrobin);
|
||||||
}
|
if (spc->spc_roundrobin == NULL)
|
||||||
if (spc->spc_profclock == NULL) {
|
panic("%s: clockintr_establish roundrobin", __func__);
|
||||||
spc->spc_profclock = clockintr_establish(&ci->ci_queue,
|
|
||||||
profclock);
|
|
||||||
if (spc->spc_profclock == NULL)
|
|
||||||
panic("%s: clockintr_establish profclock", __func__);
|
|
||||||
}
|
|
||||||
if (spc->spc_roundrobin == NULL) {
|
|
||||||
spc->spc_roundrobin = clockintr_establish(&ci->ci_queue,
|
|
||||||
roundrobin);
|
|
||||||
if (spc->spc_roundrobin == NULL)
|
|
||||||
panic("%s: clockintr_establish roundrobin", __func__);
|
|
||||||
}
|
|
||||||
|
|
||||||
kthread_create_deferred(sched_kthreads_create, ci);
|
kthread_create_deferred(sched_kthreads_create, ci);
|
||||||
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
#!/bin/ksh
|
#!/bin/ksh
|
||||||
# $OpenBSD: fw_update.sh,v 1.45 2023/08/31 18:19:21 afresh1 Exp $
|
# $OpenBSD: fw_update.sh,v 1.47 2023/08/31 21:29:53 afresh1 Exp $
|
||||||
#
|
#
|
||||||
# Copyright (c) 2021,2023 Andrew Hewus Fresh <afresh1@openbsd.org>
|
# Copyright (c) 2021,2023 Andrew Hewus Fresh <afresh1@openbsd.org>
|
||||||
#
|
#
|
||||||
@ -259,18 +259,23 @@ lock_db() {
|
|||||||
[ -e /usr/bin/perl ] || return 0
|
[ -e /usr/bin/perl ] || return 0
|
||||||
|
|
||||||
set -o monitor
|
set -o monitor
|
||||||
perl <<'EOL' |&
|
perl <<-'EOL' |&
|
||||||
use v5.16;
|
|
||||||
use warnings;
|
|
||||||
no lib ('/usr/local/libdata/perl5/site_perl');
|
no lib ('/usr/local/libdata/perl5/site_perl');
|
||||||
|
use v5.36;
|
||||||
use OpenBSD::PackageInfo qw< lock_db >;
|
use OpenBSD::PackageInfo qw< lock_db >;
|
||||||
|
|
||||||
$|=1;
|
$|=1;
|
||||||
|
|
||||||
|
$0 = "fw_update: lock_db";
|
||||||
lock_db(0);
|
lock_db(0);
|
||||||
|
|
||||||
say $$;
|
say $$;
|
||||||
sleep;
|
|
||||||
|
# Wait for STDOUT to be readable, which won't happen
|
||||||
|
# but if our parent exits unexpectedly it will close.
|
||||||
|
my $rin = '';
|
||||||
|
vec($rin, fileno(STDOUT), 1) = 1;
|
||||||
|
select $rin, '', '', undef;
|
||||||
EOL
|
EOL
|
||||||
set +o monitor
|
set +o monitor
|
||||||
|
|
||||||
@ -702,7 +707,7 @@ for f in "${add[@]}" _update_ "${update[@]}"; do
|
|||||||
if "$pending_status"; then
|
if "$pending_status"; then
|
||||||
echo " failed."
|
echo " failed."
|
||||||
elif ! ((VERBOSE)); then
|
elif ! ((VERBOSE)); then
|
||||||
status "failed (${f##*/})"
|
status " failed (${f##*/})"
|
||||||
fi
|
fi
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
@ -725,7 +730,7 @@ for f in "${add[@]}" _update_ "${update[@]}"; do
|
|||||||
if "$pending_status"; then
|
if "$pending_status"; then
|
||||||
echo " failed."
|
echo " failed."
|
||||||
elif ! ((VERBOSE)); then
|
elif ! ((VERBOSE)); then
|
||||||
status "failed ($i)"
|
status " failed ($i)"
|
||||||
fi
|
fi
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
@ -736,7 +741,7 @@ for f in "${add[@]}" _update_ "${update[@]}"; do
|
|||||||
if "$pending_status"; then
|
if "$pending_status"; then
|
||||||
echo " failed."
|
echo " failed."
|
||||||
elif ! ((VERBOSE)); then
|
elif ! ((VERBOSE)); then
|
||||||
status "failed (${f##*/})"
|
status " failed (${f##*/})"
|
||||||
fi
|
fi
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user