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