176d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman/* ----------------------------------------------------------------------- *
276d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman *
376d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman *   Copyright 2009 Erwan Velu - All Rights Reserved
476d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman *
576d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman *   Permission is hereby granted, free of charge, to any person
676d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman *   obtaining a copy of this software and associated documentation
776d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman *   files (the "Software"), to deal in the Software without
876d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman *   restriction, including without limitation the rights to use,
976d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman *   copy, modify, merge, publish, distribute, sublicense, and/or
1076d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman *   sell copies of the Software, and to permit persons to whom
1176d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman *   the Software is furnished to do so, subject to the following
1276d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman *   conditions:
1376d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman *
1476d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman *   The above copyright notice and this permission notice shall
1576d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman *   be included in all copies or substantial portions of the Software.
1676d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman *
1776d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman *   THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
1876d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman *   EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
1976d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman *   OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
2076d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman *   NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
2176d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman *   HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
2276d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman *   WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
2376d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman *   FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
2476d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman *   OTHER DEALINGS IN THE SOFTWARE.
2576d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman *
2676d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman * -----------------------------------------------------------------------
2776d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman */
2876d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman
2976d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman#include <stdio.h>
3076d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman#include <string.h>
3176d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman#include <stdlib.h>
3276d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman#include <errno.h>
3376d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman
3476d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman#include "hdt-cli.h"
3576d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman#include "hdt-common.h"
3676d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman
3776d05dc695b06c4e987bb8078f78032441e1430cGreg Hartmanvoid main_show_cpu(int argc __unused, char **argv __unused,
3876d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman		   struct s_hardware *hardware)
3976d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman{
4076d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    char features[81];
4176d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    /* We know the total number of logical cores and we
4276d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman     * know the number of cores of the first CPU. Let's consider
4376d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman     * the system as symetrical, and so compute the number of
4476d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman     * physical CPUs. This is only possible if ACPI is present */
4576d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    if (hardware->acpi.madt.processor_local_apic_count > 0) {
4676d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman	more_printf("CPU (%d logical / %d phys)\n",
4776d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman		    hardware->acpi.madt.processor_local_apic_count,
4876d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman		    hardware->physical_cpu_count);
4976d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    } else
5076d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman	more_printf("CPU\n");
5176d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    more_printf(" Manufacturer : %s \n", hardware->cpu.vendor);
5276d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    more_printf(" Product      : %s \n", hardware->cpu.model);
5376d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    more_printf(" CPU Cores    : %d \n", hardware->cpu.num_cores);
5476d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    if (hardware->dmi.processor.thread_count != 0)
5576d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman        more_printf(" CPU Threads  : %d \n", hardware->dmi.processor.thread_count);
5676d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    more_printf(" L2 Cache     : %dK\n", hardware->cpu.l2_cache_size);
5776d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman
5876d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    memset(features, 0, sizeof(features));
5976d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    snprintf(features, sizeof(features), " Features     : %d Mhz : ",
6076d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman	     hardware->dmi.processor.current_speed);
6176d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    if (hardware->cpu.flags.lm)
6276d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman	strcat(features, "x86_64 64bit ");
6376d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    else
6476d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman	strcat(features, "x86 32bit ");
6576d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    if (hardware->cpu.flags.smp)
6676d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman	strcat(features, "SMP ");
6776d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman
6876d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    /* This CPU is featuring Intel or AMD Virtualisation Technology */
6976d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    if (hardware->cpu.flags.vmx || hardware->cpu.flags.svm)
7076d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman	strcat(features, "HwVIRT ");
7176d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman
7276d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    more_printf("%s\n", features);
7376d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman}
7476d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman
7576d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman/* Let's compute the cpu flags display
7676d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman * We have to maximize the number of flags per line */
7776d05dc695b06c4e987bb8078f78032441e1430cGreg Hartmanstatic void show_flag(char *buffer, bool flag, char *flag_name, bool flush)
7876d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman{
7976d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    char output_buffer[81];
8076d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    /* Flush is only set when no more flags are present
8176d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman     * When it's set, or if the line is complete,
8276d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman     * we have to end the string computation and display the line.
8376d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman     * Before adding the flag into the buffer, let's check that adding it
8476d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman     * will not overflow the rendering.*/
8576d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    if ((((strlen(buffer) + strlen(flag_name)) > 66) && flag) || flush) {
8676d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman	snprintf(output_buffer, sizeof output_buffer, "Flags     : %s\n",
8776d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman		 buffer);
8876d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman	more_printf("%s", output_buffer);
8976d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman	memset(buffer, 0, sizeof(buffer));
9076d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman	if (flush)
9176d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman	    return;
9276d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    }
9376d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    /* Let's add the flag name only if the flag is present */
9476d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    if (flag)
9576d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman	strcat(buffer, flag_name);
9676d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman}
9776d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman
9876d05dc695b06c4e987bb8078f78032441e1430cGreg Hartmanstatic void show_cpu(int argc __unused, char **argv __unused,
9976d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman		     struct s_hardware *hardware)
10076d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman{
10176d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    char buffer[81];
10276d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    reset_more_printf();
10376d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    /* We know the total number of logical cores and we
10476d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman     * know the number of cores of the first CPU. Let's consider
10576d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman     * the system as symetrical, and so compute the number of
10676d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman     * physical CPUs. This is only possible if ACPI is present*/
10776d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    if (hardware->acpi.madt.processor_local_apic_count > 0) {
10876d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman	more_printf("CPU (%d logical / %d phys)\n",
10976d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman		    hardware->acpi.madt.processor_local_apic_count,
11076d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman		    hardware->acpi.madt.processor_local_apic_count /
11176d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman		    hardware->cpu.num_cores);
11276d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    } else
11376d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman	more_printf("CPU\n");
11476d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    more_printf("Vendor    : %s\n", hardware->cpu.vendor);
11576d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    more_printf("Model     : %s\n", hardware->cpu.model);
11676d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    more_printf("CPU Cores : %d\n", hardware->cpu.num_cores);
11776d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    if (hardware->dmi.processor.core_enabled != 0)
11876d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman        more_printf("CPU Enable: %d\n", hardware->dmi.processor.core_enabled);
11976d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    if (hardware->dmi.processor.thread_count != 0)
12076d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman        more_printf("CPU Thread: %d \n", hardware->dmi.processor.thread_count);
12176d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    more_printf("L1 Cache  : %dK + %dK (I + D) \n",
12276d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman		hardware->cpu.l1_instruction_cache_size,
12376d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman		hardware->cpu.l1_data_cache_size);
12476d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    more_printf("L2 Cache  : %dK\n", hardware->cpu.l2_cache_size);
12576d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    more_printf("Family ID : %d\n", hardware->cpu.family);
12676d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    more_printf("Model  ID : %d\n", hardware->cpu.model_id);
12776d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    more_printf("Stepping  : %d\n", hardware->cpu.stepping);
12876d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    if (hardware->is_dmi_valid) {
12976d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman	more_printf("FSB       : %d MHz\n",
13076d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman		    hardware->dmi.processor.external_clock);
13176d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman	more_printf("Cur. Speed: %d MHz\n",
13276d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman		    hardware->dmi.processor.current_speed);
13376d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman	more_printf("Max Speed : %d MHz\n", hardware->dmi.processor.max_speed);
13476d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman	more_printf("Upgrade   : %s\n", hardware->dmi.processor.upgrade);
13576d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman	more_printf("Voltage   : %d.%02d\n",
13676d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman		    hardware->dmi.processor.voltage_mv / 1000,
13776d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman		    hardware->dmi.processor.voltage_mv -
13876d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman		    ((hardware->dmi.processor.voltage_mv / 1000) * 1000));
13976d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    }
14076d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman
14176d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    if (hardware->cpu.flags.smp) {
14276d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman	more_printf("SMP       : yes\n");
14376d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    } else {
14476d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman	more_printf("SMP       : no\n");
14576d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    }
14676d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman
14776d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    if (hardware->cpu.flags.lm) {
14876d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman	more_printf("x86_64    : yes\n");
14976d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    } else {
15076d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman	more_printf("x86_64    : no\n");
15176d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    }
15276d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman
15376d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    if (hardware->cpu.flags.vmx || hardware->cpu.flags.svm) {
15476d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman	more_printf("HwVirt    : yes\n");
15576d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    } else {
15676d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman	more_printf("HwVirt    : no\n");
15776d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    }
15876d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman
15976d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    /* Let's display the supported cpu flags */
16076d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    memset(buffer, 0, sizeof(buffer));
16176d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.fpu, "fpu ", false);
16276d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.vme, "vme ", false);
16376d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.de, "de ", false);
16476d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.pse, "pse ", false);
16576d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.tsc, "tsc ", false);
16676d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.msr, "msr ", false);
16776d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.pae, "pae ", false);
16876d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.mce, "mce ", false);
16976d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.cx8, "cx8 ", false);
17076d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.apic, "apic ", false);
17176d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.sep, "sep ", false);
17276d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.mtrr, "mtrr ", false);
17376d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.pge, "pge ", false);
17476d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.mca, "mca ", false);
17576d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.cmov, "cmov ", false);
17676d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.pat, "pat ", false);
17776d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.pse_36, "pse_36 ", false);
17876d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.psn, "psn ", false);
17976d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.clflsh, "clflsh ", false);
18076d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.dts, "dts ", false);
18176d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.acpi, "acpi ", false);
18276d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.mmx, "mmx ", false);
18376d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.sse, "sse ", false);
18476d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.sse2, "sse2 ", false);
18576d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.ss, "ss ", false);
18676d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.htt, "ht ", false);
18776d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.acc, "acc ", false);
18876d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.syscall, "syscall ", false);
18976d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.mp, "mp ", false);
19076d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.nx, "nx ", false);
19176d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.mmxext, "mmxext ", false);
19276d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.lm, "lm ", false);
19376d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.nowext, "3dnowext ", false);
19476d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.now, "3dnow! ", false);
19576d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.svm, "svm ", false);
19676d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.vmx, "vmx ", false);
19776d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.pbe, "pbe ", false);
19876d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.fxsr_opt, "fxsr_opt ", false);
19976d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.gbpages, "gbpages ", false);
20076d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.rdtscp, "rdtscp ", false);
20176d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.pni, "pni ", false);
20276d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.pclmulqd, "pclmulqd ", false);
20376d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.dtes64, "dtes64 ", false);
20476d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.smx, "smx ", false);
20576d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.est, "est ", false);
20676d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.tm2, "tm2 ", false);
20776d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.sse3, "sse3 ", false);
20876d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.fma, "fma ", false);
20976d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.cx16, "cx16 ", false);
21076d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.xtpr, "xtpr ", false);
21176d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.pdcm, "pdcm ", false);
21276d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.dca, "dca ", false);
21376d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.xmm4_1, "xmm4_1 ", false);
21476d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.xmm4_2, "xmm4_2 ", false);
21576d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.x2apic, "x2apic ", false);
21676d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.movbe, "movbe ", false);
21776d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.popcnt, "popcnt ", false);
21876d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.aes, "aes ", false);
21976d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.xsave, "xsave ", false);
22076d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.osxsave, "osxsave ", false);
22176d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.avx, "avx ", false);
22276d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.hypervisor, "hypervisor ", false);
22376d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.ace2, "ace2 ", false);
22476d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.ace2_en, "ace2_en ", false);
22576d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.phe, "phe ", false);
22676d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.phe_en, "phe_en ", false);
22776d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.pmm, "pmm ", false);
22876d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.pmm_en, "pmm_en ", false);
22976d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.extapic, "extapic ", false);
23076d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.cr8_legacy, "cr8_legacy ", false);
23176d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.abm, "abm ", false);
23276d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.sse4a, "sse4a ", false);
23376d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.misalignsse, "misalignsse ", false);
23476d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.nowprefetch, "3dnowprefetch ", false);
23576d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.osvw, "osvw ", false);
23676d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.ibs, "ibs ", false);
23776d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.sse5, "sse5 ", false);
23876d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.skinit, "skinit ", false);
23976d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.wdt, "wdt ", false);
24076d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.ida, "ida ", false);
24176d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.arat, "arat ", false);
24276d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.tpr_shadow, "tpr_shadow ", false);
24376d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.vnmi, "vnmi ", false);
24476d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.flexpriority, "flexpriority ", false);
24576d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.ept, "ept ", false);
24676d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, hardware->cpu.flags.vpid, "vpid ", false);
24776d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman
24876d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    /* No more flags, let's display the remaining flags */
24976d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    show_flag(buffer, false, "", true);
25076d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman}
25176d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman
25276d05dc695b06c4e987bb8078f78032441e1430cGreg Hartmanstruct cli_module_descr cpu_show_modules = {
25376d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    .modules = NULL,
25476d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    .default_callback = show_cpu,
25576d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman};
25676d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman
25776d05dc695b06c4e987bb8078f78032441e1430cGreg Hartmanstruct cli_mode_descr cpu_mode = {
25876d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    .mode = CPU_MODE,
25976d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    .name = CLI_CPU,
26076d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    .default_modules = NULL,
26176d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    .show_modules = &cpu_show_modules,
26276d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman    .set_modules = NULL,
26376d05dc695b06c4e987bb8078f78032441e1430cGreg Hartman};
264