2019-05-18 02:51:35 +03:00
|
|
|
.\" $NetBSD: cpuctl.8,v 1.20 2019/05/17 23:51:35 gutteridge Exp $
|
2007-08-04 15:02:56 +04:00
|
|
|
.\"
|
2015-11-16 06:34:50 +03:00
|
|
|
.\" Copyright (c) 2007, 2008, 2012, 2015 The NetBSD Foundation, Inc.
|
2007-08-04 15:02:56 +04:00
|
|
|
.\" All rights reserved.
|
|
|
|
.\"
|
|
|
|
.\" This code is derived from software contributed to The NetBSD Foundation
|
|
|
|
.\" by Andrew Doran.
|
|
|
|
.\"
|
|
|
|
.\" Redistribution and use in source and binary forms, with or without
|
|
|
|
.\" modification, are permitted provided that the following conditions
|
|
|
|
.\" are met:
|
|
|
|
.\" 1. Redistributions of source code must retain the above copyright
|
|
|
|
.\" notice, this list of conditions and the following disclaimer.
|
|
|
|
.\" 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
.\" notice, this list of conditions and the following disclaimer in the
|
|
|
|
.\" documentation and/or other materials provided with the distribution.
|
|
|
|
.\"
|
|
|
|
.\" THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
|
|
|
|
.\" ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
|
|
|
|
.\" TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
|
|
|
|
.\" PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
|
|
|
|
.\" BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
|
|
|
.\" CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
|
|
|
.\" SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
|
|
|
.\" INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
|
|
|
.\" CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
|
|
|
.\" ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
|
|
|
.\" POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
.\"
|
2019-05-18 02:51:35 +03:00
|
|
|
.Dd May 17, 2019
|
2007-08-04 15:02:56 +04:00
|
|
|
.Dt CPUCTL 8
|
|
|
|
.Os
|
|
|
|
.Sh NAME
|
|
|
|
.Nm cpuctl
|
2008-06-22 18:50:40 +04:00
|
|
|
.Nd program to control CPUs
|
2007-08-04 15:02:56 +04:00
|
|
|
.Sh SYNOPSIS
|
|
|
|
.Nm cpuctl
|
2013-12-23 16:35:33 +04:00
|
|
|
.Op Fl v
|
2007-08-04 15:02:56 +04:00
|
|
|
.Ar command
|
|
|
|
.Op Ar arguments
|
|
|
|
.Sh DESCRIPTION
|
|
|
|
The
|
|
|
|
.Nm
|
|
|
|
command can be used to control and inspect the state of CPUs in the system.
|
|
|
|
.Pp
|
|
|
|
The first argument,
|
2008-06-22 18:50:40 +04:00
|
|
|
.Ar command ,
|
2007-08-04 15:02:56 +04:00
|
|
|
specifies the action to take.
|
|
|
|
Valid commands are:
|
2019-05-18 02:51:35 +03:00
|
|
|
.Bl -tag -width identify
|
2015-11-16 06:34:50 +03:00
|
|
|
.It identify Ar cpu Op Ar cpu ...
|
2008-05-05 21:54:14 +04:00
|
|
|
Output information on the specified CPU's features and capabilities.
|
|
|
|
Not available on all architectures.
|
2007-08-04 15:02:56 +04:00
|
|
|
.It list
|
|
|
|
For each CPU in the system, display the current state and time of the last
|
|
|
|
state change.
|
2015-11-16 06:34:50 +03:00
|
|
|
.It offline Ar cpu Op Ar cpu ...
|
|
|
|
Set the specified CPUs off line.
|
2007-08-04 15:02:56 +04:00
|
|
|
.Pp
|
2019-05-18 02:51:35 +03:00
|
|
|
Unbound LWPs (lightweight processes) will not be executed on a CPU
|
2007-08-04 15:02:56 +04:00
|
|
|
while it is off line.
|
2015-11-16 06:34:50 +03:00
|
|
|
Bound LWPs will continue to be executed on the CPUs, and device interrupts
|
|
|
|
routed to the CPUs will continue to be handled.
|
2007-08-04 15:02:56 +04:00
|
|
|
A future release of the system may allow device interrupts to be re-routed
|
|
|
|
away from individual CPUs.
|
|
|
|
.Pp
|
|
|
|
At least one CPU in the system must remain on line.
|
2015-11-16 06:34:50 +03:00
|
|
|
.It online Ar cpu Op Ar cpu ...
|
2019-05-18 02:51:35 +03:00
|
|
|
Set the specified CPUs on line, making them available to run unbound LWPs.
|
2014-11-20 15:49:13 +03:00
|
|
|
.It ucode Xo
|
2015-11-16 06:34:50 +03:00
|
|
|
.Op Ar cpu
|
2014-11-20 15:49:13 +03:00
|
|
|
.Op Ar file
|
|
|
|
.Xc
|
|
|
|
This applies the microcode patch to CPUs.
|
|
|
|
If
|
2015-11-16 06:34:50 +03:00
|
|
|
.Ar cpu
|
2014-11-20 16:16:05 +03:00
|
|
|
is not specified or \-1, all CPUs are updated.
|
2014-11-20 15:49:13 +03:00
|
|
|
If
|
2015-11-16 06:34:50 +03:00
|
|
|
.Ar cpu
|
2014-11-20 16:16:05 +03:00
|
|
|
is \-2, the current CPUs are updated.
|
2012-01-13 20:05:14 +04:00
|
|
|
The default filename is used if no filename is specified.
|
|
|
|
The
|
|
|
|
.Cm identify
|
2015-11-16 06:34:50 +03:00
|
|
|
command prints the installed version on the specified CPUs.
|
2012-01-13 20:05:14 +04:00
|
|
|
On success the
|
|
|
|
.Cm identify
|
2019-05-18 02:51:35 +03:00
|
|
|
command shows different ucode versions before and after this command.
|
2018-01-14 03:45:54 +03:00
|
|
|
The ucode updates are found in the default firmware path found in
|
|
|
|
sysctl hw.firmware.path.
|
2015-11-16 06:34:50 +03:00
|
|
|
.It intr Ar cpu Op Ar cpu ...
|
|
|
|
Enable interrupts for the specified CPUs if supported.
|
|
|
|
.It nointr Ar cpu Op Ar cpu ...
|
|
|
|
Disable interrupts for the specified CPUs if supported.
|
2007-08-04 15:02:56 +04:00
|
|
|
.El
|
2013-12-23 16:35:33 +04:00
|
|
|
.Pp
|
2013-12-23 16:39:55 +04:00
|
|
|
Valid flags are:
|
2013-12-23 16:35:33 +04:00
|
|
|
.Bl -tag -width indent
|
|
|
|
.It Fl v
|
|
|
|
Be more verbose.
|
|
|
|
.El
|
2007-08-04 15:02:56 +04:00
|
|
|
.Sh FILES
|
|
|
|
.Bl -tag -width /dev/cpuctl -compact
|
|
|
|
.It Pa /dev/cpuctl
|
|
|
|
control device
|
2012-01-13 20:05:14 +04:00
|
|
|
.It Pa /libdata/firmware/x86/amd/
|
|
|
|
The directory to install the microcode file for AMD CPUs into.
|
|
|
|
The default filename is
|
|
|
|
.Pa microcode_amd.bin
|
|
|
|
for CPU families 0x10 to 0x14.
|
|
|
|
The default filename is
|
|
|
|
.Pa microcode_amd_famXXh.bin
|
|
|
|
where
|
|
|
|
.Dv XX
|
|
|
|
is the CPU family starting with 15 (hex).
|
|
|
|
Get it from
|
2019-04-16 01:37:13 +03:00
|
|
|
.Lk https://git.kernel.org/pub/scm/linux/kernel/git/firmware/linux-firmware.git/tree/amd-ucode
|
2007-08-04 15:02:56 +04:00
|
|
|
.El
|
2012-01-14 04:59:56 +04:00
|
|
|
.Sh EXAMPLES
|
|
|
|
Run
|
|
|
|
.Dl cpuctl identify 0
|
|
|
|
and you should see something like this:
|
|
|
|
.Bd -literal -offset indent
|
|
|
|
cpu0: UCode version: 0x1000080
|
|
|
|
.Ed
|
|
|
|
.Pp
|
|
|
|
After applying the microcode patch with
|
2018-01-14 03:45:54 +03:00
|
|
|
.Dl cpuctl ucode 0
|
2012-01-14 04:59:56 +04:00
|
|
|
you can see with
|
|
|
|
.Dl cpuctl identify 0
|
|
|
|
that the patch got applied:
|
|
|
|
.Bd -literal -offset indent
|
|
|
|
cpu0: UCode version: 0x1000083
|
|
|
|
.Ed
|
2008-06-22 17:53:59 +04:00
|
|
|
.Sh SEE ALSO
|
2016-09-17 23:48:04 +03:00
|
|
|
.Xr intrctl 8 ,
|
2008-06-22 17:53:59 +04:00
|
|
|
.Xr psrset 8 ,
|
2018-01-14 03:45:54 +03:00
|
|
|
.Xr schedctl 8 ,
|
|
|
|
.Xr sysctl 8 ,
|
|
|
|
.Xr firmload 9
|
2007-08-04 15:02:56 +04:00
|
|
|
.Sh HISTORY
|
|
|
|
The
|
|
|
|
.Nm
|
|
|
|
command first appeared in
|
|
|
|
.Nx 5.0 .
|