2014-02-19 13:13:21 +04:00
|
|
|
.\" $NetBSD: cpuctl.8,v 1.12 2014/02/19 09:13:21 szptvlfn Exp $
|
2007-08-04 15:02:56 +04:00
|
|
|
.\"
|
2012-01-13 20:05:14 +04:00
|
|
|
.\" Copyright (c) 2007, 2008, 2012 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.
|
|
|
|
.\"
|
2013-12-23 16:35:33 +04:00
|
|
|
.Dd December 23, 2013
|
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:
|
2008-06-22 18:50:40 +04:00
|
|
|
.Bl -tag -width XofflineXcpunoX
|
2008-05-05 21:54:14 +04:00
|
|
|
.It identify Ar cpu
|
|
|
|
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.
|
2008-03-25 18:06:02 +03:00
|
|
|
.It offline Ar cpuno
|
2007-08-04 15:02:56 +04:00
|
|
|
Set the specified CPU off line.
|
|
|
|
.Pp
|
|
|
|
Unbound LWPs (lightweight processes) will not be executed on the CPU
|
|
|
|
while it is off line.
|
|
|
|
Bound LWPs will continue to be executed on the CPU, and device interrupts
|
|
|
|
routed to the CPU will continue to be handled.
|
|
|
|
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.
|
2008-03-25 18:06:02 +03:00
|
|
|
.It online Ar cpuno
|
2007-08-04 15:02:56 +04:00
|
|
|
Set the specified CPU on line, making it available to run unbound LWPs.
|
2012-01-13 20:05:14 +04:00
|
|
|
.It ucode Op Ar file
|
2012-01-14 04:59:56 +04:00
|
|
|
This applies the microcode patch on all CPUs.
|
2012-01-13 20:05:14 +04:00
|
|
|
The default filename is used if no filename is specified.
|
|
|
|
The
|
|
|
|
.Cm identify
|
2012-01-14 04:59:56 +04:00
|
|
|
command prints the installed version on that CPU.
|
2012-01-13 20:05:14 +04:00
|
|
|
On success the
|
|
|
|
.Cm identify
|
|
|
|
command show different ucode versions before and after this command.
|
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
|
2014-02-19 13:13:21 +04:00
|
|
|
.Lk http://www.amd64.org/microcode.html
|
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
|
|
|
|
.Dl cpuctl ucode
|
|
|
|
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
|
|
|
|
.Xr psrset 8 ,
|
|
|
|
.Xr schedctl 8
|
2007-08-04 15:02:56 +04:00
|
|
|
.Sh HISTORY
|
|
|
|
The
|
|
|
|
.Nm
|
|
|
|
command first appeared in
|
|
|
|
.Nx 5.0 .
|