iPXE
cpuid_cmd.c File Reference

x86 CPU feature detection command More...

#include <stdint.h>
#include <stdio.h>
#include <errno.h>
#include <getopt.h>
#include <ipxe/cpuid.h>
#include <ipxe/command.h>
#include <ipxe/parseopt.h>

Go to the source code of this file.

Data Structures

struct  cpuid_options
 "cpuid" options More...

Functions

 FILE_LICENCE (GPL2_OR_LATER_OR_UBDL)
 FILE_SECBOOT (PERMITTED)
static int cpuid_exec (int argc, char **argv)
 The "cpuid" command.
 COMMAND (cpuid, cpuid_exec)
 x86 CPU feature detection command

Variables

static struct option_descriptor cpuid_opts []
 "cpuid" option list
static struct command_descriptor cpuid_cmd
 "cpuid" command descriptor

Detailed Description

x86 CPU feature detection command

Definition in file cpuid_cmd.c.

Function Documentation

◆ FILE_LICENCE()

FILE_LICENCE ( GPL2_OR_LATER_OR_UBDL )

◆ FILE_SECBOOT()

FILE_SECBOOT ( PERMITTED )

◆ cpuid_exec()

int cpuid_exec ( int argc,
char ** argv )
static

The "cpuid" command.

Parameters
argcArgument count
argvArgument list
Return values
rcReturn status code

Definition at line 71 of file cpuid_cmd.c.

71 {
72 struct cpuid_options opts;
74 struct x86_feature_registers *feature_regs;
75 uint32_t feature_reg;
76 unsigned int bit;
77 int rc;
78
79 /* Parse options */
80 if ( ( rc = parse_options ( argc, argv, &cpuid_cmd, &opts ) ) != 0 )
81 return rc;
82
83 /* Parse bit number */
84 if ( ( rc = parse_integer ( argv[optind], &bit ) ) != 0 )
85 return rc;
86
87 /* Get CPU features */
89
90 /* Extract relevant feature register */
91 feature_regs = ( opts.amd ? &features.amd : &features.intel );
92 feature_reg = ( opts.ecx ? feature_regs->ecx : feature_regs->edx );
93
94 /* Check presence of specified feature */
95 return ( ( feature_reg & ( 1 << bit ) ) ? 0 : -ENOENT );
96}
struct arbelprm_rc_send_wqe rc
Definition arbel.h:3
unsigned int uint32_t
Definition stdint.h:12
static union @024010030001061367220137227263210031030210157031 opts
"cert<xxx>" option list
void x86_features(struct x86_features *features)
Get x86 CPU features.
Definition cpuid.c:164
static struct command_descriptor cpuid_cmd
"cpuid" command descriptor
Definition cpuid_cmd.c:61
uint32_t features
Supported features.
Definition ena.h:5
int optind
Current option index.
Definition getopt.c:52
#define ENOENT
No such file or directory.
Definition errno.h:515
static unsigned int unsigned int bit
Definition bigint.h:392
int parse_integer(char *text, unsigned int *value)
Parse integer value.
Definition parseopt.c:92
int parse_options(int argc, char **argv, struct command_descriptor *cmd, void *opts)
Parse command-line options.
Definition parseopt.c:485
"cpuid" options
Definition cpuid_cmd.c:42
An x86 CPU feature register set.
Definition cpuid.h:16
uint32_t edx
Features returned via edx.
Definition cpuid.h:20
uint32_t ecx
Features returned via ecx.
Definition cpuid.h:18
x86 CPU features
Definition cpuid.h:24

References bit, cpuid_cmd, x86_feature_registers::ecx, x86_feature_registers::edx, ENOENT, features, optind, opts, parse_integer(), parse_options(), rc, and x86_features().

Referenced by COMMAND().

◆ COMMAND()

COMMAND ( cpuid ,
cpuid_exec  )

x86 CPU feature detection command

References cpuid_exec().

Variable Documentation

◆ cpuid_opts

struct option_descriptor cpuid_opts[]
static
Initial value:
= {
OPTION_DESC ( "ext", 'e', no_argument,
struct cpuid_options, amd, parse_flag ),
OPTION_DESC ( "amd", 'a', no_argument,
struct cpuid_options, amd, parse_flag ),
OPTION_DESC ( "ecx", 'c', no_argument,
}
static uint32_t uint32_t uint32_t uint32_t * ecx
Definition cpuid.h:91
@ no_argument
Option does not take an argument.
Definition getopt.h:17
int parse_flag(char *text __unused, int *flag)
Parse flag.
Definition parseopt.c:227
#define OPTION_DESC(_longopt, _shortopt, _has_arg, _struct, _field, _parse)
Construct option descriptor.
Definition parseopt.h:68

"cpuid" option list

Definition at line 50 of file cpuid_cmd.c.

50 {
51 OPTION_DESC ( "ext", 'e', no_argument,
52 struct cpuid_options, amd, parse_flag ),
53 /* "--amd" retained for backwards compatibility */
54 OPTION_DESC ( "amd", 'a', no_argument,
55 struct cpuid_options, amd, parse_flag ),
56 OPTION_DESC ( "ecx", 'c', no_argument,
57 struct cpuid_options, ecx, parse_flag ),
58};

◆ cpuid_cmd

struct command_descriptor cpuid_cmd
static
Initial value:
=
COMMAND_DESC ( struct cpuid_options, cpuid_opts, 1, 1, "<bit>" )
static struct option_descriptor cpuid_opts[]
"cpuid" option list
Definition cpuid_cmd.c:50
#define COMMAND_DESC(_struct, _options, _min_args, _max_args, _usage)
Construct command descriptor.
Definition parseopt.h:109

"cpuid" command descriptor

Definition at line 61 of file cpuid_cmd.c.

Referenced by cpuid_exec(), and PROVIDE_REQUIRING_SYMBOL().