From patchwork Fri Aug 11 13:50:09 2023 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Tim Wiederhake X-Patchwork-Id: 1820286 Return-Path: X-Original-To: incoming@patchwork.ozlabs.org Delivered-To: patchwork-incoming@legolas.ozlabs.org Authentication-Results: legolas.ozlabs.org; spf=pass (sender SPF authorized) smtp.mailfrom=nongnu.org (client-ip=209.51.188.17; helo=lists.gnu.org; envelope-from=qemu-devel-bounces+incoming=patchwork.ozlabs.org@nongnu.org; receiver=) Authentication-Results: legolas.ozlabs.org; dkim=pass (1024-bit key; unprotected) header.d=redhat.com header.i=@redhat.com header.a=rsa-sha256 header.s=mimecast20190719 header.b=E3bJk7Nz; dkim-atps=neutral Received: from lists.gnu.org (lists.gnu.org [209.51.188.17]) (using TLSv1.2 with cipher ECDHE-ECDSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by legolas.ozlabs.org (Postfix) with ESMTPS id 4RMlbf3Qglz1yf6 for ; Fri, 11 Aug 2023 23:52:30 +1000 (AEST) Received: from localhost ([::1] helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1qUSYh-0000jQ-Bl; Fri, 11 Aug 2023 09:52:07 -0400 Received: from eggs.gnu.org ([2001:470:142:3::10]) by lists.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.90_1) (envelope-from ) id 1qUSYf-0000jB-N9 for qemu-devel@nongnu.org; Fri, 11 Aug 2023 09:52:05 -0400 Received: from us-smtp-delivery-124.mimecast.com ([170.10.129.124]) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.90_1) (envelope-from ) id 1qUSYc-000393-7L for qemu-devel@nongnu.org; Fri, 11 Aug 2023 09:52:05 -0400 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1691761921; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=UNs4tNlnihc3dFMKNslKs8pmG5INWMYJP4AgivKdHhc=; b=E3bJk7NzZA+zNbMOvGW0l+KldRTys0UunYqiO8YMn9KdjWfiZk2TCtS5Z1dmd+xXm6hZfO TdFKN3uomx2QpiGRXuXt+9TZfkGgchhQAEQgQNvtDI9exrXcZ6DhWiJ/N19t6684RLBoNC Nz0R++DPYiSWRJp2/p2ZFGXFJ85ZdCk= Received: from mimecast-mx02.redhat.com (mimecast-mx02.redhat.com [66.187.233.88]) by relay.mimecast.com with ESMTP with STARTTLS (version=TLSv1.2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id us-mta-393-a0jHwZRIO062yXZQ0Zc2tQ-1; Fri, 11 Aug 2023 09:50:15 -0400 X-MC-Unique: a0jHwZRIO062yXZQ0Zc2tQ-1 Received: from smtp.corp.redhat.com (int-mx07.intmail.prod.int.rdu2.redhat.com [10.11.54.7]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mimecast-mx02.redhat.com (Postfix) with ESMTPS id F1E4580556B for ; Fri, 11 Aug 2023 13:50:14 +0000 (UTC) Received: from work.redhat.com (unknown [10.39.193.214]) by smtp.corp.redhat.com (Postfix) with ESMTP id 6C228140E96D; Fri, 11 Aug 2023 13:50:14 +0000 (UTC) From: Tim Wiederhake To: qemu-devel@nongnu.org Cc: Tim Wiederhake Subject: [PATCH 2/4] target/i386: Translate feature_word_info to xml Date: Fri, 11 Aug 2023 15:50:09 +0200 Message-Id: <20230811135011.23343-3-twiederh@redhat.com> In-Reply-To: <20230811135011.23343-1-twiederh@redhat.com> References: <20230811135011.23343-1-twiederh@redhat.com> MIME-Version: 1.0 X-Scanned-By: MIMEDefang 3.1 on 10.11.54.7 Received-SPF: pass client-ip=170.10.129.124; envelope-from=twiederh@redhat.com; helo=us-smtp-delivery-124.mimecast.com X-Spam_score_int: -20 X-Spam_score: -2.1 X-Spam_bar: -- X-Spam_report: (-2.1 / 5.0 requ) BAYES_00=-1.9, DKIMWL_WL_HIGH=-0.001, DKIM_SIGNED=0.1, DKIM_VALID=-0.1, DKIM_VALID_AU=-0.1, DKIM_VALID_EF=-0.1, RCVD_IN_DNSWL_NONE=-0.0001, RCVD_IN_MSPIKE_H4=0.001, RCVD_IN_MSPIKE_WL=0.001, SPF_HELO_NONE=0.001, SPF_PASS=-0.001 autolearn=ham autolearn_force=no X-Spam_action: no action X-BeenThere: qemu-devel@nongnu.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: qemu-devel-bounces+incoming=patchwork.ozlabs.org@nongnu.org Sender: qemu-devel-bounces+incoming=patchwork.ozlabs.org@nongnu.org This is the data file that will be used to generate the C code. All information, including the comments, is preserved. Signed-off-by: Tim Wiederhake --- target/i386/feature_word_info.xml | 1607 +++++++++++++++++++++++++++++ 1 file changed, 1607 insertions(+) create mode 100644 target/i386/feature_word_info.xml diff --git a/target/i386/feature_word_info.xml b/target/i386/feature_word_info.xml new file mode 100644 index 0000000000..ff741b9f5a --- /dev/null +++ b/target/i386/feature_word_info.xml @@ -0,0 +1,1607 @@ + + + CPUID_FEATURE_WORD + + "fpu" + "vme" + "de" + "pse" + "tsc" + "msr" + "pae" + "mce" + "cx8" + "apic" + + "sep" + "mtrr" + "pge" + "mca" + "cmov" + "pat" + "pse36" + "pn" + "clflush" + + "ds" + "acpi" + "mmx" + "fxsr" + "sse" + "sse2" + "ss" + "ht" + "tm" + "ia64" + "pbe" + + + 1 + R_EDX + + TCG_FEATURES + + + CPUID_FEATURE_WORD + + "pni" + "pclmulqdq" + "dtes64" + "monitor" + "ds-cpl" + "vmx" + "smx" + "est" + "tm2" + "ssse3" + "cid" + + "fma" + "cx16" + "xtpr" + "pdcm" + + "pcid" + "dca" + "sse4.1" + "sse4.2" + "x2apic" + "movbe" + "popcnt" + "tsc-deadline" + "aes" + "xsave" + + "avx" + "f16c" + "rdrand" + "hypervisor" + + + 1 + R_ECX + + TCG_EXT_FEATURES + + + + CPUID_FEATURE_WORD + + + + + + + + + + + + + "syscall" + + + + + + + + + "nx" + + "mmxext" + + + "fxsr-opt" + "pdpe1gb" + "rdtscp" + + "lm" + "3dnowext" + "3dnow" + + + 0x80000001 + R_EDX + + TCG_EXT2_FEATURES + + + CPUID_FEATURE_WORD + + "lahf-lm" + "cmp-legacy" + "svm" + "extapic" + "cr8legacy" + "abm" + "sse4a" + "misalignsse" + "3dnowprefetch" + "osvw" + "ibs" + "xop" + "skinit" + "wdt" + + "lwp" + "fma4" + "tce" + + "nodeid-msr" + + "tbm" + "topoext" + "perfctr-core" + "perfctr-nb" + + + + + + + + + + 0x80000001 + R_ECX + + TCG_EXT3_FEATURES + + CPUID_EXT3_TOPOEXT + + + CPUID_FEATURE_WORD + + + + "xstore" + "xstore-en" + + + "xcrypt" + "xcrypt-en" + "ace2" + "ace2-en" + "phe" + "phe-en" + "pmm" + "pmm-en" + + + + + + + + + + + + + + + + + + + + + 0xC0000001 + R_EDX + + TCG_EXT4_FEATURES + + + CPUID_FEATURE_WORD + + "kvmclock" + "kvm-nopiodelay" + "kvm-mmu" + "kvmclock" + "kvm-asyncpf" + "kvm-steal-time" + "kvm-pv-eoi" + "kvm-pv-unhalt" + + "kvm-pv-tlb-flush" + + "kvm-pv-ipi" + "kvm-poll-control" + "kvm-pv-sched-yield" + "kvm-asyncpf-int" + "kvm-msi-ext-dest-id" + + + + + + + + + "kvmclock-stable-bit" + + + + + + + + + + KVM_CPUID_FEATURES + R_EAX + + TCG_KVM_FEATURES + + + CPUID_FEATURE_WORD + + "kvm-hint-dedicated" + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + KVM_CPUID_FEATURES + R_EDX + + TCG_KVM_FEATURES + + ~0U + + + CPUID_FEATURE_WORD + + "npt" + "lbrv" + "svm-lock" + "nrip-save" + "tsc-scale" + "vmcb-clean" + "flushbyasid" + "decodeassists" + + + "pause-filter" + + "pfthreshold" + "avic" + + "v-vmsave-vmload" + "vgif" + + + + + + + + + "vnmi" + + + "svme-addr-chk" + + + + + + 0x8000000A + R_EDX + + TCG_SVM_FEATURES + + + CPUID_FEATURE_WORD + + "fsgsbase" + "tsc-adjust" + "sgx" + "bmi1" + "hle" + "avx2" + + "smep" + "bmi2" + "erms" + "invpcid" + "rtm" + + + "mpx" + + "avx512f" + "avx512dq" + "rdseed" + "adx" + "smap" + "avx512ifma" + "pcommit" + "clflushopt" + "clwb" + "intel-pt" + "avx512pf" + "avx512er" + "avx512cd" + "sha-ni" + "avx512bw" + "avx512vl" + + + 7 + true + 0 + R_EBX + + TCG_7_0_EBX_FEATURES + + + CPUID_FEATURE_WORD + + + "avx512vbmi" + "umip" + "pku" + + "waitpkg" + "avx512vbmi2" + + "gfni" + "vaes" + "vpclmulqdq" + "avx512vnni" + "avx512bitalg" + + "avx512-vpopcntdq" + + "la57" + + + + + + "rdpid" + + "bus-lock-detect" + "cldemote" + + "movdiri" + "movdir64b" + + "sgxlc" + "pks" + + + 7 + true + 0 + R_ECX + + TCG_7_0_ECX_FEATURES + + + CPUID_FEATURE_WORD + + + + "avx512-4vnniw" + "avx512-4fmaps" + "fsrm" + + + + "avx512-vp2intersect" + + "md-clear" + + + + "serialize" + + "tsx-ldtrk" + + + "arch-lbr" + + + "amx-bf16" + "avx512-fp16" + "amx-tile" + "amx-int8" + "spec-ctrl" + "stibp" + "flush-l1d" + "arch-capabilities" + "core-capability" + "ssbd" + + + 7 + true + 0 + R_EDX + + TCG_7_0_EDX_FEATURES + + + CPUID_FEATURE_WORD + + + + + + "avx-vnni" + "avx512-bf16" + + "cmpccxadd" + + + "fzrm" + "fsrs" + "fsrc" + + + + + + + + + "amx-fp16" + + "avx-ifma" + + + + + + + + + + + 7 + true + 1 + R_EAX + + TCG_7_1_EAX_FEATURES + + + CPUID_FEATURE_WORD + + + + + + "avx-vnni-int8" + "avx-ne-convert" + + + + + + + + + "prefetchiti" + + + + + + + + + + + + + + + + + + + + 7 + true + 1 + R_EDX + + TCG_7_1_EDX_FEATURES + + + CPUID_FEATURE_WORD + + + + + + + "mcdt-no" + + + + + + + + + + + + + + + + + + + + + + + + + + + + + 7 + true + 2 + R_EDX + + TCG_7_2_EDX_FEATURES + + + CPUID_FEATURE_WORD + + + + + + + + + + "invtsc" + + + + + + + + + + + + + + + + + + + + + + + + + + 0x80000007 + R_EDX + + TCG_APM_FEATURES + CPUID_APM_INVTSC + + + CPUID_FEATURE_WORD + + "clzero" + + "xsaveerptr" + + + + + + + "wbnoinvd" + + + "ibpb" + + "ibrs" + "amd-stibp" + + "stibp-always-on" + + + + + + + "amd-ssbd" + "virt-ssbd" + "amd-no-ssb" + + "amd-psfd" + + + + + + 0x80000008 + R_EBX + + TCG_8000_0008_EBX + 0 + + + CPUID_FEATURE_WORD + + "no-nested-data-bp" + + "lfence-always-serializing" + + + + "null-sel-clr-base" + + "auto-ibrs" + + + + + + + + + + + + + + + + + + + + + + + + + + 0x80000021 + R_EAX + + 0 + 0 + + + CPUID_FEATURE_WORD + + "xsaveopt" + "xsavec" + "xgetbv1" + "xsaves" + "xfd" + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + 0xd + true + 1 + R_EAX + + TCG_XSAVE_FEATURES + + + CPUID_FEATURE_WORD + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + 0xD + true + 1 + R_ECX + + + + CPUID_FEATURE_WORD + + 0xD + true + 1 + R_EDX + + + + CPUID_FEATURE_WORD + + + + "arat" + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + 6 + R_EAX + + TCG_6_EAX_FEATURES + + + CPUID_FEATURE_WORD + + 0xD + true + 0 + R_EAX + + ~0U + XSTATE_FP_MASK | XSTATE_SSE_MASK | XSTATE_YMM_MASK | XSTATE_BNDREGS_MASK | XSTATE_BNDCSR_MASK | XSTATE_OPMASK_MASK | XSTATE_ZMM_Hi256_MASK | XSTATE_Hi16_ZMM_MASK | XSTATE_PKRU_MASK + + + CPUID_FEATURE_WORD + + 0xD + true + 0 + R_EDX + + ~0U + + + + MSR_FEATURE_WORD + + "rdctl-no" + "ibrs-all" + "rsba" + "skip-l1dfl-vmentry" + "ssb-no" + "mds-no" + "pschange-mc-no" + "tsx-ctrl" + "taa-no" + + + + + "sbdr-ssdp-no" + "fbsdp-no" + "psdp-no" + + "fb-clear" + + + + + + + "pbrsb-no" + + + + + + + + + MSR_IA32_ARCH_CAPABILITIES + + ~0U + + + MSR_FEATURE_WORD + + + + + + + "split-lock-detect" + + + + + + + + + + + + + + + + + + + + + + + + + + + + MSR_IA32_CORE_CAPABILITY + + + MSR_FEATURE_WORD + + + + + + + + + + + + + + + "full-width-write" + + + + + + + + + + + + + + + + + + + + MSR_IA32_PERF_CAPABILITIES + + + MSR_FEATURE_WORD + + + + "vmx-vintr-pending" + "vmx-tsc-offset" + + + + "vmx-hlt-exit" + + "vmx-invlpg-exit" + "vmx-mwait-exit" + "vmx-rdpmc-exit" + "vmx-rdtsc-exit" + + + "vmx-cr3-load-noexit" + "vmx-cr3-store-noexit" + + + "vmx-cr8-load-exit" + "vmx-cr8-store-exit" + "vmx-flexpriority" + "vmx-vnmi-pending" + "vmx-movdr-exit" + "vmx-io-exit" + "vmx-io-bitmap" + + "vmx-mtf" + "vmx-msr-bitmap" + "vmx-monitor-exit" + "vmx-pause-exit" + "vmx-secondary-ctls" + + MSR_IA32_VMX_TRUE_PROCBASED_CTLS + + + MSR_FEATURE_WORD + + "vmx-apicv-xapic" + "vmx-ept" + "vmx-desc-exit" + "vmx-rdtscp-exit" + "vmx-apicv-x2apic" + "vmx-vpid" + "vmx-wbinvd-exit" + "vmx-unrestricted-guest" + "vmx-apicv-register" + "vmx-apicv-vid" + "vmx-ple" + "vmx-rdrand-exit" + "vmx-invpcid-exit" + "vmx-vmfunc" + "vmx-shadow-vmcs" + "vmx-encls-exit" + "vmx-rdseed-exit" + "vmx-pml" + + + "vmx-xsaves" + + + + + "vmx-tsc-scaling" + + + + + + + + MSR_IA32_VMX_PROCBASED_CTLS2 + + + MSR_FEATURE_WORD + + "vmx-intr-exit" + + + "vmx-nmi-exit" + + "vmx-vnmi" + "vmx-preemption-timer" + "vmx-posted-intr" + + + + + + + + + + + + + + + + + + + + + + + + + + MSR_IA32_VMX_TRUE_PINBASED_CTLS + + + MSR_FEATURE_WORD + + + + + "vmx-exit-nosave-debugctl" + + + + + + + + + + "vmx-exit-load-perf-global-ctrl" + + + "vmx-exit-ack-intr" + + + "vmx-exit-save-pat" + "vmx-exit-load-pat" + "vmx-exit-save-efer" + "vmx-exit-load-efer" + "vmx-exit-save-preemption-timer" + "vmx-exit-clear-bndcfgs" + + "vmx-exit-clear-rtit-ctl" + + + + "vmx-exit-load-pkrs" + + + + MSR_IA32_VMX_TRUE_EXIT_CTLS + + + MSR_FEATURE_WORD + + + + "vmx-entry-noload-debugctl" + + + + + + + "vmx-entry-ia32e-mode" + + + + "vmx-entry-load-perf-global-ctrl" + "vmx-entry-load-pat" + "vmx-entry-load-efer" + "vmx-entry-load-bndcfgs" + + "vmx-entry-load-rtit-ctl" + + + + "vmx-entry-load-pkrs" + + + + + + + + + + + MSR_IA32_VMX_TRUE_ENTRY_CTLS + + + MSR_FEATURE_WORD + + + + + + + "vmx-store-lma" + "vmx-activity-hlt" + "vmx-activity-shutdown" + "vmx-activity-wait-sipi" + + + + + + + + + + + + + + + + + + + + + "vmx-vmwrite-vmexit-fields" + "vmx-zero-len-inject" + + + MSR_IA32_VMX_MISC + + + MSR_FEATURE_WORD + + "vmx-ept-execonly" + + + + + + "vmx-page-walk-4" + "vmx-page-walk-5" + + + + + + + + + "vmx-ept-2mb" + "vmx-ept-1gb" + + + "vmx-invept" + "vmx-eptad" + "vmx-ept-advanced-exitinfo" + + + "vmx-invept-single-context" + "vmx-invept-all-context" + + + + + + "vmx-invvpid" + + + + + + + + "vmx-invvpid-single-addr" + "vmx-invept-single-context" + "vmx-invvpid-all-context" + "vmx-invept-single-context-noglobals" + + + + + + + + + + + + + + + + + + + + + + MSR_IA32_VMX_EPT_VPID_CAP + + + MSR_FEATURE_WORD + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + "vmx-ins-outs" + "vmx-true-ctls" + + + + + + + + + + MSR_IA32_VMX_BASIC + + MSR_VMX_BASIC_DUAL_MONITOR + + + MSR_FEATURE_WORD + + "vmx-eptp-switching" + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + MSR_IA32_VMX_VMFUNC + + + CPUID_FEATURE_WORD + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + "intel-pt-lip" + + + 0x14 + true + 0 + R_ECX + + TCG_14_0_ECX_FEATURES + + + CPUID_FEATURE_WORD + + "sgx1" + "sgx2" + + + + + + + + + + "sgx-edeccssa" + + + + + + + + + + + + + + + + + + + + + + + 0x12 + true + 0 + R_EAX + + TCG_SGX_12_0_EAX_FEATURES + + + CPUID_FEATURE_WORD + + "sgx-exinfo" + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + 0x12 + true + 0 + R_EBX + + TCG_SGX_12_0_EBX_FEATURES + + + CPUID_FEATURE_WORD + + + "sgx-debug" + "sgx-mode64" + + "sgx-provisionkey" + "sgx-tokenkey" + + "sgx-kss" + + + "sgx-aex-notify" + + + + + + + + + + + + + + + + + + + + + + + + 0x12 + true + 1 + R_EAX + + TCG_SGX_12_1_EAX_FEATURES + +