2008-08-08 16:26:53 +00:00
|
|
|
.\" Copyright (c) 2006-2008 Stanislav Sedov <stas@FreeBSD.org>
|
|
|
|
.\" All rights reserved.
|
|
|
|
.\"
|
|
|
|
.\" 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 AUTHOR 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 AUTHOR 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.
|
|
|
|
.\"
|
|
|
|
.\" $FreeBSD$
|
|
|
|
.\"
|
2014-06-20 13:13:38 +00:00
|
|
|
.Dd June 20, 2014
|
2008-08-08 16:26:53 +00:00
|
|
|
.Dt CPUCTL 4
|
|
|
|
.Os
|
|
|
|
.Sh NAME
|
|
|
|
.Nm cpuctl
|
|
|
|
.Nd cpuctl pseudo device
|
|
|
|
.Sh SYNOPSIS
|
|
|
|
To compile this driver into the kernel,
|
|
|
|
place the following lines in your kernel
|
|
|
|
configuration file:
|
|
|
|
.Bd -ragged -offset indent
|
|
|
|
.Cd "device cpuctl"
|
|
|
|
.Ed
|
|
|
|
.Pp
|
|
|
|
Alternatively, to load the driver as a module
|
|
|
|
at boot time, place the following in
|
|
|
|
.Xr loader.conf 5 :
|
|
|
|
.Bd -literal -offset indent
|
|
|
|
cpuctl_load="YES"
|
|
|
|
.Ed
|
|
|
|
.Sh DESCRIPTION
|
2009-01-05 20:46:46 +00:00
|
|
|
The special device
|
2008-08-08 16:26:53 +00:00
|
|
|
.Pa /dev/cpuctl
|
2008-12-30 20:26:16 +00:00
|
|
|
presents interface to the system CPU.
|
|
|
|
It provides functionality to retrieve
|
2008-08-08 16:26:53 +00:00
|
|
|
CPUID information, read/write machine specific registers (MSR) and perform
|
2008-12-30 20:26:16 +00:00
|
|
|
CPU firmware updates.
|
2008-08-08 16:26:53 +00:00
|
|
|
.Pp
|
2009-01-05 20:46:46 +00:00
|
|
|
For each CPU present in the system, the special device
|
2008-08-08 16:26:53 +00:00
|
|
|
.Pa /dev/cpuctl%d
|
2008-12-30 20:26:16 +00:00
|
|
|
with the appropriate index will be created.
|
2009-01-05 20:46:46 +00:00
|
|
|
For multicore CPUs such a
|
|
|
|
special device will be created for each core.
|
2008-08-08 16:26:53 +00:00
|
|
|
.Pp
|
|
|
|
Currently, only i386 and amd64 processors are
|
|
|
|
supported.
|
|
|
|
.Sh IOCTL INTERFACE
|
|
|
|
All of the supported operations are invoked using the
|
2008-12-30 20:26:16 +00:00
|
|
|
.Xr ioctl 2
|
|
|
|
system call.
|
|
|
|
Currently, the following ioctls are defined:
|
2014-06-20 13:13:38 +00:00
|
|
|
.Bl -tag -width CPUCTL_CPUID_COUNT
|
2008-08-08 16:26:53 +00:00
|
|
|
.It Dv CPUCTL_RDMSR Fa cpuctl_msr_args_t *args
|
|
|
|
.It Dv CPUCTL_WRMSR Fa cpuctl_msr_args_t *args
|
2008-12-30 20:26:16 +00:00
|
|
|
Read/write CPU machine specific register.
|
|
|
|
The
|
2008-08-08 16:26:53 +00:00
|
|
|
.Vt cpuctl_msr_args_t
|
2008-12-30 20:26:16 +00:00
|
|
|
structure is defined in
|
2008-08-08 16:26:53 +00:00
|
|
|
.In sys/cpuctl.h
|
|
|
|
as:
|
|
|
|
.Bd -literal
|
|
|
|
typedef struct {
|
|
|
|
int msr; /* MSR to read */
|
|
|
|
uint64_t data;
|
|
|
|
} cpuctl_msr_args_t;
|
|
|
|
.Ed
|
2009-06-30 12:35:47 +00:00
|
|
|
.It Dv CPUCTL_MSRSBIT Fa cpuctl_msr_args_t *args
|
|
|
|
.It Dv CPUCTL_MSRCBIT Fa cpuctl_msr_args_t *args
|
|
|
|
Set/clear MSR bits according to the mask given in the
|
|
|
|
.Va data
|
|
|
|
field.
|
2008-08-08 16:26:53 +00:00
|
|
|
.It Dv CPUCTL_CPUID Fa cpuctl_cpuid_args_t *args
|
2008-12-30 20:26:16 +00:00
|
|
|
Retrieve CPUID information.
|
2014-06-20 13:13:38 +00:00
|
|
|
Arguments are supplied in the following structure:
|
2008-08-08 16:26:53 +00:00
|
|
|
.Bd -literal
|
|
|
|
typedef struct {
|
2014-06-19 21:54:41 +00:00
|
|
|
int level; /* CPUID level */
|
2008-08-08 16:26:53 +00:00
|
|
|
uint32_t data[4];
|
|
|
|
} cpuctl_cpuid_args_t;
|
|
|
|
.Ed
|
2014-06-20 13:13:38 +00:00
|
|
|
It is equivalent to the
|
|
|
|
.Dv CPUCTL_CPUID_COUNT
|
|
|
|
request with
|
|
|
|
.Va level_type
|
|
|
|
set to 0.
|
|
|
|
.It Dv CPUCTL_CPUID_COUNT Fa cpuctl_cpuid_count_args_t *args
|
|
|
|
Retrieve CPUID information.
|
|
|
|
Arguments are supplied in the following structure:
|
|
|
|
.Bd -literal
|
|
|
|
typedef struct {
|
|
|
|
int level; /* CPUID level */
|
|
|
|
int level_type; /* CPUID level type */
|
|
|
|
uint32_t data[4];
|
|
|
|
} cpuctl_cpuid_count_args_t;
|
|
|
|
.Ed
|
2008-08-08 16:26:53 +00:00
|
|
|
The
|
|
|
|
.Va level
|
2014-06-20 13:13:38 +00:00
|
|
|
field indicates the CPUID level to retrieve,
|
|
|
|
it is loaded into the
|
|
|
|
.Va %eax
|
|
|
|
register before the CPUID instruction is executed,
|
2014-06-19 21:54:41 +00:00
|
|
|
The
|
|
|
|
.Va level_type
|
2014-06-20 13:13:38 +00:00
|
|
|
field indicates the CPUID level type to retrieve,
|
|
|
|
it is loaded into the
|
|
|
|
.Va %ecx
|
|
|
|
register.
|
|
|
|
.Pp
|
|
|
|
The
|
2008-08-08 16:26:53 +00:00
|
|
|
.Va data
|
2008-12-30 20:26:16 +00:00
|
|
|
field is used to store the received CPUID data.
|
2014-06-20 13:13:38 +00:00
|
|
|
That is,
|
|
|
|
.Va data[0]
|
|
|
|
contains the value of
|
|
|
|
.Va %eax
|
|
|
|
register after the CPUID instruction is executed,
|
|
|
|
.Va data[1]
|
|
|
|
is for
|
|
|
|
.Va %ebx ,
|
|
|
|
.Va data[2]
|
|
|
|
for
|
|
|
|
.Va %ecx ,
|
|
|
|
and
|
|
|
|
.Va data[3]
|
|
|
|
for
|
|
|
|
.Va %edx .
|
2008-08-08 16:26:53 +00:00
|
|
|
.It Dv CPUCTL_UPDATE cpuctl_update_args_t *args
|
2008-12-30 20:26:16 +00:00
|
|
|
Update CPU firmware (microcode).
|
|
|
|
The structure is defined in
|
2008-08-08 16:26:53 +00:00
|
|
|
.In sys/cpuctl.h
|
|
|
|
as:
|
|
|
|
.Bd -literal
|
|
|
|
typedef struct {
|
|
|
|
void *data;
|
|
|
|
size_t size;
|
|
|
|
} cpuctl_update_args_t;
|
|
|
|
.Ed
|
|
|
|
.Pp
|
|
|
|
The
|
|
|
|
.Va data
|
|
|
|
field should point to the firmware image of size
|
|
|
|
.Va size .
|
|
|
|
.El
|
|
|
|
.Pp
|
|
|
|
For additional information refer to
|
|
|
|
.Pa cpuctl.h .
|
2017-03-20 04:41:36 +00:00
|
|
|
.Sh FILES
|
|
|
|
.Bl -tag -width /dev/cpuctl -compact
|
|
|
|
.It Pa /dev/cpuctl
|
|
|
|
.El
|
|
|
|
.Sh ERRORS
|
2008-08-08 16:26:53 +00:00
|
|
|
.Bl -tag -width Er
|
|
|
|
.It Bq Er ENXIO
|
2012-05-12 03:25:46 +00:00
|
|
|
The operation requested is not supported by the device (e.g., unsupported
|
|
|
|
architecture or the CPU is disabled).
|
2008-08-08 16:26:53 +00:00
|
|
|
.It Bq Er EINVAL
|
|
|
|
Incorrect request was supplied, or microcode image is not correct.
|
|
|
|
.It Bq Er ENOMEM
|
|
|
|
No physical memory was available to complete the request.
|
|
|
|
.It Bq Er EFAULT
|
2008-12-30 20:26:16 +00:00
|
|
|
The firmware image address points outside the process address space.
|
2008-08-08 16:26:53 +00:00
|
|
|
.El
|
|
|
|
.Sh SEE ALSO
|
2008-12-30 20:31:37 +00:00
|
|
|
.Xr hwpmc 4 ,
|
2008-12-30 20:26:16 +00:00
|
|
|
.Xr cpucontrol 8
|
2008-08-08 16:26:53 +00:00
|
|
|
.Sh HISTORY
|
|
|
|
The
|
|
|
|
.Nm
|
|
|
|
driver first appeared in
|
2009-04-23 08:37:56 +00:00
|
|
|
.Fx 7.2 .
|
2008-08-08 16:26:53 +00:00
|
|
|
.Sh AUTHORS
|
|
|
|
The
|
|
|
|
.Nm
|
2008-12-30 20:26:16 +00:00
|
|
|
module and this manual page were written by
|
2014-06-26 21:46:14 +00:00
|
|
|
.An Stanislav Sedov Aq Mt stas@FreeBSD.org .
|
2010-05-13 12:07:55 +00:00
|
|
|
.Sh BUGS
|
|
|
|
Yes, probably, report if any.
|