pax_global_header00006660000000000000000000000064145222013070014506gustar00rootroot0000000000000052 comment=3a00e73348c959330a0c0346a77696e81fd8dc0d cpuid-2.2.6/000077500000000000000000000000001452220130700126215ustar00rootroot00000000000000cpuid-2.2.6/.github/000077500000000000000000000000001452220130700141615ustar00rootroot00000000000000cpuid-2.2.6/.github/workflows/000077500000000000000000000000001452220130700162165ustar00rootroot00000000000000cpuid-2.2.6/.github/workflows/go.yml000066400000000000000000000023041452220130700173450ustar00rootroot00000000000000name: Go on: push: branches: [ master ] pull_request: branches: [ master ] jobs: build: strategy: matrix: go-version: [1.18.x, 1.19.x, 1.20.x] os: [ubuntu-latest, macos-latest, windows-latest] runs-on: ubuntu-latest steps: - uses: actions/checkout@v2 - name: Set up Go uses: actions/setup-go@v2 with: go-version: ${{ matrix.go-version }} - name: Vet run: go vet ./... - name: Test run: go test ./... - name: Test Noasm run: go test -tags=noasm ./... build-special: env: CGO_ENABLED: 0 runs-on: ubuntu-latest steps: - name: Set up Go uses: actions/setup-go@v2 with: go-version: 1.20.x - name: Checkout code uses: actions/checkout@v2 - name: fmt run: diff <(gofmt -d .) <(printf "") - name: Test 386 run: GOOS=linux GOARCH=386 go test -short ./... - name: goreleaser deprecation run: curl -sfL https://git.io/goreleaser | VERSION=v1.9.2 sh -s -- check - name: goreleaser snapshot run: curl -sL https://git.io/goreleaser | VERSION=v1.9.2 sh -s -- --snapshot --skip-publish --rm-dist cpuid-2.2.6/.github/workflows/release.yml000066400000000000000000000010741452220130700203630ustar00rootroot00000000000000name: goreleaser on: push: tags: - 'v*' jobs: goreleaser: runs-on: ubuntu-latest steps: - name: Checkout uses: actions/checkout@v2 with: fetch-depth: 0 - name: Set up Go uses: actions/setup-go@v2 with: go-version: 1.18.x - name: Run GoReleaser uses: goreleaser/goreleaser-action@v2 with: version: v1.9.2 args: release --rm-dist env: GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} CGO_ENABLED: 0 cpuid-2.2.6/.gitignore000066400000000000000000000004121452220130700146060ustar00rootroot00000000000000# Compiled Object files, Static and Dynamic libs (Shared Objects) *.o *.a *.so # Folders _obj _test # Architecture specific extensions/prefixes *.[568vq] [568vq].out *.cgo1.go *.cgo2.c _cgo_defun.c _cgo_gotypes.go _cgo_export.* _testmain.go *.exe *.test *.prof cpuid-2.2.6/.goreleaser.yml000066400000000000000000000026211452220130700155530ustar00rootroot00000000000000# This is an example goreleaser.yaml file with some sane defaults. # Make sure to check the documentation at http://goreleaser.com builds: - id: "cpuid" binary: cpuid main: ./cmd/cpuid/main.go env: - CGO_ENABLED=0 flags: - -ldflags=-s -w goos: - aix - linux - freebsd - netbsd - windows - darwin goarch: - 386 - amd64 - arm64 goarm: - 7 archives: - id: cpuid name_template: "cpuid-{{ .Os }}_{{ .Arch }}_{{ .Version }}" replacements: aix: AIX darwin: OSX linux: Linux windows: Windows 386: i386 amd64: x86_64 freebsd: FreeBSD netbsd: NetBSD format_overrides: - goos: windows format: zip files: - LICENSE checksum: name_template: 'checksums.txt' snapshot: name_template: "{{ .Tag }}-next" changelog: sort: asc filters: exclude: - '^doc:' - '^docs:' - '^test:' - '^tests:' - '^Update\sREADME.md' nfpms: - file_name_template: "cpuid_package_{{ .Version }}_{{ .Os }}_{{ .Arch }}" vendor: Klaus Post homepage: https://github.com/klauspost/cpuid maintainer: Klaus Post description: CPUID Tool license: BSD 3-Clause formats: - deb - rpm replacements: darwin: Darwin linux: Linux freebsd: FreeBSD amd64: x86_64 cpuid-2.2.6/CONTRIBUTING.txt000066400000000000000000000025771452220130700153040ustar00rootroot00000000000000Developer Certificate of Origin Version 1.1 Copyright (C) 2015- Klaus Post & Contributors. Email: klauspost@gmail.com Everyone is permitted to copy and distribute verbatim copies of this license document, but changing it is not allowed. Developer's Certificate of Origin 1.1 By making a contribution to this project, I certify that: (a) The contribution was created in whole or in part by me and I have the right to submit it under the open source license indicated in the file; or (b) The contribution is based upon previous work that, to the best of my knowledge, is covered under an appropriate open source license and I have the right under that license to submit that work with modifications, whether created in whole or in part by me, under the same open source license (unless I am permitted to submit under a different license), as indicated in the file; or (c) The contribution was provided directly to me by some other person who certified (a), (b) or (c) and I have not modified it. (d) I understand and agree that this project and the contribution are public and that a record of the contribution (including all personal information I submit with it, including my sign-off) is maintained indefinitely and may be redistributed consistent with this project or the open source license(s) involved. cpuid-2.2.6/LICENSE000066400000000000000000000020661452220130700136320ustar00rootroot00000000000000The MIT License (MIT) Copyright (c) 2015 Klaus Post Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. cpuid-2.2.6/README.md000066400000000000000000001356051452220130700141120ustar00rootroot00000000000000# cpuid Package cpuid provides information about the CPU running the current program. CPU features are detected on startup, and kept for fast access through the life of the application. Currently x86 / x64 (AMD64/i386) and ARM (ARM64) is supported, and no external C (cgo) code is used, which should make the library very easy to use. You can access the CPU information by accessing the shared CPU variable of the cpuid library. Package home: https://github.com/klauspost/cpuid [![PkgGoDev](https://pkg.go.dev/badge/github.com/klauspost/cpuid)](https://pkg.go.dev/github.com/klauspost/cpuid/v2) [![Go](https://github.com/klauspost/cpuid/actions/workflows/go.yml/badge.svg)](https://github.com/klauspost/cpuid/actions/workflows/go.yml) ## installing `go get -u github.com/klauspost/cpuid/v2` using modules. Drop `v2` for others. Installing binary: `go install github.com/klauspost/cpuid/v2/cmd/cpuid@latest` Or download binaries from release page: https://github.com/klauspost/cpuid/releases ### Homebrew For macOS/Linux users, you can install via [brew](https://brew.sh/) ```sh $ brew install cpuid ``` ## example ```Go package main import ( "fmt" "strings" . "github.com/klauspost/cpuid/v2" ) func main() { // Print basic CPU information: fmt.Println("Name:", CPU.BrandName) fmt.Println("PhysicalCores:", CPU.PhysicalCores) fmt.Println("ThreadsPerCore:", CPU.ThreadsPerCore) fmt.Println("LogicalCores:", CPU.LogicalCores) fmt.Println("Family", CPU.Family, "Model:", CPU.Model, "Vendor ID:", CPU.VendorID) fmt.Println("Features:", strings.Join(CPU.FeatureSet(), ",")) fmt.Println("Cacheline bytes:", CPU.CacheLine) fmt.Println("L1 Data Cache:", CPU.Cache.L1D, "bytes") fmt.Println("L1 Instruction Cache:", CPU.Cache.L1I, "bytes") fmt.Println("L2 Cache:", CPU.Cache.L2, "bytes") fmt.Println("L3 Cache:", CPU.Cache.L3, "bytes") fmt.Println("Frequency", CPU.Hz, "hz") // Test if we have these specific features: if CPU.Supports(SSE, SSE2) { fmt.Println("We have Streaming SIMD 2 Extensions") } } ``` Sample output: ``` >go run main.go Name: AMD Ryzen 9 3950X 16-Core Processor PhysicalCores: 16 ThreadsPerCore: 2 LogicalCores: 32 Family 23 Model: 113 Vendor ID: AMD Features: ADX,AESNI,AVX,AVX2,BMI1,BMI2,CLMUL,CMOV,CX16,F16C,FMA3,HTT,HYPERVISOR,LZCNT,MMX,MMXEXT,NX,POPCNT,RDRAND,RDSEED,RDTSCP,SHA,SSE,SSE2,SSE3,SSE4,SSE42,SSE4A,SSSE3 Cacheline bytes: 64 L1 Data Cache: 32768 bytes L1 Instruction Cache: 32768 bytes L2 Cache: 524288 bytes L3 Cache: 16777216 bytes Frequency 0 hz We have Streaming SIMD 2 Extensions ``` # usage The `cpuid.CPU` provides access to CPU features. Use `cpuid.CPU.Supports()` to check for CPU features. A faster `cpuid.CPU.Has()` is provided which will usually be inlined by the gc compiler. To test a larger number of features, they can be combined using `f := CombineFeatures(CMOV, CMPXCHG8, X87, FXSR, MMX, SYSCALL, SSE, SSE2)`, etc. This can be using with `cpuid.CPU.HasAll(f)` to quickly test if all features are supported. Note that for some cpu/os combinations some features will not be detected. `amd64` has rather good support and should work reliably on all platforms. Note that hypervisors may not pass through all CPU features through to the guest OS, so even if your host supports a feature it may not be visible on guests. ## arm64 feature detection Not all operating systems provide ARM features directly and there is no safe way to do so for the rest. Currently `arm64/linux` and `arm64/freebsd` should be quite reliable. `arm64/darwin` adds features expected from the M1 processor, but a lot remains undetected. A `DetectARM()` can be used if you are able to control your deployment, it will detect CPU features, but may crash if the OS doesn't intercept the calls. A `-cpu.arm` flag for detecting unsafe ARM features can be added. See below. Note that currently only features are detected on ARM, no additional information is currently available. ## flags It is possible to add flags that affects cpu detection. For this the `Flags()` command is provided. This must be called *before* `flag.Parse()` AND after the flags have been parsed `Detect()` must be called. This means that any detection used in `init()` functions will not contain these flags. Example: ```Go package main import ( "flag" "fmt" "strings" "github.com/klauspost/cpuid/v2" ) func main() { cpuid.Flags() flag.Parse() cpuid.Detect() // Test if we have these specific features: if cpuid.CPU.Supports(cpuid.SSE, cpuid.SSE2) { fmt.Println("We have Streaming SIMD 2 Extensions") } } ``` ## commandline Download as binary from: https://github.com/klauspost/cpuid/releases Install from source: `go install github.com/klauspost/cpuid/v2/cmd/cpuid@latest` ### Example ``` λ cpuid Name: AMD Ryzen 9 3950X 16-Core Processor Vendor String: AuthenticAMD Vendor ID: AMD PhysicalCores: 16 Threads Per Core: 2 Logical Cores: 32 CPU Family 23 Model: 113 Features: ADX,AESNI,AVX,AVX2,BMI1,BMI2,CLMUL,CLZERO,CMOV,CMPXCHG8,CPBOOST,CX16,F16C,FMA3,FXSR,FXSROPT,HTT,HYPERVISOR,LAHF,LZCNT,MCAOVERFLOW,MMX,MMXEXT,MOVBE,NX,OSXSAVE,POPCNT,RDRAND,RDSEED,RDTSCP,SCE,SHA,SSE,SSE2,SSE3,SSE4,SSE42,SSE4A,SSSE3,SUCCOR,X87,XSAVE Microarchitecture level: 3 Cacheline bytes: 64 L1 Instruction Cache: 32768 bytes L1 Data Cache: 32768 bytes L2 Cache: 524288 bytes L3 Cache: 16777216 bytes ``` ### JSON Output: ``` λ cpuid --json { "BrandName": "AMD Ryzen 9 3950X 16-Core Processor", "VendorID": 2, "VendorString": "AuthenticAMD", "PhysicalCores": 16, "ThreadsPerCore": 2, "LogicalCores": 32, "Family": 23, "Model": 113, "CacheLine": 64, "Hz": 0, "BoostFreq": 0, "Cache": { "L1I": 32768, "L1D": 32768, "L2": 524288, "L3": 16777216 }, "SGX": { "Available": false, "LaunchControl": false, "SGX1Supported": false, "SGX2Supported": false, "MaxEnclaveSizeNot64": 0, "MaxEnclaveSize64": 0, "EPCSections": null }, "Features": [ "ADX", "AESNI", "AVX", "AVX2", "BMI1", "BMI2", "CLMUL", "CLZERO", "CMOV", "CMPXCHG8", "CPBOOST", "CX16", "F16C", "FMA3", "FXSR", "FXSROPT", "HTT", "HYPERVISOR", "LAHF", "LZCNT", "MCAOVERFLOW", "MMX", "MMXEXT", "MOVBE", "NX", "OSXSAVE", "POPCNT", "RDRAND", "RDSEED", "RDTSCP", "SCE", "SHA", "SSE", "SSE2", "SSE3", "SSE4", "SSE42", "SSE4A", "SSSE3", "SUCCOR", "X87", "XSAVE" ], "X64Level": 3 } ``` ### Check CPU microarch level ``` λ cpuid --check-level=3 2022/03/18 17:04:40 AMD Ryzen 9 3950X 16-Core Processor 2022/03/18 17:04:40 Microarchitecture level 3 is supported. Max level is 3. Exit Code 0 λ cpuid --check-level=4 2022/03/18 17:06:18 AMD Ryzen 9 3950X 16-Core Processor 2022/03/18 17:06:18 Microarchitecture level 4 not supported. Max level is 3. Exit Code 1 ``` ## Available flags ### x86 & amd64 | Feature Flag | Description | |--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | ADX | Intel ADX (Multi-Precision Add-Carry Instruction Extensions) | | AESNI | Advanced Encryption Standard New Instructions | | AMD3DNOW | AMD 3DNOW | | AMD3DNOWEXT | AMD 3DNowExt | | AMXBF16 | Tile computational operations on BFLOAT16 numbers | | AMXINT8 | Tile computational operations on 8-bit integers | | AMXFP16 | Tile computational operations on FP16 numbers | | AMXTILE | Tile architecture | | APX_F | Intel APX | | AVX | AVX functions | | AVX10 | If set the Intel AVX10 Converged Vector ISA is supported | | AVX10_128 | If set indicates that AVX10 128-bit vector support is present | | AVX10_256 | If set indicates that AVX10 256-bit vector support is present | | AVX10_512 | If set indicates that AVX10 512-bit vector support is present | | AVX2 | AVX2 functions | | AVX512BF16 | AVX-512 BFLOAT16 Instructions | | AVX512BITALG | AVX-512 Bit Algorithms | | AVX512BW | AVX-512 Byte and Word Instructions | | AVX512CD | AVX-512 Conflict Detection Instructions | | AVX512DQ | AVX-512 Doubleword and Quadword Instructions | | AVX512ER | AVX-512 Exponential and Reciprocal Instructions | | AVX512F | AVX-512 Foundation | | AVX512FP16 | AVX-512 FP16 Instructions | | AVX512IFMA | AVX-512 Integer Fused Multiply-Add Instructions | | AVX512PF | AVX-512 Prefetch Instructions | | AVX512VBMI | AVX-512 Vector Bit Manipulation Instructions | | AVX512VBMI2 | AVX-512 Vector Bit Manipulation Instructions, Version 2 | | AVX512VL | AVX-512 Vector Length Extensions | | AVX512VNNI | AVX-512 Vector Neural Network Instructions | | AVX512VP2INTERSECT | AVX-512 Intersect for D/Q | | AVX512VPOPCNTDQ | AVX-512 Vector Population Count Doubleword and Quadword | | AVXIFMA | AVX-IFMA instructions | | AVXNECONVERT | AVX-NE-CONVERT instructions | | AVXSLOW | Indicates the CPU performs 2 128 bit operations instead of one | | AVXVNNI | AVX (VEX encoded) VNNI neural network instructions | | AVXVNNIINT8 | AVX-VNNI-INT8 instructions | | BHI_CTRL | Branch History Injection and Intra-mode Branch Target Injection / CVE-2022-0001, CVE-2022-0002 / INTEL-SA-00598 | | BMI1 | Bit Manipulation Instruction Set 1 | | BMI2 | Bit Manipulation Instruction Set 2 | | CETIBT | Intel CET Indirect Branch Tracking | | CETSS | Intel CET Shadow Stack | | CLDEMOTE | Cache Line Demote | | CLMUL | Carry-less Multiplication | | CLZERO | CLZERO instruction supported | | CMOV | i686 CMOV | | CMPCCXADD | CMPCCXADD instructions | | CMPSB_SCADBS_SHORT | Fast short CMPSB and SCASB | | CMPXCHG8 | CMPXCHG8 instruction | | CPBOOST | Core Performance Boost | | CPPC | AMD: Collaborative Processor Performance Control | | CX16 | CMPXCHG16B Instruction | | EFER_LMSLE_UNS | AMD: =Core::X86::Msr::EFER[LMSLE] is not supported, and MBZ | | ENQCMD | Enqueue Command | | ERMS | Enhanced REP MOVSB/STOSB | | F16C | Half-precision floating-point conversion | | FLUSH_L1D | Flush L1D cache | | FMA3 | Intel FMA 3. Does not imply AVX. | | FMA4 | Bulldozer FMA4 functions | | FP128 | AMD: When set, the internal FP/SIMD execution datapath is 128-bits wide | | FP256 | AMD: When set, the internal FP/SIMD execution datapath is 256-bits wide | | FSRM | Fast Short Rep Mov | | FXSR | FXSAVE, FXRESTOR instructions, CR4 bit 9 | | FXSROPT | FXSAVE/FXRSTOR optimizations | | GFNI | Galois Field New Instructions. May require other features (AVX, AVX512VL,AVX512F) based on usage. | | HLE | Hardware Lock Elision | | HRESET | If set CPU supports history reset and the IA32_HRESET_ENABLE MSR | | HTT | Hyperthreading (enabled) | | HWA | Hardware assert supported. Indicates support for MSRC001_10 | | HYBRID_CPU | This part has CPUs of more than one type. | | HYPERVISOR | This bit has been reserved by Intel & AMD for use by hypervisors | | IA32_ARCH_CAP | IA32_ARCH_CAPABILITIES MSR (Intel) | | IA32_CORE_CAP | IA32_CORE_CAPABILITIES MSR | | IBPB | Indirect Branch Restricted Speculation (IBRS) and Indirect Branch Predictor Barrier (IBPB) | | IBRS | AMD: Indirect Branch Restricted Speculation | | IBRS_PREFERRED | AMD: IBRS is preferred over software solution | | IBRS_PROVIDES_SMP | AMD: IBRS provides Same Mode Protection | | IBS | Instruction Based Sampling (AMD) | | IBSBRNTRGT | Instruction Based Sampling Feature (AMD) | | IBSFETCHSAM | Instruction Based Sampling Feature (AMD) | | IBSFFV | Instruction Based Sampling Feature (AMD) | | IBSOPCNT | Instruction Based Sampling Feature (AMD) | | IBSOPCNTEXT | Instruction Based Sampling Feature (AMD) | | IBSOPSAM | Instruction Based Sampling Feature (AMD) | | IBSRDWROPCNT | Instruction Based Sampling Feature (AMD) | | IBSRIPINVALIDCHK | Instruction Based Sampling Feature (AMD) | | IBS_FETCH_CTLX | AMD: IBS fetch control extended MSR supported | | IBS_OPDATA4 | AMD: IBS op data 4 MSR supported | | IBS_OPFUSE | AMD: Indicates support for IbsOpFuse | | IBS_PREVENTHOST | Disallowing IBS use by the host supported | | IBS_ZEN4 | Fetch and Op IBS support IBS extensions added with Zen4 | | IDPRED_CTRL | IPRED_DIS | | INT_WBINVD | WBINVD/WBNOINVD are interruptible. | | INVLPGB | NVLPGB and TLBSYNC instruction supported | | KEYLOCKER | Key locker | | KEYLOCKERW | Key locker wide | | LAHF | LAHF/SAHF in long mode | | LAM | If set, CPU supports Linear Address Masking | | LBRVIRT | LBR virtualization | | LZCNT | LZCNT instruction | | MCAOVERFLOW | MCA overflow recovery support. | | MCDT_NO | Processor do not exhibit MXCSR Configuration Dependent Timing behavior and do not need to mitigate it. | | MCOMMIT | MCOMMIT instruction supported | | MD_CLEAR | VERW clears CPU buffers | | MMX | standard MMX | | MMXEXT | SSE integer functions or AMD MMX ext | | MOVBE | MOVBE instruction (big-endian) | | MOVDIR64B | Move 64 Bytes as Direct Store | | MOVDIRI | Move Doubleword as Direct Store | | MOVSB_ZL | Fast Zero-Length MOVSB | | MPX | Intel MPX (Memory Protection Extensions) | | MOVU | MOVU SSE instructions are more efficient and should be preferred to SSE MOVL/MOVH. MOVUPS is more efficient than MOVLPS/MOVHPS. MOVUPD is more efficient than MOVLPD/MOVHPD | | MSRIRC | Instruction Retired Counter MSR available | | MSRLIST | Read/Write List of Model Specific Registers | | MSR_PAGEFLUSH | Page Flush MSR available | | NRIPS | Indicates support for NRIP save on VMEXIT | | NX | NX (No-Execute) bit | | OSXSAVE | XSAVE enabled by OS | | PCONFIG | PCONFIG for Intel Multi-Key Total Memory Encryption | | POPCNT | POPCNT instruction | | PPIN | AMD: Protected Processor Inventory Number support. Indicates that Protected Processor Inventory Number (PPIN) capability can be enabled | | PREFETCHI | PREFETCHIT0/1 instructions | | PSFD | Predictive Store Forward Disable | | RDPRU | RDPRU instruction supported | | RDRAND | RDRAND instruction is available | | RDSEED | RDSEED instruction is available | | RDTSCP | RDTSCP Instruction | | RRSBA_CTRL | Restricted RSB Alternate | | RTM | Restricted Transactional Memory | | RTM_ALWAYS_ABORT | Indicates that the loaded microcode is forcing RTM abort. | | SERIALIZE | Serialize Instruction Execution | | SEV | AMD Secure Encrypted Virtualization supported | | SEV_64BIT | AMD SEV guest execution only allowed from a 64-bit host | | SEV_ALTERNATIVE | AMD SEV Alternate Injection supported | | SEV_DEBUGSWAP | Full debug state swap supported for SEV-ES guests | | SEV_ES | AMD SEV Encrypted State supported | | SEV_RESTRICTED | AMD SEV Restricted Injection supported | | SEV_SNP | AMD SEV Secure Nested Paging supported | | SGX | Software Guard Extensions | | SGXLC | Software Guard Extensions Launch Control | | SHA | Intel SHA Extensions | | SME | AMD Secure Memory Encryption supported | | SME_COHERENT | AMD Hardware cache coherency across encryption domains enforced | | SPEC_CTRL_SSBD | Speculative Store Bypass Disable | | SRBDS_CTRL | SRBDS mitigation MSR available | | SSE | SSE functions | | SSE2 | P4 SSE functions | | SSE3 | Prescott SSE3 functions | | SSE4 | Penryn SSE4.1 functions | | SSE42 | Nehalem SSE4.2 functions | | SSE4A | AMD Barcelona microarchitecture SSE4a instructions | | SSSE3 | Conroe SSSE3 functions | | STIBP | Single Thread Indirect Branch Predictors | | STIBP_ALWAYSON | AMD: Single Thread Indirect Branch Prediction Mode has Enhanced Performance and may be left Always On | | STOSB_SHORT | Fast short STOSB | | SUCCOR | Software uncorrectable error containment and recovery capability. | | SVM | AMD Secure Virtual Machine | | SVMDA | Indicates support for the SVM decode assists. | | SVMFBASID | SVM, Indicates that TLB flush events, including CR3 writes and CR4.PGE toggles, flush only the current ASID's TLB entries. Also indicates support for the extended VMCBTLB_Control | | SVML | AMD SVM lock. Indicates support for SVM-Lock. | | SVMNP | AMD SVM nested paging | | SVMPF | SVM pause intercept filter. Indicates support for the pause intercept filter | | SVMPFT | SVM PAUSE filter threshold. Indicates support for the PAUSE filter cycle count threshold | | SYSCALL | System-Call Extension (SCE): SYSCALL and SYSRET instructions. | | SYSEE | SYSENTER and SYSEXIT instructions | | TBM | AMD Trailing Bit Manipulation | | TDX_GUEST | Intel Trust Domain Extensions Guest | | TLB_FLUSH_NESTED | AMD: Flushing includes all the nested translations for guest translations | | TME | Intel Total Memory Encryption. The following MSRs are supported: IA32_TME_CAPABILITY, IA32_TME_ACTIVATE, IA32_TME_EXCLUDE_MASK, and IA32_TME_EXCLUDE_BASE. | | TOPEXT | TopologyExtensions: topology extensions support. Indicates support for CPUID Fn8000_001D_EAX_x[N:0]-CPUID Fn8000_001E_EDX. | | TSCRATEMSR | MSR based TSC rate control. Indicates support for MSR TSC ratio MSRC000_0104 | | TSXLDTRK | Intel TSX Suspend Load Address Tracking | | VAES | Vector AES. AVX(512) versions requires additional checks. | | VMCBCLEAN | VMCB clean bits. Indicates support for VMCB clean bits. | | VMPL | AMD VM Permission Levels supported | | VMSA_REGPROT | AMD VMSA Register Protection supported | | VMX | Virtual Machine Extensions | | VPCLMULQDQ | Carry-Less Multiplication Quadword. Requires AVX for 3 register versions. | | VTE | AMD Virtual Transparent Encryption supported | | WAITPKG | TPAUSE, UMONITOR, UMWAIT | | WBNOINVD | Write Back and Do Not Invalidate Cache | | WRMSRNS | Non-Serializing Write to Model Specific Register | | X87 | FPU | | XGETBV1 | Supports XGETBV with ECX = 1 | | XOP | Bulldozer XOP functions | | XSAVE | XSAVE, XRESTOR, XSETBV, XGETBV | | XSAVEC | Supports XSAVEC and the compacted form of XRSTOR. | | XSAVEOPT | XSAVEOPT available | | XSAVES | Supports XSAVES/XRSTORS and IA32_XSS | # ARM features: | Feature Flag | Description | |--------------|------------------------------------------------------------------| | AESARM | AES instructions | | ARMCPUID | Some CPU ID registers readable at user-level | | ASIMD | Advanced SIMD | | ASIMDDP | SIMD Dot Product | | ASIMDHP | Advanced SIMD half-precision floating point | | ASIMDRDM | Rounding Double Multiply Accumulate/Subtract (SQRDMLAH/SQRDMLSH) | | ATOMICS | Large System Extensions (LSE) | | CRC32 | CRC32/CRC32C instructions | | DCPOP | Data cache clean to Point of Persistence (DC CVAP) | | EVTSTRM | Generic timer | | FCMA | Floatin point complex number addition and multiplication | | FP | Single-precision and double-precision floating point | | FPHP | Half-precision floating point | | GPA | Generic Pointer Authentication | | JSCVT | Javascript-style double->int convert (FJCVTZS) | | LRCPC | Weaker release consistency (LDAPR, etc) | | PMULL | Polynomial Multiply instructions (PMULL/PMULL2) | | SHA1 | SHA-1 instructions (SHA1C, etc) | | SHA2 | SHA-2 instructions (SHA256H, etc) | | SHA3 | SHA-3 instructions (EOR3, RAXI, XAR, BCAX) | | SHA512 | SHA512 instructions | | SM3 | SM3 instructions | | SM4 | SM4 instructions | | SVE | Scalable Vector Extension | # license This code is published under an MIT license. See LICENSE file for more information. cpuid-2.2.6/cmd/000077500000000000000000000000001452220130700133645ustar00rootroot00000000000000cpuid-2.2.6/cmd/cpuid/000077500000000000000000000000001452220130700144705ustar00rootroot00000000000000cpuid-2.2.6/cmd/cpuid/main.go000066400000000000000000000052521452220130700157470ustar00rootroot00000000000000// Copyright (c) 2021 Klaus Post, released under MIT License. See LICENSE file. // Package cpuid provides information about the CPU running the current program. // // CPU features are detected on startup, and kept for fast access through the life of the application. // Currently x86 / x64 (AMD64) as well as arm64 is supported. // // You can access the CPU information by accessing the shared CPU variable of the cpuid library. // // Package home: https://github.com/klauspost/cpuid package main import ( "encoding/json" "flag" "fmt" "log" "os" "strings" "github.com/klauspost/cpuid/v2" ) var js = flag.Bool("json", false, "Output as JSON") var level = flag.Int("check-level", 0, "Check microarchitecture level. Exit code will be 0 if supported") func main() { flag.Parse() if level != nil && *level > 0 { if *level < 1 || *level > 4 { log.Fatalln("Supply CPU level 1-4 to test as argument") } log.Println(cpuid.CPU.BrandName) if cpuid.CPU.X64Level() < *level { // Does os.Exit(1) log.Fatalf("Microarchitecture level %d not supported. Max level is %d.", *level, cpuid.CPU.X64Level()) } log.Printf("Microarchitecture level %d is supported. Max level is %d.", *level, cpuid.CPU.X64Level()) os.Exit(0) } if *js { info := struct { cpuid.CPUInfo Features []string X64Level int }{ CPUInfo: cpuid.CPU, Features: cpuid.CPU.FeatureSet(), X64Level: cpuid.CPU.X64Level(), } b, err := json.MarshalIndent(info, "", " ") if err != nil { panic(err) } fmt.Println(string(b)) os.Exit(0) } fmt.Println("Name:", cpuid.CPU.BrandName) fmt.Println("Vendor String:", cpuid.CPU.VendorString) fmt.Println("Vendor ID:", cpuid.CPU.VendorID) fmt.Println("PhysicalCores:", cpuid.CPU.PhysicalCores) fmt.Println("Threads Per Core:", cpuid.CPU.ThreadsPerCore) fmt.Println("Logical Cores:", cpuid.CPU.LogicalCores) fmt.Println("CPU Family", cpuid.CPU.Family, "Model:", cpuid.CPU.Model, "Stepping:", cpuid.CPU.Stepping) fmt.Println("Features:", strings.Join(cpuid.CPU.FeatureSet(), ",")) fmt.Println("Microarchitecture level:", cpuid.CPU.X64Level()) if cpuid.CPU.AVX10Level > 0 { fmt.Println("AVX10 level:", cpuid.CPU.AVX10Level) } fmt.Println("Cacheline bytes:", cpuid.CPU.CacheLine) fmt.Println("L1 Instruction Cache:", cpuid.CPU.Cache.L1I, "bytes") fmt.Println("L1 Data Cache:", cpuid.CPU.Cache.L1D, "bytes") fmt.Println("L2 Cache:", cpuid.CPU.Cache.L2, "bytes") fmt.Println("L3 Cache:", cpuid.CPU.Cache.L3, "bytes") if cpuid.CPU.Hz > 0 { fmt.Println("Frequency:", cpuid.CPU.Hz, "Hz") } if cpuid.CPU.BoostFreq > 0 { fmt.Println("Boost Frequency:", cpuid.CPU.BoostFreq, "Hz") } if cpuid.CPU.SGX.Available { fmt.Printf("SGX: %+v\n", cpuid.CPU.SGX) } } cpuid-2.2.6/cpuid.go000066400000000000000000001427561452220130700142730ustar00rootroot00000000000000// Copyright (c) 2015 Klaus Post, released under MIT License. See LICENSE file. // Package cpuid provides information about the CPU running the current program. // // CPU features are detected on startup, and kept for fast access through the life of the application. // Currently x86 / x64 (AMD64) as well as arm64 is supported. // // You can access the CPU information by accessing the shared CPU variable of the cpuid library. // // Package home: https://github.com/klauspost/cpuid package cpuid import ( "flag" "fmt" "math" "math/bits" "os" "runtime" "strings" ) // AMD refererence: https://www.amd.com/system/files/TechDocs/25481.pdf // and Processor Programming Reference (PPR) // Vendor is a representation of a CPU vendor. type Vendor int const ( VendorUnknown Vendor = iota Intel AMD VIA Transmeta NSC KVM // Kernel-based Virtual Machine MSVM // Microsoft Hyper-V or Windows Virtual PC VMware XenHVM Bhyve Hygon SiS RDC Ampere ARM Broadcom Cavium DEC Fujitsu Infineon Motorola NVIDIA AMCC Qualcomm Marvell lastVendor ) //go:generate stringer -type=FeatureID,Vendor // FeatureID is the ID of a specific cpu feature. type FeatureID int const ( // Keep index -1 as unknown UNKNOWN = -1 // Add features ADX FeatureID = iota // Intel ADX (Multi-Precision Add-Carry Instruction Extensions) AESNI // Advanced Encryption Standard New Instructions AMD3DNOW // AMD 3DNOW AMD3DNOWEXT // AMD 3DNowExt AMXBF16 // Tile computational operations on BFLOAT16 numbers AMXFP16 // Tile computational operations on FP16 numbers AMXINT8 // Tile computational operations on 8-bit integers AMXTILE // Tile architecture APX_F // Intel APX AVX // AVX functions AVX10 // If set the Intel AVX10 Converged Vector ISA is supported AVX10_128 // If set indicates that AVX10 128-bit vector support is present AVX10_256 // If set indicates that AVX10 256-bit vector support is present AVX10_512 // If set indicates that AVX10 512-bit vector support is present AVX2 // AVX2 functions AVX512BF16 // AVX-512 BFLOAT16 Instructions AVX512BITALG // AVX-512 Bit Algorithms AVX512BW // AVX-512 Byte and Word Instructions AVX512CD // AVX-512 Conflict Detection Instructions AVX512DQ // AVX-512 Doubleword and Quadword Instructions AVX512ER // AVX-512 Exponential and Reciprocal Instructions AVX512F // AVX-512 Foundation AVX512FP16 // AVX-512 FP16 Instructions AVX512IFMA // AVX-512 Integer Fused Multiply-Add Instructions AVX512PF // AVX-512 Prefetch Instructions AVX512VBMI // AVX-512 Vector Bit Manipulation Instructions AVX512VBMI2 // AVX-512 Vector Bit Manipulation Instructions, Version 2 AVX512VL // AVX-512 Vector Length Extensions AVX512VNNI // AVX-512 Vector Neural Network Instructions AVX512VP2INTERSECT // AVX-512 Intersect for D/Q AVX512VPOPCNTDQ // AVX-512 Vector Population Count Doubleword and Quadword AVXIFMA // AVX-IFMA instructions AVXNECONVERT // AVX-NE-CONVERT instructions AVXSLOW // Indicates the CPU performs 2 128 bit operations instead of one AVXVNNI // AVX (VEX encoded) VNNI neural network instructions AVXVNNIINT8 // AVX-VNNI-INT8 instructions BHI_CTRL // Branch History Injection and Intra-mode Branch Target Injection / CVE-2022-0001, CVE-2022-0002 / INTEL-SA-00598 BMI1 // Bit Manipulation Instruction Set 1 BMI2 // Bit Manipulation Instruction Set 2 CETIBT // Intel CET Indirect Branch Tracking CETSS // Intel CET Shadow Stack CLDEMOTE // Cache Line Demote CLMUL // Carry-less Multiplication CLZERO // CLZERO instruction supported CMOV // i686 CMOV CMPCCXADD // CMPCCXADD instructions CMPSB_SCADBS_SHORT // Fast short CMPSB and SCASB CMPXCHG8 // CMPXCHG8 instruction CPBOOST // Core Performance Boost CPPC // AMD: Collaborative Processor Performance Control CX16 // CMPXCHG16B Instruction EFER_LMSLE_UNS // AMD: =Core::X86::Msr::EFER[LMSLE] is not supported, and MBZ ENQCMD // Enqueue Command ERMS // Enhanced REP MOVSB/STOSB F16C // Half-precision floating-point conversion FLUSH_L1D // Flush L1D cache FMA3 // Intel FMA 3. Does not imply AVX. FMA4 // Bulldozer FMA4 functions FP128 // AMD: When set, the internal FP/SIMD execution datapath is no more than 128-bits wide FP256 // AMD: When set, the internal FP/SIMD execution datapath is no more than 256-bits wide FSRM // Fast Short Rep Mov FXSR // FXSAVE, FXRESTOR instructions, CR4 bit 9 FXSROPT // FXSAVE/FXRSTOR optimizations GFNI // Galois Field New Instructions. May require other features (AVX, AVX512VL,AVX512F) based on usage. HLE // Hardware Lock Elision HRESET // If set CPU supports history reset and the IA32_HRESET_ENABLE MSR HTT // Hyperthreading (enabled) HWA // Hardware assert supported. Indicates support for MSRC001_10 HYBRID_CPU // This part has CPUs of more than one type. HYPERVISOR // This bit has been reserved by Intel & AMD for use by hypervisors IA32_ARCH_CAP // IA32_ARCH_CAPABILITIES MSR (Intel) IA32_CORE_CAP // IA32_CORE_CAPABILITIES MSR IBPB // Indirect Branch Restricted Speculation (IBRS) and Indirect Branch Predictor Barrier (IBPB) IBRS // AMD: Indirect Branch Restricted Speculation IBRS_PREFERRED // AMD: IBRS is preferred over software solution IBRS_PROVIDES_SMP // AMD: IBRS provides Same Mode Protection IBS // Instruction Based Sampling (AMD) IBSBRNTRGT // Instruction Based Sampling Feature (AMD) IBSFETCHSAM // Instruction Based Sampling Feature (AMD) IBSFFV // Instruction Based Sampling Feature (AMD) IBSOPCNT // Instruction Based Sampling Feature (AMD) IBSOPCNTEXT // Instruction Based Sampling Feature (AMD) IBSOPSAM // Instruction Based Sampling Feature (AMD) IBSRDWROPCNT // Instruction Based Sampling Feature (AMD) IBSRIPINVALIDCHK // Instruction Based Sampling Feature (AMD) IBS_FETCH_CTLX // AMD: IBS fetch control extended MSR supported IBS_OPDATA4 // AMD: IBS op data 4 MSR supported IBS_OPFUSE // AMD: Indicates support for IbsOpFuse IBS_PREVENTHOST // Disallowing IBS use by the host supported IBS_ZEN4 // AMD: Fetch and Op IBS support IBS extensions added with Zen4 IDPRED_CTRL // IPRED_DIS INT_WBINVD // WBINVD/WBNOINVD are interruptible. INVLPGB // NVLPGB and TLBSYNC instruction supported KEYLOCKER // Key locker KEYLOCKERW // Key locker wide LAHF // LAHF/SAHF in long mode LAM // If set, CPU supports Linear Address Masking LBRVIRT // LBR virtualization LZCNT // LZCNT instruction MCAOVERFLOW // MCA overflow recovery support. MCDT_NO // Processor do not exhibit MXCSR Configuration Dependent Timing behavior and do not need to mitigate it. MCOMMIT // MCOMMIT instruction supported MD_CLEAR // VERW clears CPU buffers MMX // standard MMX MMXEXT // SSE integer functions or AMD MMX ext MOVBE // MOVBE instruction (big-endian) MOVDIR64B // Move 64 Bytes as Direct Store MOVDIRI // Move Doubleword as Direct Store MOVSB_ZL // Fast Zero-Length MOVSB MOVU // AMD: MOVU SSE instructions are more efficient and should be preferred to SSE MOVL/MOVH. MOVUPS is more efficient than MOVLPS/MOVHPS. MOVUPD is more efficient than MOVLPD/MOVHPD MPX // Intel MPX (Memory Protection Extensions) MSRIRC // Instruction Retired Counter MSR available MSRLIST // Read/Write List of Model Specific Registers MSR_PAGEFLUSH // Page Flush MSR available NRIPS // Indicates support for NRIP save on VMEXIT NX // NX (No-Execute) bit OSXSAVE // XSAVE enabled by OS PCONFIG // PCONFIG for Intel Multi-Key Total Memory Encryption POPCNT // POPCNT instruction PPIN // AMD: Protected Processor Inventory Number support. Indicates that Protected Processor Inventory Number (PPIN) capability can be enabled PREFETCHI // PREFETCHIT0/1 instructions PSFD // Predictive Store Forward Disable RDPRU // RDPRU instruction supported RDRAND // RDRAND instruction is available RDSEED // RDSEED instruction is available RDTSCP // RDTSCP Instruction RRSBA_CTRL // Restricted RSB Alternate RTM // Restricted Transactional Memory RTM_ALWAYS_ABORT // Indicates that the loaded microcode is forcing RTM abort. SERIALIZE // Serialize Instruction Execution SEV // AMD Secure Encrypted Virtualization supported SEV_64BIT // AMD SEV guest execution only allowed from a 64-bit host SEV_ALTERNATIVE // AMD SEV Alternate Injection supported SEV_DEBUGSWAP // Full debug state swap supported for SEV-ES guests SEV_ES // AMD SEV Encrypted State supported SEV_RESTRICTED // AMD SEV Restricted Injection supported SEV_SNP // AMD SEV Secure Nested Paging supported SGX // Software Guard Extensions SGXLC // Software Guard Extensions Launch Control SHA // Intel SHA Extensions SME // AMD Secure Memory Encryption supported SME_COHERENT // AMD Hardware cache coherency across encryption domains enforced SPEC_CTRL_SSBD // Speculative Store Bypass Disable SRBDS_CTRL // SRBDS mitigation MSR available SSE // SSE functions SSE2 // P4 SSE functions SSE3 // Prescott SSE3 functions SSE4 // Penryn SSE4.1 functions SSE42 // Nehalem SSE4.2 functions SSE4A // AMD Barcelona microarchitecture SSE4a instructions SSSE3 // Conroe SSSE3 functions STIBP // Single Thread Indirect Branch Predictors STIBP_ALWAYSON // AMD: Single Thread Indirect Branch Prediction Mode has Enhanced Performance and may be left Always On STOSB_SHORT // Fast short STOSB SUCCOR // Software uncorrectable error containment and recovery capability. SVM // AMD Secure Virtual Machine SVMDA // Indicates support for the SVM decode assists. SVMFBASID // SVM, Indicates that TLB flush events, including CR3 writes and CR4.PGE toggles, flush only the current ASID's TLB entries. Also indicates support for the extended VMCBTLB_Control SVML // AMD SVM lock. Indicates support for SVM-Lock. SVMNP // AMD SVM nested paging SVMPF // SVM pause intercept filter. Indicates support for the pause intercept filter SVMPFT // SVM PAUSE filter threshold. Indicates support for the PAUSE filter cycle count threshold SYSCALL // System-Call Extension (SCE): SYSCALL and SYSRET instructions. SYSEE // SYSENTER and SYSEXIT instructions TBM // AMD Trailing Bit Manipulation TDX_GUEST // Intel Trust Domain Extensions Guest TLB_FLUSH_NESTED // AMD: Flushing includes all the nested translations for guest translations TME // Intel Total Memory Encryption. The following MSRs are supported: IA32_TME_CAPABILITY, IA32_TME_ACTIVATE, IA32_TME_EXCLUDE_MASK, and IA32_TME_EXCLUDE_BASE. TOPEXT // TopologyExtensions: topology extensions support. Indicates support for CPUID Fn8000_001D_EAX_x[N:0]-CPUID Fn8000_001E_EDX. TSCRATEMSR // MSR based TSC rate control. Indicates support for MSR TSC ratio MSRC000_0104 TSXLDTRK // Intel TSX Suspend Load Address Tracking VAES // Vector AES. AVX(512) versions requires additional checks. VMCBCLEAN // VMCB clean bits. Indicates support for VMCB clean bits. VMPL // AMD VM Permission Levels supported VMSA_REGPROT // AMD VMSA Register Protection supported VMX // Virtual Machine Extensions VPCLMULQDQ // Carry-Less Multiplication Quadword. Requires AVX for 3 register versions. VTE // AMD Virtual Transparent Encryption supported WAITPKG // TPAUSE, UMONITOR, UMWAIT WBNOINVD // Write Back and Do Not Invalidate Cache WRMSRNS // Non-Serializing Write to Model Specific Register X87 // FPU XGETBV1 // Supports XGETBV with ECX = 1 XOP // Bulldozer XOP functions XSAVE // XSAVE, XRESTOR, XSETBV, XGETBV XSAVEC // Supports XSAVEC and the compacted form of XRSTOR. XSAVEOPT // XSAVEOPT available XSAVES // Supports XSAVES/XRSTORS and IA32_XSS // ARM features: AESARM // AES instructions ARMCPUID // Some CPU ID registers readable at user-level ASIMD // Advanced SIMD ASIMDDP // SIMD Dot Product ASIMDHP // Advanced SIMD half-precision floating point ASIMDRDM // Rounding Double Multiply Accumulate/Subtract (SQRDMLAH/SQRDMLSH) ATOMICS // Large System Extensions (LSE) CRC32 // CRC32/CRC32C instructions DCPOP // Data cache clean to Point of Persistence (DC CVAP) EVTSTRM // Generic timer FCMA // Floatin point complex number addition and multiplication FP // Single-precision and double-precision floating point FPHP // Half-precision floating point GPA // Generic Pointer Authentication JSCVT // Javascript-style double->int convert (FJCVTZS) LRCPC // Weaker release consistency (LDAPR, etc) PMULL // Polynomial Multiply instructions (PMULL/PMULL2) SHA1 // SHA-1 instructions (SHA1C, etc) SHA2 // SHA-2 instructions (SHA256H, etc) SHA3 // SHA-3 instructions (EOR3, RAXI, XAR, BCAX) SHA512 // SHA512 instructions SM3 // SM3 instructions SM4 // SM4 instructions SVE // Scalable Vector Extension // Keep it last. It automatically defines the size of []flagSet lastID firstID FeatureID = UNKNOWN + 1 ) // CPUInfo contains information about the detected system CPU. type CPUInfo struct { BrandName string // Brand name reported by the CPU VendorID Vendor // Comparable CPU vendor ID VendorString string // Raw vendor string. featureSet flagSet // Features of the CPU PhysicalCores int // Number of physical processor cores in your CPU. Will be 0 if undetectable. ThreadsPerCore int // Number of threads per physical core. Will be 1 if undetectable. LogicalCores int // Number of physical cores times threads that can run on each core through the use of hyperthreading. Will be 0 if undetectable. Family int // CPU family number Model int // CPU model number Stepping int // CPU stepping info CacheLine int // Cache line size in bytes. Will be 0 if undetectable. Hz int64 // Clock speed, if known, 0 otherwise. Will attempt to contain base clock speed. BoostFreq int64 // Max clock speed, if known, 0 otherwise Cache struct { L1I int // L1 Instruction Cache (per core or shared). Will be -1 if undetected L1D int // L1 Data Cache (per core or shared). Will be -1 if undetected L2 int // L2 Cache (per core or shared). Will be -1 if undetected L3 int // L3 Cache (per core, per ccx or shared). Will be -1 if undetected } SGX SGXSupport AVX10Level uint8 maxFunc uint32 maxExFunc uint32 } var cpuid func(op uint32) (eax, ebx, ecx, edx uint32) var cpuidex func(op, op2 uint32) (eax, ebx, ecx, edx uint32) var xgetbv func(index uint32) (eax, edx uint32) var rdtscpAsm func() (eax, ebx, ecx, edx uint32) var darwinHasAVX512 = func() bool { return false } // CPU contains information about the CPU as detected on startup, // or when Detect last was called. // // Use this as the primary entry point to you data. var CPU CPUInfo func init() { initCPU() Detect() } // Detect will re-detect current CPU info. // This will replace the content of the exported CPU variable. // // Unless you expect the CPU to change while you are running your program // you should not need to call this function. // If you call this, you must ensure that no other goroutine is accessing the // exported CPU variable. func Detect() { // Set defaults CPU.ThreadsPerCore = 1 CPU.Cache.L1I = -1 CPU.Cache.L1D = -1 CPU.Cache.L2 = -1 CPU.Cache.L3 = -1 safe := true if detectArmFlag != nil { safe = !*detectArmFlag } addInfo(&CPU, safe) if displayFeats != nil && *displayFeats { fmt.Println("cpu features:", strings.Join(CPU.FeatureSet(), ",")) // Exit with non-zero so tests will print value. os.Exit(1) } if disableFlag != nil { s := strings.Split(*disableFlag, ",") for _, feat := range s { feat := ParseFeature(strings.TrimSpace(feat)) if feat != UNKNOWN { CPU.featureSet.unset(feat) } } } } // DetectARM will detect ARM64 features. // This is NOT done automatically since it can potentially crash // if the OS does not handle the command. // If in the future this can be done safely this function may not // do anything. func DetectARM() { addInfo(&CPU, false) } var detectArmFlag *bool var displayFeats *bool var disableFlag *string // Flags will enable flags. // This must be called *before* flag.Parse AND // Detect must be called after the flags have been parsed. // Note that this means that any detection used in init() functions // will not contain these flags. func Flags() { disableFlag = flag.String("cpu.disable", "", "disable cpu features; comma separated list") displayFeats = flag.Bool("cpu.features", false, "lists cpu features and exits") detectArmFlag = flag.Bool("cpu.arm", false, "allow ARM features to be detected; can potentially crash") } // Supports returns whether the CPU supports all of the requested features. func (c CPUInfo) Supports(ids ...FeatureID) bool { for _, id := range ids { if !c.featureSet.inSet(id) { return false } } return true } // Has allows for checking a single feature. // Should be inlined by the compiler. func (c *CPUInfo) Has(id FeatureID) bool { return c.featureSet.inSet(id) } // AnyOf returns whether the CPU supports one or more of the requested features. func (c CPUInfo) AnyOf(ids ...FeatureID) bool { for _, id := range ids { if c.featureSet.inSet(id) { return true } } return false } // Features contains several features combined for a fast check using // CpuInfo.HasAll type Features *flagSet // CombineFeatures allows to combine several features for a close to constant time lookup. func CombineFeatures(ids ...FeatureID) Features { var v flagSet for _, id := range ids { v.set(id) } return &v } func (c *CPUInfo) HasAll(f Features) bool { return c.featureSet.hasSetP(f) } // https://en.wikipedia.org/wiki/X86-64#Microarchitecture_levels var oneOfLevel = CombineFeatures(SYSEE, SYSCALL) var level1Features = CombineFeatures(CMOV, CMPXCHG8, X87, FXSR, MMX, SSE, SSE2) var level2Features = CombineFeatures(CMOV, CMPXCHG8, X87, FXSR, MMX, SSE, SSE2, CX16, LAHF, POPCNT, SSE3, SSE4, SSE42, SSSE3) var level3Features = CombineFeatures(CMOV, CMPXCHG8, X87, FXSR, MMX, SSE, SSE2, CX16, LAHF, POPCNT, SSE3, SSE4, SSE42, SSSE3, AVX, AVX2, BMI1, BMI2, F16C, FMA3, LZCNT, MOVBE, OSXSAVE) var level4Features = CombineFeatures(CMOV, CMPXCHG8, X87, FXSR, MMX, SSE, SSE2, CX16, LAHF, POPCNT, SSE3, SSE4, SSE42, SSSE3, AVX, AVX2, BMI1, BMI2, F16C, FMA3, LZCNT, MOVBE, OSXSAVE, AVX512F, AVX512BW, AVX512CD, AVX512DQ, AVX512VL) // X64Level returns the microarchitecture level detected on the CPU. // If features are lacking or non x64 mode, 0 is returned. // See https://en.wikipedia.org/wiki/X86-64#Microarchitecture_levels func (c CPUInfo) X64Level() int { if !c.featureSet.hasOneOf(oneOfLevel) { return 0 } if c.featureSet.hasSetP(level4Features) { return 4 } if c.featureSet.hasSetP(level3Features) { return 3 } if c.featureSet.hasSetP(level2Features) { return 2 } if c.featureSet.hasSetP(level1Features) { return 1 } return 0 } // Disable will disable one or several features. func (c *CPUInfo) Disable(ids ...FeatureID) bool { for _, id := range ids { c.featureSet.unset(id) } return true } // Enable will disable one or several features even if they were undetected. // This is of course not recommended for obvious reasons. func (c *CPUInfo) Enable(ids ...FeatureID) bool { for _, id := range ids { c.featureSet.set(id) } return true } // IsVendor returns true if vendor is recognized as Intel func (c CPUInfo) IsVendor(v Vendor) bool { return c.VendorID == v } // FeatureSet returns all available features as strings. func (c CPUInfo) FeatureSet() []string { s := make([]string, 0, c.featureSet.nEnabled()) s = append(s, c.featureSet.Strings()...) return s } // RTCounter returns the 64-bit time-stamp counter // Uses the RDTSCP instruction. The value 0 is returned // if the CPU does not support the instruction. func (c CPUInfo) RTCounter() uint64 { if !c.Supports(RDTSCP) { return 0 } a, _, _, d := rdtscpAsm() return uint64(a) | (uint64(d) << 32) } // Ia32TscAux returns the IA32_TSC_AUX part of the RDTSCP. // This variable is OS dependent, but on Linux contains information // about the current cpu/core the code is running on. // If the RDTSCP instruction isn't supported on the CPU, the value 0 is returned. func (c CPUInfo) Ia32TscAux() uint32 { if !c.Supports(RDTSCP) { return 0 } _, _, ecx, _ := rdtscpAsm() return ecx } // LogicalCPU will return the Logical CPU the code is currently executing on. // This is likely to change when the OS re-schedules the running thread // to another CPU. // If the current core cannot be detected, -1 will be returned. func (c CPUInfo) LogicalCPU() int { if c.maxFunc < 1 { return -1 } _, ebx, _, _ := cpuid(1) return int(ebx >> 24) } // frequencies tries to compute the clock speed of the CPU. If leaf 15 is // supported, use it, otherwise parse the brand string. Yes, really. func (c *CPUInfo) frequencies() { c.Hz, c.BoostFreq = 0, 0 mfi := maxFunctionID() if mfi >= 0x15 { eax, ebx, ecx, _ := cpuid(0x15) if eax != 0 && ebx != 0 && ecx != 0 { c.Hz = (int64(ecx) * int64(ebx)) / int64(eax) } } if mfi >= 0x16 { a, b, _, _ := cpuid(0x16) // Base... if a&0xffff > 0 { c.Hz = int64(a&0xffff) * 1_000_000 } // Boost... if b&0xffff > 0 { c.BoostFreq = int64(b&0xffff) * 1_000_000 } } if c.Hz > 0 { return } // computeHz determines the official rated speed of a CPU from its brand // string. This insanity is *actually the official documented way to do // this according to Intel*, prior to leaf 0x15 existing. The official // documentation only shows this working for exactly `x.xx` or `xxxx` // cases, e.g., `2.50GHz` or `1300MHz`; this parser will accept other // sizes. model := c.BrandName hz := strings.LastIndex(model, "Hz") if hz < 3 { return } var multiplier int64 switch model[hz-1] { case 'M': multiplier = 1000 * 1000 case 'G': multiplier = 1000 * 1000 * 1000 case 'T': multiplier = 1000 * 1000 * 1000 * 1000 } if multiplier == 0 { return } freq := int64(0) divisor := int64(0) decimalShift := int64(1) var i int for i = hz - 2; i >= 0 && model[i] != ' '; i-- { if model[i] >= '0' && model[i] <= '9' { freq += int64(model[i]-'0') * decimalShift decimalShift *= 10 } else if model[i] == '.' { if divisor != 0 { return } divisor = decimalShift } else { return } } // we didn't find a space if i < 0 { return } if divisor != 0 { c.Hz = (freq * multiplier) / divisor return } c.Hz = freq * multiplier } // VM Will return true if the cpu id indicates we are in // a virtual machine. func (c CPUInfo) VM() bool { return CPU.featureSet.inSet(HYPERVISOR) } // flags contains detected cpu features and characteristics type flags uint64 // log2(bits_in_uint64) const flagBitsLog2 = 6 const flagBits = 1 << flagBitsLog2 const flagMask = flagBits - 1 // flagSet contains detected cpu features and characteristics in an array of flags type flagSet [(lastID + flagMask) / flagBits]flags func (s *flagSet) inSet(feat FeatureID) bool { return s[feat>>flagBitsLog2]&(1<<(feat&flagMask)) != 0 } func (s *flagSet) set(feat FeatureID) { s[feat>>flagBitsLog2] |= 1 << (feat & flagMask) } // setIf will set a feature if boolean is true. func (s *flagSet) setIf(cond bool, features ...FeatureID) { if cond { for _, offset := range features { s[offset>>flagBitsLog2] |= 1 << (offset & flagMask) } } } func (s *flagSet) unset(offset FeatureID) { bit := flags(1 << (offset & flagMask)) s[offset>>flagBitsLog2] = s[offset>>flagBitsLog2] & ^bit } // or with another flagset. func (s *flagSet) or(other flagSet) { for i, v := range other[:] { s[i] |= v } } // hasSet returns whether all features are present. func (s *flagSet) hasSet(other flagSet) bool { for i, v := range other[:] { if s[i]&v != v { return false } } return true } // hasSet returns whether all features are present. func (s *flagSet) hasSetP(other *flagSet) bool { for i, v := range other[:] { if s[i]&v != v { return false } } return true } // hasOneOf returns whether one or more features are present. func (s *flagSet) hasOneOf(other *flagSet) bool { for i, v := range other[:] { if s[i]&v != 0 { return true } } return false } // nEnabled will return the number of enabled flags. func (s *flagSet) nEnabled() (n int) { for _, v := range s[:] { n += bits.OnesCount64(uint64(v)) } return n } func flagSetWith(feat ...FeatureID) flagSet { var res flagSet for _, f := range feat { res.set(f) } return res } // ParseFeature will parse the string and return the ID of the matching feature. // Will return UNKNOWN if not found. func ParseFeature(s string) FeatureID { s = strings.ToUpper(s) for i := firstID; i < lastID; i++ { if i.String() == s { return i } } return UNKNOWN } // Strings returns an array of the detected features for FlagsSet. func (s flagSet) Strings() []string { if len(s) == 0 { return []string{""} } r := make([]string, 0) for i := firstID; i < lastID; i++ { if s.inSet(i) { r = append(r, i.String()) } } return r } func maxExtendedFunction() uint32 { eax, _, _, _ := cpuid(0x80000000) return eax } func maxFunctionID() uint32 { a, _, _, _ := cpuid(0) return a } func brandName() string { if maxExtendedFunction() >= 0x80000004 { v := make([]uint32, 0, 48) for i := uint32(0); i < 3; i++ { a, b, c, d := cpuid(0x80000002 + i) v = append(v, a, b, c, d) } return strings.Trim(string(valAsString(v...)), " ") } return "unknown" } func threadsPerCore() int { mfi := maxFunctionID() vend, _ := vendorID() if mfi < 0x4 || (vend != Intel && vend != AMD) { return 1 } if mfi < 0xb { if vend != Intel { return 1 } _, b, _, d := cpuid(1) if (d & (1 << 28)) != 0 { // v will contain logical core count v := (b >> 16) & 255 if v > 1 { a4, _, _, _ := cpuid(4) // physical cores v2 := (a4 >> 26) + 1 if v2 > 0 { return int(v) / int(v2) } } } return 1 } _, b, _, _ := cpuidex(0xb, 0) if b&0xffff == 0 { if vend == AMD { // Workaround for AMD returning 0, assume 2 if >= Zen 2 // It will be more correct than not. fam, _, _ := familyModel() _, _, _, d := cpuid(1) if (d&(1<<28)) != 0 && fam >= 23 { return 2 } } return 1 } return int(b & 0xffff) } func logicalCores() int { mfi := maxFunctionID() v, _ := vendorID() switch v { case Intel: // Use this on old Intel processors if mfi < 0xb { if mfi < 1 { return 0 } // CPUID.1:EBX[23:16] represents the maximum number of addressable IDs (initial APIC ID) // that can be assigned to logical processors in a physical package. // The value may not be the same as the number of logical processors that are present in the hardware of a physical package. _, ebx, _, _ := cpuid(1) logical := (ebx >> 16) & 0xff return int(logical) } _, b, _, _ := cpuidex(0xb, 1) return int(b & 0xffff) case AMD, Hygon: _, b, _, _ := cpuid(1) return int((b >> 16) & 0xff) default: return 0 } } func familyModel() (family, model, stepping int) { if maxFunctionID() < 0x1 { return 0, 0, 0 } eax, _, _, _ := cpuid(1) // If BaseFamily[3:0] is less than Fh then ExtendedFamily[7:0] is reserved and Family is equal to BaseFamily[3:0]. family = int((eax >> 8) & 0xf) extFam := family == 0x6 // Intel is 0x6, needs extended model. if family == 0xf { // Add ExtFamily family += int((eax >> 20) & 0xff) extFam = true } // If BaseFamily[3:0] is less than 0Fh then ExtendedModel[3:0] is reserved and Model is equal to BaseModel[3:0]. model = int((eax >> 4) & 0xf) if extFam { // Add ExtModel model += int((eax >> 12) & 0xf0) } stepping = int(eax & 0xf) return family, model, stepping } func physicalCores() int { v, _ := vendorID() switch v { case Intel: return logicalCores() / threadsPerCore() case AMD, Hygon: lc := logicalCores() tpc := threadsPerCore() if lc > 0 && tpc > 0 { return lc / tpc } // The following is inaccurate on AMD EPYC 7742 64-Core Processor if maxExtendedFunction() >= 0x80000008 { _, _, c, _ := cpuid(0x80000008) if c&0xff > 0 { return int(c&0xff) + 1 } } } return 0 } // Except from http://en.wikipedia.org/wiki/CPUID#EAX.3D0:_Get_vendor_ID var vendorMapping = map[string]Vendor{ "AMDisbetter!": AMD, "AuthenticAMD": AMD, "CentaurHauls": VIA, "GenuineIntel": Intel, "TransmetaCPU": Transmeta, "GenuineTMx86": Transmeta, "Geode by NSC": NSC, "VIA VIA VIA ": VIA, "KVMKVMKVMKVM": KVM, "Microsoft Hv": MSVM, "VMwareVMware": VMware, "XenVMMXenVMM": XenHVM, "bhyve bhyve ": Bhyve, "HygonGenuine": Hygon, "Vortex86 SoC": SiS, "SiS SiS SiS ": SiS, "RiseRiseRise": SiS, "Genuine RDC": RDC, } func vendorID() (Vendor, string) { _, b, c, d := cpuid(0) v := string(valAsString(b, d, c)) vend, ok := vendorMapping[v] if !ok { return VendorUnknown, v } return vend, v } func cacheLine() int { if maxFunctionID() < 0x1 { return 0 } _, ebx, _, _ := cpuid(1) cache := (ebx & 0xff00) >> 5 // cflush size if cache == 0 && maxExtendedFunction() >= 0x80000006 { _, _, ecx, _ := cpuid(0x80000006) cache = ecx & 0xff // cacheline size } // TODO: Read from Cache and TLB Information return int(cache) } func (c *CPUInfo) cacheSize() { c.Cache.L1D = -1 c.Cache.L1I = -1 c.Cache.L2 = -1 c.Cache.L3 = -1 vendor, _ := vendorID() switch vendor { case Intel: if maxFunctionID() < 4 { return } c.Cache.L1I, c.Cache.L1D, c.Cache.L2, c.Cache.L3 = 0, 0, 0, 0 for i := uint32(0); ; i++ { eax, ebx, ecx, _ := cpuidex(4, i) cacheType := eax & 15 if cacheType == 0 { break } cacheLevel := (eax >> 5) & 7 coherency := int(ebx&0xfff) + 1 partitions := int((ebx>>12)&0x3ff) + 1 associativity := int((ebx>>22)&0x3ff) + 1 sets := int(ecx) + 1 size := associativity * partitions * coherency * sets switch cacheLevel { case 1: if cacheType == 1 { // 1 = Data Cache c.Cache.L1D = size } else if cacheType == 2 { // 2 = Instruction Cache c.Cache.L1I = size } else { if c.Cache.L1D < 0 { c.Cache.L1I = size } if c.Cache.L1I < 0 { c.Cache.L1I = size } } case 2: c.Cache.L2 = size case 3: c.Cache.L3 = size } } case AMD, Hygon: // Untested. if maxExtendedFunction() < 0x80000005 { return } _, _, ecx, edx := cpuid(0x80000005) c.Cache.L1D = int(((ecx >> 24) & 0xFF) * 1024) c.Cache.L1I = int(((edx >> 24) & 0xFF) * 1024) if maxExtendedFunction() < 0x80000006 { return } _, _, ecx, _ = cpuid(0x80000006) c.Cache.L2 = int(((ecx >> 16) & 0xFFFF) * 1024) // CPUID Fn8000_001D_EAX_x[N:0] Cache Properties if maxExtendedFunction() < 0x8000001D || !c.Has(TOPEXT) { return } // Xen Hypervisor is buggy and returns the same entry no matter ECX value. // Hack: When we encounter the same entry 100 times we break. nSame := 0 var last uint32 for i := uint32(0); i < math.MaxUint32; i++ { eax, ebx, ecx, _ := cpuidex(0x8000001D, i) level := (eax >> 5) & 7 cacheNumSets := ecx + 1 cacheLineSize := 1 + (ebx & 2047) cachePhysPartitions := 1 + ((ebx >> 12) & 511) cacheNumWays := 1 + ((ebx >> 22) & 511) typ := eax & 15 size := int(cacheNumSets * cacheLineSize * cachePhysPartitions * cacheNumWays) if typ == 0 { return } // Check for the same value repeated. comb := eax ^ ebx ^ ecx if comb == last { nSame++ if nSame == 100 { return } } last = comb switch level { case 1: switch typ { case 1: // Data cache c.Cache.L1D = size case 2: // Inst cache c.Cache.L1I = size default: if c.Cache.L1D < 0 { c.Cache.L1I = size } if c.Cache.L1I < 0 { c.Cache.L1I = size } } case 2: c.Cache.L2 = size case 3: c.Cache.L3 = size } } } } type SGXEPCSection struct { BaseAddress uint64 EPCSize uint64 } type SGXSupport struct { Available bool LaunchControl bool SGX1Supported bool SGX2Supported bool MaxEnclaveSizeNot64 int64 MaxEnclaveSize64 int64 EPCSections []SGXEPCSection } func hasSGX(available, lc bool) (rval SGXSupport) { rval.Available = available if !available { return } rval.LaunchControl = lc a, _, _, d := cpuidex(0x12, 0) rval.SGX1Supported = a&0x01 != 0 rval.SGX2Supported = a&0x02 != 0 rval.MaxEnclaveSizeNot64 = 1 << (d & 0xFF) // pow 2 rval.MaxEnclaveSize64 = 1 << ((d >> 8) & 0xFF) // pow 2 rval.EPCSections = make([]SGXEPCSection, 0) for subleaf := uint32(2); subleaf < 2+8; subleaf++ { eax, ebx, ecx, edx := cpuidex(0x12, subleaf) leafType := eax & 0xf if leafType == 0 { // Invalid subleaf, stop iterating break } else if leafType == 1 { // EPC Section subleaf baseAddress := uint64(eax&0xfffff000) + (uint64(ebx&0x000fffff) << 32) size := uint64(ecx&0xfffff000) + (uint64(edx&0x000fffff) << 32) section := SGXEPCSection{BaseAddress: baseAddress, EPCSize: size} rval.EPCSections = append(rval.EPCSections, section) } } return } func support() flagSet { var fs flagSet mfi := maxFunctionID() vend, _ := vendorID() if mfi < 0x1 { return fs } family, model, _ := familyModel() _, _, c, d := cpuid(1) fs.setIf((d&(1<<0)) != 0, X87) fs.setIf((d&(1<<8)) != 0, CMPXCHG8) fs.setIf((d&(1<<11)) != 0, SYSEE) fs.setIf((d&(1<<15)) != 0, CMOV) fs.setIf((d&(1<<23)) != 0, MMX) fs.setIf((d&(1<<24)) != 0, FXSR) fs.setIf((d&(1<<25)) != 0, FXSROPT) fs.setIf((d&(1<<25)) != 0, SSE) fs.setIf((d&(1<<26)) != 0, SSE2) fs.setIf((c&1) != 0, SSE3) fs.setIf((c&(1<<5)) != 0, VMX) fs.setIf((c&(1<<9)) != 0, SSSE3) fs.setIf((c&(1<<19)) != 0, SSE4) fs.setIf((c&(1<<20)) != 0, SSE42) fs.setIf((c&(1<<25)) != 0, AESNI) fs.setIf((c&(1<<1)) != 0, CLMUL) fs.setIf(c&(1<<22) != 0, MOVBE) fs.setIf(c&(1<<23) != 0, POPCNT) fs.setIf(c&(1<<30) != 0, RDRAND) // This bit has been reserved by Intel & AMD for use by hypervisors, // and indicates the presence of a hypervisor. fs.setIf(c&(1<<31) != 0, HYPERVISOR) fs.setIf(c&(1<<29) != 0, F16C) fs.setIf(c&(1<<13) != 0, CX16) if vend == Intel && (d&(1<<28)) != 0 && mfi >= 4 { fs.setIf(threadsPerCore() > 1, HTT) } if vend == AMD && (d&(1<<28)) != 0 && mfi >= 4 { fs.setIf(threadsPerCore() > 1, HTT) } fs.setIf(c&1<<26 != 0, XSAVE) fs.setIf(c&1<<27 != 0, OSXSAVE) // Check XGETBV/XSAVE (26), OXSAVE (27) and AVX (28) bits const avxCheck = 1<<26 | 1<<27 | 1<<28 if c&avxCheck == avxCheck { // Check for OS support eax, _ := xgetbv(0) if (eax & 0x6) == 0x6 { fs.set(AVX) switch vend { case Intel: // Older than Haswell. fs.setIf(family == 6 && model < 60, AVXSLOW) case AMD: // Older than Zen 2 fs.setIf(family < 23 || (family == 23 && model < 49), AVXSLOW) } } } // FMA3 can be used with SSE registers, so no OS support is strictly needed. // fma3 and OSXSAVE needed. const fma3Check = 1<<12 | 1<<27 fs.setIf(c&fma3Check == fma3Check, FMA3) // Check AVX2, AVX2 requires OS support, but BMI1/2 don't. if mfi >= 7 { _, ebx, ecx, edx := cpuidex(7, 0) if fs.inSet(AVX) && (ebx&0x00000020) != 0 { fs.set(AVX2) } // CPUID.(EAX=7, ECX=0).EBX if (ebx & 0x00000008) != 0 { fs.set(BMI1) fs.setIf((ebx&0x00000100) != 0, BMI2) } fs.setIf(ebx&(1<<2) != 0, SGX) fs.setIf(ebx&(1<<4) != 0, HLE) fs.setIf(ebx&(1<<9) != 0, ERMS) fs.setIf(ebx&(1<<11) != 0, RTM) fs.setIf(ebx&(1<<14) != 0, MPX) fs.setIf(ebx&(1<<18) != 0, RDSEED) fs.setIf(ebx&(1<<19) != 0, ADX) fs.setIf(ebx&(1<<29) != 0, SHA) // CPUID.(EAX=7, ECX=0).ECX fs.setIf(ecx&(1<<5) != 0, WAITPKG) fs.setIf(ecx&(1<<7) != 0, CETSS) fs.setIf(ecx&(1<<8) != 0, GFNI) fs.setIf(ecx&(1<<9) != 0, VAES) fs.setIf(ecx&(1<<10) != 0, VPCLMULQDQ) fs.setIf(ecx&(1<<13) != 0, TME) fs.setIf(ecx&(1<<25) != 0, CLDEMOTE) fs.setIf(ecx&(1<<23) != 0, KEYLOCKER) fs.setIf(ecx&(1<<27) != 0, MOVDIRI) fs.setIf(ecx&(1<<28) != 0, MOVDIR64B) fs.setIf(ecx&(1<<29) != 0, ENQCMD) fs.setIf(ecx&(1<<30) != 0, SGXLC) // CPUID.(EAX=7, ECX=0).EDX fs.setIf(edx&(1<<4) != 0, FSRM) fs.setIf(edx&(1<<9) != 0, SRBDS_CTRL) fs.setIf(edx&(1<<10) != 0, MD_CLEAR) fs.setIf(edx&(1<<11) != 0, RTM_ALWAYS_ABORT) fs.setIf(edx&(1<<14) != 0, SERIALIZE) fs.setIf(edx&(1<<15) != 0, HYBRID_CPU) fs.setIf(edx&(1<<16) != 0, TSXLDTRK) fs.setIf(edx&(1<<18) != 0, PCONFIG) fs.setIf(edx&(1<<20) != 0, CETIBT) fs.setIf(edx&(1<<26) != 0, IBPB) fs.setIf(edx&(1<<27) != 0, STIBP) fs.setIf(edx&(1<<28) != 0, FLUSH_L1D) fs.setIf(edx&(1<<29) != 0, IA32_ARCH_CAP) fs.setIf(edx&(1<<30) != 0, IA32_CORE_CAP) fs.setIf(edx&(1<<31) != 0, SPEC_CTRL_SSBD) // CPUID.(EAX=7, ECX=1).EAX eax1, _, _, edx1 := cpuidex(7, 1) fs.setIf(fs.inSet(AVX) && eax1&(1<<4) != 0, AVXVNNI) fs.setIf(eax1&(1<<7) != 0, CMPCCXADD) fs.setIf(eax1&(1<<10) != 0, MOVSB_ZL) fs.setIf(eax1&(1<<11) != 0, STOSB_SHORT) fs.setIf(eax1&(1<<12) != 0, CMPSB_SCADBS_SHORT) fs.setIf(eax1&(1<<22) != 0, HRESET) fs.setIf(eax1&(1<<23) != 0, AVXIFMA) fs.setIf(eax1&(1<<26) != 0, LAM) // CPUID.(EAX=7, ECX=1).EDX fs.setIf(edx1&(1<<4) != 0, AVXVNNIINT8) fs.setIf(edx1&(1<<5) != 0, AVXNECONVERT) fs.setIf(edx1&(1<<14) != 0, PREFETCHI) fs.setIf(edx1&(1<<19) != 0, AVX10) fs.setIf(edx1&(1<<21) != 0, APX_F) // Only detect AVX-512 features if XGETBV is supported if c&((1<<26)|(1<<27)) == (1<<26)|(1<<27) { // Check for OS support eax, _ := xgetbv(0) // Verify that XCR0[7:5] = ‘111b’ (OPMASK state, upper 256-bit of ZMM0-ZMM15 and // ZMM16-ZMM31 state are enabled by OS) /// and that XCR0[2:1] = ‘11b’ (XMM state and YMM state are enabled by OS). hasAVX512 := (eax>>5)&7 == 7 && (eax>>1)&3 == 3 if runtime.GOOS == "darwin" { hasAVX512 = fs.inSet(AVX) && darwinHasAVX512() } if hasAVX512 { fs.setIf(ebx&(1<<16) != 0, AVX512F) fs.setIf(ebx&(1<<17) != 0, AVX512DQ) fs.setIf(ebx&(1<<21) != 0, AVX512IFMA) fs.setIf(ebx&(1<<26) != 0, AVX512PF) fs.setIf(ebx&(1<<27) != 0, AVX512ER) fs.setIf(ebx&(1<<28) != 0, AVX512CD) fs.setIf(ebx&(1<<30) != 0, AVX512BW) fs.setIf(ebx&(1<<31) != 0, AVX512VL) // ecx fs.setIf(ecx&(1<<1) != 0, AVX512VBMI) fs.setIf(ecx&(1<<6) != 0, AVX512VBMI2) fs.setIf(ecx&(1<<11) != 0, AVX512VNNI) fs.setIf(ecx&(1<<12) != 0, AVX512BITALG) fs.setIf(ecx&(1<<14) != 0, AVX512VPOPCNTDQ) // edx fs.setIf(edx&(1<<8) != 0, AVX512VP2INTERSECT) fs.setIf(edx&(1<<22) != 0, AMXBF16) fs.setIf(edx&(1<<23) != 0, AVX512FP16) fs.setIf(edx&(1<<24) != 0, AMXTILE) fs.setIf(edx&(1<<25) != 0, AMXINT8) // eax1 = CPUID.(EAX=7, ECX=1).EAX fs.setIf(eax1&(1<<5) != 0, AVX512BF16) fs.setIf(eax1&(1<<19) != 0, WRMSRNS) fs.setIf(eax1&(1<<21) != 0, AMXFP16) fs.setIf(eax1&(1<<27) != 0, MSRLIST) } } // CPUID.(EAX=7, ECX=2) _, _, _, edx = cpuidex(7, 2) fs.setIf(edx&(1<<0) != 0, PSFD) fs.setIf(edx&(1<<1) != 0, IDPRED_CTRL) fs.setIf(edx&(1<<2) != 0, RRSBA_CTRL) fs.setIf(edx&(1<<4) != 0, BHI_CTRL) fs.setIf(edx&(1<<5) != 0, MCDT_NO) // Add keylocker features. if fs.inSet(KEYLOCKER) && mfi >= 0x19 { _, ebx, _, _ := cpuidex(0x19, 0) fs.setIf(ebx&5 == 5, KEYLOCKERW) // Bit 0 and 2 (1+4) } // Add AVX10 features. if fs.inSet(AVX10) && mfi >= 0x24 { _, ebx, _, _ := cpuidex(0x24, 0) fs.setIf(ebx&(1<<16) != 0, AVX10_128) fs.setIf(ebx&(1<<17) != 0, AVX10_256) fs.setIf(ebx&(1<<18) != 0, AVX10_512) } } // Processor Extended State Enumeration Sub-leaf (EAX = 0DH, ECX = 1) // EAX // Bit 00: XSAVEOPT is available. // Bit 01: Supports XSAVEC and the compacted form of XRSTOR if set. // Bit 02: Supports XGETBV with ECX = 1 if set. // Bit 03: Supports XSAVES/XRSTORS and IA32_XSS if set. // Bits 31 - 04: Reserved. // EBX // Bits 31 - 00: The size in bytes of the XSAVE area containing all states enabled by XCRO | IA32_XSS. // ECX // Bits 31 - 00: Reports the supported bits of the lower 32 bits of the IA32_XSS MSR. IA32_XSS[n] can be set to 1 only if ECX[n] is 1. // EDX? // Bits 07 - 00: Used for XCR0. Bit 08: PT state. Bit 09: Used for XCR0. Bits 12 - 10: Reserved. Bit 13: HWP state. Bits 31 - 14: Reserved. if mfi >= 0xd { if fs.inSet(XSAVE) { eax, _, _, _ := cpuidex(0xd, 1) fs.setIf(eax&(1<<0) != 0, XSAVEOPT) fs.setIf(eax&(1<<1) != 0, XSAVEC) fs.setIf(eax&(1<<2) != 0, XGETBV1) fs.setIf(eax&(1<<3) != 0, XSAVES) } } if maxExtendedFunction() >= 0x80000001 { _, _, c, d := cpuid(0x80000001) if (c & (1 << 5)) != 0 { fs.set(LZCNT) fs.set(POPCNT) } // ECX fs.setIf((c&(1<<0)) != 0, LAHF) fs.setIf((c&(1<<2)) != 0, SVM) fs.setIf((c&(1<<6)) != 0, SSE4A) fs.setIf((c&(1<<10)) != 0, IBS) fs.setIf((c&(1<<22)) != 0, TOPEXT) // EDX fs.setIf(d&(1<<11) != 0, SYSCALL) fs.setIf(d&(1<<20) != 0, NX) fs.setIf(d&(1<<22) != 0, MMXEXT) fs.setIf(d&(1<<23) != 0, MMX) fs.setIf(d&(1<<24) != 0, FXSR) fs.setIf(d&(1<<25) != 0, FXSROPT) fs.setIf(d&(1<<27) != 0, RDTSCP) fs.setIf(d&(1<<30) != 0, AMD3DNOWEXT) fs.setIf(d&(1<<31) != 0, AMD3DNOW) /* XOP and FMA4 use the AVX instruction coding scheme, so they can't be * used unless the OS has AVX support. */ if fs.inSet(AVX) { fs.setIf((c&(1<<11)) != 0, XOP) fs.setIf((c&(1<<16)) != 0, FMA4) } } if maxExtendedFunction() >= 0x80000007 { _, b, _, d := cpuid(0x80000007) fs.setIf((b&(1<<0)) != 0, MCAOVERFLOW) fs.setIf((b&(1<<1)) != 0, SUCCOR) fs.setIf((b&(1<<2)) != 0, HWA) fs.setIf((d&(1<<9)) != 0, CPBOOST) } if maxExtendedFunction() >= 0x80000008 { _, b, _, _ := cpuid(0x80000008) fs.setIf(b&(1<<28) != 0, PSFD) fs.setIf(b&(1<<27) != 0, CPPC) fs.setIf(b&(1<<24) != 0, SPEC_CTRL_SSBD) fs.setIf(b&(1<<23) != 0, PPIN) fs.setIf(b&(1<<21) != 0, TLB_FLUSH_NESTED) fs.setIf(b&(1<<20) != 0, EFER_LMSLE_UNS) fs.setIf(b&(1<<19) != 0, IBRS_PROVIDES_SMP) fs.setIf(b&(1<<18) != 0, IBRS_PREFERRED) fs.setIf(b&(1<<17) != 0, STIBP_ALWAYSON) fs.setIf(b&(1<<15) != 0, STIBP) fs.setIf(b&(1<<14) != 0, IBRS) fs.setIf((b&(1<<13)) != 0, INT_WBINVD) fs.setIf(b&(1<<12) != 0, IBPB) fs.setIf((b&(1<<9)) != 0, WBNOINVD) fs.setIf((b&(1<<8)) != 0, MCOMMIT) fs.setIf((b&(1<<4)) != 0, RDPRU) fs.setIf((b&(1<<3)) != 0, INVLPGB) fs.setIf((b&(1<<1)) != 0, MSRIRC) fs.setIf((b&(1<<0)) != 0, CLZERO) } if fs.inSet(SVM) && maxExtendedFunction() >= 0x8000000A { _, _, _, edx := cpuid(0x8000000A) fs.setIf((edx>>0)&1 == 1, SVMNP) fs.setIf((edx>>1)&1 == 1, LBRVIRT) fs.setIf((edx>>2)&1 == 1, SVML) fs.setIf((edx>>3)&1 == 1, NRIPS) fs.setIf((edx>>4)&1 == 1, TSCRATEMSR) fs.setIf((edx>>5)&1 == 1, VMCBCLEAN) fs.setIf((edx>>6)&1 == 1, SVMFBASID) fs.setIf((edx>>7)&1 == 1, SVMDA) fs.setIf((edx>>10)&1 == 1, SVMPF) fs.setIf((edx>>12)&1 == 1, SVMPFT) } if maxExtendedFunction() >= 0x8000001a { eax, _, _, _ := cpuid(0x8000001a) fs.setIf((eax>>0)&1 == 1, FP128) fs.setIf((eax>>1)&1 == 1, MOVU) fs.setIf((eax>>2)&1 == 1, FP256) } if maxExtendedFunction() >= 0x8000001b && fs.inSet(IBS) { eax, _, _, _ := cpuid(0x8000001b) fs.setIf((eax>>0)&1 == 1, IBSFFV) fs.setIf((eax>>1)&1 == 1, IBSFETCHSAM) fs.setIf((eax>>2)&1 == 1, IBSOPSAM) fs.setIf((eax>>3)&1 == 1, IBSRDWROPCNT) fs.setIf((eax>>4)&1 == 1, IBSOPCNT) fs.setIf((eax>>5)&1 == 1, IBSBRNTRGT) fs.setIf((eax>>6)&1 == 1, IBSOPCNTEXT) fs.setIf((eax>>7)&1 == 1, IBSRIPINVALIDCHK) fs.setIf((eax>>8)&1 == 1, IBS_OPFUSE) fs.setIf((eax>>9)&1 == 1, IBS_FETCH_CTLX) fs.setIf((eax>>10)&1 == 1, IBS_OPDATA4) // Doc says "Fixed,0. IBS op data 4 MSR supported", but assuming they mean 1. fs.setIf((eax>>11)&1 == 1, IBS_ZEN4) } if maxExtendedFunction() >= 0x8000001f && vend == AMD { a, _, _, _ := cpuid(0x8000001f) fs.setIf((a>>0)&1 == 1, SME) fs.setIf((a>>1)&1 == 1, SEV) fs.setIf((a>>2)&1 == 1, MSR_PAGEFLUSH) fs.setIf((a>>3)&1 == 1, SEV_ES) fs.setIf((a>>4)&1 == 1, SEV_SNP) fs.setIf((a>>5)&1 == 1, VMPL) fs.setIf((a>>10)&1 == 1, SME_COHERENT) fs.setIf((a>>11)&1 == 1, SEV_64BIT) fs.setIf((a>>12)&1 == 1, SEV_RESTRICTED) fs.setIf((a>>13)&1 == 1, SEV_ALTERNATIVE) fs.setIf((a>>14)&1 == 1, SEV_DEBUGSWAP) fs.setIf((a>>15)&1 == 1, IBS_PREVENTHOST) fs.setIf((a>>16)&1 == 1, VTE) fs.setIf((a>>24)&1 == 1, VMSA_REGPROT) } if mfi >= 0x20 { // Microsoft has decided to purposefully hide the information // of the guest TEE when VMs are being created using Hyper-V. // // This leads us to check for the Hyper-V cpuid features // (0x4000000C), and then for the `ebx` value set. // // For Intel TDX, `ebx` is set as `0xbe3`, being 3 the part // we're mostly interested about,according to: // https://github.com/torvalds/linux/blob/d2f51b3516dade79269ff45eae2a7668ae711b25/arch/x86/include/asm/hyperv-tlfs.h#L169-L174 _, ebx, _, _ := cpuid(0x4000000C) fs.setIf(ebx == 0xbe3, TDX_GUEST) } if mfi >= 0x21 { // Intel Trusted Domain Extensions Guests have their own cpuid leaf (0x21). _, ebx, ecx, edx := cpuid(0x21) identity := string(valAsString(ebx, edx, ecx)) fs.setIf(identity == "IntelTDX ", TDX_GUEST) } return fs } func (c *CPUInfo) supportAVX10() uint8 { if c.maxFunc >= 0x24 && c.featureSet.inSet(AVX10) { _, ebx, _, _ := cpuidex(0x24, 0) return uint8(ebx) } return 0 } func valAsString(values ...uint32) []byte { r := make([]byte, 4*len(values)) for i, v := range values { dst := r[i*4:] dst[0] = byte(v & 0xff) dst[1] = byte((v >> 8) & 0xff) dst[2] = byte((v >> 16) & 0xff) dst[3] = byte((v >> 24) & 0xff) switch { case dst[0] == 0: return r[:i*4] case dst[1] == 0: return r[:i*4+1] case dst[2] == 0: return r[:i*4+2] case dst[3] == 0: return r[:i*4+3] } } return r } cpuid-2.2.6/cpuid_386.s000066400000000000000000000020411452220130700145060ustar00rootroot00000000000000// Copyright (c) 2015 Klaus Post, released under MIT License. See LICENSE file. //+build 386,!gccgo,!noasm,!appengine // func asmCpuid(op uint32) (eax, ebx, ecx, edx uint32) TEXT ·asmCpuid(SB), 7, $0 XORL CX, CX MOVL op+0(FP), AX CPUID MOVL AX, eax+4(FP) MOVL BX, ebx+8(FP) MOVL CX, ecx+12(FP) MOVL DX, edx+16(FP) RET // func asmCpuidex(op, op2 uint32) (eax, ebx, ecx, edx uint32) TEXT ·asmCpuidex(SB), 7, $0 MOVL op+0(FP), AX MOVL op2+4(FP), CX CPUID MOVL AX, eax+8(FP) MOVL BX, ebx+12(FP) MOVL CX, ecx+16(FP) MOVL DX, edx+20(FP) RET // func xgetbv(index uint32) (eax, edx uint32) TEXT ·asmXgetbv(SB), 7, $0 MOVL index+0(FP), CX BYTE $0x0f; BYTE $0x01; BYTE $0xd0 // XGETBV MOVL AX, eax+4(FP) MOVL DX, edx+8(FP) RET // func asmRdtscpAsm() (eax, ebx, ecx, edx uint32) TEXT ·asmRdtscpAsm(SB), 7, $0 BYTE $0x0F; BYTE $0x01; BYTE $0xF9 // RDTSCP MOVL AX, eax+0(FP) MOVL BX, ebx+4(FP) MOVL CX, ecx+8(FP) MOVL DX, edx+12(FP) RET // func asmDarwinHasAVX512() bool TEXT ·asmDarwinHasAVX512(SB), 7, $0 MOVL $0, eax+0(FP) RET cpuid-2.2.6/cpuid_amd64.s000066400000000000000000000035531452220130700151120ustar00rootroot00000000000000// Copyright (c) 2015 Klaus Post, released under MIT License. See LICENSE file. //+build amd64,!gccgo,!noasm,!appengine // func asmCpuid(op uint32) (eax, ebx, ecx, edx uint32) TEXT ·asmCpuid(SB), 7, $0 XORQ CX, CX MOVL op+0(FP), AX CPUID MOVL AX, eax+8(FP) MOVL BX, ebx+12(FP) MOVL CX, ecx+16(FP) MOVL DX, edx+20(FP) RET // func asmCpuidex(op, op2 uint32) (eax, ebx, ecx, edx uint32) TEXT ·asmCpuidex(SB), 7, $0 MOVL op+0(FP), AX MOVL op2+4(FP), CX CPUID MOVL AX, eax+8(FP) MOVL BX, ebx+12(FP) MOVL CX, ecx+16(FP) MOVL DX, edx+20(FP) RET // func asmXgetbv(index uint32) (eax, edx uint32) TEXT ·asmXgetbv(SB), 7, $0 MOVL index+0(FP), CX BYTE $0x0f; BYTE $0x01; BYTE $0xd0 // XGETBV MOVL AX, eax+8(FP) MOVL DX, edx+12(FP) RET // func asmRdtscpAsm() (eax, ebx, ecx, edx uint32) TEXT ·asmRdtscpAsm(SB), 7, $0 BYTE $0x0F; BYTE $0x01; BYTE $0xF9 // RDTSCP MOVL AX, eax+0(FP) MOVL BX, ebx+4(FP) MOVL CX, ecx+8(FP) MOVL DX, edx+12(FP) RET // From https://go-review.googlesource.com/c/sys/+/285572/ // func asmDarwinHasAVX512() bool TEXT ·asmDarwinHasAVX512(SB), 7, $0-1 MOVB $0, ret+0(FP) // default to false #ifdef GOOS_darwin // return if not darwin #ifdef GOARCH_amd64 // return if not amd64 // These values from: // https://github.com/apple/darwin-xnu/blob/xnu-4570.1.46/osfmk/i386/cpu_capabilities.h #define commpage64_base_address 0x00007fffffe00000 #define commpage64_cpu_capabilities64 (commpage64_base_address+0x010) #define commpage64_version (commpage64_base_address+0x01E) #define hasAVX512F 0x0000004000000000 MOVQ $commpage64_version, BX MOVW (BX), AX CMPW AX, $13 // versions < 13 do not support AVX512 JL no_avx512 MOVQ $commpage64_cpu_capabilities64, BX MOVQ (BX), AX MOVQ $hasAVX512F, CX ANDQ CX, AX JZ no_avx512 MOVB $1, ret+0(FP) no_avx512: #endif #endif RET cpuid-2.2.6/cpuid_arm64.s000066400000000000000000000015271452220130700151270ustar00rootroot00000000000000// Copyright (c) 2015 Klaus Post, released under MIT License. See LICENSE file. //+build arm64,!gccgo,!noasm,!appengine // See https://www.kernel.org/doc/Documentation/arm64/cpu-feature-registers.txt // func getMidr TEXT ·getMidr(SB), 7, $0 WORD $0xd5380000 // mrs x0, midr_el1 /* Main ID Register */ MOVD R0, midr+0(FP) RET // func getProcFeatures TEXT ·getProcFeatures(SB), 7, $0 WORD $0xd5380400 // mrs x0, id_aa64pfr0_el1 /* Processor Feature Register 0 */ MOVD R0, procFeatures+0(FP) RET // func getInstAttributes TEXT ·getInstAttributes(SB), 7, $0 WORD $0xd5380600 // mrs x0, id_aa64isar0_el1 /* Instruction Set Attribute Register 0 */ WORD $0xd5380621 // mrs x1, id_aa64isar1_el1 /* Instruction Set Attribute Register 1 */ MOVD R0, instAttrReg0+0(FP) MOVD R1, instAttrReg1+8(FP) RET cpuid-2.2.6/cpuid_test.go000066400000000000000000000167611452220130700153260ustar00rootroot00000000000000// Copyright (c) 2015 Klaus Post, released under MIT License. See LICENSE file. package cpuid import ( "fmt" "strings" "testing" ) func TestLastID(t *testing.T) { if lastID.String() != "lastID" { t.Fatal("stringer not updated, run go generate") } } func TestLastVendorID(t *testing.T) { if lastVendor.String() != "lastVendor" { t.Fatal("stringer not updated, run go generate") } } // There is no real way to test a CPU identifier, since results will // obviously differ on each machine. func TestCPUID(t *testing.T) { Detect() n := maxFunctionID() t.Logf("Max Function:0x%x", n) n = maxExtendedFunction() t.Logf("Max Extended Function:0x%x", n) t.Log("VendorString:", CPU.VendorString) t.Log("VendorID:", CPU.VendorID) t.Log("Name:", CPU.BrandName) t.Log("PhysicalCores:", CPU.PhysicalCores) t.Log("ThreadsPerCore:", CPU.ThreadsPerCore) t.Log("LogicalCores:", CPU.LogicalCores) t.Log("Family", CPU.Family, "Model:", CPU.Model, "Stepping:", CPU.Stepping) t.Log("Features:", strings.Join(CPU.FeatureSet(), ",")) t.Log("Cacheline bytes:", CPU.CacheLine) t.Log("L1 Instruction Cache:", CPU.Cache.L1I, "bytes") t.Log("L1 Data Cache:", CPU.Cache.L1D, "bytes") t.Log("L2 Cache:", CPU.Cache.L2, "bytes") t.Log("L3 Cache:", CPU.Cache.L3, "bytes") t.Log("Hz:", CPU.Hz, "Hz") t.Log("VM:", CPU.VM()) t.Log("BoostFreq:", CPU.BoostFreq, "Hz") } func TestExample(t *testing.T) { Detect() // Print basic CPU information: fmt.Println("Name:", CPU.BrandName) fmt.Println("PhysicalCores:", CPU.PhysicalCores) fmt.Println("ThreadsPerCore:", CPU.ThreadsPerCore) fmt.Println("LogicalCores:", CPU.LogicalCores) fmt.Println("Family", CPU.Family, "Model:", CPU.Model, "Vendor ID:", CPU.VendorID) fmt.Println("Features:", strings.Join(CPU.FeatureSet(), ",")) fmt.Println("Cacheline bytes:", CPU.CacheLine) fmt.Println("L1 Data Cache:", CPU.Cache.L1D, "bytes") fmt.Println("L1 Instruction Cache:", CPU.Cache.L1D, "bytes") fmt.Println("L2 Cache:", CPU.Cache.L2, "bytes") fmt.Println("L3 Cache:", CPU.Cache.L3, "bytes") fmt.Println("Frequency", CPU.Hz, "hz") // Test if we have these specific features: if CPU.Supports(SSE, SSE2) { fmt.Println("We have Streaming SIMD 2 Extensions") } } func TestDumpCPUID(t *testing.T) { n := int(maxFunctionID()) for i := 0; i <= n; i++ { a, b, c, d := cpuidex(uint32(i), 0) t.Logf("CPUID %08x: %08x-%08x-%08x-%08x", i, a, b, c, d) ex := uint32(1) for { a2, b2, c2, d2 := cpuidex(uint32(i), ex) if a2 == a && b2 == b && d2 == d || ex > 50 || a2 == 0 { break } t.Logf("CPUID %08x: %08x-%08x-%08x-%08x", i, a2, b2, c2, d2) a, b, c, d = a2, b2, c2, d2 ex++ } } n2 := maxExtendedFunction() for i := uint32(0x80000000); i <= n2; i++ { a, b, c, d := cpuid(i) t.Logf("CPUID %08x: %08x-%08x-%08x-%08x", i, a, b, c, d) } } func Example() { // Print basic CPU information: fmt.Println("Name:", CPU.BrandName) fmt.Println("PhysicalCores:", CPU.PhysicalCores) fmt.Println("ThreadsPerCore:", CPU.ThreadsPerCore) fmt.Println("LogicalCores:", CPU.LogicalCores) fmt.Println("Family", CPU.Family, "Model:", CPU.Model) fmt.Println("Features:", CPU.FeatureSet()) fmt.Println("Cacheline bytes:", CPU.CacheLine) } func TestBrandNameZero(t *testing.T) { if len(CPU.BrandName) > 0 { // Cut out last byte last := []byte(CPU.BrandName[len(CPU.BrandName)-1:]) if last[0] == 0 { t.Fatal("last byte was zero") } else if last[0] == 32 { t.Fatal("whitespace wasn't trimmed") } } } // TestSGX tests SGX detection func TestSGX(t *testing.T) { got := CPU.SGX.Available expected := CPU.featureSet.inSet(SGX) if got != expected { t.Fatalf("SGX: expected %v, got %v", expected, got) } t.Log("SGX Support:", got) if CPU.SGX.Available { var total uint64 = 0 leaves := false for _, s := range CPU.SGX.EPCSections { t.Logf("SGX EPC section: base address 0x%x, size %v", s.BaseAddress, s.EPCSize) total += s.EPCSize leaves = true } if leaves && total == 0 { t.Fatal("SGX enabled without any available EPC memory") } } } func TestHas(t *testing.T) { Detect() defer Detect() feats := CPU.FeatureSet() for _, feat := range feats { f := ParseFeature(feat) if f == UNKNOWN { t.Error("Got unknown feature:", feat) continue } if !CPU.Has(f) { t.Error("CPU.Has returned false, want true") } if !CPU.Supports(f) { t.Error("CPU.Supports returned false, want true") } // Disable it. CPU.Disable(f) if CPU.Has(f) { t.Error("CPU.Has returned true, want false") } if CPU.Supports(f) { t.Error("CPU.Supports returned true, want false") } // Reenable CPU.Enable(f) if !CPU.Has(f) { t.Error("CPU.Has returned false, want true") } if !CPU.Supports(f) { t.Error("CPU.Supports returned false, want true") } } } // TestSGXLC tests SGX Launch Control detection func TestSGXLC(t *testing.T) { got := CPU.SGX.LaunchControl expected := CPU.featureSet.inSet(SGXLC) if got != expected { t.Fatalf("SGX: expected %v, got %v", expected, got) } t.Log("SGX Launch Control Support:", got) } // Test VM function func TestVM(t *testing.T) { got := CPU.VM() expected := CPU.featureSet.inSet(HYPERVISOR) if got != expected { t.Fatalf("TestVM: expected %v, got %v", expected, got) } t.Log("TestVM:", got) } // Test RTCounter function func TestRtCounter(t *testing.T) { a := CPU.RTCounter() b := CPU.RTCounter() t.Log("CPU Counter:", a, b, b-a) } // Prints the value of Ia32TscAux() func TestIa32TscAux(t *testing.T) { ecx := CPU.Ia32TscAux() t.Logf("Ia32TscAux:0x%x\n", ecx) if ecx != 0 { chip := (ecx & 0xFFF000) >> 12 core := ecx & 0xFFF t.Log("Likely chip, core:", chip, core) } } func TestThreadsPerCoreNZ(t *testing.T) { if CPU.ThreadsPerCore == 0 { t.Fatal("threads per core is zero") } } // Prints the value of LogicalCPU() func TestLogicalCPU(t *testing.T) { t.Log("Currently executing on cpu:", CPU.LogicalCPU()) } func TestMaxFunction(t *testing.T) { expect := maxFunctionID() if CPU.maxFunc != expect { t.Fatal("Max function does not match, expected", expect, "but got", CPU.maxFunc) } expect = maxExtendedFunction() if CPU.maxExFunc != expect { t.Fatal("Max Extended function does not match, expected", expect, "but got", CPU.maxFunc) } } // This example will calculate the chip/core number on Linux // Linux encodes numa id (<<12) and core id (8bit) into TSC_AUX. func ExampleCPUInfo_Ia32TscAux() { ecx := CPU.Ia32TscAux() if ecx == 0 { fmt.Println("Unknown CPU ID") return } chip := (ecx & 0xFFF000) >> 12 core := ecx & 0xFFF fmt.Println("Chip, Core:", chip, core) } func TestCombineFeatures(t *testing.T) { cpu := CPU for i := FeatureID(0); i < lastID; i++ { if cpu.Has(i) != cpu.HasAll(CombineFeatures(i)) { t.Errorf("id %d:%s mismatch", i, i.String()) } } } func BenchmarkFlags(b *testing.B) { var a bool var cpu = CPU b.Run("ids", func(b *testing.B) { for i := 0; i < b.N; i++ { a = cpu.Supports(CMOV, CMPXCHG8, X87, FXSR, MMX, SYSCALL, SSE, SSE2, CX16, LAHF, POPCNT, SSE3, SSE4, SSE42, SSSE3, AVX, AVX2, BMI1, BMI2, F16C, FMA3, LZCNT, MOVBE, OSXSAVE) || a } _ = a }) b.Run("features", func(b *testing.B) { f := CombineFeatures(CMOV, CMPXCHG8, X87, FXSR, MMX, SYSCALL, SSE, SSE2, CX16, LAHF, POPCNT, SSE3, SSE4, SSE42, SSSE3, AVX, AVX2, BMI1, BMI2, F16C, FMA3, LZCNT, MOVBE, OSXSAVE) for i := 0; i < b.N; i++ { a = cpu.HasAll(f) || a } _ = a }) b.Run("id", func(b *testing.B) { for i := 0; i < b.N; i++ { a = cpu.Has(CMOV) || a } _ = a }) b.Run("feature", func(b *testing.B) { f := CombineFeatures(CMOV) for i := 0; i < b.N; i++ { a = cpu.HasAll(f) || a } _ = a }) } cpuid-2.2.6/detect_arm64.go000066400000000000000000000233241452220130700154350ustar00rootroot00000000000000// Copyright (c) 2015 Klaus Post, released under MIT License. See LICENSE file. //go:build arm64 && !gccgo && !noasm && !appengine // +build arm64,!gccgo,!noasm,!appengine package cpuid import "runtime" func getMidr() (midr uint64) func getProcFeatures() (procFeatures uint64) func getInstAttributes() (instAttrReg0, instAttrReg1 uint64) func initCPU() { cpuid = func(uint32) (a, b, c, d uint32) { return 0, 0, 0, 0 } cpuidex = func(x, y uint32) (a, b, c, d uint32) { return 0, 0, 0, 0 } xgetbv = func(uint32) (a, b uint32) { return 0, 0 } rdtscpAsm = func() (a, b, c, d uint32) { return 0, 0, 0, 0 } } func addInfo(c *CPUInfo, safe bool) { // Seems to be safe to assume on ARM64 c.CacheLine = 64 detectOS(c) // ARM64 disabled since it may crash if interrupt is not intercepted by OS. if safe && !c.Supports(ARMCPUID) && runtime.GOOS != "freebsd" { return } midr := getMidr() // MIDR_EL1 - Main ID Register // https://developer.arm.com/docs/ddi0595/h/aarch64-system-registers/midr_el1 // x--------------------------------------------------x // | Name | bits | visible | // |--------------------------------------------------| // | Implementer | [31-24] | y | // |--------------------------------------------------| // | Variant | [23-20] | y | // |--------------------------------------------------| // | Architecture | [19-16] | y | // |--------------------------------------------------| // | PartNum | [15-4] | y | // |--------------------------------------------------| // | Revision | [3-0] | y | // x--------------------------------------------------x switch (midr >> 24) & 0xff { case 0xC0: c.VendorString = "Ampere Computing" c.VendorID = Ampere case 0x41: c.VendorString = "Arm Limited" c.VendorID = ARM case 0x42: c.VendorString = "Broadcom Corporation" c.VendorID = Broadcom case 0x43: c.VendorString = "Cavium Inc" c.VendorID = Cavium case 0x44: c.VendorString = "Digital Equipment Corporation" c.VendorID = DEC case 0x46: c.VendorString = "Fujitsu Ltd" c.VendorID = Fujitsu case 0x49: c.VendorString = "Infineon Technologies AG" c.VendorID = Infineon case 0x4D: c.VendorString = "Motorola or Freescale Semiconductor Inc" c.VendorID = Motorola case 0x4E: c.VendorString = "NVIDIA Corporation" c.VendorID = NVIDIA case 0x50: c.VendorString = "Applied Micro Circuits Corporation" c.VendorID = AMCC case 0x51: c.VendorString = "Qualcomm Inc" c.VendorID = Qualcomm case 0x56: c.VendorString = "Marvell International Ltd" c.VendorID = Marvell case 0x69: c.VendorString = "Intel Corporation" c.VendorID = Intel } // Lower 4 bits: Architecture // Architecture Meaning // 0b0001 Armv4. // 0b0010 Armv4T. // 0b0011 Armv5 (obsolete). // 0b0100 Armv5T. // 0b0101 Armv5TE. // 0b0110 Armv5TEJ. // 0b0111 Armv6. // 0b1111 Architectural features are individually identified in the ID_* registers, see 'ID registers'. // Upper 4 bit: Variant // An IMPLEMENTATION DEFINED variant number. // Typically, this field is used to distinguish between different product variants, or major revisions of a product. c.Family = int(midr>>16) & 0xff // PartNum, bits [15:4] // An IMPLEMENTATION DEFINED primary part number for the device. // On processors implemented by Arm, if the top four bits of the primary // part number are 0x0 or 0x7, the variant and architecture are encoded differently. // Revision, bits [3:0] // An IMPLEMENTATION DEFINED revision number for the device. c.Model = int(midr) & 0xffff procFeatures := getProcFeatures() // ID_AA64PFR0_EL1 - Processor Feature Register 0 // x--------------------------------------------------x // | Name | bits | visible | // |--------------------------------------------------| // | DIT | [51-48] | y | // |--------------------------------------------------| // | SVE | [35-32] | y | // |--------------------------------------------------| // | GIC | [27-24] | n | // |--------------------------------------------------| // | AdvSIMD | [23-20] | y | // |--------------------------------------------------| // | FP | [19-16] | y | // |--------------------------------------------------| // | EL3 | [15-12] | n | // |--------------------------------------------------| // | EL2 | [11-8] | n | // |--------------------------------------------------| // | EL1 | [7-4] | n | // |--------------------------------------------------| // | EL0 | [3-0] | n | // x--------------------------------------------------x var f flagSet // if procFeatures&(0xf<<48) != 0 { // fmt.Println("DIT") // } f.setIf(procFeatures&(0xf<<32) != 0, SVE) if procFeatures&(0xf<<20) != 15<<20 { f.set(ASIMD) // https://developer.arm.com/docs/ddi0595/b/aarch64-system-registers/id_aa64pfr0_el1 // 0b0001 --> As for 0b0000, and also includes support for half-precision floating-point arithmetic. f.setIf(procFeatures&(0xf<<20) == 1<<20, FPHP, ASIMDHP) } f.setIf(procFeatures&(0xf<<16) != 0, FP) instAttrReg0, instAttrReg1 := getInstAttributes() // https://developer.arm.com/docs/ddi0595/b/aarch64-system-registers/id_aa64isar0_el1 // // ID_AA64ISAR0_EL1 - Instruction Set Attribute Register 0 // x--------------------------------------------------x // | Name | bits | visible | // |--------------------------------------------------| // | TS | [55-52] | y | // |--------------------------------------------------| // | FHM | [51-48] | y | // |--------------------------------------------------| // | DP | [47-44] | y | // |--------------------------------------------------| // | SM4 | [43-40] | y | // |--------------------------------------------------| // | SM3 | [39-36] | y | // |--------------------------------------------------| // | SHA3 | [35-32] | y | // |--------------------------------------------------| // | RDM | [31-28] | y | // |--------------------------------------------------| // | ATOMICS | [23-20] | y | // |--------------------------------------------------| // | CRC32 | [19-16] | y | // |--------------------------------------------------| // | SHA2 | [15-12] | y | // |--------------------------------------------------| // | SHA1 | [11-8] | y | // |--------------------------------------------------| // | AES | [7-4] | y | // x--------------------------------------------------x // if instAttrReg0&(0xf<<52) != 0 { // fmt.Println("TS") // } // if instAttrReg0&(0xf<<48) != 0 { // fmt.Println("FHM") // } f.setIf(instAttrReg0&(0xf<<44) != 0, ASIMDDP) f.setIf(instAttrReg0&(0xf<<40) != 0, SM4) f.setIf(instAttrReg0&(0xf<<36) != 0, SM3) f.setIf(instAttrReg0&(0xf<<32) != 0, SHA3) f.setIf(instAttrReg0&(0xf<<28) != 0, ASIMDRDM) f.setIf(instAttrReg0&(0xf<<20) != 0, ATOMICS) f.setIf(instAttrReg0&(0xf<<16) != 0, CRC32) f.setIf(instAttrReg0&(0xf<<12) != 0, SHA2) // https://developer.arm.com/docs/ddi0595/b/aarch64-system-registers/id_aa64isar0_el1 // 0b0010 --> As 0b0001, plus SHA512H, SHA512H2, SHA512SU0, and SHA512SU1 instructions implemented. f.setIf(instAttrReg0&(0xf<<12) == 2<<12, SHA512) f.setIf(instAttrReg0&(0xf<<8) != 0, SHA1) f.setIf(instAttrReg0&(0xf<<4) != 0, AESARM) // https://developer.arm.com/docs/ddi0595/b/aarch64-system-registers/id_aa64isar0_el1 // 0b0010 --> As for 0b0001, plus PMULL/PMULL2 instructions operating on 64-bit data quantities. f.setIf(instAttrReg0&(0xf<<4) == 2<<4, PMULL) // https://developer.arm.com/docs/ddi0595/b/aarch64-system-registers/id_aa64isar1_el1 // // ID_AA64ISAR1_EL1 - Instruction set attribute register 1 // x--------------------------------------------------x // | Name | bits | visible | // |--------------------------------------------------| // | GPI | [31-28] | y | // |--------------------------------------------------| // | GPA | [27-24] | y | // |--------------------------------------------------| // | LRCPC | [23-20] | y | // |--------------------------------------------------| // | FCMA | [19-16] | y | // |--------------------------------------------------| // | JSCVT | [15-12] | y | // |--------------------------------------------------| // | API | [11-8] | y | // |--------------------------------------------------| // | APA | [7-4] | y | // |--------------------------------------------------| // | DPB | [3-0] | y | // x--------------------------------------------------x // if instAttrReg1&(0xf<<28) != 0 { // fmt.Println("GPI") // } f.setIf(instAttrReg1&(0xf<<28) != 24, GPA) f.setIf(instAttrReg1&(0xf<<20) != 0, LRCPC) f.setIf(instAttrReg1&(0xf<<16) != 0, FCMA) f.setIf(instAttrReg1&(0xf<<12) != 0, JSCVT) // if instAttrReg1&(0xf<<8) != 0 { // fmt.Println("API") // } // if instAttrReg1&(0xf<<4) != 0 { // fmt.Println("APA") // } f.setIf(instAttrReg1&(0xf<<0) != 0, DCPOP) // Store c.featureSet.or(f) } cpuid-2.2.6/detect_ref.go000066400000000000000000000010211452220130700152460ustar00rootroot00000000000000// Copyright (c) 2015 Klaus Post, released under MIT License. See LICENSE file. //go:build (!amd64 && !386 && !arm64) || gccgo || noasm || appengine // +build !amd64,!386,!arm64 gccgo noasm appengine package cpuid func initCPU() { cpuid = func(uint32) (a, b, c, d uint32) { return 0, 0, 0, 0 } cpuidex = func(x, y uint32) (a, b, c, d uint32) { return 0, 0, 0, 0 } xgetbv = func(uint32) (a, b uint32) { return 0, 0 } rdtscpAsm = func() (a, b, c, d uint32) { return 0, 0, 0, 0 } } func addInfo(info *CPUInfo, safe bool) {} cpuid-2.2.6/detect_x86.go000066400000000000000000000022071452220130700151260ustar00rootroot00000000000000// Copyright (c) 2015 Klaus Post, released under MIT License. See LICENSE file. //go:build (386 && !gccgo && !noasm && !appengine) || (amd64 && !gccgo && !noasm && !appengine) // +build 386,!gccgo,!noasm,!appengine amd64,!gccgo,!noasm,!appengine package cpuid func asmCpuid(op uint32) (eax, ebx, ecx, edx uint32) func asmCpuidex(op, op2 uint32) (eax, ebx, ecx, edx uint32) func asmXgetbv(index uint32) (eax, edx uint32) func asmRdtscpAsm() (eax, ebx, ecx, edx uint32) func asmDarwinHasAVX512() bool func initCPU() { cpuid = asmCpuid cpuidex = asmCpuidex xgetbv = asmXgetbv rdtscpAsm = asmRdtscpAsm darwinHasAVX512 = asmDarwinHasAVX512 } func addInfo(c *CPUInfo, safe bool) { c.maxFunc = maxFunctionID() c.maxExFunc = maxExtendedFunction() c.BrandName = brandName() c.CacheLine = cacheLine() c.Family, c.Model, c.Stepping = familyModel() c.featureSet = support() c.SGX = hasSGX(c.featureSet.inSet(SGX), c.featureSet.inSet(SGXLC)) c.ThreadsPerCore = threadsPerCore() c.LogicalCores = logicalCores() c.PhysicalCores = physicalCores() c.VendorID, c.VendorString = vendorID() c.AVX10Level = c.supportAVX10() c.cacheSize() c.frequencies() } cpuid-2.2.6/featureid_string.go000066400000000000000000000206521452220130700165130ustar00rootroot00000000000000// Code generated by "stringer -type=FeatureID,Vendor"; DO NOT EDIT. package cpuid import "strconv" func _() { // An "invalid array index" compiler error signifies that the constant values have changed. // Re-run the stringer command to generate them again. var x [1]struct{} _ = x[ADX-1] _ = x[AESNI-2] _ = x[AMD3DNOW-3] _ = x[AMD3DNOWEXT-4] _ = x[AMXBF16-5] _ = x[AMXFP16-6] _ = x[AMXINT8-7] _ = x[AMXTILE-8] _ = x[APX_F-9] _ = x[AVX-10] _ = x[AVX10-11] _ = x[AVX10_128-12] _ = x[AVX10_256-13] _ = x[AVX10_512-14] _ = x[AVX2-15] _ = x[AVX512BF16-16] _ = x[AVX512BITALG-17] _ = x[AVX512BW-18] _ = x[AVX512CD-19] _ = x[AVX512DQ-20] _ = x[AVX512ER-21] _ = x[AVX512F-22] _ = x[AVX512FP16-23] _ = x[AVX512IFMA-24] _ = x[AVX512PF-25] _ = x[AVX512VBMI-26] _ = x[AVX512VBMI2-27] _ = x[AVX512VL-28] _ = x[AVX512VNNI-29] _ = x[AVX512VP2INTERSECT-30] _ = x[AVX512VPOPCNTDQ-31] _ = x[AVXIFMA-32] _ = x[AVXNECONVERT-33] _ = x[AVXSLOW-34] _ = x[AVXVNNI-35] _ = x[AVXVNNIINT8-36] _ = x[BHI_CTRL-37] _ = x[BMI1-38] _ = x[BMI2-39] _ = x[CETIBT-40] _ = x[CETSS-41] _ = x[CLDEMOTE-42] _ = x[CLMUL-43] _ = x[CLZERO-44] _ = x[CMOV-45] _ = x[CMPCCXADD-46] _ = x[CMPSB_SCADBS_SHORT-47] _ = x[CMPXCHG8-48] _ = x[CPBOOST-49] _ = x[CPPC-50] _ = x[CX16-51] _ = x[EFER_LMSLE_UNS-52] _ = x[ENQCMD-53] _ = x[ERMS-54] _ = x[F16C-55] _ = x[FLUSH_L1D-56] _ = x[FMA3-57] _ = x[FMA4-58] _ = x[FP128-59] _ = x[FP256-60] _ = x[FSRM-61] _ = x[FXSR-62] _ = x[FXSROPT-63] _ = x[GFNI-64] _ = x[HLE-65] _ = x[HRESET-66] _ = x[HTT-67] _ = x[HWA-68] _ = x[HYBRID_CPU-69] _ = x[HYPERVISOR-70] _ = x[IA32_ARCH_CAP-71] _ = x[IA32_CORE_CAP-72] _ = x[IBPB-73] _ = x[IBRS-74] _ = x[IBRS_PREFERRED-75] _ = x[IBRS_PROVIDES_SMP-76] _ = x[IBS-77] _ = x[IBSBRNTRGT-78] _ = x[IBSFETCHSAM-79] _ = x[IBSFFV-80] _ = x[IBSOPCNT-81] _ = x[IBSOPCNTEXT-82] _ = x[IBSOPSAM-83] _ = x[IBSRDWROPCNT-84] _ = x[IBSRIPINVALIDCHK-85] _ = x[IBS_FETCH_CTLX-86] _ = x[IBS_OPDATA4-87] _ = x[IBS_OPFUSE-88] _ = x[IBS_PREVENTHOST-89] _ = x[IBS_ZEN4-90] _ = x[IDPRED_CTRL-91] _ = x[INT_WBINVD-92] _ = x[INVLPGB-93] _ = x[KEYLOCKER-94] _ = x[KEYLOCKERW-95] _ = x[LAHF-96] _ = x[LAM-97] _ = x[LBRVIRT-98] _ = x[LZCNT-99] _ = x[MCAOVERFLOW-100] _ = x[MCDT_NO-101] _ = x[MCOMMIT-102] _ = x[MD_CLEAR-103] _ = x[MMX-104] _ = x[MMXEXT-105] _ = x[MOVBE-106] _ = x[MOVDIR64B-107] _ = x[MOVDIRI-108] _ = x[MOVSB_ZL-109] _ = x[MOVU-110] _ = x[MPX-111] _ = x[MSRIRC-112] _ = x[MSRLIST-113] _ = x[MSR_PAGEFLUSH-114] _ = x[NRIPS-115] _ = x[NX-116] _ = x[OSXSAVE-117] _ = x[PCONFIG-118] _ = x[POPCNT-119] _ = x[PPIN-120] _ = x[PREFETCHI-121] _ = x[PSFD-122] _ = x[RDPRU-123] _ = x[RDRAND-124] _ = x[RDSEED-125] _ = x[RDTSCP-126] _ = x[RRSBA_CTRL-127] _ = x[RTM-128] _ = x[RTM_ALWAYS_ABORT-129] _ = x[SERIALIZE-130] _ = x[SEV-131] _ = x[SEV_64BIT-132] _ = x[SEV_ALTERNATIVE-133] _ = x[SEV_DEBUGSWAP-134] _ = x[SEV_ES-135] _ = x[SEV_RESTRICTED-136] _ = x[SEV_SNP-137] _ = x[SGX-138] _ = x[SGXLC-139] _ = x[SHA-140] _ = x[SME-141] _ = x[SME_COHERENT-142] _ = x[SPEC_CTRL_SSBD-143] _ = x[SRBDS_CTRL-144] _ = x[SSE-145] _ = x[SSE2-146] _ = x[SSE3-147] _ = x[SSE4-148] _ = x[SSE42-149] _ = x[SSE4A-150] _ = x[SSSE3-151] _ = x[STIBP-152] _ = x[STIBP_ALWAYSON-153] _ = x[STOSB_SHORT-154] _ = x[SUCCOR-155] _ = x[SVM-156] _ = x[SVMDA-157] _ = x[SVMFBASID-158] _ = x[SVML-159] _ = x[SVMNP-160] _ = x[SVMPF-161] _ = x[SVMPFT-162] _ = x[SYSCALL-163] _ = x[SYSEE-164] _ = x[TBM-165] _ = x[TDX_GUEST-166] _ = x[TLB_FLUSH_NESTED-167] _ = x[TME-168] _ = x[TOPEXT-169] _ = x[TSCRATEMSR-170] _ = x[TSXLDTRK-171] _ = x[VAES-172] _ = x[VMCBCLEAN-173] _ = x[VMPL-174] _ = x[VMSA_REGPROT-175] _ = x[VMX-176] _ = x[VPCLMULQDQ-177] _ = x[VTE-178] _ = x[WAITPKG-179] _ = x[WBNOINVD-180] _ = x[WRMSRNS-181] _ = x[X87-182] _ = x[XGETBV1-183] _ = x[XOP-184] _ = x[XSAVE-185] _ = x[XSAVEC-186] _ = x[XSAVEOPT-187] _ = x[XSAVES-188] _ = x[AESARM-189] _ = x[ARMCPUID-190] _ = x[ASIMD-191] _ = x[ASIMDDP-192] _ = x[ASIMDHP-193] _ = x[ASIMDRDM-194] _ = x[ATOMICS-195] _ = x[CRC32-196] _ = x[DCPOP-197] _ = x[EVTSTRM-198] _ = x[FCMA-199] _ = x[FP-200] _ = x[FPHP-201] _ = x[GPA-202] _ = x[JSCVT-203] _ = x[LRCPC-204] _ = x[PMULL-205] _ = x[SHA1-206] _ = x[SHA2-207] _ = x[SHA3-208] _ = x[SHA512-209] _ = x[SM3-210] _ = x[SM4-211] _ = x[SVE-212] _ = x[lastID-213] _ = x[firstID-0] } const _FeatureID_name = "firstIDADXAESNIAMD3DNOWAMD3DNOWEXTAMXBF16AMXFP16AMXINT8AMXTILEAPX_FAVXAVX10AVX10_128AVX10_256AVX10_512AVX2AVX512BF16AVX512BITALGAVX512BWAVX512CDAVX512DQAVX512ERAVX512FAVX512FP16AVX512IFMAAVX512PFAVX512VBMIAVX512VBMI2AVX512VLAVX512VNNIAVX512VP2INTERSECTAVX512VPOPCNTDQAVXIFMAAVXNECONVERTAVXSLOWAVXVNNIAVXVNNIINT8BHI_CTRLBMI1BMI2CETIBTCETSSCLDEMOTECLMULCLZEROCMOVCMPCCXADDCMPSB_SCADBS_SHORTCMPXCHG8CPBOOSTCPPCCX16EFER_LMSLE_UNSENQCMDERMSF16CFLUSH_L1DFMA3FMA4FP128FP256FSRMFXSRFXSROPTGFNIHLEHRESETHTTHWAHYBRID_CPUHYPERVISORIA32_ARCH_CAPIA32_CORE_CAPIBPBIBRSIBRS_PREFERREDIBRS_PROVIDES_SMPIBSIBSBRNTRGTIBSFETCHSAMIBSFFVIBSOPCNTIBSOPCNTEXTIBSOPSAMIBSRDWROPCNTIBSRIPINVALIDCHKIBS_FETCH_CTLXIBS_OPDATA4IBS_OPFUSEIBS_PREVENTHOSTIBS_ZEN4IDPRED_CTRLINT_WBINVDINVLPGBKEYLOCKERKEYLOCKERWLAHFLAMLBRVIRTLZCNTMCAOVERFLOWMCDT_NOMCOMMITMD_CLEARMMXMMXEXTMOVBEMOVDIR64BMOVDIRIMOVSB_ZLMOVUMPXMSRIRCMSRLISTMSR_PAGEFLUSHNRIPSNXOSXSAVEPCONFIGPOPCNTPPINPREFETCHIPSFDRDPRURDRANDRDSEEDRDTSCPRRSBA_CTRLRTMRTM_ALWAYS_ABORTSERIALIZESEVSEV_64BITSEV_ALTERNATIVESEV_DEBUGSWAPSEV_ESSEV_RESTRICTEDSEV_SNPSGXSGXLCSHASMESME_COHERENTSPEC_CTRL_SSBDSRBDS_CTRLSSESSE2SSE3SSE4SSE42SSE4ASSSE3STIBPSTIBP_ALWAYSONSTOSB_SHORTSUCCORSVMSVMDASVMFBASIDSVMLSVMNPSVMPFSVMPFTSYSCALLSYSEETBMTDX_GUESTTLB_FLUSH_NESTEDTMETOPEXTTSCRATEMSRTSXLDTRKVAESVMCBCLEANVMPLVMSA_REGPROTVMXVPCLMULQDQVTEWAITPKGWBNOINVDWRMSRNSX87XGETBV1XOPXSAVEXSAVECXSAVEOPTXSAVESAESARMARMCPUIDASIMDASIMDDPASIMDHPASIMDRDMATOMICSCRC32DCPOPEVTSTRMFCMAFPFPHPGPAJSCVTLRCPCPMULLSHA1SHA2SHA3SHA512SM3SM4SVElastID" var _FeatureID_index = [...]uint16{0, 7, 10, 15, 23, 34, 41, 48, 55, 62, 67, 70, 75, 84, 93, 102, 106, 116, 128, 136, 144, 152, 160, 167, 177, 187, 195, 205, 216, 224, 234, 252, 267, 274, 286, 293, 300, 311, 319, 323, 327, 333, 338, 346, 351, 357, 361, 370, 388, 396, 403, 407, 411, 425, 431, 435, 439, 448, 452, 456, 461, 466, 470, 474, 481, 485, 488, 494, 497, 500, 510, 520, 533, 546, 550, 554, 568, 585, 588, 598, 609, 615, 623, 634, 642, 654, 670, 684, 695, 705, 720, 728, 739, 749, 756, 765, 775, 779, 782, 789, 794, 805, 812, 819, 827, 830, 836, 841, 850, 857, 865, 869, 872, 878, 885, 898, 903, 905, 912, 919, 925, 929, 938, 942, 947, 953, 959, 965, 975, 978, 994, 1003, 1006, 1015, 1030, 1043, 1049, 1063, 1070, 1073, 1078, 1081, 1084, 1096, 1110, 1120, 1123, 1127, 1131, 1135, 1140, 1145, 1150, 1155, 1169, 1180, 1186, 1189, 1194, 1203, 1207, 1212, 1217, 1223, 1230, 1235, 1238, 1247, 1263, 1266, 1272, 1282, 1290, 1294, 1303, 1307, 1319, 1322, 1332, 1335, 1342, 1350, 1357, 1360, 1367, 1370, 1375, 1381, 1389, 1395, 1401, 1409, 1414, 1421, 1428, 1436, 1443, 1448, 1453, 1460, 1464, 1466, 1470, 1473, 1478, 1483, 1488, 1492, 1496, 1500, 1506, 1509, 1512, 1515, 1521} func (i FeatureID) String() string { if i < 0 || i >= FeatureID(len(_FeatureID_index)-1) { return "FeatureID(" + strconv.FormatInt(int64(i), 10) + ")" } return _FeatureID_name[_FeatureID_index[i]:_FeatureID_index[i+1]] } func _() { // An "invalid array index" compiler error signifies that the constant values have changed. // Re-run the stringer command to generate them again. var x [1]struct{} _ = x[VendorUnknown-0] _ = x[Intel-1] _ = x[AMD-2] _ = x[VIA-3] _ = x[Transmeta-4] _ = x[NSC-5] _ = x[KVM-6] _ = x[MSVM-7] _ = x[VMware-8] _ = x[XenHVM-9] _ = x[Bhyve-10] _ = x[Hygon-11] _ = x[SiS-12] _ = x[RDC-13] _ = x[Ampere-14] _ = x[ARM-15] _ = x[Broadcom-16] _ = x[Cavium-17] _ = x[DEC-18] _ = x[Fujitsu-19] _ = x[Infineon-20] _ = x[Motorola-21] _ = x[NVIDIA-22] _ = x[AMCC-23] _ = x[Qualcomm-24] _ = x[Marvell-25] _ = x[lastVendor-26] } const _Vendor_name = "VendorUnknownIntelAMDVIATransmetaNSCKVMMSVMVMwareXenHVMBhyveHygonSiSRDCAmpereARMBroadcomCaviumDECFujitsuInfineonMotorolaNVIDIAAMCCQualcommMarvelllastVendor" var _Vendor_index = [...]uint8{0, 13, 18, 21, 24, 33, 36, 39, 43, 49, 55, 60, 65, 68, 71, 77, 80, 88, 94, 97, 104, 112, 120, 126, 130, 138, 145, 155} func (i Vendor) String() string { if i < 0 || i >= Vendor(len(_Vendor_index)-1) { return "Vendor(" + strconv.FormatInt(int64(i), 10) + ")" } return _Vendor_name[_Vendor_index[i]:_Vendor_index[i+1]] } cpuid-2.2.6/go.mod000066400000000000000000000001171452220130700137260ustar00rootroot00000000000000module github.com/klauspost/cpuid/v2 go 1.15 require golang.org/x/sys v0.5.0 cpuid-2.2.6/go.sum000066400000000000000000000005461452220130700137610ustar00rootroot00000000000000golang.org/x/sys v0.0.0-20220704084225-05e143d24a9e h1:CsOuNlbOuf0mzxJIefr6Q4uAUetRUwZE4qt7VfzP+xo= golang.org/x/sys v0.0.0-20220704084225-05e143d24a9e/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= golang.org/x/sys v0.5.0 h1:MUK/U/4lj1t1oPg0HfuXDN/Z1wv31ZJ/YcPiGccS4DU= golang.org/x/sys v0.5.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= cpuid-2.2.6/mockcpu_test.go000066400000000000000000000132121452220130700156470ustar00rootroot00000000000000package cpuid import ( "archive/zip" "fmt" "io/ioutil" "math" "path/filepath" "sort" "strings" "testing" ) type fakecpuid map[uint32][][]uint32 type idfuncs struct { cpuid func(op uint32) (eax, ebx, ecx, edx uint32) cpuidex func(op, op2 uint32) (eax, ebx, ecx, edx uint32) xgetbv func(index uint32) (eax, edx uint32) } func (f fakecpuid) String() string { var out = make([]string, 0, len(f)) for key, val := range f { for _, v := range val { out = append(out, fmt.Sprintf("CPUID %08x: [%08x, %08x, %08x, %08x]", key, v[0], v[1], v[2], v[3])) } } sorter := sort.StringSlice(out) sort.Sort(&sorter) return strings.Join(sorter, "\n") } func mockCPU(def []byte) func() { lines := strings.Split(string(def), "\n") anyfound := false fakeID := make(fakecpuid) for _, line := range lines { line = strings.Trim(line, "\r\t ") if !strings.HasPrefix(line, "CPUID") { continue } // Only collect for first cpu if strings.HasPrefix(line, "CPUID 00000000") { if anyfound { break } } //if !strings.Contains(line, "-") { // continue //} items := strings.Split(line, ":") if len(items) < 2 { if len(line) == 51 || len(line) == 50 { items = []string{line[0:14], line[15:]} } else { items = strings.Split(line, "\t") if len(items) != 2 { //fmt.Println("not found:", line, "len:", len(line)) continue } } } items = items[0:2] vals := strings.Trim(items[1], "\r\n ") var idV uint32 n, err := fmt.Sscanf(items[0], "CPUID %x", &idV) if err != nil || n != 1 { continue } existing, ok := fakeID[idV] if !ok { existing = make([][]uint32, 0) } values := make([]uint32, 4) n, err = fmt.Sscanf(vals, "%x-%x-%x-%x", &values[0], &values[1], &values[2], &values[3]) if n != 4 || err != nil { n, err = fmt.Sscanf(vals, "%x %x %x %x", &values[0], &values[1], &values[2], &values[3]) if n != 4 || err != nil { //fmt.Println("scanned", vals, "got", n, "Err:", err) continue } } existing = append(existing, values) fakeID[idV] = existing anyfound = true } restorer := func(f idfuncs) func() { return func() { cpuid = f.cpuid cpuidex = f.cpuidex xgetbv = f.xgetbv } }(idfuncs{cpuid: cpuid, cpuidex: cpuidex, xgetbv: xgetbv}) cpuid = func(op uint32) (eax, ebx, ecx, edx uint32) { if op == 0x80000000 || op == 0 || op == 0x4000000c { var ok bool _, ok = fakeID[op] if !ok { return 0, 0, 0, 0 } } first, ok := fakeID[op] if !ok { if op > maxFunctionID() { panic(fmt.Sprintf("Base not found: %v, request:%#v\n", fakeID, op)) } else { // we have some entries missing return 0, 0, 0, 0 } } theid := first[0] return theid[0], theid[1], theid[2], theid[3] } cpuidex = func(op, op2 uint32) (eax, ebx, ecx, edx uint32) { if op == 0x80000000 { var ok bool _, ok = fakeID[op] if !ok { return 0, 0, 0, 0 } } first, ok := fakeID[op] if !ok { if op > maxExtendedFunction() { panic(fmt.Sprintf("Extended not found Info: %v, request:%#v, %#v\n", fakeID, op, op2)) } else { // we have some entries missing return 0, 0, 0, 0 } } if int(op2) >= len(first) { //fmt.Printf("Extended not found Info: %v, request:%#v, %#v\n", fakeID, op, op2) return 0, 0, 0, 0 } theid := first[op2] return theid[0], theid[1], theid[2], theid[3] } xgetbv = func(index uint32) (eax, edx uint32) { first, ok := fakeID[1] if !ok { panic(fmt.Sprintf("XGETBV not supported %v", fakeID)) } second := first[0] // ECX bit 26 must be set if (second[2] & 1 << 26) == 0 { panic(fmt.Sprintf("XGETBV not supported %v", fakeID)) } // We don't have any data to return, unfortunately return math.MaxUint32, math.MaxUint32 } return restorer } func TestMocks(t *testing.T) { zr, err := zip.OpenReader("testdata/cpuid_data.zip") if err != nil { t.Skip("No testdata:", err) } defer zr.Close() for _, f := range zr.File { t.Run(filepath.Base(f.Name), func(t *testing.T) { rc, err := f.Open() if err != nil { t.Fatal(err) } content, err := ioutil.ReadAll(rc) if err != nil { t.Fatal(err) } rc.Close() t.Log("Opening", f.FileInfo().Name()) restore := mockCPU(content) Detect() t.Log("Name:", CPU.BrandName) n := maxFunctionID() t.Logf("Max Function:0x%x", n) n = maxExtendedFunction() t.Logf("Max Extended Function:0x%x", n) t.Log("VendorString:", CPU.VendorString) t.Log("VendorID:", CPU.VendorID) t.Log("PhysicalCores:", CPU.PhysicalCores) t.Log("ThreadsPerCore:", CPU.ThreadsPerCore) t.Log("LogicalCores:", CPU.LogicalCores) t.Log("Family", CPU.Family, "Model:", CPU.Model, "Stepping:", CPU.Stepping) t.Log("Features:", strings.Join(CPU.FeatureSet(), ",")) t.Log("Microarchitecture level:", CPU.X64Level()) t.Log("Cacheline bytes:", CPU.CacheLine) t.Log("L1 Instruction Cache:", CPU.Cache.L1I, "bytes") t.Log("L1 Data Cache:", CPU.Cache.L1D, "bytes") t.Log("L2 Cache:", CPU.Cache.L2, "bytes") t.Log("L3 Cache:", CPU.Cache.L3, "bytes") t.Log("Hz:", CPU.Hz, "Hz") t.Log("Boost:", CPU.BoostFreq, "Hz") if CPU.AVX10Level > 0 { t.Log("AVX10 level:", CPU.AVX10Level) } if CPU.LogicalCores > 0 && CPU.PhysicalCores > 0 { if CPU.LogicalCores != CPU.PhysicalCores*CPU.ThreadsPerCore { t.Fatalf("Core count mismatch, LogicalCores (%d) != PhysicalCores (%d) * CPU.ThreadsPerCore (%d)", CPU.LogicalCores, CPU.PhysicalCores, CPU.ThreadsPerCore) } } if CPU.ThreadsPerCore > 1 && !CPU.Supports(HTT) { t.Fatalf("Hyperthreading not detected") } if CPU.ThreadsPerCore == 1 && CPU.Supports(HTT) { t.Fatalf("Hyperthreading detected, but only 1 Thread per core") } restore() }) } Detect() } cpuid-2.2.6/os_darwin_arm64.go000066400000000000000000000073351452220130700161560ustar00rootroot00000000000000// Copyright (c) 2020 Klaus Post, released under MIT License. See LICENSE file. package cpuid import ( "runtime" "strings" "golang.org/x/sys/unix" ) func detectOS(c *CPUInfo) bool { if runtime.GOOS != "ios" { tryToFillCPUInfoFomSysctl(c) } // There are no hw.optional sysctl values for the below features on Mac OS 11.0 // to detect their supported state dynamically. Assume the CPU features that // Apple Silicon M1 supports to be available as a minimal set of features // to all Go programs running on darwin/arm64. // TODO: Add more if we know them. c.featureSet.setIf(runtime.GOOS != "ios", AESARM, PMULL, SHA1, SHA2) return true } func sysctlGetBool(name string) bool { value, err := unix.SysctlUint32(name) if err != nil { return false } return value != 0 } func sysctlGetString(name string) string { value, err := unix.Sysctl(name) if err != nil { return "" } return value } func sysctlGetInt(unknown int, names ...string) int { for _, name := range names { value, err := unix.SysctlUint32(name) if err != nil { continue } if value != 0 { return int(value) } } return unknown } func sysctlGetInt64(unknown int, names ...string) int { for _, name := range names { value64, err := unix.SysctlUint64(name) if err != nil { continue } if int(value64) != unknown { return int(value64) } } return unknown } func setFeature(c *CPUInfo, name string, feature FeatureID) { c.featureSet.setIf(sysctlGetBool(name), feature) } func tryToFillCPUInfoFomSysctl(c *CPUInfo) { c.BrandName = sysctlGetString("machdep.cpu.brand_string") if len(c.BrandName) != 0 { c.VendorString = strings.Fields(c.BrandName)[0] } c.PhysicalCores = sysctlGetInt(runtime.NumCPU(), "hw.physicalcpu") c.ThreadsPerCore = sysctlGetInt(1, "machdep.cpu.thread_count", "kern.num_threads") / sysctlGetInt(1, "hw.physicalcpu") c.LogicalCores = sysctlGetInt(runtime.NumCPU(), "machdep.cpu.core_count") c.Family = sysctlGetInt(0, "machdep.cpu.family", "hw.cpufamily") c.Model = sysctlGetInt(0, "machdep.cpu.model") c.CacheLine = sysctlGetInt64(0, "hw.cachelinesize") c.Cache.L1I = sysctlGetInt64(-1, "hw.l1icachesize") c.Cache.L1D = sysctlGetInt64(-1, "hw.l1dcachesize") c.Cache.L2 = sysctlGetInt64(-1, "hw.l2cachesize") c.Cache.L3 = sysctlGetInt64(-1, "hw.l3cachesize") // from https://developer.arm.com/downloads/-/exploration-tools/feature-names-for-a-profile setFeature(c, "hw.optional.arm.FEAT_AES", AESARM) setFeature(c, "hw.optional.AdvSIMD", ASIMD) setFeature(c, "hw.optional.arm.FEAT_DotProd", ASIMDDP) setFeature(c, "hw.optional.arm.FEAT_RDM", ASIMDRDM) setFeature(c, "hw.optional.FEAT_CRC32", CRC32) setFeature(c, "hw.optional.arm.FEAT_DPB", DCPOP) // setFeature(c, "", EVTSTRM) setFeature(c, "hw.optional.arm.FEAT_FCMA", FCMA) setFeature(c, "hw.optional.arm.FEAT_FP", FP) setFeature(c, "hw.optional.arm.FEAT_FP16", FPHP) setFeature(c, "hw.optional.arm.FEAT_PAuth", GPA) setFeature(c, "hw.optional.arm.FEAT_JSCVT", JSCVT) setFeature(c, "hw.optional.arm.FEAT_LRCPC", LRCPC) setFeature(c, "hw.optional.arm.FEAT_PMULL", PMULL) setFeature(c, "hw.optional.arm.FEAT_SHA1", SHA1) setFeature(c, "hw.optional.arm.FEAT_SHA256", SHA2) setFeature(c, "hw.optional.arm.FEAT_SHA3", SHA3) setFeature(c, "hw.optional.arm.FEAT_SHA512", SHA512) // setFeature(c, "", SM3) // setFeature(c, "", SM4) setFeature(c, "hw.optional.arm.FEAT_SVE", SVE) // from empirical observation setFeature(c, "hw.optional.AdvSIMD_HPFPCvt", ASIMDHP) setFeature(c, "hw.optional.armv8_1_atomics", ATOMICS) setFeature(c, "hw.optional.floatingpoint", FP) setFeature(c, "hw.optional.armv8_2_sha3", SHA3) setFeature(c, "hw.optional.armv8_2_sha512", SHA512) setFeature(c, "hw.optional.armv8_3_compnum", FCMA) setFeature(c, "hw.optional.armv8_crc32", CRC32) } cpuid-2.2.6/os_darwin_test.go000066400000000000000000000025411452220130700161760ustar00rootroot00000000000000package cpuid import ( "os/exec" "strconv" "strings" "testing" ) // Tests that the returned L1 instruction cache value matches the value returned from // a call to the OS `sysctl` utility. Skips the test if we can't run it. func TestDarwinL1ICache(t *testing.T) { out, err := exec.Command("/usr/sbin/sysctl", "-n", "hw.l1icachesize").Output() if err != nil { t.Skipf("cannot run sysctl utility: %v", err) return } v, err := strconv.ParseInt(strings.TrimSpace(string(out)), 10, 0) if err != nil { t.Skipf("sysctl output %q could not be parsed as int: %v", string(out), err) return } if CPU.Cache.L1I != int(v) { t.Fatalf("sysctl output %q did not match CPU.Cache.L1I %d", string(out), CPU.Cache.L1I) } } // Tests that the returned L1 data cache value matches the value returned from a call // to the OS `sysctl` utility. Skips the test if we can't run it. func TestDarwinL1DCache(t *testing.T) { out, err := exec.Command("/usr/sbin/sysctl", "-n", "hw.l1dcachesize").Output() if err != nil { t.Skipf("cannot run sysctl utility: %v", err) return } v, err := strconv.ParseInt(strings.TrimSpace(string(out)), 10, 0) if err != nil { t.Skipf("sysctl output %q could not be parsed as int: %v", string(out), err) return } if CPU.Cache.L1D != int(v) { t.Fatalf("sysctl output %q did not match CPU.Cache.L1D %d", string(out), CPU.Cache.L1D) } } cpuid-2.2.6/os_linux_arm64.go000066400000000000000000000076041452220130700160300ustar00rootroot00000000000000// Copyright (c) 2020 Klaus Post, released under MIT License. See LICENSE file. // Copyright 2018 The Go Authors. All rights reserved. // Use of this source code is governed by a BSD-style // license that can be found in the LICENSE file located // here https://github.com/golang/sys/blob/master/LICENSE package cpuid import ( "encoding/binary" "io/ioutil" "runtime" ) // HWCAP bits. const ( hwcap_FP = 1 << 0 hwcap_ASIMD = 1 << 1 hwcap_EVTSTRM = 1 << 2 hwcap_AES = 1 << 3 hwcap_PMULL = 1 << 4 hwcap_SHA1 = 1 << 5 hwcap_SHA2 = 1 << 6 hwcap_CRC32 = 1 << 7 hwcap_ATOMICS = 1 << 8 hwcap_FPHP = 1 << 9 hwcap_ASIMDHP = 1 << 10 hwcap_CPUID = 1 << 11 hwcap_ASIMDRDM = 1 << 12 hwcap_JSCVT = 1 << 13 hwcap_FCMA = 1 << 14 hwcap_LRCPC = 1 << 15 hwcap_DCPOP = 1 << 16 hwcap_SHA3 = 1 << 17 hwcap_SM3 = 1 << 18 hwcap_SM4 = 1 << 19 hwcap_ASIMDDP = 1 << 20 hwcap_SHA512 = 1 << 21 hwcap_SVE = 1 << 22 hwcap_ASIMDFHM = 1 << 23 ) func detectOS(c *CPUInfo) bool { // For now assuming no hyperthreading is reasonable. c.LogicalCores = runtime.NumCPU() c.PhysicalCores = c.LogicalCores c.ThreadsPerCore = 1 if hwcap == 0 { // We did not get values from the runtime. // Try reading /proc/self/auxv // From https://github.com/golang/sys const ( _AT_HWCAP = 16 _AT_HWCAP2 = 26 uintSize = int(32 << (^uint(0) >> 63)) ) buf, err := ioutil.ReadFile("/proc/self/auxv") if err != nil { // e.g. on android /proc/self/auxv is not accessible, so silently // ignore the error and leave Initialized = false. On some // architectures (e.g. arm64) doinit() implements a fallback // readout and will set Initialized = true again. return false } bo := binary.LittleEndian for len(buf) >= 2*(uintSize/8) { var tag, val uint switch uintSize { case 32: tag = uint(bo.Uint32(buf[0:])) val = uint(bo.Uint32(buf[4:])) buf = buf[8:] case 64: tag = uint(bo.Uint64(buf[0:])) val = uint(bo.Uint64(buf[8:])) buf = buf[16:] } switch tag { case _AT_HWCAP: hwcap = val case _AT_HWCAP2: // Not used } } if hwcap == 0 { return false } } // HWCap was populated by the runtime from the auxiliary vector. // Use HWCap information since reading aarch64 system registers // is not supported in user space on older linux kernels. c.featureSet.setIf(isSet(hwcap, hwcap_AES), AESARM) c.featureSet.setIf(isSet(hwcap, hwcap_ASIMD), ASIMD) c.featureSet.setIf(isSet(hwcap, hwcap_ASIMDDP), ASIMDDP) c.featureSet.setIf(isSet(hwcap, hwcap_ASIMDHP), ASIMDHP) c.featureSet.setIf(isSet(hwcap, hwcap_ASIMDRDM), ASIMDRDM) c.featureSet.setIf(isSet(hwcap, hwcap_CPUID), ARMCPUID) c.featureSet.setIf(isSet(hwcap, hwcap_CRC32), CRC32) c.featureSet.setIf(isSet(hwcap, hwcap_DCPOP), DCPOP) c.featureSet.setIf(isSet(hwcap, hwcap_EVTSTRM), EVTSTRM) c.featureSet.setIf(isSet(hwcap, hwcap_FCMA), FCMA) c.featureSet.setIf(isSet(hwcap, hwcap_FP), FP) c.featureSet.setIf(isSet(hwcap, hwcap_FPHP), FPHP) c.featureSet.setIf(isSet(hwcap, hwcap_JSCVT), JSCVT) c.featureSet.setIf(isSet(hwcap, hwcap_LRCPC), LRCPC) c.featureSet.setIf(isSet(hwcap, hwcap_PMULL), PMULL) c.featureSet.setIf(isSet(hwcap, hwcap_SHA1), SHA1) c.featureSet.setIf(isSet(hwcap, hwcap_SHA2), SHA2) c.featureSet.setIf(isSet(hwcap, hwcap_SHA3), SHA3) c.featureSet.setIf(isSet(hwcap, hwcap_SHA512), SHA512) c.featureSet.setIf(isSet(hwcap, hwcap_SM3), SM3) c.featureSet.setIf(isSet(hwcap, hwcap_SM4), SM4) c.featureSet.setIf(isSet(hwcap, hwcap_SVE), SVE) // The Samsung S9+ kernel reports support for atomics, but not all cores // actually support them, resulting in SIGILL. See issue #28431. // TODO(elias.naur): Only disable the optimization on bad chipsets on android. c.featureSet.setIf(isSet(hwcap, hwcap_ATOMICS) && runtime.GOOS != "android", ATOMICS) return true } func isSet(hwc uint, value uint) bool { return hwc&value != 0 } cpuid-2.2.6/os_other_arm64.go000066400000000000000000000005571452220130700160120ustar00rootroot00000000000000// Copyright (c) 2020 Klaus Post, released under MIT License. See LICENSE file. //go:build arm64 && !linux && !darwin // +build arm64,!linux,!darwin package cpuid import "runtime" func detectOS(c *CPUInfo) bool { c.PhysicalCores = runtime.NumCPU() // For now assuming 1 thread per core... c.ThreadsPerCore = 1 c.LogicalCores = c.PhysicalCores return false } cpuid-2.2.6/os_safe_linux_arm64.go000066400000000000000000000002271452220130700170200ustar00rootroot00000000000000// Copyright (c) 2021 Klaus Post, released under MIT License. See LICENSE file. //go:build nounsafe // +build nounsafe package cpuid var hwcap uint cpuid-2.2.6/os_unsafe_linux_arm64.go000066400000000000000000000003551452220130700173650ustar00rootroot00000000000000// Copyright (c) 2021 Klaus Post, released under MIT License. See LICENSE file. //go:build !nounsafe // +build !nounsafe package cpuid import _ "unsafe" // needed for go:linkname //go:linkname hwcap internal/cpu.HWCap var hwcap uint cpuid-2.2.6/test-architectures.sh000077500000000000000000000006751452220130700170120ustar00rootroot00000000000000#!/bin/sh set -e go tool dist list | while IFS=/ read os arch; do echo "Checking $os/$arch..." echo " normal" GOARCH=$arch GOOS=$os go build -o /dev/null . echo " noasm" GOARCH=$arch GOOS=$os go build -tags noasm -o /dev/null . echo " appengine" GOARCH=$arch GOOS=$os go build -tags appengine -o /dev/null . echo " noasm,appengine" GOARCH=$arch GOOS=$os go build -tags 'appengine noasm' -o /dev/null . done cpuid-2.2.6/testdata/000077500000000000000000000000001452220130700144325ustar00rootroot00000000000000cpuid-2.2.6/testdata/cpuid_data.zip000066400000000000000000017277361452220130700173020ustar00rootroot00000000000000PKgpY VP/./AuthenticAMD/AuthenticAMD0000500_K5_CPUID.txt]Q՚0ySWhYX aY{zloch ("-ϰ7"$jںt#4 M66 Q;{VYTLgyI4Oh*dt_cĞQe# R #f"UyPK/./AuthenticAMD/AuthenticAMD0000511_K5_CPUID.txtS0/7F瘨Q13'sNC?=$K& -YJxێ;΃"f '#"#2߹j]:M h#X"AڃpӍؓ/!+w-8c-rfʯu Z;7]YuZymbϾ]IWu,m$3+ -NVSМFj2+ݙmΥb!g TSpٮ;&,7Gdt],g!-V\ N ՞~ 4urÖFb8,$RJ"1:`rkrmr}HAed"J=cRc.22ґLMUn-۸J0O,\ʚ8h!⻶e7 _ -NK=*NOt2)l.8ͽg'`Q*$d3I]g)N$:kL: /8^3,In+x۽lm=(QR???~[}] =e3=|thԟb"ŕ1g<Ȟ/wK@/J'9|Mf]Dq0шdFLNRP}g}x<"'C(us>~p4j,^1dX)ĢAkv0z x2]x%ڍm5W\PK޳/./AuthenticAMD/AuthenticAMD0000534_K5_CPUID.txtPnEATÄd5{FPϖ&Z6CJ䐈I@IdG6 lsp lv܅*6'OjJ-߮B%&'dW=ܕ/<RP_^ yXj6mbq܎X?DKyPPK]w-/./AuthenticAMD/AuthenticAMD0000562_K6_CPUID.txtSe \i 4gݏ'˶Kگ?h&7}J>K5lolo<S zoz/z/_$a'm9+G>-C;1O:kyvp! n=!^8I:Dг0s=]^΋4K# 5w7J8P/UY+ SiZʙQϧOT6h5;J<0r"׽{9B' 㡥܃YƷ= mV&6b2)UoD8G=:Ҳ,U>YUypw#骎H&~;;svD^EJVV̵MbL-duU&/ye>奲ϷF?5»a jq7xzvXNmEeHՅ ,J x,Sx X6d'RjsyNh #oIDr؟+_*РcN0#=h9=3QS6#`8z"ƱMB댌'qq3Vd"i7$p2JGμyO-_ذ;Gf&jeo_VvDQ%2oA!㯙cvͱ}Tm;PK2P}E7./AuthenticAMD/AuthenticAMD0000580_K6_Chomper_CPUID.txtSՖ0|-sD23VΓ`s 7,{i֚r vggX _U,j՜ki1E iKo{4yU/mWP†/kpJ)-e/oomJ>!coNdiܱAd;_:m֖fQ&nQq~c񷰶v{׏%,I7NBjy,i9EYSUeUj sUyaVWC]{60-4h֊TRVuak5P`=<-#"|M錜Byл }^ Zp7l`xXS;Z,(7% ;*j@̓b kL+=%1``lyDkݜ2Ÿ1,`)r/"]*R2ITi!FY'z}VG=@u,\|Mo؄=!qwR.O`кv~Hqw"MSN7Shڌ :̱An!>q}C"QQ{N7q1%%R&:_J4èkq#ˢU3vC<6̡ȡr.ߓ%ѪHF%%JcFY0qB6D|Vo5!)TEƴpf!ԀVR7+HΔQ,z@"n~?3l$0a*")~7PKat4./AuthenticAMD/AuthenticAMD00005A2_GeodeLX_CPUID.txtr4B)0AKnIvna2'ͰC]jN8!t\Q$Z2/I  j]ZY?R=K?J^XdNo65I OޤI id>!-MXRH&["ESY{<gI6VcDqeY>I>D* >ǞZ+If"Y$[0{oicu:s)XěZAӗBЙQV:3Q쏢Kԣ3EUzuPK`!4./AuthenticAMD/AuthenticAMD00005D4_K62Plus_CPUID.txtSg0 WyPmI"wÅrׇ&n*؇-ţ0\5][A8u7L2lu-.,(E[D- :+'M|mT5 VVHMkōVSnL̳RUX. >]),eVeB6_t7 zz> TYEc_縴ڎ(u=qzP=/Cڷ-$:U>d5]~=AءN)Ggw!|;i ( א&7I";;<,#%Cޅ\8.q1WȻ3!0DA]H2b̘H?bYZR#ڎ'>\OꄳQom ՘-h$cv=g ,Ra~V*^Leֱ3lUzRƔ*)vPK4؊ 8./AuthenticAMD/AuthenticAMD0000630_K7_Spitfire_CPUID.txt喜0ǿp9 P3͡ a ;Q*e𳉬Y?FSW]B?`Ph~YEW3#GضQOI>؇B@ JM`';p5Kˡ}!D*Ѥ,jէt!4e1HUԆ d$(HNA CI#K|ǐ(bOx w\ s='!(9QA% 1b)B{c H2i$ ' wR D;C)J.M#lm K03 B(CyDm=ي߂bU1i IJU~?PKO';./AuthenticAMD/AuthenticAMD0000644_K7_Thunderbird_CPUID.txtA0HzI` A! FJVQ*U=hRcCIdyޛ3\4y]51 X X !<"S'4fJh!86ϷSOv/GtTfE]&oad{ uǝoZvY[=r-b]0EyVl0[ɏǼ:\XTm*u[.s@`|nt_zw/"XݳT oe+^A7d957M-z?ywr%$3s3Ju>q3Qx8e}SV Ί"=!<"W [4lB"kщOhL+ $IzSГ)xM$࠮E皥8$LhterCui;﨟뻷+ FOLI+I 0B\D"c P ix#V l!o$޺Ntr<;UV]N2G:PP]gͅJy"ϖW |'bdϰ J#4PK(<8./AuthenticAMD/AuthenticAMD0000662_K7_Palomino_CPUID.txt:a-3-Ɏ!s(P52z(TTh}$vNʢg۲""59a0 FcxGZ 0sJVWfѼцH˥~ J;8ߤk Bg؇N5Oe!1jQ.f]j tXDq7DTyңsZ TxpތvasY m_$IC$~e['4vXB3am;&n1u6/xsc D?mKR~ErC`=PHE )rXq;&/\i v=䡟;&®&LEcD] X[oI1uoGGp$gqYbKH7A|#!c)A\tY" YG6%T+ƯS2]BJ#ɤҶ~PK6YG6./AuthenticAMD/AuthenticAMD0000670_K7_Morgan_CPUID.txtr4>/90EHnI h2diT<ѩBrz~~< ]dzZVkiRm餧xSi0o 6nPh޽y vm NOԯ*TB| O%*@T~,? ;2}PK< <./AuthenticAMD/AuthenticAMD0000680_K7_Thoroughbred_CPUID.txt喤0C+}Ь7F+ˤ]ߤ*@|qRm_:8ls`ٻ"\@9,H 2 w Uܣc9ҕJI^+v$_6|8vCZi(׳-xbpg@B/>4a2YXi\KC_tR;nDA; NU7zo%iE?i?qcp|%P}}%+qJafu,VZHCM97ӴL γ1,?+BIJ[MTV_%:=aVܴrXIVYY:qCU#X.o?F܇ꭌZ+PW{Uqd&RڭLlWUz #U!>w]NS>\u]O{H&GG?s$QQ{p'؜VO"0f1|Fa<<:r-13ws*iFf5$0L1\,5F% 'ASkQul:r)MҴ+ MpLܻ)Lr'() Y(=|2dU 2@v9P.;h+]=x6:ؾe!X!z*]0NkO/f΀"jt0UJGuT ܡqV+7:Årgu N'|t<%ѓv٨㬲˰:w&]{#vkkO/݅dzӪbXSCUDž.􎫞Uyf9Xu5?jx .qIn|ơm) z-18P0iAXݺڭvk8rV.V\[r|gj0\T5dc ?Xqy!=f:13GDt=&4u6di:Iִ'')qbNue""eQi R + r2⹂ h)zTK\4t Wc}HS"iJ^v2s'4h/&['omrSwP @Q(n%M`i&bM M $Jw;$EBSYLu9[Xنm}.{u }X4ILE%\`0V%%VXM]-5tZzpg˭bPNt_I#DzPe PK=W<./AuthenticAMD/AuthenticAMD0000F51_K8_Sledgehammer_CPUID.txtk@xc-»0 J MW 1hKӊYh@޽#<1_NE|eu Mpӎ Hc  Jպ 4=F={v}v袿>mtQ{=-U^9 pBٰx$CxZF& ,t,JpTm;M2-|zKU6c{iY4 :n˥_D=0݇QU^]2͵mnTc|rs!D(\f~-c+A=Ci+8!8*֥RuH U0W1Lhs.LpЮm3,imgD f96YeA)uC[Nil3.$_v%> eVNH>(˳2\ -0U?mX&3+L <ȅnU%ǐB a(SAց D0$DU'-s @ =9} 1M@} >>>@vH4i$ryI dMA&yL1epjpj?|ZE?zӚAl$)f'Ak$L#N|n8:&ílUU@PI7PKQh^<./AuthenticAMD/AuthenticAMD0000F5A_K8_Sledgehammer_CPUID.txt嶝0_ykueqs+pjO_BYAY7'͵͵{USِ'#@ %x7<'[H1\Ϸ>s`\r;e֖< #k_a'zJSavԵ8TKq]T()ՀC 6,QpW7׮uS-FP5} ,ܾ,㡳amx7nr;Ne*]ԲUy m'ulS^DuQ. aO7yŠ"qews-8߂V .I? MTCi؞SӋwK;#8q&҅'q牫"Y&[( 2d2ƺXH>@ҋ( 98"CB#0]؏,:!Ev#w ݙi f9J#ȅ?@…(BWEAcdM#!!J~d=C&r59sqé9P0 @ 91s sDs 1@H r~8 N7~n?|^ݨ= υo, 6r{u3 WTB|p:j]JP&29lfL=ln:f.g2^-P)1; ~zptL̎It4?#;$XLLyyb=iTĸ&4Y+( Z PK[:./AuthenticAMD/AuthenticAMD0020FB1_K8_Manchester_CPUID.txtWe0?l]sg#@{^]jzyn]lf Dgxfd~f~^6^.OG^$dxg<=J[XXOeDx{iap!(?4\byPKY`}<\!iB]P*5:kq8Ά-84LVFK-FB1?s}Yu>*y<gggw'c_L:be,XIN!&;P7JpjP U<gm z՚ 0ww^~j2niKfq_+ީ }kăz*GprǃA2)]xV@.~=ܩET-A"Tr"[PZHtmz6"iP[yESj}(̀*qo\`D&7Za *pɐ92D.pf)\IC"#JXX,m" %lFlV G8gM㸉dEM056dN!`P4um"H;G`NJ~6t!y]H~RЅv!EHhB]H B]Hv:)j,_!?&Cb1Xb@foo>zil6*Ѡ (°W~SkKle( *T%XmKɒvA:-]ӂL[SU H.-K[ԴC-/2<|2Qyp2LQݒu0)6ݫMmnNg]Hl#%9m~fW$5MSCo"Rd c5@(Ecx111~@0.1)rCb3xf6;{08KDg ?'))R)#L(Wpak;yrk&Lo4B`f{Y]PK- 6./AuthenticAMD/AuthenticAMD0020FF0_K8_Venice_CPUID.txtvHޡ}JҲheQڐĒECOݖitm^_L.'GGj; %ydgO$Nu1~]ߘUwsSv–$KR>_`Q}{h-\7"RLS!ltß;Dh"w9Y_Nv5[:pUŹ{0䊛%^yDjŕܓH_qHk# a;'=(;8W;W8(Pjk&)R_/@,Eb(&dVKQQ*Fڕ2ķݣ! NҔ wUz|w"$wsv=Z'u==@ ~ӻC?1P4@(y8@t @| $@r @tX*O EA1q ~p'{lvy{1xxa;S&Id߻fJ0\J8 J9FN9qZyY1uo)|L(pere}j}{z?PKR!,7./AuthenticAMD/AuthenticAMD0040F33_K8_Windsor_CPUID.txte0-2+rP:2wﳯ#R^cf$}p7ʁǽhHlPh0mTt>kɻz᧩"u&֭.HKOGa4Jk"ܺNR !B3pkOd%6{w&x}0*צ j:չUkIEdTns=y)­[O⺷'z+yYZnI."U[EWIGzϕDpnǧlG^A,}`l "<@[L0Y--͖8兪eV\ck;oNV([9O>ipvW%sJ]A%' ٓ&m耡hd uv N6>mt|Mm me";K`6 YSv7A!DR8@pC6AH.?ru cb; r|̗C%4ysh3P렝{82o Dwrji aS]7Ԯԩu@:PPXu Vu Qr@ցA} qП9Z\.&aÜ'A&tt4sY | %AA=^yUIT DBy}fqTiBGȖPKu.7./AuthenticAMD/AuthenticAMD0050FF3_K8_Orleans_CPUID.txtrtBG0@+\q,eBVt+jKV@}Ưdի2jWBvs0``NA&xbfhKmE4O& NV,\*h9K.p92[5%m+}NL gV!m]K XpfԦKP>ĉHϿrWq0+lʵs؜cb+99Vsrs]bPK~!8./AuthenticAMD/AuthenticAMD0060FB1_K8_Brisbane_CPUID.txtAo0޴Kѳ1 JMU5]5iځ1a#ٺ}x$]v ><;UE ͓h<ʻ*Yw9 5|SS* |$/tw)2ۙԩoସ-U ˃pAYI/B7\ oEpBqj=0S4YR6Ҥ/-.,ϲQJ,dݞM^謨j6ڊlL'X^ߞM`څ> a$m?6+Y4Y>+Q+\$ki,8i֧Ɔ hRʺ.+AJ~]3MTJ`x]oʖͻA894<:LqEߛwz]&y)pov5ԥzs=8}\Y}Li܃^_[Q @( C :bC kć@H !wPl'A/888+wYSNr{IE*!@嵙%ڈV™9 s u]`e-Iʸ_HK`8 _Z'p-Y%X*ٶ~PK)R4./AuthenticAMD/AuthenticAMD0070FF1_K8_Lima_CPUID.txtrtBG '` $oKMmn+E !x' <7uB "MH l0{9} F.#"{㑜ˈO0bovIv,*~!~NDpLyE<5tˠA[EfegP ɠAAA~ PK+wlQ;:./AuthenticAMD/AuthenticAMD0100F21_K10_Barcelona_CPUID.txt\Ֆ s"zw94vn9H+dȸm3BƜIx%Bp!x(H:Avvvo[u0r06`W\vNNfmͺfY/n|9Tv3|Xw.5lsgW6,-`[N !'D." g$_$D\s5}{sD57V~,\[\8dR Mt׾ufݚ^}zMpN J _@6|b:vf2pFR? ^oɢ/%f>p;pwc<B=G|EH,1%Z"I6ܑ$ iϨ1!DcVs#UjY126͘l5v%|6 ?:@@q%= H+}! @L<1Dq` I[}~ 1xJG,fe05LonD\}l% 5UYz];ZhHV#1^O}x2~izBl5H:%7rGps})E rwwRd"Hgh/3ן''G,ýLË/D{G-Ҳ IzwQfsV:G㬐h8 fۈ 4Nz(>`Ne賓8(ϳ"i,|,˺0}K#Ry[ ',Tg XtۈM/|mm"k"6->iVAXV,ԀUY/UFaf9 h6wyJY c' @ :HMH+א68Yꌒu F^M•cLT!N~ZK, Xѳbv8wBF(9 O8%%PڼyOdqޓi(BZ4|C̲bK~ % B h] iY2'zGz #~_Ǔ>zܤAY6!HE#bF.5LeC`>^_ϵ5w^zA@FQ;2":˱LHӽ;-h}\;#=Ƞ- ˠA5=:./AuthenticAMD/AuthenticAMD0100F2A_K10_Barcelona_CPUID.txto0?q٤<ێV␶@P또&Qm4)i 'i6rzpOO%SNutd>Wv,˂z _K}4y uޏ߾]kx:N)urnO)vs2 nFi7\g^2h:q{Z! pZQkd$ MY>Mï:G*/T+4yբzdg0/Z[(XL>!6~xvS,+GI,o0_f:3x^'y^KLE7C9gȜU4+19wߣ}SlfAr\F{Nl e[w<>]q a܃8 Y/•\:`K.|4Ld|8L}L;TC&ZOabmL7`{& TF*}5fAu "`I⌎q1p(p01cRFHXr ߸@X2&Q(FH7;ܥDR "h9iŤǜ1"#o$?\ [pO7yFu#aI6qƤZ16&ژx$ژd ?M{IUדn$$$!96ZZZZZZC - - - - - - !IȎ$FBKBKBKBKBKBKB$t$FBKBKBKBKBKBKByH# %%%%%%dz.]uh~F:+:yf >^NG{KeG8ҙDYu;Ŝj:eQo>@% ζHّ|Totqw񫎒m dS8Hؕ%&⺘(]t`yGlB!TRYGZKe-~-uѵؗ)];{Ri#G?px($#!HF^Q(-m&VI,_L,XK=,(>6 @#/ PK ]KGy?9./AuthenticAMD/AuthenticAMD0100F42_K10_Shanghai_CPUID.txtW8]p7* dot@;́O_8uaKTYu kA}O L2ƣ)Qܩ굃d| 8 x5T* Znjޏ?ε-` `j]iޥ{p ߍ]콓뉁ŕp>ORGv D> !~Tӎp ] ¨>| sNا:85I4(EGewiMؤܕ;v R;{{˷v8<E;o]v<짳$Ђ,Q%{"a:ctGEZaGZAf?PNA&绁|tjX&+)\cq|8;|a'q(,G J=A%' HoD#(P!F$WzNH.LɛIA<"ukh4/5 t/ P5L:S{ d=dȚғ\w-`h[p}9;=U5G)`H"C*b$m&!lPքȱi>\k&U85-pw4Kxb=NN*^SPŤ+(V1*&VīDW$*&UlF^H$Ǚ|}1&]\ӝ/t+^&>VᓿL|ççççççx[OOOOOOOe |:|:|:|:|:|:|ʗOtttttt_&>7Gpd.ij7xaƛMqwcjw$LxUF5:XH9V,AWH $bCTouƐPZEVIZJ ED$&HJxVAo6AcEڮ#T[RڑsȖJ)obS܏DZc'P-GW$JX>ƣщwfFk' +81ÉIBw@xͦPKV<9./AuthenticAMD/AuthenticAMD0100F42_K10_Callisto_CPUID.txtrtQ0+@{u1 ^F?cӬt]D/xё yV1fJT;b L4׶1!' iYh jx}vn*NC[l6i[U"ŷF{* l!-R wU^kEzfz&`?cPHZٝO:}bBk 2A@ *T3e=/qkh''uYxk^,_ PKx]75./AuthenticAMD/AuthenticAMD0100F42_K10_Heka_CPUID.txtrtQJM,.I-*V ((jZrA @AYF@>O,G* ۦʖ1HH2" yV1jJTˤP P4zIɘ t&)U}SmqF7h阨Fl6գJ7e LJ/nwj!`U}:lE l#Lʏd1δ2;GYZE;z9W|_$U0aBI3?i#y?0} ޥI;~vbۛYFa\,>0\a|^#dĺGqEP?T{CN,O5I!NU+V1J<ԏ3?ȋTeAaP+2XQ>[l>[lgk}gk8Pa4{4KKxw'I#^zmp5-fy8*zхp5R-r2)#@FPk:U K ,1 p\+ CYǀQ1 |߭arDҞkXT֩3P߈mr⪆J977D^][$TtĪۼ3}I@TR8x TWG*ϋTeau;PKuv^.:./AuthenticAMD/AuthenticAMD0100F42_K10_DenebTWKR_CPUID.txtrtQ0+ 9F ArZrOH#Ѐ=.ۅUŘl3v%1&ĵ'$ 24U2:}>}cgL؄p9[iOE[žPK(5  __Ưů &"pJylۥsQmTOEjr"+#B`Y&[?7(B2]UK+RW.*ŕ=➐>9c,bXPOL}&b{$|hD0/jTD%z$:$^/zD.F`#\eOV>#(M Rc%\ԣ2JxB |S푘3'BlSR<fYIb%f*i$aA4XIM]vLw>D)B!$5a !!$:ĆBtPO#=]i'au I礞]\>>>>;W?V¼H\%嬹?dQj˫lg!{:Y!Շc`]ż \G 12¥8نN:ن."  y]fH~cD BAxK #e&qYAdqՎsѐo0LBo3x܁,@hwF[9]{djU?wz@ )g"X%^6L5I uvPK\b ŵ 7./AuthenticAMD/AuthenticAMD0100F62_K10_Sargas_CPUID.txtr0 +tխfݓ0ZJ|R3Ż08r}*͒0+FzLrV¾آSl6<5ww&GZ,B}Ҥ^wFUkݣzn;Ӣ,BcKyˀC`*'2;2ɬJne3J(\ɰ7.Yz^;*r7b5h?ޏA+w^-K-{;2R]5̓hs")vx/jՀ6#VY6J'̖O' "ELlh-ER9܆B.ݙ©CZ55™Ww^~7p~<{2+{ ?J* >~UxM"%,CP"591Ki,At6Aو!:-ۋ(Zش%ׁ $,W {jDQFثFPDovY[Q@(FS#V' 4 N]Y0dXb Zi )q4[ĕܳE(H! ː``!8uY ȗ윞:FSH*-A^J~(uDD@@dԁ:U@#W_7ht(%{MW_Nlzr}=@]gl^*]9ٿq-d%ɸa kܢ0,"ĢƼiEIa`MLhK) ۂĞ'S8.H؅L~D!_Cv,hFV9Rs* J*PZZSmH}MpY`qZ?VaG$6?*4{؂^ E`2E#V~6Tor(U0> 1?y]5TkyFU?Kf?PKl{ 6./AuthenticAMD/AuthenticAMD0100F63_K10_Regor_CPUID.txt핅1Pxxw Wahǯ/l^po<+70W.>>ٻ+uvhf)oC8+"CqmhQ~7/?xwqL $ bk_t3ƢQ_0@=?ൖi6S 2UCC"qT#PP&mnYD-JC& !ɎO'D|C>O'ħ8 |">O')OyD|">O'?$>QD|"> O'D|CwD|">O'3<$>GO'D|">)'D~"?W~"?O'9ߐ,s-pQi]#bY*3#3iȣ[odf+wo1k >LH+]@SP""^D@B{&"b!8L޺uX]H oE ٵ7RV@]lLE& l#ȏ3L!$;?.28BYڻ3-7@<~ rBkeomWPZy zݧ#~}>ߴ^#_{ul %Po`ػx3 G<N% ެx#G5 B<x#^x[@x#G:xG<xu#G<Չw;G<xī !G<N E0,X#&TF'}1! ͠4 ^x}_ӓ[I#vyMGzd5;R+VA[5n\Vm3H/B^3C(د=9H YֻL_& N[tdP$#8JIi jOG }<4-:' f0AlTd򡅃,d! 3 YBq ,d! ,daB,XB,K%$! IHBZB,da“,d! Y¸ YBq o,d! >,d! YB- YBq GB,d! 縅,d! YB.q YB,\,d! Y-d! YBp[B,d,d! Y3n! YBWB,d! ︅,d! YB>,d! YPK(]47./AuthenticAMD/AuthenticAMD0100FA0_K10_Thuban_CPUID.txtMoFH&bz6H]@+Ew:@c05_߱Rd,e43sʳIi2_wU1L4mA'h lRZЕYxy4omMѤ-|mo'IJBjÝ\^J z0y2~@P-Pw5xpY]j~#X:\ 1dY(qcSBd֩Ձzu ԀցHցXׁDȮ9u jCLGl$ARw (E{:drɧ(%]%%%%%%ӋL?E(*(((((]d)JF_WFFFFF"%OQ25JJ6J6J6J6J6J)Y|QRQQQQQr'.t yAj+gݷ4ڕ9r8Jm_TR5hRjP(E l\ @UnֹD bH_@ A<8{q(4fрseM#3̴g l} J J*cJQ[ZʼnU7j e^4* K5nDjs .)IJXk|a4dd#@%s;M0{H@5N5~ T a k ZHH@f d@zrQ"ˠMrNzrn ע5F2.d["HΑ#9Gr9iQ$Fr9s$HΑ̋"HG*s$HΑ#9Gr͵CPݼO^8GL0ԁqy;0O<y_/߽ew$_O*SyCU|-" L dd޴UeRE Vo;U @L#H&p@%4)0\!{OG/"SMFRG#rv2dVĪU[I4Ј}UN3</5H:Gq ?whd3>2hɠ5"$T2H3feP Ϡ)4?QKٟ( .л@ .OPK镖1L8./AuthenticAMD/AuthenticAMD0500F10_K14_Bobcat2_CPUID.txtrtQJM,.I-*V ((jZrA F @=`YH%l]Rن4Fl)M;*._)ģ~33hɠ5"$T2H3feP Ϡ)4(lIUwM5y]wM5PK1QJ7./AuthenticAMD/AuthenticAMD0500F20_K14_Bobcat_CPUID.txtrtQJM,.I-*V ((jZr8aW#Y5GZܴ,(H&u`d޴UeRU Yoj @8Fp7_bM0A43dMXoO\7i=lJ |zd*ZBYP0NMc*daԘlm*n OHow&dźy{c)BH3\7aNG@|qUz8'd - Z3hˠH FqI d23g#7Dhì&hPMjr&Gjr&PKe7./AuthenticAMD/AuthenticAMD0500F10_K14_Bobcat_CPUID.txtgoF wIOLerT5^A酠6c˧{;z-7p4R~n[d~]=$#C(Yn,>^I@;n1,%741<Ә^-4.  FD(ǿD<= (Hᯃ0ȴuN ;'y8/ufzf絨֓Y%yufK%H{px8*Z8?#n?8gANBϲ(,$T V}Cq NyR)˨D>v@I0;BjrznY==2ټ~sQeoq..L28׀!+D]8 mVtr+8q8CN$sr9b "D )E!}߂h -5Dqt d7AL Y1=uPNK w?dS(!KRdL dRU=rGe>SUj)BKc9/4㠡1{wy e!oj-5Dj oA&Mah@@ D@ ě@ $@nH5&P ԯ ߿^n\^+)+Vn%Vn%Vn%Vr/.q~̺M `|e 5\ z]8QJqx^»/43Y6GVqg"tRxdI#w C?+%HJ ^IA7(ؒuZt#$D!w&n Ri%ToTq݆TR{- ߖJJJgET~5{wNKG:bTAvFp|CBH4vkF+OϹ BR<8i,HO: k0qi+PK]':./AuthenticAMD/AuthenticAMD0600F01_K15_Bulldozer_CPUID.txtrtQJM,.I-*V ((jZrA iF@>#NYHRUQ_;B0BcWZ[ZVcWo^r mj"kcIa@ABk4eW-vT#j >#+aR=o7 ۞ }/$ca[/3 f*|u.JYQ/Bլ|BlV+%Td8A{h/sZN=!؅§m-,lX*~X?R1vթ=f{9B9MGB ~~; h_LuりSk7R}~axz6V. 1Dр$Y88kٗp| ։D;^cBDD3qȱ,FL𓖨nzh&ʻ&HXożΰmk> >'$#dc;] "X%ަ)|UKD{%Ob ¢e]{e7Fn_-|iA8JeGso@|8Ђ |?fAY$1{[~Gڢ,inaDיvެc2ݸ*եY2!~|‘ -.kĄdL *'2P0ߡy=Ϡ%3hˠ}֏7l |؇I> ._ co$sa}VПLċ[%Rwqu)J4aM Դi-U'd$qzF#ԃ0Pl:Z^G: @ptmFZ2!HY돛i-g-bBkfҖA{2(AAAAA%j S@`jcO>9־  a6z`Og9G}Dl\Xwǯ?5b,1`023-^03*+kI'o>w_\?8 k7ْV%VB߰RP\Heؿ},%/4I/7"|n//.yKonyZ2Zʓ/"hHEЂ4FA#hD4ցQA#h4Fz AkUЂ)hHEІ4FA#hE4QA#h4Fz A{UЊ)@NDtA#h4FA!WJz~od Eﬕ&AzntQr, t{ v{l u{ w{䬶a\}$S)Τ-$)}h덶;31?ݮn\<| /j%g/VY6})cSەf2/P(~f\@:ĺ}ܺy3F%b A  H be.PCq">Mx],|7#v;ҌSeI;xBax7(ln7A!l$m>|6]Jۦ lÝ6"ܖ ]nFdJKIY2Xf+ ѡ *LKYeY*]+X2FʆY-VȲ 2Y)~ #T!u3.1/!Udqg[#fk865v7t*}Z7?p6ƣCpļ8KOx6Z‹x?F0 fg)ˢtGHN]PKО u:./AuthenticAMD/AuthenticAMD0600F12_K15_Zambezi8C_CPUID.txtTW6~gpJƸshaIoP # 6"vyPN/eQOp0dy,7=#ׁEq^'(\`ʋ8~62!8h`l]\g8FTUW`069S\Db9b._Eaҷ@sױB}Qj˜6Pn[F!,SŲY)9DtZ>86@߼mз/Z(-/Zp1/enLr5jbO'QnJsL\5wGb(vqhYz5A亷jZF>.Ɖ9PV,UgeYyD3`8 /,獛|/Bj[#UUJ#毢)i#=-9?swҤ&IftBU_ဲ 񫅺o9@Le0:"*Ҵ|= nsRgLnK&wk67Jܱ `"GkvqIs2}X0l|G0 tp׋uG#K֬:W@'Q9U <tH3hF*o64eW쨶Gf]܆[[vE7;-b;"z[mw_^KDĢ[ne,$PQګke۶j%Xk7YP=?NO$O9xO <'xB$OH OH'xO <''4( SO <'xOOMT\\2FΠArˈB0,e Se). A9J+ %LI2eA-?C؈]b+MbQ_B 0 UT>ͺA%I<?PN/BtDit~} G!>>M>>>ck}ͭG4ht( jU"I$qֱXB[kdׁ[P-&Rƅ0Zػ]J&4p5i  iD o~PKbF y7./AuthenticAMD/AuthenticAMD0600F12_Interlagos_CPUID.txtL@0.?̹!mi. E}7EVʸϔ>#ea0%\1OI|AAnުFll!'\7fW6XF2Ǻ-C]`xc)x?Y/Su8RQBj%,gr G;=&/"~ʴ2"Ki|3ؤ9k65Ɇc3Y=&ӝ$6ȵج$(EYPKW4+[wKu,Aw9][1CG\Hw%!gHBd֋brgH,_+paK" (Hٮ Kn*M| ('0Dᓴ׭nrۆ( :@x#.ᦹ7]-rJM Rl ? zT=dfSr77z*` CD6 tX!-AhU@o!wBB jJK JPO[p.:G|؝N!6U<lVs6H{]6 ҝ<,7X_[F9N 5hQ&u~l.8(BA @6++)wJ 0#aX})׾YBW{k n?nI*iNy6-ԕ %( F $%HKKP(A:?\`ჳ{u[n>nki{/ɑ.c!C [hЭd͠6h6h6h6hn%6t/t7h6h6h6h6Ġs3虃^C^KAAAAtbkɠ z z+fmmmmЉAo#} z z/nmmmЉAA]2#4dGbmmmm}8=sghgɠĠ ڠ ڠ ڠ ڠ 4A_A_%6h6h6h6h6kyh=awhwɠĠ ڠ ڠ ڠ ڠ 6A%T趔ЉC?Fv;t+9ӡڡڡڡڡ~:t͡{н/vhvhvhvhN5|L=CC%~;C;C;C;C;to9;VrC;C;C;C;C'u>ڡءCڡڡڡڡ:qCס8RQZZZZz[Ɯ3 gЭMZZZZn ]S+T^R ЉB16 } zUhVhVhVhVDW.)t_BJ )B+B+B+B+toS -T轤лB+B+B+B+B' +tM{GIVhVhVhVhNs^ZPϒB (5BJ })B+B+B+B+tטB+*]R[ZZZZGm)9áڡڡڡڡ~:SgЭOvhvhvhvhN5b%~9C;C;C;C;tЯQcz-9ۡڡڡڡڡ~;tɡ%vvhvhvhvhN3|N=CءCڡڡڡڡ:qC;wm%Q ![l l?à@72)yz;s}{yDv Ql;`5AqhԸťq)<)/%ư5 Ql;`5AqhԸť1pY8(6'5^NqjlťwxhOq63lM8(6'5^8Nqjlˢm[7)&y -o+(.{1ͫb}}6qH␍Cu8f㘉`ysCm=<֋;aAC4Ǩό}uFc^1]φBn \\y|Ao0 )d,tcgy{a}y<^~:l[X.O?M~E>. iJ A"Ǯ,5"!HLDf$* (áXaa쎕ei/9"/ (}Ĝ0Pp!GDfߛwpiWߍ,Hq uݞ_{HMdVM޿lh3l :Ur>_ ?%PK+l';./AuthenticAMD/AuthenticAMD0610F01_K15_Piledriver_CPUID.txtrU600PpLKM,ζR00@ \@U. 0+'u#'CQx1ytm_\qh_RPHf?a!2B:]"B;5\bg,C!D5ݰj] ìRK2 [[5Zo-[Km-hR|Ɖ/N6~+RdKkm[UW)lJ) :Ju òbA%*ZsVG)$`0HxYTUrQPBQJh To2uVy*OÖUJN{Ym][RQҖbK---5Z*[@|?uUo_ A;PjW_ 97nATdɢb"pGc\]۱۱۱۱vv[]۱۱۱۱vlY]۱۱۱۱vPKd|~B9./AuthenticAMD/AuthenticAMD0610F31_K15_Richland_CPUID.txtTv }O,\J%l+ g~lyk8:.q\B&)|ZJ[;z5zL$+fMR6l͓ ꞝ3-pQ՛gUswވ$i@TN5X[Fs9A&4.WW";x^s/P5:,^#,8ܶ^#v#ة50>-[xV`k/,-\ Y~Tdk>|$jL׹iըΩ%m ^ޕbz;\D6z%x{}kֽAq(KSʼRG<"0BXyB۵\乞.*DZK~%)0ܯUʀ]ːod<6g++]-'84l!\"Q `1fgs"z2-5+&4:j" K-[S898kfALsH\6C'רuF}|17*$VM.Ͷp Ojsb&7áo7mFL)*"uh{+?CD:Ld .%"VheMY],kJp8!Lnݸlx!\`%(e*ۙy x8X,[ye3֓a8 `ba-xZ?7߶m(JG" `IP$k5@nM[h+ִCe}GzJ<(֕Fq63y.bD YEPHmQu) S7iT/{+rtMo[f73PB=D>ԧPB} )ԧPB} )ԧPB} 4(KzC} )ԧPB} )ԧPB} RWBzPPB} )ԧPB} )ԧPB:S>n:~(I>y[¦~:N9Զv귫ݝc{wf::=#?M#^O -/| fufߖ<=u a < qsYl7B/ C=%#Dtm,HtQɪU3䛵_ 5J%kf$$mVg _鬄bv[#I8t$y9/J[#ćǠxD/7뜗YQ  -dy?:$`ႄ4bNqU~h')B_CZb0ԁ[DE4LC+)4iTF]Z\蘆n$Ңf1E#60 & XV-F +nB]Xi`42 ̿`&>i +1#`k`:,ըfۋ#ABiwϺrUkPé:}y#+LX~\` Ae`~$o(MYzd6!h~Y n/xO7]D8?i6Or7FnVq6xMwz/PKP洡B7./AuthenticAMD/AuthenticAMD0630F01_K15_Kaveri_CPUID.txtTWs8}ތ"oN"lk?p w滝(o '"UYitĔzAq<:4q6ߡaL9F~2haӨPONHY_LW!D{z/ܱ-oz,ۇ)rk5;&y& c1d'GB6_h3_fpq:y)tuHcvRnFp's~P-{bWuָߊ!-F.:B"?JÝZJi%67t03L9!9uU\~~ /8B!`zzaa[45M f"rZӠ %gsx)e!/K4[eՄu?ߠ)W`%( Zӟm;|Dm{$7T^[rr-2V4O3+l#[R&,‚"+G ,q<DG.%4Hͦm<6@=/|Sl&C9x-IۏdY^z( e#):ȔVb:r%(pcD#Ac hLz&dwܘ=c:6%T U{L,}ݵX<9{T`jN^)nRIyu&WZ jF8?noa7o=%3zHҌXc+ j"PSo kT $`b$OZX  T̊PD"FkuN6T A8TׯK5r|aXxw1Bao.E13S5cz01x @z d@v @jPP{\v}?ӦiaHA}VffM |1X0&a?]G# hc1q)G4J"&.oX=FUC‹]4)<]hAhщPGzPC}9PC}9PC=sB=}PO|ϡ>sϡ>sϡ '(z>*͇sϡ>sϡ>yϡ~r+C" }1SwqJ8\^׫_nW;g?Wywg/Zpͩ7W?nW*)z*._wabt\7(?KvPe%'n^ЬJ+:KYf6(qT@4S'vڪ!**i>%p9\bp JP@uszǢ/W˼`"{, %tp"ÇKT!'ԔB' km@Lq3\lzcЊ[հ) fպUhmmtcSl4VqcSjo[6,c[Q=mFC2hQF}`eɰ[+9d٤NP'L lɸldʠ(IC#Ӆ@f5i/A nKTW {]%=PU<;D <+HDݪ_ٿE(؀ç,ܯ+3oon]݋͍P܇` @G*g&cp?PW~@"(P`:}Pw`uNu柮]_gOQW7Z}FWۙؔ\HhYlB \ `qtQ@sQ\)S`U &‚_0q&4PKװp@F:./AuthenticAMD/AuthenticAMD0630F01_K15_BaldEagle_CPUID.txt8ow2*F3,BW B :%xN~ Xyک]޿{/qvGoAyc_ =}.w3鋰zpA]>F2QE%י!]kW~k1ah άPp4ps-|2.&562^Q ̼)[{<9e]LySTML&H$hQ\9u;k~[u=ʕzAK#7ŽϿ! [vu]^9.\%g{NzK@(%JY%8 H FSzMc**ڭaЖkTrf&.2] Cpo^=͡<4n@dZ̓'ˆx1|vKX shyXH\HXjvhxϲ.&7?HX76܄"ܲo_TYdIXKMCMyO8orB*T*.u0!t1ab]LŤtb]L8oᎰiOrJ~B67P;e z>CnSqȩݜrjʩ)rjʩ)r*n1rFNͩ)rjʩ)rjʩ)qN?ʍrFNͩ)rjʩ)rjʩ)2˙< kg~Tጡf)[SgfŬ.v9k}9wFo7,=}~8LPٹ+e35:ѫwT5]W^ _3y$]kf%6AJjIưlu zt&bX> `eNa8~~ d +0a&*=&0+&{*Q30{55$g& J-~Y /E\sAϬXB?iZ\VUbJ kyFҔJS*M,Mz..iJOhJA^sXb[u)RiJ)TRRRw)VqejS*M4ҔJS*MPK:@&R:./AuthenticAMD/AuthenticAMD0630F01_K15_Berlin_00_CPUID.txtlSgw6sn0xv2Ƴ Vl5qxG~}/pZϣGw_*2v"% 3.Co<݋soFֈXk<͍3Zؚߍng#ҝ|74_\eJw)q]F?Us5+b}>J@-؂h[y|q8z"Dᗂ8x4GcgH8;z _:Cj-/,oh\%"(aQ2~"gH^=۹Ls02M +d+,jT昰]ۻ/QPț/*O.C,-Y ֻjc* GeG^z]#G ǬLߌ΍=#W rFCsJL2)|_,-4U*t^ wܮrǡz/=wnj+ Kՠ߈3 &eșZ6͖$SWB}H/lCH*MO%r<R>}58,h!v!S.Z.Z.>Cmz q!֕48Mf0 ·cO~]Kftr'N"x;FE̒OHXY1*=8^,Y"0xȋv΂qEJ\6ef_iqb%z!g!%~ 3qVYP*:2z@ rLHAN2C D93n 5}[5GTsD ,-Hq⩳&85&5CID)'ܿ4u M㽗;^oP74(AH00A& 53[q"|гl4EP+Mgbit% Dn9G},,-UlJSXP 1c4` 0164XTE3 ◌8qpx'pw'U%mhh \r3oǣsŝ.#b %얰[n %얰[n .viaJ-avK-avK=a|.#r %얰[n %얰[n ̓X ck7m F|quv.w4-uy]ΛѣfxR_cx>dL[7AeV~xtᵻ7]E xnϿ=<҃ExB<Fן<>*7* Z/{+71T{v$Q(1#DPռK%IP6xpЏJtFIF%{d 'jFKTJ}riD n(Б>D-UJB'OC:şa(‚(u<@>j8AniHj3ifEDk@+hLmtjXc`mŠlXa w 07sX6<:xVFa<¨LSq7qYL`֯FN?Jo#$ PU<? Z `D"MX]*+ *.U\TqRt\ucܥUpRťK*.ʥ*ܥj.U\TqRť~tr.= 33@HƶK޹ ى n]/3%802PாIQDŭ  ,~h[_\xz#XD{7:GHftf!cܲ xվek1u9tdT2}e$=IPKr!V79./AuthenticAMD/AuthenticAMD0630F81_K15_Godavari_CPUID.txto@?ffͱc@jKՃI D5)u\;~$fdoNo%;Y~ޱGGGb1v7fgK)chy[o?f51{.׹9ܯqY\[#ȥD-Sexݬ4jy`$9H\L+&$$iAT5_ 1R%$ }K'L ny`!P\A E\Bʼn]ױRJζm/,lI**$$a7N$X'VDP4P,lx"@۵Bˍ6𚝧"q{L KAe@:a򆝛g E˯>rrJ+#? Bpnu1b2z_$$hyQ%p  $W(m䑉d HVnc[Bas a9!!P<@4C 9RC =2C ;r󔀄Ἒ}vy$9ϓ(&>?-(.;:m+[VEwgH䤶`҆w6[ p5 :tNEs6fnf'Gr6O3%kMVЯnVQi&fq]hFѨn;#<!" {73f;a쇩NaQNXt98g٧jv>KXξo_œ1Chvwۋ=*Gwb:(]u3:>CcL ېv뒩iH &gOthSN#)ۑtˬޕCȁb,$p]kACZ.ť!%fwA@lH\"ˍZqQ%)Kkᢠ!/p" Z4R#WG(`Һ{,tU1\5Tnrnf놤6n;nti&"MWnBn4[kk2 L3[35#4kVff:ęaeF{lQ,L\@Pf6M2S0 "LVfP1;2M34Tf"FJ;`kjaIkHp+\Js_u(QQ]H`P® pcfKrc9PKU#l .뮊([Cz1ކ偡NTݯ೬MVϹta;2APIOi@Ͳj\D4}'o=ғ,=ьjqV79@JzcһjvD}k qdu%*%|~$`J2&3[R~[N~?r **1G4Hj0?4HGPC&[PiwowG~c=G2֊ʹd8|v1+kS.n_{źUI7ߛTs%yX$MA.kr˔)[$io/m-GN$EK2(SIy1%]>CTT$l& @`E}O2Gm# t ʀCEـEǛ @0VH`_hY )9E ^[Ѡy$iAFP $#HG4*#G> v?OT"~}r@!m7Ѡz&@:7bbSޓ?EB`_pHݽ=LēuU{+'@HW^Ztd9Ҟ>4BWD;+kFAǩYڸL[+lnZ Ի[~mrk͂rjbyy+N!<"<AxAxg;/ <ƒ <ƒ At›B7Axƒ <ƒ <>M?꺟Dv*&E\VƮ {e:NCBٯPL3}.ۇiރo(qA{hl.l q{ 71xu;J O&A]! 0Bg#wm2RUHaVkڦS" u)"Bm|&hY|by^ ^'`F ;0 _4bzHމVAke4_~QL? |Űt3y$5\b_ K$$]0$UaS?GC=GbK9gicJo:ꁐeO}ss|L@ Is` "=7`0,Vt;9oFaNr"j iůXƄ&Qa<ϻ_wUYBR {$M`Lj2pJVkߪ]s?| u9]fff]ىMK >kfv-iy9]= <,@ aYAfլz$jC1H<$ E/"6HC/d3cH1Ң%V 3gdؒqk(A2 fud^di;p$DTMg? vD$*hĨ tDZuk4ਰL% hʜ%u&sp?j3l  ,lUn2ڶUeP&`" 1葴mxh h7w -kaQHҐEÛƴ4I8ol٘L1r ABC1$C1$;ƐRC1$ ,TJ/ھE:'?ӺBUO0)XvuԶt73U͟foO^~?cdOf?dOf?dIO'i~2'~2'~~l?{I;$Of?dOf?dO'j/jD8=\MrAʆ2n%0:dJa2wȼ̛t9r2dcZ|g=;{އ.KcGq(t~z~Gn&*ޞCG]~v駆{;&dZ.5*I  Yb}(fe#L H 2,4ym %vB0IebJN [D܆]dHaمxܢ DwCt j (ii9{fQ8.g+)Ո'oզآ:Uc VC?TWZhy#f*ĐVbnS^eҊi*Vs#FYTl5bx: 1#Tlڊ񪲙FI^O6bUBڹVLix"Kt7#W@P!(5+bAGYgQE۷B ۺ&ĺ6A &ġOnW⃫׫'?zm0KOןzxMǽ1ėCU}3vOQ 0[FHht,'- G /8I5:ÏuwQj?P!Q W `~PKakG'8./AuthenticAMD/AuthenticAMD0660F51_K15_Carrizo_CPUID.txtrtQJM,.I-*V ((jZrAI1;Xzخ̭7saQN'NI/il*%H~X4hISP:*E4N1k/wjvĈP40zO\!ނᏇ I +Rj%.Poӛg-Ԃ4qCiD0>vCLG#L륬mC,ӆmkvșσ3` ܆ FnoP.(QatFxH (FI ]QWjD;}KЂ4܀-Z iAڂB -( kAO\z$yڧ> Gr+U$ֱ D~[x9/ <#c$%p\38όf1vYl$ >I;IpyQ8|QIqF\f/H(""T }?gܯWå'TD)TGR(R)VnoݽP*IcI x6gKX9PHp "jh޼ BޭvPi, [`S \6aQvnOc\B1>&D}LI1>&v~r&d[4=O@ QKZ88vrDzqZ,ы%fF5He9t֪E-ޮɍbGf3( H%XB!rL (PbX0lk'4iHhءaJӑ@*6YƲ4Ha&¨ Ba:@1 L kFt1 Ld ), ¬5*SLay,jx4xԆQ +.aaFfd0U30}3HpԍDsSi0 f0%\AH!rNaX._PKm<^77./AuthenticAMD/AuthenticAMD0700F01_K16_Kabini_CPUID.txtTR՚0y3njvQ],% a7qSC{!J(GG9Yk83Bϩ|&e*Qz[vh 2sesؔvSL}71(lG q*>*S!l~­w0KpOC1%ך7%PPnDf,h0o/?a兂GSXc|<2`_a<#δ8R&>du!FV+;J0 ̩ IgȵhIJRȭh^sCŠ["*VDu8:d &Fx-$(] EpdWPyjM-h@*_Dщ]ⲾTh}3&)%E)f x xQ{)%T~ ^Vh/@L㵗i9#7]87h9VTc/%7@>̡o>Lw3b+"Q&tS/jsǒ'$G'D[d$yfqGy1MLsZ",F @$iJ(Gjj'{('J.)>C z}fRL~tA'M'F5`J-iRH+o߬愁(|_y] I$un,kY .>$>:,|`WX2" kǐn6k{"290uKv{a4{vΤj1l8'd.N&N&N&N&N&N&N&N&N&N{|&N濃q2q2q2q2q2q2q2q2q2q2Jdd1'8888888888Y2ӵ#~'wKüuB.mId nÎ>ڎ+ (@ O'A6dwU@mQ"Egy,=9WRaC;0aU_ d`aqӄ־(R iq\ RKh;S7ʠUu裾b<.T(@J-8@(j[b'9;'|!ۀTBbcɕׄOSO8Ԁ}ŗ(W!F?YDz-v"$;{kc츧s S0̧`>)O| S0\D`3sws S0̧`>)O| S0t @\\̧`>)O| S0%O)yh_d`!tW~nb!o_60n8 cE>"Ϟagw|xuXG9 g_Oq$[ϝm6g/^-3B#H/U )ޔtE"F\H@"9E%2wZI/DݒbFI`h,WQgqE].V"idp@";[b瀢muɮ]gWq& /*_:j\OLfh=23f7.F0k3\Aj&RbmVFQPfLfve&.JY!z3Eo&1SYٛ*P{LD3EbS7+7SެQA6CWfLLjVKϞ6%fu$ #SUAQ*s]/e_ȿB& \g/œ b=aYZa1_to7}nd(g8;w^,^dk  g)o-˙4'\ut],6ol9|=G$L 2)=qI3(T䞚L2YIK&K2YɚL6s HIOsGȭGyRnH"y>ɤ L*2ɤ!d$iK@]dl%7Sdx1Nv騤2dRII&dҐɂLZOڌKdC&[2ّIG%%xRѫFv=H Rxҵ%9둔v6'Uٍ2HMƼ41έGd'G*gIK>J2YɚL6d%] 댨ޏPK:p7W68./AuthenticAMD/AuthenticAMD0700F01_K16_Kabini3_CPUID.txtŒ@{*joOff|sg/n_S~}ُ3grΌKfc꬏A" z ޙo_}E}{TGH"m]$b4M=UJS^u9HCVUp9B8'BCm?-vyD ̓2Ϸ|6GE8 󾋯B^<:"C3}Ϸγr}e5|/կ 6%a",8D+Zl?\aAƶ*UE RuV:jjTUN*4 APHXDJy *URzR|jTZ/$GN!od[1RY5ĸ(lW'%S_@@!d8ioKa+0000002=aUtUqqqqqqqXu ;888888(PK;Ҙ&7./AuthenticAMD/AuthenticAMD0700F01_K16_Temash_CPUID.txtrtQpVWI1@PU _=a;2N(b%5㬔byPҹUK}@rYyFP:#  kgܣvjdF>_0{z)1Aa}a/+dNMo [/͖T$9Qќ PTRċU+j2$l;:ޯ0rwI&>F2'u/-oyO14S2L>iy[OiA-bDGDFEPA%jM ]s'\5 UGBߡ=vMd@Nb:(:Sw+T !V b b b b ֨2[ b b b b v/% b b b b b'PK풿O_5./AuthenticAMD/AuthenticAMD0720F61_K16_Cato_CPUID.txtQk0{ֻ,~s\(t-K,$#MO7(uIlo1rs, a>GjeYՀpf_uu MjnaVGz MHPJ:^evQ,<jnj'b3k=( !Pt @97:B噐kJB,C+܀U 5bPAC}{-tHAՠ"+LÜƣN22V-qg-ֲ+#$\+WRd2s(i:Ӿrt{'CCxewLh2uz$bIx>Kt“?44 锇@E4 lDQ! T@:C %!PCP'k?MI8䡥+4Ա&z66夤@y/g)0\>$pvNݬ['l]>] e;z~m?B4ԷGt{=&=c00 _X&IX-,ЃiRN04L)!:DCtEE=!:DCt!:Dl)''!:DCtߧE= DCt!:Dϛ LxD!:DCt^65V z"z z.Ct!:Dnj@6EA!:DCt!?><jw_:q=n}~z̓΃quL}(,QEiqp[S@|g5y}f2$Q2;ww^J] W/߻ x^Ħ%3Vin5jOlwݺhWJ lsئ%y#jK|b.8.!/#PB \ӄBUJܖ% FT0yEygJՄx,rU񟑵pLcS5RTQu>uΚ+W~+j;8|<*V',!dU{fl %}+s$O Mc%xKQ2ŦwޭjKȜgM."i7x+{$ 0Ce*37]mBv o M'%BX4m?\z8Sy|M:)+z7Ŋ"D,}cfpHră#+4&f>-ܥ:"]np๟%]UUNfƃ VHNn4XpڶֈS0ic*y8m<$8_*X ÀIh 1^%-f9T29Vc0"qU^&+b0GbËdj$ Abhh^ ~,T1ƕ0Ț*JR!v{ir[hx[56h684 y2mG3ZcI"[>c7+W W^Zu_9@s.HWZJI; 9PU [S ra#ʩ'5 )9{*~5O<o^& ŕH/?+J=_/ݓQʹQ«/_L޹ik[8tHz?ܶ `K_>+u6g"~χ a|C|2anjjjjjRj%tX|5ć9#fjjjjjua.jbjHM a|C|X2aojjjjj؇Rj#t8|[kF:ܚnC k)5PSCj:gM>ÖW36`6`6`6`6`5ذb6L16ý^0gã1ذb6,16óYpdë5pb6l16û]p}3 ea K,HTv2&)~}e?ҾxG)ȠsL"}qMs8nVӽ:F$jX ٰPbA %pf%/&;h!ΗP%jz upX%$pLGASK@L¨%PbAKIpX젥KpI)aqes}rl+O^=>z؜;]^2]tfÛ<vGe8h%[0u74 4E@x6)z:6w=*f[ #/d [7괁2@)Ҹ 7!-D4HEP.(ce-/ߏaH ,*#۽{_@l%{8j`8qpOȜ~eu'mn[RRV McoM*o GBi(p6Mz( -簽r}^6廔RYZmJC(@IN6Bb3[:.6z> "JY M)U;fqVIIN "laZL'2lqi)aשYwۏwO#-x'ΕOce̞ĜA-՗o۹i>1A`DыB{LW G T7lj弫ؕ3gЇcV ҆m6--]أ}}/+\͇n~mj,6W-NZh5Zfg̣[.$ՕDϙ0V&vqI5bJ_ssehњGя=?:A WTN_Oy򍫗vw$# ȨʒsrrDzby`ybyayc~dte1>g,9Ȓ3F,˂eƲaٱTˈe2cY\ܱܰ~9ueItbyaycٰX*3TM]YՕ%-GnOT??&SZ?Go,iludo?ɒihʒ򙺲$glXvz$ PK㳵 35./AuthenticAMD/AuthenticAMD0800F11_K17_Zen3_CPUID.txtTW6}&VFqb6qzՂ ȟ~}|yP333cR2޴j%x)H}@HBρISRe!$Wm]\6}6=;=˘\o%hF D&vgçc<0YKsWseOd|ݑ"B&~y RG`{A:OmUU!IX1Ҟ%ɺf֬(rQ<K*=kJqeDjѴRt?rp=Q34Ul2,ְj1q?8pz})<,HImI.;Ajc'w,WhZtwAE՝-:tM!1BSwW'H;Oio6pqo&fcJM& X揚<Æ{*HYbZkdT ƮgfGEM*HhVsKTNDɻ%g#dް0 F\#ޱ}Ky M_eIȹC÷zvM,*y⌕ERF.J9/C*wE HQ://_ 0uP?3y_xT#_F&tKJB+PT_QA\ND&(dLOݒ,WI9|"[RR@aTP-Чƾi8 PJ_ex5Y3T#A(oW R@Uw*P~}Z5w#yv߻0@s0uH2<"rꜤtDˆt[N:%ne>Q }}\b; -_c2D2s1W"fk,[[ X (|px#ޏV 1*W$W*&먿IZ{|knqoq ؑ<(! oWPD@gNw)?{-PH|U=L=Qy=6o<;zDnfI[t K *T3eP @>'1eD@JLKxHw߰ELX%L'oT &{bX">=/s퟈^.C pI,ITpNLHqt,t+5XrfbIfYpx5l@tz@%&u:i)ݦDmM nCR{ ^BXfQIi"=;6a8$;K{wj?q>b|||||З"ҡS5P5P5P5PC15F 0a>lK|pS5P5P5P5P5S [*5Pþt8N|ɇFD:\@ @ @ @ PL TN ^WCX:P7>2wn0+>yُSy0femG~rs;FW/"~94a(Q1ˋ"FтXV-mr zT+ʂ"-Q1-3Ne??pGq4_^qF${TH)5NcH?{tnjiu8ގyB!Zs޾= "#@' {?$S.Ȫqydb2f 6XS7SE?ls;pf#{C>F{ﳑ#*TXe2|Yhv!U/l{h^-䊹zpK\Eno?(w3)_4邉,ӵ2ٍe-k=,vR/)@EK0?h/#(zK‰%X%ʧnˊeƲc9%9iɀ3,# ˌerbybٰLMf iɁsR7,˄eƲ`cy`YjIȴTUG'1͐黻S1(Ayl + 06^:&ԇTcm:x3$fPM]֙dvNHq3$m3H :ըG~k f?2Z8,0NY Rm8?lfRj^>?CEsJj~'AvnQL%aUM1Š<c@1bAT 1 ɡB~GM?s磘~F$ GnJz'؅z2|{Ec>j!< \'jKry1!#/6d, W߼*6 ?_7%LeYfHUkp~UAk:6wgp5w?7_ jjϞyl%ʌ&bv߿y>sM>ÜK35P5P5P5P5P20R515ڌ>l!>,5S5P5P5P5P5lC K)5PSCj:{M>ÚG35P5P5P5P5P1԰R515ٌp>\!>lp5S5P5P5P5P5\C [)5PSCj:wM> o-7ptCj<|     EK GB<,S/7p7p7p7p7p2GynXJ֠2a     梀-3#fnnnnnean؃nH     b- 8b2aknnnnn؆Zn3x؛     +;#fnnnnncannH     ئ )#fnnnnnkannH     . Xb3 nk֠R , bX2 n8jR . 8bX3 n8kΠR - bazinXK2a     暀}bψankRamX  xؚG-7ptCj<{Q@ęG37p7p7p7p7p1n؃nH     , 8b2jnnnnn^ g p7@@@@@EW wF<< Zn;xx6@@@@@k0ѐDk46|`!og &qC>k${h0|Hp"^L4FFog &D\c߆L4rC>k-IUx>k$w$5x>k0ђDk46|`%og &ZqC>k,&+Fr';E 5wfFog &f& 5'5#L%VaܑD(eD[ݮY$& 5hK5#0h)0|H}'\ʱeI ïRUv򺹶mx1rqøc|\6xi~x9Go4]0NV^N✷:W߾zy6?g7╯>rLw=^j#/!C@,ۤ 9g;M$ڑ:IvY)wԥ -܊ E|2E"C}eXnGE_(2qMZ?ݫY;z/{?YJrWS~hgT'f>%zO<̗ï?(VIys!?hBi SΔ_C1>>>>>Ð00#5P5P5P5P5S0PC*5L15t>>>>>Ô00s15P5P5P5P5P0R5,15tK1>>>>>Ò0k15P5P5P5P5P0R5l15t[1>>>>>Öp a@ @ @ @ @ Ǧ9SCp*|||||8> !?,=^ ؀ ؀ ؀ ؀ ذ76,؀ C ]ù0blllllKcÚ 05;?????%?!?l=õذb6,16tb~~~~~[?~_8<,qx=8<9  5M`/\wwbg\9fԼΛq|;%g<;!?Q6fHεr߁=sQ'z9ʇ3i_#}ptι&%iM Q C٨V`kg7@s]؋erĎcUƓ3q|򟭥\_G_`(Râ瓲 a\̛d <˅8gf5~K}妩0RH1FLSm'NL{ɶ)*$ 3vPfeU8r4H b])]k<7 q$""CŘ8BlPu{, lA vz$aT\bPq"M2o8)&#!2$Ĺeː,++W2zLŧRqq$#E`(>:rRħND)5F$6IQʼ> !cU$+"PvrأD1D9#j֨w4CP`:bEԤ!#K/MV!u*RѽdSuYY֕, Y(UVڴ[3WR_f-|ﮚzzh~"` ?qq+Q8cYz٬VBxF  €V¹$psŨ6؜PNMO|0hOvtvu*V3LWulZl;@b1)4Ӊ_o7=> do`EZX,=#0![QsJm&^5ş%,lՈzS]UN:ȕ0| KGz&dv=BHC7ےLXf,G&֩Ρ,Y;W,7,w,+'7KP4_=ٸ5%gJXf,, +; Kg~㻤d_kT˄er`baccʒƲaٱ4*giw?k(Kz?[zGHT??&Cz?H~:dO? eIg8%1e4%Ogɒ˅eò<4%Y?PKw4 ]6./AuthenticAMD/AuthenticAMD0800F82_K17_ZenP3_CPUID.txtkPB{ι?7PBYR\ZYHMu1^|(t}W-%dW aNrEUܕu벸LXVY[IWLGF%I)sIZ0'Z,}ܗMH׃8CۚI cF&۱}0ÅDRȼŮ %!gHiϋBSG=EH `v99Ff~Jrrun]oVd?>p2&P[)+Ȍ0B+ ѶsQJZb WH v@!!Cd-__|mCQn`d{ݣYY$MM1IBP&! D! dR!H '`Q>$G< kG!Dy$qbEE!Ĝ!tK%=-obH;,^`{L-><hP!IAvyIF'SbS@V,O"xԽU~%)aZV7ZVw5U*oZbsIG'o~GG#hq Uy*ٳ8-^>K2i$@S0(=((((bEMP,!PX8#8#8#8#8#ɇ+PPPPPZ@@dM>,{i1PPPPP5AGkFLq'PPPPP 5Aq@eqM>lQw1qPPPPE{P@QŞ1O h 1bHQQQQQŋ(b Ȩ7HHHHH{ZXcHQQQQQŇ(b ̨/HHHHHwZcHQQQQQŏ(J 0$J@A"& DQTWHwFM,     ~BcH(((((ڋb%X!QGMl$A$A$A$A$^B$1ˉ)))))ړbGXb9qIIIID{I+IԒD^NHHHHHў'R%#ŒIIIII5D-IqIčHHHHIq#EQR1R9$ xN@$QKg\y9B @ @ @ @x!EQR\1Rl9& xO@$QKw\y9A @ @ @ @ EMR)IIIID{I|' N%D^N))))=)~HQN#%|YB1 >F$9Knݐv̮ dn@°X鿱Kq(P'gOpF)^5{3Z8flSq?;{g<>#tрE3"}FݜQ9c=ъ9cq?猫XqS3Ry0#Cp8gzrgpXY'9o}VϞ=GCϸ깳gqS3J-X1B^:r0_%bF[ [Q$?^t]|ŧO>nz%I=zv}̓{&Lzٙ?I44u/޿~84#;O>MX{7K-UqkCˤ9\O(m{5F;;j<RW*H =ψH¶+GE_*\ZkH ]}bvi%!u8rU"/#HA 'jܼ\k';j`W[ЪЪ+;$L0+"wa C3pp4L0C´oaɩ[! C?'K,LAVÉ%KiҎB%;kN{) @O)'HVWQ&Zūu$mWN9B<%x B|&\giVJ9N,* Z vY,ʅiFN n:~PKg366./AuthenticAMD/AuthenticAMD0800F82_K17_ZenP2_CPUID.txt璛0?æ7C5-9&֝ǐ^uX6Jy#t:loWaxMExç˕W._ am&يe 8nٽ{=RI\,өgvYm7,[𓼖H/%`Tmd;f˃;m:d3У+%Coٚv۴F\P1640,[f޼m;.S #y-nt3K\rGߩp@e+c5T~KqIݎvm7j{ X46lFoЀE}y$PAhI"y$Pz$cIORZq*D4Ϲ0Iy. Ey+ef)'Ӑ8s6003x1nMU}ԆWx|Qa`=)Ty^՚B*h`Dzю˔iJ_1)I`Ls`Ot-o\*CNOvXUF'/୫HPRhΰ׼6:;(BdK>i500I*@RcGnT.l'dl*9O_-C_86ښ*Ƙnm-=w:j*`թՇ!%K38'6LE"GecW,҈JRQ]$IQf$NV^\ԇ$a _-7Tmͪ0}i$wۙMK B\J\C !O,'MQ TuV2bXkifнy8< C )BPYݤt)U8LH{{ЃN=hAsEiEk(,__%,slGPQ>eD9\&#둶'qYk=E`1,Ge3YLm$LhCbfLlbAa9,!2Ux-B&怷$,ގ)]tW}FH%(BJM!n5L{v-oahP^W]QOsE-qroسiAs: @=z AڃbzPAOt<>O4H ʈe[);1-Cl;1Md&cZxw@[c.*z|B\5Lo?_O!duNDPPG4PYBtzHL M6L2SSM S7P/Pݸ# ̢D{vmlQ>/܋UF?=(f h &(b bΈ#8#8#8#8#8bK9#֘#Rcbm Xk((;#8#8#8#8#ሥ#8b9"5& &(b͈#8#8#8#8#8XK9#Θ#Rcl 8k((;#8#8#8#8#ር#89"5& &(bB3f     kA$$Rk^DADADADAD,* XB82j     8jA$$Rk^DADADADAD.* B83j     8kA$$Rk^DADADADAD-* 8BjbC$@$@$@$@$i@bXJ@$$2kbۋ(((((梢 +$;& e@b cH(((((b) X()& mHb% H͉=)))))b/J Xb3rh/ 8$Z 5(Ԝ8ۓ)))))΢@-F%#' kHb% ؃H͉=))))).J 8bX3r^$A$A$A$A$kI$Π$RsٞHHHHH,J b2r^$A$A$A$A$8jI$$RsݞHHHHHI X)IIIII|$Z 9(Ԝ'R R R R R|)) e$ 5(̜@ @ @ @ @()bȉ$H$H$H$H$HbkI$$RsbmO @ @ @ @ X))K$H$H$H$H$!$H J"5'@ @ @ @ @()⊑ȉ$H$H$H$H$HXkI$$RslO @ @ @ @ 8k))Deȉ$H$H$H$H$HjI$$RsnO @ @ @ @ ))挜xIIIII<$Z 5(Ԝx'R R R R R<))xIIIII$Z =(Ԝx'R R R R R))֌IIIII|$Z 3(Ԝ'R R R R R|))X u$ ;(̜X@ @ @ @ @&)bb3rbi/ X$Z 9(ԜXۓ)))))֢@%F##' mHb% XH͉=)))))b/J b83rh/ 8$Z =(Ԝ8ۓ)))))΢@#F+#' kHb% 8H͉=))))).J b3r^$A$A$A$A$kI$$RsٞHHHHHI 8))#'^%A$A$A$A$A!$HbJ"5'IHHHH@%F9#'>%A$A$A$A$A!$Hb J"5'IHHHH2@E} hPu t+ѵ cR"k7$@x@@&~.d, ȁw\w|1Ń[#u'gR5}'XooOw}'Yco D -0S5\w x~k@x~kh~ъ7᷆&j(>uS5\w|1Ń[#u'gR54Q`V 54QdQ|5B HP#Lq#p݁DkA6kE$F+ބh@~k&{W4Mq#p}X#oԝw5J"x'x~kh'~k&ZhFF>Ń[#um(ŋ[C-HcV 54тD5Fx 7o w5BcVkn@/.K7"[*T\fF/W ϒR 3Cdޭ7#xc>>$C^~FD"hAc`|R9%FYH ?b@Oi D#~ȨBR%YKWLiXBt? !Ť)i2r*-$`. 4V:AHF fBlТThCiU,G"vs"q-nn*cQб& ~sKd|D]II@Fa 1Muݶu[5#bՒ2e)Sȴt2ޕi#XƱ,#FLIHDbxHz[i_YRUħ^LBhQ2B7F8BdR|9@|H1 ["lJ-`! B.T9FH+`Pr-ail.&iTYzcDeGw'pM> MG& 2D&wˊ$UY<]oZ*cj&W^5ZмL7Ш7o]7v;th:8>ޘ'+>]΢~%Np݁ zg_?kl[AzIPU&,;XNI0SC3laθ+ZO Xa:^x Pv}k XazD 1)/o(w<:vʔ%0œ3C)f}ݜ@( & 62<`+I*p~-}Wg-3Jŷ iw-[sT>}A=d84~LFG`p* 04f5ޏԻK\dp\̨O>f-]DJ`,y=Iɔ2zM})h0 L,Jۭf_ĞGE9 fWYDǓE*d:Hd1'a 5#xbF];gu(*\ UI:nf'`V E C/RYoKB "б^^~5(@@hץ &xvt:T2> } H$9YR{=qFLc]2hΠeGm_DLg9 D2cRg. ؖZq X*^/{?tlV75*\u]p=3#Y:*4F~>ax;971+]њݏRvPPWa;4|'GD|x(LҜAK]30(8JI j3d(гOsS1eD> 1/f>"})f@|1b)!<1o]:.؞6\">_ŭt#4@ 0ܑp4qKOHU`̷q`T*ntap^ V)↯zг{U۹gwcWIjhUCVC'ۇƞ0|zj!&aχVrzF:bjjjjj~RFL Wa>>>>>|'ć~#bjjjjj稡R5̘|||b||9+ćq#V15P5P5P5P5P:j@ ;鰋v>KYG U|%9g){JݽoPaTC'Imڵb@!E:pНGu:oHzDG{ffJojzTG onf{fd,޳ˣa5]mv.bٗaaX"9#DrΜ,o///2&P>g?]m6b O$|o9 %X PM"KD^Twل.eAAdY 3JH&=|PHFrl  &dQ E8B+rM芌CAT=JLr+)[˞&)}}xCdȔ xGv(iZӌ8*./3'2.P2rp=X68ǑQWbm ^nDkRW&Ed˧o, vpcpG7ǻU {@ȉ:.bEDYe (9v" y 1TlL'R=ljB %s&0r8ï'O%-zr1;=2v=·}<һ4GG(t Q&&3I(362-[Gh΀ؗN BU< Til+2Ri`Uȁ4̡֩,7W,7,w, '7GZ(KGߒ쏬}Ȓie2c`bacY<4CYn,*A=%~Sf, ˄errrrY4%q?ӉeŲa٩f\4 eɟ~9%i=%ɐY$Kz?kE䷟ eIgK8%3XX^XXV,sL#YPKBhl?./AuthenticAMD/AuthenticAMD0810F10_K17_GreatHornedOwl_CPUID.txtr0DSP@7&8u{(*bTZgZZT됿O~74Z_l }5YfF|^ޝUS!|W<;(V8mIh MF 3ڔ&Qz<_o߁ d [NIY]0E(i!"Q.I${$rtp鹘k@i @EfDi `5ѱo=2|TdA- ol~Y"z~=tR)\Cb$LbS;H0N$RKb$8>6Ϧ0sXsBem]DJ/ F)|%IG+1C0#a<9,fC Dj:ڄ -Ch]^cNHDBsN-( 40@ɢCRvd0 @ U3B Ytttх]$qB彗"Ic"*c @H@:Jb @'y{t'uPLh M[ԙm$x#,y Cn ,X^ 3Eau05 ޿ǍgLo~|$^+ȫlS^e NU'mMV-'34eA?궻cGYH:>}ڒs;y^?^`768ԋmCv͡69 #gtA#_!q)8o=(P @(&(j bB8G#p8BrbBP @(Bw4jc1az#p8Ga GN9G8b=(P @(MP (t 8G#pn)G#Z]LxP @(z @(: @11ؔq!lgU\e7QeM^Bb9uU^ c1sT1;wc|>g^i^+ ^$ g_.~DSXןޭ%9K>J( ,GWbN7iLlxdb_0 UQpU006uAaH3A Ld<2bOcQ>\R < }|f]“D)*ᷣ"Kq78GD&,IGԳW)!V #1  Zm6wdĕLL)9uniA7ӑPK|k/ p8./AuthenticAMD/AuthenticAMD0810F81_K17_Picasso_CPUID.txt]O0G-|ܵI @^6hU;A_BSpVQl+[9&IʞGM=-^'b1}i9UT d6V x 增582MʙqVY)rF2XeFFC1_ϫ庞NI{SəN >dh lw  8 /1LWI JO2幘)1PdSAΛ@d@<R˟u&ooԙ{&|._C3l\j͈I 4%TΞVK aqҒ1-vV164fm!^ᬜU%\VGr:e&33cf AqS^T W9X#EuCcr=y,ks)Vn,Z:sQsJܻy>}R ؓI~-цf~O>m}ۼ(Ӷ1> GbR9FҒVx7)"eee) u HY]=)4#G4iB :bLԾQőFh1D_x6:A!opFx4CY?Cx +K(m:âpx2TW2}Rd4/#^vb}4$OeQgVM0K30Ux)~R$RyjHl1E(@ A $=hX` AYPI[kH2ANktJj4<&l-)/MJZL['1#$inPK6ӊ-9./AuthenticAMD/AuthenticAMD0810F81_K17_Picasso3_CPUID.txtr1{T*ô )ye{5;;\??:'&:߹;˪Jɫjdmzwz=zдG$H">]F)&5)ɼJ߿ȕ)=zxͫX(H[E ]hX(cԂёͨHEEv+EV #8 Liq9AsRIeT-9u5q5yoo4mRT`Xoɋ04UNFտ}]qIfuZiwg<˟ιdnSRL~U0A N )` x[` `=TkjUQ\ ~f'kU41X\QO(-R]T*Q"EE)-RU"T,RJP$qzj9_1T|b< PI+ᾘ=Si_%>%`ii%ǃ_:ʞJel6L֡ 0 ltɊmq8 +I+@{{PK7P*)5./AuthenticAMD/AuthenticAMD0820F01_K17_Dali_CPUID.txtY8?pQ=U"K& 9'?it!Or{D|t-Q\'t yOsr _NABdT"^z);8˜Cgh,v|Ed_jJҁ@*H*N J$t7?Nv2h`X@ 4 Ds@G6BbK@7B Z1 I-=)X{˘LR؅w!%KRPB^dpp#2|F [cV%pM IO-%2*(5KץJ K)^Hq'%vM(2jI|t{%4#q6Ϳrw|Iow$b!a3$j Mwk-T!lrVdBM6Af[AI܏0#U Jj̃(_Eh*)pz 2T*\ i4փx;kPT\e 2i?-(`Ȼ yjż>yW+7+c4f5͑mnwM1U>PKiVh5./AuthenticAMD/AuthenticAMD0830F10_K17_Rome_CPUID.txtQo6+;ivαc'y# ˕PZmBV  RQ @`tLAGFgYdN1rw:1G k > x 0.8<:VNO]' LR4 `qP2TJi%ՃQ ZeU+a8AF#uvűHXÅaݬnУ,5I*>1E: QdRtW8:rQ+DمNdyd 5*>7dY%ҩ52'(U$i,TT*c*@6"(H@*Jb (,*>CS%}9Tr٧CSt5}I+y\SL L>;;S3**٩SӠGV!fY?.\UWM~nRow^ofKۗ~sp6tBrHźq_W>}ĥ^g>P׵3N \R3P3'j آߺuY7X7.f˺˺˺˺Xij>q/!n%."."."."."E[+˺CuuYuYuYuYuYumں+5r;wD\E\E,qqqw|Fh"qwJ 9wg]֝J;e˺˺˺˺˺;5m]֝_YwsxEܹs3BWVȹKVX7un˺˺˺˺˺Yn۴uS S3n<%qqqqqݟ:1nM[+`7v%.....fݶۿ\#ϸGqe\e\e\e\eܬqgΌۤqƭtO؍ݳ'....n'춍vAbxƽJ{1.2.2.2.2.f{=#ta&;}5n{.%ؽ؅]؅]؅]؅]؅]ؽamίV g\M]qS3.2.2.2.2.2n2n]>BM)va7`7e `m쮯}<2n_b>k\e\e\e\e\e?#tc&}5n;.%؅]؅]؅]؅]؅]`i+즮F!rYB.B.B.B.B.!IȭtxڥݩDSVKKKKKvS;C.%ȝȅ\ȅ\ȅ\ȅ\ȅ\ȝ&;|Fn..%]ڥ]ڥ]ڥ]ڥ]ڥ]]hmHkݛD.[!NOSv'ڥ]ڥ]ڥ]ڥ]ڥݬvK;.5 ; w\ȅ\ȅ\ȅ\ȅ\"w~k;}Fnn<.%]hviviviviv].ﴻH+CZr!r!r!r!r!7AM"w IwxJ.....fn]iwtwȍܽ;B.B.B.B.BnrDviW....nV?mZsJCW#G rȅ\ȅ\ȅ\ȅ\ȅ,r6I{h]ڥ]ڥ]ڥ]ڥ]jݶۿnt/ȍܫB.B.B.B.Bn׃rDM{h]ڥ]ڥ]ڥ]ڥ]jݶ;n_!C w r!r!r!r!rs}>?6+r+$1n<&ڥ]ڥ]ڥ]ڥ]ڥݬvvIxKC.B.B.B.B.f?M$rȭtڍݡD....nVvIwxK;B.B.B.B.B.f;>!In[!NOSv'ڥ]ڥ]ڥ]ڥ]ڥݬv'mZKNS;Cn<%ȝ!r!r!r!r!rȝ$rgVH R݅vivivivivi7݅vnNsBn<%]!r!r!r!r!r]䎐$rȭt7ڍݭD....nVvIwxKC.B.B.B.B.f?ȝ IN[!h7v%.....fݶ;Z#G rȅ\ȅ\ȅ\ȅ\ȅ,r363r+$ݓvi,IKKKKImkw}ݭFҽ 7r^ Y^rmgVH7]ݛvivivivivi7ݛvڽUHS;uȝ:ȅ\ȅ\ȅ\ȅ\ȅrA M"7}En;%ڍTDKKKKnݶۿnt{ȍܾ=B.B.B.B.Bn rD@;hw]ڥ]ڥ]ڥ]ڥ]jwݶ;n_#鎐c rGȅ\ȅ\ȅ\ȅ\ȅ,r;63r+$݉viw*DKKKKDmkw~ݡFҝ!7rΐ Yr$rȭtڍݥD ....nV vIwx]KB.B.B.B.B.f>= In[!nO[v7ڥ]ڥ]ڥ]ڥ]ڥݬv7mZ[NSCn<%!r!r!r!r!r䞐$rgVH?ڍ_vKKKKKYhm;HCQr!r!r!r!r!7AM"w Ix=K{.....f{niwt/ȍܫB.B.B.B.Bn׃rDM{h]ڥ]ڥ]ڥ]ڥ]jݶ;Z!C w r!r!r!r!rsȝe:mWVHsxM%MKKKKKY&m[;n5nۗ \ȅ\ȅ\ȅ\ȅ\" In[!OCvڥ]ڥ]ڥ]ڥ]ڥݬvmZ^qwj4ݑr)w,QHKKKKU(6>+Bԝp7wNYN8wwM5L;(w\ʥ\ʥ\ʥ\ʥ\*w~;Pn>+B]p7w.Y.8wwkDݕr)w-QJKKKKU(w6;}Vnn(Zp7wYsww]kDݑr)w,QHKKKKU(woS|Pn;n Vn(ZԽq7w޸Yލsww+D_G (r)r)r)r)rsur6K֊JpwqwqwqwqwMswwܝjDݞr)/QnOKKKKUn(wkS}Pn;n<%pwqwqwqwqw.;5H;(w\ʥ\ʥ\ʥ\ʥ\*w|\M[-NS w']]]],wƹ;.5L;(w\ʥ\ʥ\ʥ\ʥ\*w~kS;|Pnn<.%]pwqwqwqwqw].︻ֈ+SZܕr)r)r)r)r)7QѦr)wjQwxJ.....f5]ܝqwuwʍܽD;R.R.R.R.RnVܳMRAբwqW....nƹ+]{Pn<%=(r)r)r)r)r=^m*rʭuO܍ݳ'....ngݭ{T#^OWr/ʥ\ʥ\ʥ\ʥ\ʥܬrGwʥAբ{p]]]]]rnۿn_!S((r)r)r)r)rs=e6K֊GxM%MYƹ;5nOۗ(\ʥ\ʥ\ʥ\ʥ\*T.N[-C w]]]],wƹ;5H;(w\ʥ\ʥ\ʥ\ʥ\*w|۷\]>(Zԝp7wNYNswwܝjDݙr)w.QLKKKKU(whS}Pnn<.%]pwqwqwqwqw].]sRn<%])r)r)r)r)r]m*rVV wqwqwqwqwq7ݭqnKSn<%)r)r)r)r)rNm*rʭupwqwqwqwqw5]qwuʍܣDR.R.R.R.RnVǣܹMRAբ{p]]]]]rl;V#^OWr/ʥ\ʥ\ʥ\ʥ\ʥܬrGKʥrEwq.8wqw}ݱuώr) {vKKKKK9ݣܵMRAp7wS w....nmnq7Ո=Sn_ܞr)r)r)r)r)7Q֦r)7}Pn;n<%pwqwqwqwqw.׈#SXܑr)r)r)r)r)7Qަr)wjQwxܝJ;.....f;5]qwugʍܹD3R.R.R.R.RnV_ʥrEwqw)8wqw~ݱF])7r宔KKKKKY宏r6KVV wqwqwqwqwq7ݭqSSn<%)r)r)r)r)rm*rʭupwqwqwqwqw]wܝkD݃r)(QAKKKKU(jS>(Z=qwY.....sww]jD+r)*QU.R.R.R.R.R(nS;|Pn{.%ܽ]]]]]ܽ.︻VWN{uʽr)r)r)r)r)roMRAqwS wSq[S.%ʥ\ʥ\ʥ\ʥ\ʥ\6KVC(Z=qwY.....swwܝjD+r)*QU.R.R.R.R.R(wiS}Pn{.%ܽ]]]]]ܽ.;݅S.]r.\ʥ\ʥ\ʥ\ʥ\ʥܻ{\M[+)wq7p7e.︻Ԉ}\ʥ\ʥ\ʥ\ʥ\ʥQ֦r)wjQw]J;d;4]qwuxʥܱDcVKKKKKܽMRAբ;pwrwqwqwqwqwqwj;V#Ksrr)r)r)r)r)rG6KVKS2z1pŝ-#pF*oW=w8gfOpF++NmhbFqcF&ZcULqF)^+O=0VW2+<+j_SV3z1p}1#pF*+W=w8gfOpF++N&jF [ažuH¥`f{&ZNJcQL9#njRLrF+ބW=0Q|3\'ևn[P<2z㜑'[FޞV2zt& Ň%#t=0ō-osF(+G= Hs1SoVW3z`8e聉fSV3\=0Pg)#u=iۊcPŇ%t=f[P<2z'[Fޞx3e\D3Fa|pD 37Ʒ WL9#ƷT<2J=0V2t?vLAuХV.=%K7. ]z KBoX]V.߰$t7. ]auIoX]Х߰$t%KauIR KBХV.=%K7. ]z KBoX]V.߰$t7. ]auIoX]Хc,%W0*޻B8$uwwwȩ9¬[F/?9y8rƮ(agG٭G^>xˊ""VGO5C#o~;/¼kuZQ& M E8y$U37 [!u\ٌ,IS)OI:btq3$x@Rbԩ' 88CAFQ"3#GzHftcU2TYeA~! ͪ0Ѻi (uTBقJ" :r-{D+lTTЅ٨!R K *sb PBĠk*aRXo,G| y" v_RnCRU g[\SB~֖sB݅@l.igv_P)u:8F# u2fbc[\tQ b@'o"b듖il\d.Ĺ阱ia\z]AW1&5W3خ+0 LӮ+Ж735&k&Ml5u&v2LdpEݵ._8\wx0N2 Ğ"bk$q bA,}s"bS9}$V"TJtbA, c2KHv:Mb!bOݔfәbA, k}nk+MlÞhV@, ~ҴDĮEn;Z 6:A, ~إ) vCsu؜1V uI80؏[ؚ2J2elĽRa,0~[dꥤCN$Y`g#^`,0~f摱]([1dk`.dž0X1c%Kjl}X9v`Vͅ ca,%0v&'6/Wm;k= 5Tk ca,3VөSݮ+Yv`A|}X ca,6-2V&>Uc!cU b\493X caXߤ{CƮҨlΕ,5ca,0Ǝ"cW"Kp`N{0X cc4Cƚ$ZfYG0X chdlT懌]iZXf/cX ca,yXi4.WweN30JY~X ca,rd+ijlyXZֳȧ ca,0v[W{zeԧ ca,0=^~ǶwuNʖv`ٝ׌0X;:'m]窱~z 3X c{ض2UccWꋼsh3X ca*Uc!cbAXrS]kX ca,<ԫUc!c)4s`Ɵ+BVN.;W5@v[&/6,@~ .%B iw55:+<65Y d,]w!d4*9@s6,Y d,cٓdl~ٳ;@IvtY d, Jw]I& d,Cv:#dU<"[Bv N ]Iw d,_C!;U..dwm`GvY dǐ%kڔȶQd^@ٯ!;FlJ9u"+ {rtf OZ"kY d,DFyyY}YًN=@Vt@Y d)3BV'=.d]S;Y d,L. RY+=d,@kFNrzٙ*٬}r@Y 5dzlΕE6l~ 'Y d,ӊEȶAceddgӲ=iV,@~ UyGz^=l.JRK@Y 5dEAy9Ujg@Y 1dw3Bt*5=N\F6 d,CdR.d{Ήl)@v:SUi@Y d?lۊJEBִԬ27d,@kZ#d)w- ;LOٱm d,@c^vܔ]dCȚUZcRL d,@kȲUw .dgڙ Ua d,CbT]d!d`\\g8@ٯ!#detY}s2M) eQn2,@~ :L{rY{٥ɶ|Y dǐmZjRs]d!dOOeYF@Y 1d iQ^|ٖAv^$mJN@Y 5d)'kw!(sdM@ُ!C,BVT,iPDž^Y dǐ$BG]dCL޿նN d,@kȞPʪw )@v,@~ YZd-j]F=loLg4@ُ!k+U)g;朌 ۳P+ց,@~ 5BVirY}YS%'H@Y 1dG=Bv$r. ; k-Ӵ],@~ ҈ݕ;ȲIRlȞH d,CveIjrYI!v͋jOY dאU#d46E6lT' 3m d,Cv+Y<]d!dd2%;VrNY dǐ=\R:]d;& Q)@Y d=BvR?.!dcqY d췐ΙطEl)Yb$@ُ!e&zCouodM>,@~ YNG 9" +\2NSY dK#dg"wɇiY<Y dǐ-UWiTKkw=թo)i Y dא=TѫjzYm[us d,@csl4̻懐]SnS,@~ T#dЙ" k:U ۧQ,@~ YI:"dE79e'R"[AeGrJd,@c63B|d93Y dǐ)=B%.E8YʪY dǐ՜NtC.ϔٳ+YiY dאIwwu :-ڼ?f1 cԁ,@~ YeDȶI{,Mj~#;.2 d,Ctw!;Ǧ^nI$Y dאݵEN'" +՝F>KvIZħ@ُ!;zsysUOΝfY dǐY.uZ,X٭85 d,@cȮ<[ z.#BvC[l- d,_CvJ~YyYc5i/Sj!kY dאݦ'Bv)I[.>*m/#@7!v>@Y d?Qْ&R]dd=MS졔@Y d?P*}EVEB]d͝i@Y 5dY5UdszcLg {zmkY d,mGMvE6l٩I2 5 d,@crm!+Yk~Y~ٵ *;@vBd,@k>5.dGLsU,ש4W@Y 5dKgm~S65f؝NY dǐMF).dgOD%d,@cȶrؤR.5@kTv@Y 5dg'{ -qY}~ 5"@Y d?hNl=Ej ԛ d,CVyvֻ;&\ONed,@kȮ#dQ"!d6JgMҜÀ,@~ YsIIw {RT; d,.-JJлCJۃY dǐ,+B.!d2R@ٯ!{Gʤed+2%mNcv\ɺY d,c!ۙ.!dYv@Y 1d]Fc}Yy٬[ Jۭz!)d,@kȮ)@VӦ33EVBBu ;PiY d,;![%uY{YQzL@Y 5dY ?N* w&ہ,@~ ٣#dG&3_Ew-M.7=Y d,JEnl~;@٩. d,_Cvq IijlTH d,_Cv!{tGGn Y dǐ1#d*B?PKm9+;g;./AuthenticAMD/AuthenticAMD0830F10_K17_CastlePeak_CPUID.txtTv8"q[cHۮ`kGS+僷\`U#\.(+\De 8eFKB8=F `|)+md;=~_w|o4+x]i`M,yY+\k8 eCJH9^!³ʏ9Ţn D?Ԁ(rxa1KdWbIV+Zf;@Y%i)$_RkY{߂0Tx\ n5zj4طsЂ$q|Ӡr:N \RTcjK\쿪6,%B0nb#o\@硉;1,nȦ& 0તRT8WxAm d-Mw]~4ˊ`HrAB'A.hAeiض84+!bOZFY! x0F|#CYAB59Qf!:=k+A`GN?0 "N\+yx PF&C%Y^efE% `|-VrR+bN:8wᴹ= [G)Ler-s{w)lc+aqvm2c4?|wps0Yu.AHFwO]2F6 k8ٹ _LT4\FT88 f O>~c (yؔ#0\a.[kA3M"ng{b0pD"inKZ52j1-̖'V9p #LH7VgcZJ0%8@]KsPψ*V` }M@p'Pqhzե_rP uL:jť!U1+v׍ ?A Sq!6PE^C Bb1u5h(T@5@Tq dj [I j _5 ` }md[AP_ӧa H9)9;n<5ѓ&\^Mp?EZ/ǁtktss}-MsI/'+(سwi 0EY9=%iBK-q?_~Ͽ~nϺJe]e]e]e]e] ۴u,9wD;wLqqqqq -qc>q؟uY7X7&˺˺˺˺˺YiNYkܩ?"TB)I\E\E\E\E\E;cE9rܟuYw......ܴuYwɲnsK q$qqqqqqk>qܵ?Zb5i]e]e]e]e]eݕueݩF#.n%ݒE\E\E\E\E\ݾ:!n[-YuI.....۴uÐݹF=3.%=e\e\e\e\e\=:3n ƭt g v$vavavavavavOmcvAϸ{JqqqqqN¸M7Zн.%ؽ؅]؅]؅]؅]؅]ؽamNY]kݧ?2Sb܇qqqqq7i;ke9߸Ղva- 6vawV!膡;2n e\e\e\e\eܔqЭI2oZA7 vavavavava76vaw^#q㎌˸˸˸˸˸I8{e=߸ՂnKavavavavav؍Mcv! aQt S r'ȅ\ȅ\ȅ\ȅ\ȅ$rM"rC>r%ݹ?\ݙvivivivivi7ݹmP#.!r. I. =D.|KkڥݵD+....nRkڥ)Oc\JA.B.B.B.B.&}'j;#^.%iviviviviv..yڍ5r!(A DлIBzIO{h]ڥ]ڥ]ڥ]ڥ]Mjl[iwt/W r$r!r!r!r!r!r>M"r|K7ݻDwRKKKKKwڥ8iwtO r$r!r!r!r!r!rM"rC>r%ݗv[7]ڥ]ڥ]ڥ]ڥ]ڥݷmݥBPqH!r!r!r!r!r!w9ah[-鎁vn(nHjvivivivivi7]ڝH#ܱc $r!wGni?Ƥvivivivivivcڥ%O[;AnȝJ;% ;}D.ȭtgOsvviviviviviv綵K[vIw wI"r!r!r!r!r!wD.ȭtWOkvפvivivivivivצKӐqt7[ r$r!r!r!r!r!rSȅܐzIwhwOjviviviviviwo[;i7HܣG LJܹIBnGn{n=K{&KKKKK{]ڝ;HܫW ׇܥIBzI{hNjvivivivivin[i7HܧO χܵIBzIhMjvivivivivim[iwt!7ȍC q5\[-@i7h7$KKKKK.CvIw; wL"r!r!r!r!r!w7\ ȭt#Xݘ.....nl[;iwt'S r$r!r!r!r!r!rGȅܘzIw;hwNjviviviviviwn[;iwtK r$r!r!r!r!r!rgȅ9Jiw-JKKKKڶviwV#n!rn Inr& k>r%ݽ?^ݝvivivivivi7ݽmݽF=C.%= r!r!r!r!r=>M"r|KgڥݳD'....nRgڥenj$ݫ?BU r!r!r!r!r!7C$r!7#^ҽ.%ڽivivivivivڽ.y 5r!)A D!m[/ivKKKKKIrk;@>0`;x:Qや1gra ҎG ib{ݚV8#njTORN3Z={3F!䌧0D 37 WL9# TLt8 VLQ|.3>Dg<߁sD})n=x\8gzr8gE1wƧo$g<wFD&Z~gz`x~gz`x~gz`gC&8)3R'D_4Mq#p1Ń;#Փ9/VOQ|3>|'9)3J'Z0Œ2ō;mŃ;#(ŋ;8cO=0O:'mwwqF('fr0'ɘrefffKђSX4& VVgc8{'i޼Z>ۇoP#'~+_|y˧͵p/O?P) 'ĮCA#"#cT>QȈw7f H#m.^֓k3tZ LRf,j)""4;%"Ĭ<Ď2)Q;D0 rzBI {Mi0ik;Hd*Z**]xTU*Mu 2O a.ù e$eNlY6$OeXKKY~GVj΁k,U5p} #r̈́luꚽjL}vVj}\kp {HYWwRUꚿתʦ֔V2%o55kf,k=;P^(5NW5򚛧ȵ̶n&P^;\Yזv='5Z#זP|׵N^< )۵N#\kCF\ۋy5g_r͋ldǿp 5\U=ވթF>vkp a7v&pZy8v|Q=E?p 55v$YZ$c竮wՓ߮iIkp 5syZUZCu7SW!ϥ~\kp =$\j15kkT:ZCK5װnJb\Ilꚿ$oLd*5א>p !Sr礬+rMO!N\zHY"f"krmE \^I2\kp y"זaW]K5m.ī߮9s5\k-vkN^kjB6s \+I\C ׺42?Z?Jg4d/\kpm<"$W]+v,V4'5װ5ȵp 5Z#׆Rcӛ~ȵ\#p$ev^v>UC~Z͢kK岯rAu4(Ov#p 5t؉\ۋ ꚼٳx3vmH5\kp kvWyr6vZz$z/\k[ZZdk72<4x'=\kkk=K\˕vZ}ǵ%vhu zmb\kpm"$W]Ӈ\ށkU:\kp 6w*k4=CeZ?k$K\kp5!k[#<:︶Y;m;dsfv#q\kjwZ{g oVA\\]sJ|,rm(.kk͙k \f\kp 5&9ȵW]KRr\2\kp 5Kȵ]W?W]w\;2;Ro6o$\kpȵhLW]fn4- \n;\S5OvqZyȵYyk%>p 5Ͷ#ײҬ2V_q-'Vje\k!C4kZ94k櫮C1i~v\\kp 5 55jkkݔ\sW*O56954}urT&)#zH \kp kV.%rMR~յk)/~V5Cµm%GJ,7]S~5W#2kp 5׎kse^u-=AS \hZp 55bݡk;Sޮ&&i43 25A^5I-tl\Hi]Kedrkp 55䵬k-5ӵia^E8f*sPf޾$pbgQ?L0_Lo@IsnmR,„{/,\ co<.W(TÈTi<. 4Sg$TxՀJBqP*bʼn[뻭ozq+GC+ZyϧepZН]7]vSW׀\V͵?scd}DȔR'SjXΞmV*pwV#"4LK#8挴mnmlM$bd$ @D(Meү)R o5<_b&4@ya q G ` "ܲQ ]:HW D(1*}ϧ4|Zbv} V:Ť 31oG#w4,B8ONj0FiQjFtWM kk4xDL{i!/ᘸĉJKF<&(yNWs-|pYv޵Gf sGVё{`͈N2VG4H *3s;QGSH* w!JL;  mw*I2$܋!!sۯMbp]4 y1ʔd*b2@6"(1d @*1 ,JI=$z}2#V"Jl޵` ISCJaGy5itI$ 6MiJVٝ:*TNF=l=[ ju[gЭ!ag]vTm>%ُ綆EPwö|9\<4?zG'7-4uw4h?eiI0/EfLi]{7] % ˻˻˻˻˻]Zlݡ_bPܡ:s1s1s1s1s1sWkܗ373֍zwcwc}.....FwSw[7\M%Mj0t뎼ۯw˻˻˻˻˻;W;ey7غܩb.b.b.b.bn}NOF}9s<6ݺ3ݹĻ3....n}μ.YM-/s1w)aRS s_5Mگwyw-Z߻˻˻˻˻˻+~ŻOx_w׹8w\\\\\֑sܐܦcww^^^^^x?! S{\=J{w.r.r.r.r.rTĹownsnӱ{ ^=K{///// ob^:s^˹˹˹˹˹{=:ݹ;9ؽ/%xxxxx~ xwGۿ܁@_/]Ri"09{^smXm@8{0sp^rZ#0'9HYrZcN81 ,5VkY 52Ik!7 sȈv^Ñ;u2HI9_L &Y ƤA05BA PK$ u;./AuthenticAMD/AuthenticAMD0870F10_K17_Matisse_11_CPUID.txtdTis8N7Ąεb)Kd+ȋw K~j=nai X!x t;κwMM 0 ߅Ec7Bv,K[k{W?ngHE*:U 6d.Gߵ^۹aRDk* l}qq46%+,/L9l? d4?ypp Bw;!-mX݇X31] Zݩ9aDxւjع_HL]Sȃn sp/9-_t]+67l|BhaeD 2 ]Q0-N)_.$^(+]";&8<,6c@FePMln /azh] MU#k==@geΪ[i}0 bjf7C6hn&xjM`uc7 vY6\U?Do3E>z^8h~ ԰kAA-qN9\r \6yd;.B;Co OcX#1@V-o+|/'f] W][`p%uw}7#(CpIzg\cPcmmq?qV4FЅ@$t9$@ I^bu۾]pT޼U5skk] L幥K@ ) wX Z{dKp_/(B ZK \*+H(/hEq۩cYA!d%/x6G`Ҕ 1ki~KjjH\4c5L sG6nچA,Y<[G`XਉSr6V<.`~,AET#7C  K(ۜI]/ߤ:)F5ڮHBN}u.j6ֵmbӾ\dD#H۠J@Bl/u5=5P5Pj @M dk WɞC8=i!ZyRB~hN4d:fJ׃#%oYxOaSbQU3SVC5a(Dug rx)\>;npiR*ioUݼj'?O_%؏*U>?ۣ;@5 9tn螊z ǵTc퉵YYYYY;c -ڬ=ߵv=Ck=C7tC7tC7tC7tC7t=7E7tCw,BcpGڱڑYYYYY;gx5ڬک]wqѝjНsN M(Bcp/=k/ڬڬڬڬ9k/WFf~-vB^kн н6E7tCRcpoZko9k6k6k6k6k6koWfm^ZE7t5snnnnnޛ;;8Ǹ؆G۰ ۰ ۰ ۰ ۰ ՠ&؆mwaq㪛u9uS7uS7uS7uS7uS7uy9n2aW7fC:BzOd݊%.pgF_K^nq'&z^<"_/|xׇ4D7\!>rOCuhxoC}DnG{Ӡjٟhx_]G }itϣ]ѳ?uYv^yI1:ßYs"î~N4ۧ;{vU2x?1ԲI(`(`J3Kf7 J,LBDk->**$|Bx hyP&QL%fTA=o!f8ԸHyѸ…C&iJ3IZz+ RuM tg3l15+1#\j-΀4TffP3pk ޙfLYLf fcs3ɢqqI=*1EUݏíȃ-1"e.DDcngg9o!_#L"$R`$M\E.$Ip D&q]IpKlKsRq)>]3x>lR3/n~Uz MD:s)Yn 2dcm.~ݦnC nJ~J.MrZd-TX+X+X+XCFK\`05E*ZAESbMbk4kR+8ǚZx= J&XATkJv)JXn(7k5T!Վյkr{6!k'xDߏ5YTkkk5̨7!K)XS!yl݈)g҃XӤX+X+X;M-LZјV@NR}| bk 0SbMotp,š<UV}X+cʹByrk53pJل> R?eۺ```m6^M xmmR) j)=\ %5MbEZZBD/'W Zpj0D>-p{!C\31mݱkkk^˷!&32l YZk>I6'O^<ة;vw*i8V֩ XX--ZO(.&o`ogOjzIplYS۾?1ά:93G#.ƨ%.ffQeP.fEp#eX>"ιJ%%is5XNv2'=S1/PK I;./AuthenticAMD/AuthenticAMD0890F02_K17_VanGogh_01_CPUID.txt]k8 v{$K%0) 7f;钸r$A !oH8{VE _0t˧~>/qsvW{ګ ?0wnF>%BR-u"I)kIJ0ixo/ёfh3ɾNǒNKSAB`D ! (@ATIh~3=NYQ1kxͷ% w1Y[1P|!ί͇Ut NJBpvߚ9>VQ1; "kA@,,CN疌p8[y ƯK<a7 Bø =bQX $I6Tχ5W5Hzp[a1T(D3*̃R baeT:g(MOPuԃHUʘJU T@M d" b H@I b 1PAr8URC c.5ĉYXӕt!8hW#g?k{TT*Ve*r*1UIB\㪟OOES;p23lܸp]_- ۡ>t9 e/PO۾O$e`:G/vakaݙNbZ4Ҥ>cMIzW!MR! -:;\uvwy{wsfznnnnn Kv:;8;r6gs6gs6gs6gs6gٜi[vsf{N Kw:;8;s6gs6gs6gs6gs6gW89\u]\ppnnnnRp7p!pcrή3ήٜٜٜٜ=gwlnWal7>m =ug(7Wvf2P]#6)gpJvPC>Fʋ%y> N}xއp-aaT20sޛ}R}w9h̹U+uD&뫏o_=Aӏ!P? q )҆-]Sڪsin ^,yRZg)8Pl# gd,mN&DԇB\y$dL2B+q.\Qd(P6#_!>hd+e: =sV`? LFSf++32Onӌj3 ={sÖYDو WA6 ʒ<HG,9lٶ1G ٺvlfr🩐!WȘC(.6S0"WH''8q6Xw"@r-?41i F뛄g]XIR!nEF"!_<BD#H# !<|c_+RHeB yZ 銴`aίnd!Ŀ;LjѲt (55Xӆ:Ys֜{"+^B謝.d@v'bխ@Κݗ5пgEc)ޭDL2vktֈB #ߗ5gYs21KXCVL #M&İ'bmURNwbYs֜;.f ?QX e'kBMs:"Q0-=n?ې[P6]h:]+8'9azD;XkRc,R sQu#I&Aj "ʊ,"&SU14ra D1@(L dc4rp*2h..ʘ{:TT@oލUM&q.8pgc**ɴ*9QYSE^%J L1=O>&+TӟC|a$C,e D(AUF @(P @:VcA(@{X`PgP @(t甃P )W(P @(X)`/S=Bn 05 pS @(P бS @(QG( QP @(+k^(8P7W5 P @(cxO9+W\ *F>P @(t)G{.S;B 0<5 P @(P б5 0` 0d0w ac` 0 g \G|e ao 0` 07370He pF0o\u` 0,e p09+e 0` 9o50k e j u` 0U ` "Xe 01` 0` 䭖`/c X;f 0` ּe D06.`` 0`-o0g `ac` 0`[ 0U[28j0` 08VG` p1 8;f 0` μٞ0X28"0UW 0` 0`Tg2k0` 0Vw` 1qj1` 0` [`x]` 0`wlE p 0>3` 0'0 E03.`` 0`'o0G, 03` 0߼708``߸ ~5 0` 0w+ sb>4 2< (о?H^ bZ-܀ 8lr4wιkȃ<'y!/KFޜ|8r$47ƹiȝs<y"OSB^捼9op>/|5?I?inȍsܑ;y CD慼8/ysޚ|4_j~ȏ<xܐ禹#w]@<9O yq^75hȗ'y>(ϧ!7MsG<8yr4oyk>ȇ|/!?OzQ^OsCn9wyp'<5/yiț|"_WC~87s<4O 5/Źițs|"_SC~57hȝ<y"Oi^ȋsӼ7 CE懜T-[R/V_nIuXݒ}}bu˫W-[^ǿVw?Hu~Xݑ#}auGT;RVw?xuQ{nqޚr|4wjȃ<'4/Źițs|"_SC~57hȝ<y"Oi^ȋsӼ7 CE8/yknȍܑ;y ODӼy#o]f8 _ۢs$5re2333ׯ3ʹuߧ`n4LÇ9ᓻ_[>g?|~^ǧQXIş~ocP栮\GT}Vb% kIɹ |M1MDWŒ;TGJ,dMbmh'k-WUXk`T ڐMZ~yR;jk3jy5X%ECydMbM}䀵Xk` ^k57Y+6Y̚zh` 5־`mNb7Y6xW:kZdrk` 5kUXJj&kk4j̀J5X5gX]2%9y*5X)b$&k!Uf>؊5X5j*T%~ǵyQ_ص%p9Qֈs픤pJkp 5vk;UCUSژkp 5fN3rMR+k!fJɁk[ %kp 52"j=ꚽZJrr eפL25\µUk/:p-"׊Q^qH4[o#k\kp }Z;f<䚏F \R\kp })6yuZ~ȵڑqwNp 5>pMJȵ)Uתx6:\kp /\DJ\cyZBkp 5k9q\t^urIx%-\ki5+}\iNn?v4\kp /\=G5ztCS\kZl5kc5W]KyMkkp 5kuEMü_uMrs3I57ɉL|յk7k11Hp 5׾pе>O᫮w\%.;pmJRx5\µK\MUCydIkp 5k׎\;LR_urmL0q/\kp vkk+٤cX\\kp /\GBy|յk5o5puTt5\µsJZi|?ZoN%pm꠳5\%tzյk'OjkG\kp zΑkP>&W]w\;yIk;Lf[\kp }1\tqյk^:5$pMG!ap 5>pmȵ]iv5}ȵ9^+pʦS5\µf5pkNj /\eS<\kp }I&fzյke2mq\j5\Gͽ]urw*IZ\kp /\s5$iU!. N\kp }Zki-/W]k։2jkZCȀkp 5k[ʉ\u5\Tx3o\k_Vw\[ض\u-=L< \kp O\['EMi~յk–H8k8qOw 5Z%eED\u>LJZLV5\56*%|5{ȵvr6gFkp 5k+ȵը<ˢ:e5%vMeZ{ǵP5Mskp 5kvrZD:tCy:bmT\ke{M.KY.?>pMr-uյk& =pM%?5j=?_ŵq^z5KJ]k*)1V?$\\kp !}ȵgNW]{߈ZRǮ Ayp uHO\+XhdU!촊5m5\EmOZyYrtxKڨ\kC5!y>&LW]fTzӘZ\S\{ǵVˉ\ˉJ~5{ȵiFKص:hxp 5>pɑk̶V[\(p 5!MLk!ת9SN^\40+:_NZ7ҝM?pNdi4Bӻ6,lhؾm6!~l&b%ׇ 6lvVS <J`9H&`|7`KZئ,bl 6 l$Mwaw`sa`;eϱt`l qVs\ѩ%&y66|}-%Veؒy`Ak [}(Mm:#جZ`Cb[",Kf݇ 6y܅#-el:엄 !VD)2]"ؖ*waw[+syޅflHl  sȥϻ`*j稀 = Js6Z [wJ]xZ؜Plh >&lzwaKV;Ͷl/ 6>͊pU]!؆23 ږD`l }7lmӲZ–MVVE`l }[[G#fq rw`:Z[N}6`DM\ǹ [y$l 6lp `+)>,waЪs6]Hkl a6}J#r܅6j) ̧6clؠ ؾmVt܅Yx2Ju`lKlnwaktqls.u?`lB_D+vr`Zwa~%lnU} 6Hl%N`[J) [z6W6eϔ+`l 9`;vu6y-iJlu `l-q%<RVň9廰`}l&Jo5`[nz:>XczF ذ a66h[+* |lfe؀ 6>]lmSVmCú&d&Ȁ 6" j6+5yg: bLCsaj:`5_6, 6f9_ۿPK69./AuthenticAMD/AuthenticAMD0A20F10_K19_Vermeer2_CPUID.txtdT]o0}G?\i/&4):b=@Yin;ܛt T#VV`0  |+r%|Bڭϓx63!g]wn=|StT$PŋT\,b:wB_[?F|sHt9ȑT㆔uJu}ϡCnXH0o@S܁k~;<8(r]g RYQv"e"yOpk<|Lr%^&Ž}SN]*'T f}Zk :<h {;k3Yk|jIJ$\BKWu78&v1IƄxp*4zZWֹЪ9v5 `^lNҪd+d孚5y(2$9,rlK!> M!5-_(5bwyfUw6T#j ˈ`=sYsG}16yMo[D 9oVm9dV;X*6%MNcʎhNyky.33ovTє xkPcZq68pي60Aч:1& 4]z=$@v $O1 ^JAt[u@:dlU +jp򱥰!S)n;A^7 !뮺9+ 8)E!5L$ "_UT/:0G1qp87)ܕw1b J*lr?{!d0d:!-Ou8ux5Ŗp8cCY%"pf`, Oii| lО\4L ڳ>}K=O/ ` <+Hя@O%wlL?:wDP; @Q'iq0>g-3>[j\^6WUbyiD좳cyCJK}H &[KuIKM Ԗ@]  K *2%-\ KP~`e'z8P~v jQHI olX5A_ /t>hyx.wME :QE{_:Gfjn8@ <h۳H n~󩤆QyG5w=~p,?H?vr2tɝO>>8Riޗ#=}XDS<Ƀ mq39=%7yp:8R}ɉ0єў?>,G$ H,X `,k8 ]"v%Hs%L;0( JOb%4x8?'1IϬ=p3<?[{g<=#>xBNtiFpHzdpϘ(3Mz!=3=ħW{FҳkOx ,0*g'U Kr0C]W;e>r9u3C/o޿r׌Ic;u;x! Q^N}zۗc셏>>0cܶAA KKi|:{NWߤI~~G{7ޅ`ka8N~ZdgXp<|"kdb-XS^kky/!LoÚGKvhŝd-Zi kf9Y#kLM~d-Ϭ56WDX|:ZK¿ adV笅 U"kd-BY?!YK֎f{bУ k=(b򝬑5l5sy˚ Rov55 " ]5vȚ=^;rܯ5A.f;~d^Z-K߰ZG5Fαf}T2AY+򮬑 7X[99ɚw!LݸP]ktk5Xksetsלsz5kUڀj)]kI{޵kYKt\+TεPУ\6sĕ45F^cFV~Z\hQ=5?&rqt 15F>F蚢ܺ&u-]䚊bV\ ]ktѵw"v&6{ZK(3\ktuS]kĴsM+rrԵ|k=6͜XtѵptAםkzG]+FF1M]+&jF]c}ka̺s7ȘkzkfBus/)5FkDFlsmtQEe*4ŌktoN^Kѵ>еw͐kaNm'] "׆uyZׂZ<]kt-5ktmCڸ]DG]6bsj޹E]^ \ks[?ZȵrqAM>5F>|ѵ 1k1jG]B$o\khykt5Fki w!s@(UvXo,j<@m5 ,Goj/ɫݳG>-MP10 ~x{#;;W6'8Z").(1EԺH ' 9U:йWX|B8k;Ŭ](#%3I+EB)THPzf`#쑿g'VAv-܍{!u`Own_g3U~;PK':./AuthenticAMD/AuthenticAMD0A20F12_K19_Warhol_00_CPUID.txtrtQ0g( C}Y%y+ J " !~=!!SKJRȓirhGF']bAۼ de}@|4!sDFP:"  ~ӴL3^,OD4E'抆es )t-0Z"vh#rlT7|m:ȚoM=>#(;(?3}3dҮ*26IC"@v^@J1%0nb:0:#~#3r dļ#O2_)4 4$"q丳D~H ?IbAfvAaAaa<ȃ<ȃ<ȃ<- AOAAA<PuFyAL<ȃ<ȃ<ȃ<ȃ<-S( S&SyAAAA*y9y9<    s<ʃ<Ò"   P: fʃ<ȃ<ȃ<ȃ o( o&<ȃ<ȃ<ȃA̓^v[Qwpݭ~3~E_~lgw\vw>M޶ލ(ƈ)$1)e#I r-Be<>ve8hpCD#m*[Y@A`A( ,PQL2J@sq<+s NgK>z Y4)kS2 }@& G ` :eq1]ܘh/3 D;*2 MZ)hH|~~f"w^uPRas+\"6LŰ-K0ϝl)afsه}p6M@g5Zm#>@>S.uqQhj >| ʱarQvL&q;Ptʭ+8폶e# p0*4Py8eڽ~y=YJ>2*p 8<,=uB@\ ݗt-:^@F+FBlQf(d<$܋QN 2Xun\B 7 *~on@TUuTLUJ:jRE d R H@Y R (/zPyI!a:eM$qbN9%/&~VL`JԤJL*oTWA%=G#xY3!!GpTʛ]vRIG+v.Ǒ<͟ySIw&RkKCJ~/c I!ɚ<)SO2DnSXJeT\:'5cX{Yc29}άE kQxZP,e_(5CYZ)ufX3֌[0xYm*4aaJKY{~58q-V \3̵76O<57txs}RњW/qv˱ּk\#?PK@H=./AuthenticAMD/AuthenticAMD0A40F41_K19_Rembrandt_03_CPUID.txtgs&?Wo*{rV|Jq>B.+{c=.CawqS`f}_ϿTj.F o8t3"LpP僗g6r0(@kCTJ*rBrNl7mzdFEz(C %T~[ VfG4HGհ#ԩ rtj |20 >Q)a$F 5Q6JyQN qz~JY#փLjLmև>5#$s }h>m~5[MtazpI$ |07;5)^M*UbP "O"S4wwCHnB|HG OCX5a u\uO| ʃe(8;qݍߒho?nhmZ8,6-x))~Gg aE%DR)K6һ!q@!fS9[;s8D8ߔyyyyyqηIorDS|Q|KOOOO_oQŏŏOOOOO*~SQ\)))))SOɿ݇sG6/DRro/M\MF4j4FA#hMd4M҈E D[/B@! B@SM@KCKDW#hD]A#h4FA#hDY#h4-DqB9׋B@! BwB@! !.C\CF j4FA#hCd4bL҈1E1 X/B@! B@1D!4(DLq5FL91QFA#h4FL5FЈ9I#K! Ĝ3"B@! |o! XhB#hDA#h4FDA#$J<k\kBBԫBP A!(]CDISS#pĖr8G#p#ph8b,1EqB9 S QBP A!(BwBP.M!NG\GGr8G#pGh8O∩qU q(YBP A!(BP q;ET A!4(:E\q9G\9q8G#p8G\#pX_:< q7|1kr0݊J2.g2IaC$Q>}oԜ:N'ۋ88q*CCk8wR\{Hx<2ξ]f5Hο]2H*h#]A:뺞5Wl-}T҃G6HZ#8-AfÊd-6Ii~_ $HԑZE ͋X j AGG(s$ @H(:LZ[DoTXd.L4Tfb 0z! d ԑ2rXȰJ KY,emj#Leq#C +Y,eTj}J$:HEje9|}?]&o6**TߟjЃ6)ѣP6MxK#$x_ ~v+IU| }t coVɳ6Sz S P4bDl+Ͼ`$gI= i$]?^}rRL`5_w*H~_[|vgMM +қhίԒ>}| }`~ʒ5VX3֨oV@ 5gYsWekہ2*?!uX`;Y&8 zm1mbYs֜5g$-YeZ佬X@,X8 0bYs<[K!q'`YcָdW;YfCby֜5gY;FZdMzK:H㰓t"0d`m hyvLCaZ.Y NyXKQ:΋lRPXs֜5g͋^,ƒ UdMOZ".Xk=6kΚE[}Q9kV1"̠r"j EHXKu֜5gm*֯r=/,am}GamٗEq/koF]tᇻ*H|l6!rMkڋ¦]W/eZ}U,5|y^kx,k\fК歮[nX.pהctѻ5L&ak)4W^ebқVZ{_1(C v=cf ʵ`VNH/\3i }kg|w$k nunKwFxf#G]62B,)s]s<_:&+uJn(鮊Vxc_#V&=k?kF\!vI[];R#٦ꮹk|YtM!ɉ\K%CW^k= r=k!7]szt1r PKb. b?;./AuthenticAMD/AuthenticAMD0A60F12_K19_Raphael_01_CPUID.txtז0@SA5JfFռa{i청AGƦ Dԡ+y6bWy;Ϊ)Na cW_)ǧ{i9>(w+y;=j_mmO|W? ېP o 7xo !7ކކކvxmFۺmLmm6xomyߍ?6mcmcmcm}MmV:M ۔T o 7xo )7ަަަަxmfmmNm6xom6xNommNmNmNmJGux[x[j 7xo 7ےےےrxokMۺxom6xo[6m6޶y[趁.xo[o[-7xo 7޶xxxxomobty[=xom6xomƟ;===>ێ6o+oH7xo 7ۑxoGoGoGo} /m8NnL7܀pn 7܀NpnLLL JWuyyj卼7Fy#o䍼7vFەەە䍼5a ^E!9bmffff8}B+wP\f|q+ 1Oֹ"wmn=ȑʑW/->ch*-9PSQmKp}t;rߒ1 uӎ<6| ⃍E6c R92J z}]w{.|񻽇5։׮x}{_fQg̓toϿy6'QnL)R  "o#JIJ!D rrA:F r<5 ;vL}"mKɕ2 '1ϥ8˙ӟuC\-|LqWö/f K3~:#G"<2j.Ŷc:O8yLPݸV%*=SڤV=]ۮ]dP^Q!!H mԹ[.j8{DAˢIGZI{/_#~x!^DTnۤʤ۸BGFIg6GlIv1erO>ϰ1Y*Nn-YV?OA9ӹL?/ r>Op;c+G2&aԌH0i͈Y#c` KyX%cX<cݝc=SI3o+fd 0c`wq".G2VXiq3q&3ưEE}ȵllu6-cRv$cD$6ꆱ2'l a6 06Z[eH#e+߈eQfVd610c+F0ö1Z-#pبsZRw 18X&斶iPgӦL؈O hQeRB*BUJ/lN:X1 Hݝa1+k86ͭ tpxA<KH0UI"(b%Bn3=hWEEa3y{} l= >lR@(w;XCAbX.ߖd+1EJuJd-Tn1;YstV1,N1~*Z% +$/Nq̆KMmhQL,Q-x͐+sG?yu@ >\4Q@z=*AFQb,,%\Gh?WpZU@-\eVs L"E3dqr/WygsF23pLQYtd#J*ܧEb 4=43#t)k! ogSq9" ~]Șa]y?_FDr肮N]pDeEIJ5õLqE!ʢq`f2)silAP6/ƔT@e T@6A )OD $S Ȥ@?Y&aZ'I'." fq}Ԅ;M0$gzL|D܏D|CZw"D0#[r p*yȄKt}B[ Y1l#`Ix JP@2R)G0g `܃DAܼ]e=IQO뇛AƳ.Qcސ{Y_h$ݍP ss6y mwɋv:RǮPnCQLI_K?&ެ CTBֆ [o 7xo [K [K%o+ݮ!xoJo 7xo ەxoWoWoWo<.x+F{xooyom6xomv6y=}V:=Cۓxo 7x'7ޞޞޞ6KގnmZpn 7܀pn ?p777MnV!yyj卼7Fy#o䍼7FۗۗۗG&K΂խ- [[pkK)7܀pn 7k1pkKnm -Mn[?Un76$o-V+o䍼7Fy#o䍼y#o-[K䭑mbu[p5܀pn 7܀pnnmV6Vm䍼 ۖV+o䍼7Fy#o䍼-7F޶D޶D޶D66]vWn;pnC'ׂpn 7܀pnm5 ܀ m"plu;y#Vy#o䍼7Fy#oG*o䍼m"yXN܆L7܀pn 7܀kAp;p;p;p;D[v76$oW"oy#o䍼7Fy#oVޮTyyyy<.]֖&nmHDnF܈q#nč7F܈[ݿAqqqqDŭnv{z'7zCo 7VKoOJo = = = =m"z[Un/q#nC&7F܈q#nč7Fj5č ۛۛۛK&_f!zzzCo 7zCoۗۗۗۇ"zrJgFefffIG[OUEw&jÖUs`gu6{Ro6ʑQw؍>}hˍ$ǰNqi#\$y=F>q1'A^|PN(1˃$ǰG p\jr9g>$tJc.ǚ\M$9FrS1Acr}1 Q.`gCC=uw_w݋w+;^g)ޞΓܼh)V8⓫*e(k?[ $44 GB .iAR)du@ A"zuL"S t!A6ٹ_-nɮG:H".Kyb UH0n#'\ عHa YufLT򦲳[Pla l:m`e Aiu$֑TG:V4dJ1vbp~p;St֦$66oS=xoe0dP&*_بm@R@q%]JXerh>\XHY&MZ#4 vYA=7 YcDܢ OSn[ N;3soDZD'ሺ n 42ܽ>?[pcIʓ{Iv`AUc`\XIUJ;E">X1Z򙱒Մc` `>N餼=XmziѶX` /`,c5lj1s&IƄ}Ӛ+[-f0?e,Scj dŏҘO2&16Pާzc` ߿Re0GƺԞdLaLK3&CcϞd.b̘)Vό2bc`ublfQET˪<;c` KE gQ#c4$c9y*d&s)4N8r 9cu,;9Aܶ>Xȱb986op 18d{ CIzrl C磎{yXQJ)2c:ŌS~rl+QE1OBɆ18pc/8c%Gk8ֳ+1M)hp 1 M;:|"ԂRvpLlp 1c/8v?:V2Q"B$Ycp z,} =ƔcA{:i1}p X[JE8Vx+'jP7Gs4c=ÿ"{EO5EmNTgC9?c"ǤwXINcp ֱR+4kc(_rPKeNty Z;./AuthenticAMD/AuthenticAMD0A60F12_K19_Raphael_04_CPUID.txtr+;wPU֪jz7ԗ3KA?}{`-쿡}+VSB.xAm :.zgͫwo=~yFUWr ^q H&h5J+L9.Tq2?~Ró36<& L;Z蛨 ZJM1%8TMlRMj7*?1VOhs@&G)^Lq#P lm 8+a3-cӏxLP)LQ9΍\yx= sɟC%Qy_Z#"""O0^[;-in l9Wl*wo=VQh>Jc$A{rbM@c'_:=y~K}ɍ[/m SPx\]yK/cWJz (R n6p[Q>[knSF1 d*depoGr>&)aOJ[jR}(*UW)SlrUWPJ `@ rgN9CU/GePvs,Q("6`/܃z v8bNqV𔙒ElG41wؑtl&w3 ^{.DJ*j_rlp8fSON8b_5STsv܈q$KoI\\Mb6ҋi_ȣ9yz!>!>!.y ɣ=y y !!<@y <Dy y y y ucLcGy y<@y <.#<Ƅ<Ƅ<Ƅ<ƺ1}&1#<<{@y <@cy 1%1%1%1%#y1#<<{@y <@c~Uh@sBsBsBs]X>Gy,y %!<@y <XDy, y, y, y,Uɣ4ɣG.iҩ é/@c t ~zn5V` ]z!Œ_fIC<#T<.Cel6_pf!ΩΩΩΩTʩrNΩΩΩΩ(/;~_F(`-WhZTǩ8qny7.l6^ߙ-Ng|PKQxu6./CentaurHauls/CentaurHauls0000541_WinChipC6_CPUID.txtRՖ0}Ô1Q \]S7PE3<^PBonri8(sh13UHq5 (}Xv_&(ȝa(kL3XBŀh|+]uDzymS"J'!P%4M#r,>+K&.\L5ymUiUE KwO~.}ߋ..E̶ X`wm̤7gj5g2uCidZIӼXi@/ ɪKt,lJoׄ*$?HX>Afs!Wr9t: '9?=.#{|$c0eݖC18۳4-">ۉtPKh~S8./CentaurHauls/CentaurHauls0000541_WinChipC6_2_CPUID.txtstQ0+PXPPPBffjbk`f cXXL,`Y" mPKQ+r6./CentaurHauls/CentaurHauls0000542_WinChipC6_CPUID.txtRպ@ڸR9g0==gzk7r) ӄEu24);x |o>HEb4ɐ4[B1nJ}lkSXQL04̈́oz;"KiܢRrǃq*\^$C^]qr㒽2 \PN]&"b d?E@)4`UG+c1ΐkP/PKH.|:./CentaurHauls/CentaurHauls0000585_WinChipC6Plus_CPUID.txtT0x-& \p*h\lۃMA?p`]V_6[CpC,L_G g RUd_rWg^G˅~kYa>+,,l.N_e]f\XP0PE)IUO5]SOZ~yJ7*h\0&++htUAnF]URu0 jƲ-N[3)-"7@娖sI_j@0.1Ơ08dZ'kRn9#Ve"c  >y ^Bx '5.A{"K..|%˗H._"K. B_\''źvߣӏW==Q9ۮb[8iz`]W$I#\PKO\6./CentaurHauls/CentaurHauls0000587_WinChip2A_CPUID.txtTg0 WuNu 1D۶֍$>~I sF V*\&qqN@.\x r%E\<󴰶 B_{b\;Q+8R~im[iz/`]Gʗ$q#ZPKŧ 7./CentaurHauls/CentaurHauls0000660_C5A_Samuel_CPUID.txtrttBF)1C/xM^bViV-U@`~7߸Jot-*Qf8>$ i0 ~&@W)R'?Sߥ<.q(0S9Q.6z/ٴ6;$G!<PKNHtՇ7./CentaurHauls/CentaurHauls0000662_C5A_Samuel_CPUID.txtrtB)0 a.H'Ҏ4vQ<^$!W<`Z+4p|H%;BpYJ)aH8/u)7aX}Iho翧Hv"Gʬ,e^`r_PK-j 7./CentaurHauls/CentaurHauls0000663_C5A_Samuel_CPUID.txtrtB)0 a.H'Ҏ 6vQ<^$!W<`Z+4p|H%;BpYJ)aH8/u)7aF}+<=G?Rfe)'PK n}8./CentaurHauls/CentaurHauls0000673_C5B_Samuel2_CPUID.txtrt:v)1|C/z+I)UvA\XɶDQ yp}8QoBE;՝0pNN;(#@ ad12?iN\*?9  PKg8"5./CentaurHauls/CentaurHauls0000678_C5C_Ezra_CPUID.txtS0~sϹPf=H f_`()}duiuQ 5uC"y<}ãX¾Ҿ6{fY'?zM/Sg3 e^ރ\Ep \p+-o2T94`8_h6eUie?UK;:ܿ:v+STZՅ.ZM▪'j6Oо)م 9hDUB.?7c+'ERI:h5~tYwW('Qc8 ^|'B/dDaN$]?'sy^QD8XQ$zDI=Y;1' rS9f~n(:+^H;T-J}ϳxcNS%;I_nT&;("q-?*UY[PK߅7./CentaurHauls/CentaurHauls0000689_C5N_Ezra-T_CPUID.txtrtQ0N(9A*%_-/im=?؅Bjl҃*tXL_(QQ nE7BnK50R5\lPm/T&F7[^PK&y:./CentaurHauls/CentaurHauls0000691_C5XL_Nehemiah_CPUID.txtrt:609݁HZ*G:}×sZGJG"gx  =_oA94ʺzTujOg Iԫp5iE\ؒSJ 3n1R V> (ZroPK>?΍E:./CentaurHauls/CentaurHauls0000693_C5XL_Nehemiah_CPUID.txtrttBVG@~>2nK8ǝ?.ZeCMCd+H:Ymء@O栿FPe jT`nhUK$g CAyO4T6%ov#rɱzPKչM~:./CentaurHauls/CentaurHauls0000694_C5XL_Nehemiah_CPUID.txt1 ;CFh5?G*8n_` KjM*dQen˟rQó:-r*N{%;%pWJʲߨdXaŝ‹,+WPK3̑<:./CentaurHauls/CentaurHauls0000695_C5XL_Nehemiah_CPUID.txtrttF) 0?z@g;_i  <L%zIG>jcv_p<:p ;iI@08L7CP^9FGo8sܹRfeI_888(Nx[7PKs:9./CentaurHauls/CentaurHauls0000698_C5P_Nehemiah_CPUID.txtSe0Ô1Pef"}-ǴtZI2<2)ǰYOXSK֬mdI7^n"ZK' gdQ"b}0ZV˰3 `cY'Ymfp_|[t4au\siԧﳠְqfmEVF6kՃװN.aC0bd-Zr™h*>?Y ʿ1E'b"=lȒ+B>ۏhHOFѸYڬB"!-SqL86u .|W<`gϜ W0 4+HbAfg%*դ2-\W]dn ߃ϙ,qBbyy--n?/0Sɇ;h5xfS\i,w`ڎg[6v0cF8eپPK+h7./CentaurHauls/CentaurHauls00006A9_C5J_Esther_CPUID.txtTz0maQ$:N\f);ӟdG8NƀXv0ҳg;INPQsZ5b(6YFYtRjnְ$x;)ÈtqhD6WK;tVq Nw'hY%KV4K YV-ln|fqPZ4^m&  , i&TD+D<DDW"**")>Q9 %Ԃ6okwӌ%sQ7u MJ4C!q("O)rԫ^S !PU| y~e"0`~✅|U7m]7p#Pe ݜ~PKl;p7./CentaurHauls/CentaurHauls00006D0_C5J_Esther_CPUID.txtTe0~޺f!uw/Aگoney;ì }몃/' z-^f^/69$XBr-}qC 2JLqsIJe|O [oͪ]]L|v(1+OyO^eBڹRxRTJQC[OtC{ņzZl$=!L'xBDꯙƶ~n.:׫eeRlm?Za̜:d"Q$H$1%nRdaQ$ ܉srH g~D$Owt,8({D Rɨp" *r3WKovB'#wRO0]p@$.BfK\9*OyF#xV<͐ gq4FYJJ[KxW׻^_ƅY(٢] ِ gyr홂7ee%>NIPgv(Rn]P.PK_^7./CentaurHauls/CentaurHauls00006F1_CNA_Isaiah_CPUID.txtrtJ)@/z/3چ#«Yoj"W[V![<[" ?o(Jzjdh*PR:Yf`Cz/P8:RPٕ'WpM2eHC&U|yRҗKH@NqqtH^qWah"gGxslbV\H\l;ޙ4tP~SI$}F>׻0F6Fhi?G[C|jOPKz7./CentaurHauls/CentaurHauls00006F2_CNA_Isaiah_CPUID.txtrttNw 1=ɤ`5HSMOgP5z1LUz ޑ7!z5&Z:sk Ɇg ȑ{ ArJHHkI^sMR76EbZ02:\982q )vץH˽%$-dMNHI,"()=NjK^ޒs=ы\&Emb; 'I!baQA!mZECk 41@;X$l=Pw?WH)AY}p0"#<!t!Kdd!Tg3hAk cGNe m48#!6b.x Ů!h#tF!6b%!*\몮;Io!!{ʹߵ Ɵ;ngDF5sk ;%$3H豱I9.qyc\ŸPKb:L 7./CentaurHauls/CentaurHauls00006FC_CNQ_Isaiah_CPUID.txtn0+ _۲ m $ą5Х#Ic7f-*hYl߅Ѣ}O&˓Yv:fcЃhԏk qp!6nb'/tè/>(=Uqߝ^X|35 |Ex.A'"|QMW:P?.gNgۈ'Jҋሴ[4/p581E9p#Ş{pxyNN.zf{1ԇCg&(z4m]r k*otKx3:qckb&}Vu ləӗ;w\ D Pa 2.Ad >R uQB"-DW${QU\=*𪄄)]J x &s:af~M:@8#ȅSsye28ey2ϝ PBttx[PK@OyV+7./CentaurHauls/CentaurHauls00006FE_CNR_Isaiah_CPUID.txthPeX8//W"]jۆu?QzHfjv;]sT&; 'ϾXWܸ;W_/./N~kU|zhq`~\\9; 0'5Tv늭E-Pѵ;>^ܽrl \aNЕku7}D/2/ 0  w;e*ʸC(csrl*84\Iv#ߠ*'S7E=έ=T%K2Ԥ3E  7=3ʪ Mv+UdͲۖtdL[m_=֕+u!9`K.o*s4̌]Vjkf?UwxtM#s"L0ijcU-N*(/dCH0!ZBPdGeg׫G:.yHP=$̭D{)q$H.; ZD{ojŝӣy-T}ŝ{Gσ;GkG+kܺX6F"`-G5Ed Ɣ5^O5pS֘5cߐA{e zY1eW$kГd Ɣ51esBm] TZ# ѥ|ST$T+1Kv`;is؉o2v*L{DXDXDXDXDXDXDEm""""""""-",",",","PKa<3./CentaurHauls/CentaurHauls0040672_CNS_04_CPUID.txtr0)31y w32cӭQN{ +MC@/odZVuaoNnqi/+?>$\t/Z7a,N&Y\V'MĥD2섁$Gux..`}aĉ SYTk' lxC 51+v%Zyh*\#oI┰ؼTM0}0ܲW.ge~/u}ӭ^ $?Jˆ{Esظ~VIK ,n0:L/UPFu{ߐ2J^Nivi"~Kڥ]ڥ]ڥ^OivizKڥ]ڥ]ڥ]ڥNivivKڥ]ڥ]ڥ]ڥOivi~Kڥ]ڥ]ڥ]ڥ}>N}iviqKڥ]ڥ]ڥ]ڥ}>O}iviyKڥ]ڥ]ڥ]ڥ}ҾN}ivi7iviviviϗЁ*}H@ǥ5&KKMEt?O~9fZ^>4vqqlDZw|CQ.|*/mm%gp+VRb1jb֎f] Y1mygzl%)xޫra] Q84rb%jTpԗDՀR'Gё3Y[Qv,ΧLawh7OW$#Q:0GOE w12'%#GΠrN=Ok30Ӊ)FM&' %t9NxlbJ~p&c"94 W.ZCp?S]}SZJW7*psx,r)NWzۆo=hwPK:'Kdc0./CyrixInstead/CyrixInstead0000600_MII_CPUID.txt]P@.c Xgrdc<}.?,% 01=t[֕ 4g82C- P:;;w`e早S{uǤUQޝ?P1@$ixu[Ĵ [bjJE8?J9"vm`#b`gK?Pq5vLQg))]Mӌ)D {2&KϴPE/M&VMg (s ܒ ,J#T&M|M?1*H(6b:дo܍ȃ;$c$%8:“|QlPedGL5LH?(W>3THՓk:µś6JE"'dBC=5X0*OW$ytt SBhx!&ǟ3ֹPKp M6./Geode_by_NSC/Geode by NSC0000551_Geode_GX2_CPUID.txtA 1 Ew4iIg xhqFe@Sx:yMIht fD*C'2ߡRBe5;Le3LnZ٪B2a(h3 {cʑBUo {Bi*Yij0+}rH(I I/&#( 9PK6./Geode_by_NSC/Geode by NSC0000552_Geode_GX2_CPUID.txtőCA D 98U7O8 z}/=ZRapʌ|;te`N=#O|!RJF"Yw 0ΰ)D3X25~ e 3B3qz uՄN*$U6jʃz5CZPK`[H2./HygonGenuine/HygonGenuine0900F02_Hygon_CPUID.txtQk0 {;,~kh+ˠu B/Z4o\;Lh&OVffY7ӓӓjZ|Znk@xfۅwۺKjnpQ>Oަif,MLIo7Y׋A#C!:DұLQ&~}0!8JzȠ S ;T2tR<{\3e1y T@%_r6{W3@\K>P Z|5= WZ_ 7G{q{ؾ:'f^i_pC{ h%UeJ=Y`r @XyXT"MR>[/!2q0wjnͲlCAcSOrE FtHԑ 9x39 uV.2 >Zt:tkh}Yvqw&Y@ Qva w !wiSh0H@(l @.~h=C}?C1DeҤD!8h½0DbcxoL_w!dET*TܪXT>D-XcӓUPT˻:n]=¹|4Mk~g`a֬뎾Xotypn7͞N<]B_0]HA&@hҟرnaaaaac>c cTǘC;1>>>>>cN߇},},Xaaaaa\akhk>ֺ}؇}؇}؇}؇}؇}-c[>>>>>>ks>cc^=}qqtۇ}؇}؇}؇}؇}qcڇ}}8aaaaaq>!ԏqǭk?ccǽG???????g??????%i53_u= AD {M6d="ѤĪix;h0b,eck"_nȍsܑ;yD9'yF9ϚyE^97yG9^񫳣87sGyB8OgL8|u vPKjz@e5./HygonGenuine/HygonGenuine0900F11_Hygon_01_CPUID.txtQo0ߑNk$xƤj[If4Zmsf*+U~&4Bq}sUzlz`Z4 AA0u5Y-j@X}z;n]ݸ>B[2B'z4nJT0X-fY  DB4"եa#Aّ$(N(C Ew(tWI ЩJۓHìG#LL1Eٲh1PA_"[Ϫ!0kI =O)EtNa6DsRHfk%ڤFD=,B]a( eF$I*ںJ7q05bռlVУrD?.P`%  Q*s` GHW9h~ u:@ 9$$[CH a+FϯdY1_B^!^6a Ȅ޵4T@e 4lDQ $c T @:Jc e9XTؾ·C~bkχbJ)$KлIt3 ML3gR|xO~]u"o{JEi#ك[;O=Q36׆av! Ǚ_`BFYm+(}n.S=iMm~חa,kO_-7#Z+Oi 7GSή}}w43ڇ=\m>c΍#dQ)?v|%gPW͒jfQM f(1 Yc)-jUC5TC5TC5TC5TC5+̢-VQ4[>f`f`f`f`f`f3cfch|P P P P P 쳨jj֊913030303030st̬cffJW P P P P P9jRVQ4| :f13W 3Es嫆jjjjjE5TXW͝fhfhfhfhfh&_3}tLY<kkkkkY5XB9*I34C34C34C34C34g1fhfk,i^X5X5X5X5X5yMB9+M34C34C34C34C34w9fhfk,i>X5X5X5X5X5 '.Z >sYy\n aީ%o/7HLP^Hҷł{~%K߆{Q{$y\3 1{ayܾ3q{4yܿ3 { y<G3`=X9 1&oOTo/};D<}"lPΤiKPB7dX(G"-,k$NBQP4BqP<%BI@I"EE6EcD( (m[ 0@M}oMA?eđU{E(D!JQBrjD=Q"QBZ{E(D!j=D! QrD(D\(D!-zB(D! Q*rF1Q*F1QbT F1QbT QbmF1QbQPK2/333鸓D-_/4q g($Ox$hT` VVVO5lb;KȃN6o$#Na@%Ah0.) b: &!Z,/,cI-[&J@eQ /?\]J dfs><}qL2;N "tV][|?x ؉G,a^'Үa)8!TʤTf|[\x˞;途xb.YGL*. "Iykk ̂iN愕m3`Y2iPKZ55;]e1./GenuineIntel/GenuineIntel0000526_P54C_CPUID.txt]PՖ@}C+qww>lnӰ-3I~x UWr )Xi֚Ƃ$ke5kkȣl35d ~r .h# N+`.UF?>ju0(\~K%t 稪Eg&(!pHnHi"l#הc`prL_b|'h0ZH nm_<}? 8HcV0ez՟m~^hzſ)=rjXz׶Yc* 9.Ix[kQg]{)..&d(Hf`Z6kPKvzeo1./GenuineIntel/GenuineIntel000052C_P54C_CPUID.txt]RՖ0 }^1p23'̸ua ‘1wBҚK9llRjA]yf`N|\e/^̵ g~h%}E}p D)d N'GcCF<]1^aP`ՠ ]چZlPK„"1./GenuineIntel/GenuineIntel0000532_P24T_CPUID.txtmRU0~aʘp2NwMӛB4/F?` ¯^W$Z$$Xά3'p5)oz-ú5ej5J˙ G(:F؆1y< <(ʣr#tw#m_Yͣ$#(ez0pI2,?FV&Lh# 'd .WW6YH"/ jj.=ڵC\6wM$3Hmۘ]8YBqUs8MUQm[ Fapawaon3tӳEATep0rGr}(ڔXIz) a8 `Ae o2 X~53%SͶvDD/eq,IflUYI`2JP4H-+l;st,?6qDf'#&17%-󟙌#6Oy#Q4H=IlQu.!K/)!nIY]]BF?-3ȳ7Zt{,k@EPKe޵j/./GenuineIntel/GenuineIntel0000619_P6_CPUID.txtݓ0[F{d\4eoxΑSn,a,o.pr셳h&͖wB1{{tiĨ؅1rxDC̑iQ$2IR||l&=j95UgЖr(! A½Oj ;y'+@S.Х{j9^41+( uűjŃ &]V0m#{R)|7-7b%Ik}TܜދfRxlΐu9!|du,#+jxn:fY#KE"ֿD.Idd^{ oqRIb=u ({Xm"~BRj]KcVPKT1./GenuineIntel/GenuineIntel0000632_P2OD_CPUID.txtr-D1kl ąD]On;B}iuW;## ?&HHsl@T8PK}{7RS7./GenuineIntel/GenuineIntel0000633_P2_Klamath_CPUID.txtrt-@@kl9:txv|on8hwWQ\MM| #!-* PKaNf9./GenuineIntel/GenuineIntel0000651_P2_Covington_CPUID.txt}Sm@. p#뺉1['%6n&^}w9ΧeyĹ+Qi x3N3NC:ZDx_>lc,e3Fg>}b*jp ߐJ uzxp~UAʢ Svej|Yh&TNIJFΞAKUmeRVROMl!ݛ T0, xzQ?U[,>,ߥ.DY+2K76QG7/C!wE𑰹уqփzh2y1#F(($xKYډg"p"8_>|v&Qd%MaAr~)ͅ#ҨBqFR%8BF) ,c ϰ7f^UPK(cp9./GenuineIntel/GenuineIntel0000651_P2_Descuthes_CPUID.txtTU0~^Ô$23>guԖN_xS8΋)`H<00G 9tvکxB=V&J0DkkT[TdimòG,aZ}yCB!5`6/knɴ€'em$&+q<7FfE"cK. ya}(.a T1^DiaepMLx. ߠsQC⇈nn`+ţ[tHy< jGho̪^sTGIjY 8̽{Xv צE# u,ܫ:(_]hhai%܃%{C>^؁;sVN-ᓡp yw2ZȚkȚy|()X2U@K(UTv naFG^]e mD#D6oXfqλ/@rV$hgPķD.!tޕ4jwr>i5?o,N.2v}v̚]3T~`sD+ѫ(}Hr&9/bXZZ B:poz!4+4);9vhׁliIdyZkUwO!zkT-ERbmvUi:gudXLI {Z$BѼդCM( $ӈ_)Gɾeױ= \dz]buWODx8ϣ5'"S,d"Kȷ'"kv@M_]yG X"vay4IppQu30DH :/-, = –m؎KmAEȚ)[0F)r?1]wYJ=&E/PKSy6./GenuineIntel/GenuineIntel0000673_P3_Katmai_CPUID.txt}咫0ǿù0 ^ &6mS ֞d&(s,Nx(8wgg6 \ dµZHŖLuAS U3m^=XPR LRևM&R `ii;&{l&FK-4+4P^l8=9yEDK"I,HˬvXZ:wX[;;;R/5aE4Y\0 Ld\*1ͮy*;? `r'z"E }x $p5lRCr!i 3i_uxh㙮ئE,Ӱ˳L۰b4rH(c;DwlDZ!ґ0ωV{lg0+.R3&CJ @e*4=A ?]>Irm}{=Nj 8{pbT+I *RA^V !2 L(jJ֨7Bb*$ɐ.,Q !ɀiV%Pʖ97Ni6PWt!n%bXF,}ȅ˗ x=  J2("9]#P )6BG j j"d3jlu3;ZHbKoPK<J:./GenuineIntel/GenuineIntel0000686_P3_Coppermine_CPUID.txt]a@  UfTG+кz[h^9XܴNGoԥ{ftIbb4:{:+E }d:N-<\1 2sXd8sc$zBC bv<$K%"tĎ8wxMAysZlŶ>EoP Q6%}uPK}k6./GenuineIntel/GenuineIntel0000695_PM_Banias_CPUID.txte@ߟ|kXiuC E>}w!BRETmG+b1g6"{X Ѵ5STyuA1(Mg#5EMcJ5,jayYL DEM; 1=6o7&ln25hǠgK7M|TQmJCA,&B&e&bp BH0D S%k"6uP}11 ę;QN Z2PVd[aBj$Axnq)q$iR \D_% PKexIo8./GenuineIntel/GenuineIntel00006A4_P3_Cascades_CPUID.txtuL51; =jxTp٩Ƌ8@&QJ N_<0WYfi:yGTXSu _+~^ )U~Jj^ N3PKFsr8./GenuineIntel/GenuineIntel00006B1_P3_Tualatin_CPUID.txt[@Á#s4VXCvt&沸If[sp?WQ}^E| xƣhL; Ag>xJu`J9U=-Z:SjSl"YgXec?^N g͕*ʸJaZp ?ƝZpmbIJU2eM``hW,3U7"&'Kf{jLne'/uۺ6V=fʗ1'Os=`py]VM涿û!dR7)$:U$~4Z|9^kQd["es s"u..a|1L1c;;kEεc_$h|=튺]xm=o}xgψ. U/':36*p:V 6/nlJp$?Í[B=ƾYȺ,q/:oYVKȽ^VE5_#nJF{nx#ܻ?6ŕndpЪVT5SfTۻMs:W]W@֗.覆S46/ jaUo@SX|'lcƎn]E_퓘e|x`{ş^dQ$K$"H.=aּ K5Q&^^A4d,S.0gXS;7Y=4l{9f ֆ{zF2gdc'4Tjߟ ֕TT204aFp˽ g3ӿB N *6HA ƽpW͋WΣ8,NVGŘr *At_yÇ ˧I-mgAMj$'dA BHqD% jPxvo71$8@;Hx ;H])]D{jS/rT9sc.p_-Wc\1D슡x/PKGs5./GenuineIntel/GenuineIntel00006E4_PM_Yonah_CPUID.txtz8aQyFc;ffTm]*]JraFM& wᆚL"rfuiuҤؘj H$Wy\]T>;W}xė|hF1s׎ԣَ\DiL6\Ec_JLNn,.z1]]-FjKLet l2Lj.p~tC8/5*gTxAXv+%ϲ1[/PSǕLOhM@SMyq^UhAd+4b#w܏rgg7 2C<0>b0zf.x]CDAȢ4 (M;""HY9ZbÎy -&Mґxlܤmȟ)W .(M)r1HnMޢbug"u(|@| ( ^^_P"dD3sHȼz/:"ǜ%\2BAHP#"Nb@WhB=U)(E|9z LB,Gf8gv `0Lβ};x=>)8媔ۻ@l=SkP/%+0¯____^+j#Ԥdn;Ʌ- ,([/plbɧIРǞm$Wr]$.wb3 / X9cM$4s ( 8o!Q FM$4<.1Bv]]PKTP f 5./GenuineIntel/GenuineIntel00006E8_PM_Yonah_CPUID.txte{8Sg4á[8oM?J\'SDz_Yþ)'euiuM9>*Yҝ]8)TRl36)ov,ɛ=.Ylթ}>25[$fdz~j ^n]×~ʍlq3eZz4rgp!pR"T^Z.&yj(׫ qI)R͟Nۇ`d)j}n6:tn4!o}w~<xd/0EvJ'-"asP0snGDj"2 $ #bZdPu؈?€[Ȼ,*FGĵ4DC&6l@\{m"h5Eq\]đt $FВe;9o=o"Id^A$^iWG C,:#')N ڌIvDm#j<舸 %,"˴NGdzkxT/?WI$Y,d`&X =Icg0M㹂i y~这,LF-\NŋϽy_µpUmޒP[vD}&y֭A|ErgRj EAT A Ϙ8-H(/ p l!)DXnBV3 jBi " m" d2-[-4Ru9< i{ [IFsxoox0x/pb->RBRpd 2Dܓk@75.!ȏB?Q Ahsy'fAnDLB!N8CU(z.$s5mI K-E͒&${zׁ7o!E5C#bR[/_ ! J sFT$<h\jTkx|f1.ޤ'C SBh} Y A<6=ppht@: xH;&dz_7)Ll8Ǟp"_?ׁɇt`:p\Buց[nZfҁW:p_kf+̤X,5b"FQ ݇6u}Xys}60Jh* HZW%lJT`PHƼ& lHEE$JBU ƅҚD$,)Aj:MqBj?TQBӹ"q>kNiI$$& j3Ҍ>-y&B"1be_J"N&ܤUB,_;10fo]` ٛ&PKu圻%3./GenuineIntel/GenuineIntel00006F6_Conroe_CPUID.txtdT]@}7?ܤ/.TD&KMӇ):-̘a_ߙ! $^=~Ko0Z{ g' AvzSXsl߷3[` `jO?joz`U5YK@9Ԫşٮ=H!A/paMD Uf(y-=Dʷ}vX^Q1%Y Zp\`x\2x1za- *["F9 H/ [R/BO[ޖ_3=iޝ278~4]ij;V%Ĉ^(WykLb=aH M] z>džOdcbӱ:g,[a=$ 0x(\YG3uYl{A'L(4#چ8v@N? T̑p^kFŽDh&f?ta<9uE|ofx|Y[^8w8,r\džR.|iBϤˍRbaJCjR1}wəaJj@y$NH QɖEGG9 q Fl$[3VآzcRf%r=%ݵl6MЮa ƳwR9A9ROqCNPfjWjC#fzheN$C~e>8m<.@vkƛct'/(۞Y(GaUTxTwKpyXxSK 2xvqVv7WCTJ[JSjH xy?ȯRREDnC.sQ?բ$_9SKK&hE L!巿mV(EQG Ľ93t )库+<5;Жi+nnSi2Y$BKEv\'R@ߐi6?zU$~ɧg}w~dKwfnVR?]lnnB QdgJ&?1L1?]?!g]@,| 8b9N+쵫^RAЯ~e9*rDz 1&F`P9F4Վq.Zw\Գp0U[ci ,Vc9jz%ͬA:<8l 'K[3NII7Aab6%FVY#Rj3Ug͸[Ƃ$?F<=p*2A|>S" "$u)O5GY2ALh) x+I;?B&`4 B_ k+/C [lREɦ B d0CѺ}Jt]&#!q%H?ElhQoͰa~#ye=_O܊va` FZ\p7?/mrcc/ hp;gΉ Yw#S^g^y5'[P/{\#ѵ_곉+Ga~q{_n{A/vGV/š )Ƴ^ .uV]3),Wve9Pkzikpxrs5ׯҤ װM_b1*N̹fxLPK+2./GenuineIntel/GenuineIntel00006F6_Merom_CPUID.txtv8';2Ƚhft1+1.3TG~Qٞ#XfEU֥Kw"=`^|c"ҭKɧ{э5;:c*j/ᝇp5)^\߃Mf6;4ðX+ZC(Mj{ x $# 1y>&NHI5ތfQ!zsvQ3|pUͲ|uj\-ӕ+}KZI>7ryFp3;t^_6:M`=J̅r{'$7@ƚ]r^<]&g!X6X a~'-^S.DK'ݓzͦa{{jl=Ga:EԖ\!J"fb3p̂I$A DԊDe!a Dl @ĭ0DB7Mخ/q@$?(uN3mÜdSR {"k/D_ɷ"E5 /?_D~$<(&}QsVZHQpF1G DlnQjEb!F +c `. ei3wr5W%oD{E`"kckywwNV,!F H@gtZkG@|H=9vz3Ζ]핆 |Z'2P|&(QB?R P!_Uˌij/.:/JpHe~Lߎ$09gJ|٪–`jF882,*;ZQ~I>K:׹:tyZb\ˣWW7@J}Ԗ}cŶX^Iv Fx9ʘmQeEj<'26b~IHO@ ޴QD$<.';& 2 8㎉`b!!a݉S-y8蘸16Mjv"6bնL4'8 a6&>Ǩ` hL6aRk)tM9SNccTa?T}aH<AπJHH1x9lc#`QƘg2}r&qɞ^aI>g'UQS7%`$)m‡`ƫr&Ez 8~[h^Wyv ,էc_v"?H`OSG`G`G`GLI`ܘ> ,#0'####pcrI`ܘ> 9;;;7&G`O#8 `;je%IuqB ,_ǦtA|U+}E&1nK- I~Ԗfa-nKI-i:ՑDe~1m$ڒHW¤ ؑ; ؎$= `Ғ# "%oK|cJJ:# Iؖ(E{^ec0Wa:'\ǹ^Qf LnX_^<*]PKR]<./GenuineIntel/GenuineIntel00006F7_Kentsfield_DDR2_CPUID.txtO8+^@N.Im9qj@Jʥ) _@ \ٟ=3Q&}SUop0f,`ixΏV%d.&ߤlV`c1fݩ>%8dbRӫu}bVþ63m\/ »<+ 8&_p@ yX/xS_NU%pu#_J6Iw<."swJ >vNћ_v t{/m3tޱBL+;8=)882i,_{$E\,9A`( yoUIi@/2=rNҞrݎ"^&&𡍪'p$b,\EH'1%m"rTELHADQKbFr (RúfJ63|В1%Hȉ,[ >+WKrSYɭđt-ITҊe=Җ[${N$SȐl*R/G CFP~ G2ĘH&"0$|r3$g.e0f$\Pu] ʟGP#BH%Iy%$Z$|NdEߛR0m1ōA"?{7"\4Iu?÷ *ї{'Ngv Uwx/ugf]*pW g]*pW ?)d|PLmf' 9'3q6[$|&gJ*}'T {b"#4#8@#dX 눢rBx8 $%Fѫ#ȞvJ ڨxK?F6:@l ƍ U|gzuxy10M{PK^kr^%'5./GenuineIntel/GenuineIntel00006F9_Tigerton_CPUID.txtTQӶ+A|}`ض^u:=~QU[Ѡ-a" ˗_>LM6Y(Oʃp.FQL*cA$Rjn,01:F=q/P'ᅪκOwPL#"OrfYh.' '`ZzVkĶ$UBi-J;9Z'm:9NF%"n"0 V_-Э#!vLU8* noڇ!!aAZHIߒ⹝ w_ْf_@3R-MVyWSB󺓅 ª?Q.f6 C/"pEQrKEQe%)^:xia Q q&mח{5R CXHx}7t!g;@(>_(%y/!4]StBz]t!YBǎக7p](WPWo+ڞL>eOзи+*!cUKCu2u\e Ʃ A~,jQZxQTR o5JutTX(KДm$2) j>]H2\8W^rI vH-2(GZqG=2>" ZD#׍.ȈDPE)VG%%׳U*[CPKo-0 3./GenuineIntel/GenuineIntel00006FB_Conroe_CPUID.txthST& EMF*Oej5{CUjKJqί_FC=' "~x4 8!Ǵ8kO-gǣɲNCd@;u]և3ٍoMab($5TU)B8 xCEuZ 7C5gK(7.=mW̒$u]{On-_iyyӃH #g|1ko BVdD!Ob[5SZe75_Ogp$,CEXA"0R9ߌajtdpEvFpW%=_21epcLPa0|^@[gֲg(촽?M^7,(P&CGؾ=)n>vu0X2]Lc45ϒD # $0H/nUmΧl`Hm Um$,N }GH\GarW^%%%+g2* XHwK%5X^5X>2?wa\J)}a="MHY.Kh2d8!qqBƷO}9ɗ;Ւx DJ{tBDHqB-'d8GȍGGE' I-5S݊R KݚJ[CcC C EPKB:./GenuineIntel/GenuineIntel0000F0A_P4_Willamette_CPUID.txtr1 ; iFk LTy C~XPݢ/ؾ=_)n.rVe(wOww„FأMt%cۃ)*t@Um1 4wpijt5U; Իq&vJ'V)Yj 1RWr wOo+W:Dv $"#b'ށ ƈNPK2La:./GenuineIntel/GenuineIntel0000F13_P4_Willamette_CPUID.txtj0rB$Yl;B2JuR@jͱ3W?I%t2cyϗ,;fÝlڢZxخGmS .Y$^Cbى(U|9 ldB' Ҟ(pS=v|H8PA,a*K`̯ sxVhmᏢ,Zvt0m)Y(Y'7ZDe}S]睮LlM%԰v- *t̎R"K<[QeMQ=a/~i:%pEXz[M rwjIDDVDҢab].M,b6O~N8 -2p3Y ݮƛy)/w$Pug#DB_KHHXB,Bto]=>y&o8? %O+4LM*ؿkw+xC:68"ݎ#i:a2Y|1iGQ{fH^rV$b ׯү(Y[xţa EE,cn?E #b ͑ˬo,O W"|~;w WLayT%""EYEXVTQ {~Ydo5"vuZk9T=h6dcpR?# N؁6Nzo;5K6a2/lp+FQ6*'NviYISK8;-Nq0Ð 89#M88yp:)Ze˳j*^x4bv^[|,tyQ5.Btd|Lɤx&gDA_A$"r S{@)L֕TA3V_@iv 5 AYfz"4{n0:ʇt<8mxE4Dzc2͎l1X3=[yK"}ޗ&~040$L%Qdr0BM"W'-Sa U$˓dyۧGcYdN4YvL4jQ=!$2EZh !:階W'pzd|랝v $Jug@,%qmy*B(KH" K7Uĝ'2Fѽ&r?D'₣Y~T,K/Y% l2eFFqX_ PKPn\g8./GenuineIntel/GenuineIntel0000F27_P4_Nortwood_CPUID.txte0߯|9WV`]+f[64i `EiçaN2?V>h;vHɰ]Q+]bۀ[)o!Ie`+9M,rox9X *D")20A6ih.D4+iz2F~qfEs`P,L&7@\_J"+B=qa) n[}2YEn QwkߏGIi ɡ+;ga>@7(wfyn: ?k#(mQXYUW[Yn0 {NCd.:3_d#Gv5D .5iD*OYDc.R)D-Jҡ`'rŕiCDd&HJ@)E2,ZXClñy!^:{uӝ|ROK|W \tw}5ؔGkb,(Dx C? Sd@xQ$fQPB%10Ld|vTn=aPK9./GenuineIntel/GenuineIntel0000F29_P4_Northwood_CPUID.txt0ǿ]7ICRYGqE%d6cOI; m3ܓ_E⼂0MY]Z]HX>xEK-:v :A{QZMzgs_B`'Y@j`gnN#t6MTd4º*zc0LF%(%M<b;%d"Kc.m$LAY8uzg`woH|[1 acqLOwwDN#id7ᨉQ!cfo~"Vy,Qq~mU60&*Sʮ uoI)eS di$*#{Ih)y)K)Av!g{q 8vuGHr'֞Z[}r/=tQ7 C#,H#~vUqM] Dt-Z$aLZٚٗ8R/QIODo\Y4F[Y &7"ٷa)4 E2*y/D5/O^d&h8)5W-4HeF<<I2+QUP,/]pBծ Vs'r)gfe55cIQ5!·Ii !5AAw0h ]CʵyubMDQC;PA4E4QL'SfZdex >UYM~~ᆨ,9Av)%g.s_Ͱm3"yiߠҮaHQG:!vE͆xrs+"vHn2DƓtD胢gC{50n .5txB@c'0xOD ;mphO`4EQLt$<2/[VEMgۖ"/ ږ? @"W p!F3{lODM$Z`!FDkwH}k'E=(&߈\D賢ngA(Dr+`!OâX%(;NIPu*QU>x 2Jd6mvot1IR;E|Gu+0y|Ço8 d#d"l A|+{r#2vX OKv^F"qmdljv| ~/<JdTɃ>@s\\G&dVUPKS -+ :./GenuineIntel/GenuineIntel0000F43_P4EE_Prescott_CPUID.txtew6S#a~(y'3>$J]&dz&/yV|A§c]D+C;ij}]ޥBu䳌?[ּ={|0p*M MV& 8enfͤ;c0y@ 5H]CMiCOu5gKbrchJX$y6p++ʼ]fxdƱȎBw`:}ށG߬xk SU[:.VwdUCw̴g~5ĺݸyun}nEؒ0u Xw>}2;$8g7o'N:>W4^T}xd=hG-\!9Bq"ޓYw1F0F)b(mCa\hF ȅX])HE/b%~ AQDɮ$ɌSx%[zvR&?qut}Tк/x.9( øЁGZ_ $$HJdjd| 騍 ptABNEo&w=&O;z( 0&j #IU PKzH% :./GenuineIntel/GenuineIntel0000F44_P4_Smithfield_CPUID.txtw{6x׽I[٫{Di2^}%Lgptb9} gA(` Yr%s4ƜZloRexgDzS c:&#35[s'7+ 6E,kYTu, !}| b @z'(rQ9^| Qϖy.ǵ\ruq tOTUMV˺ \{|dv#`I#~$]ꦔ=ɕl'eyO,]6kv 2УǷVw$/s;2R:%BSZ^).ۉ5zZvy&PDQdf gumuΦcxuqR8?8@q8v4 0M"2X0ŽMwE D)p"EԔIt&a;?)VHPlyC<϶zE~Zȶ| 3MgᾹ8se5(5NC4H2!fqQw bdq?(rM&M?*-Hds9cóp9WZfK9N/oj ;ZNT\?ȱ3?C?=>#yW,׾MV`7@?]C[4MX t>?H#O#O#w>>BH?didZoziW q 'r0_@ɢʛj{[PK% U58./GenuineIntel/GenuineIntel0000F48_P4_Paxville_CPUID.txtrpJG0@W;, fl M?R7 lȰ?p'd^ݘ7DY߾p, uյ HV_Cť'< ODA lbjC1PMzrŹeFW$_A,+'՛ۀTEaf`ѵF }03 S)(B[t}O4GICQQ(:QFe2((2jGeQw8(QFe/eQFM(2 GeQ[8(QFe2(pQFuewGPK1Zz9./GenuineIntel/GenuineIntel0000F4A_P4_Irwindale_CPUID.txtXv6}wI" @$BnIaYRXܾ>iʐ.ei5 U8oեեd|QC?o"6:*K罝dM&Hu6ӱE' V*p 5`3Dݸgā++b; ej70>Nh?T*q&0>b74K }r\,Evp2OeJ ޺0VeG5Dgޓ#U׭}ώ ?>/vM9R-Zc6t@ W2.6 Lf#uJfEQв/Z_K 5t C4!]C/w5!6!&5⹷BhϚZ3Htu"MSKqHFB-d7!sQ#}3}$@%\uqfMT"UX@( tuPKv5S77./GenuineIntel/GenuineIntel0000F62_P4_Presler_CPUID.txtXws6;lz;n$\*{oEM.O 8i 1#vʼ?֨+x*"]4+++Vf=F245v%__L۷[ NeOf ?rsϢ/ςE.L9D{e.5B;s`fDsQd"o3^n.y}ͳmq>*rʭ+7dQURg~$Ʊ簉 F'p > !F"n^6Z~a:!W<f9qfMMgsDjWsgw;$b\֞-h&o=#UWk0 >\Ewœ"J(y\KDQ>NbvY>BWׯeƟꄥ0P7 ;(Um3YNʣa~NDc&=׫hV>mqXqt'&Ѷ L̠n~ɻ뮻]wuwn]wuwPK 4./GenuineIntel/GenuineIntel0010650_Tolapai_CPUID.txtrtQJM,.I-*V ((jZr:AWcl]nHPE? vcgY6ɬAVʲ.EHF #խԥ#Z[_ԑd{P3 mоKLy M%%yzHm}@LE_^y"oPKVM d 4./GenuineIntel/GenuineIntel0010661_ConroeL_CPUID.txtv8@lohBx+ؐYGIup+jdCr9{)+/yuʓ|'mFE_JrI>HWBMw&h(zC,[j{?y wKYxO52Pg03DwNGG@?n0KY>A~2KyۥlK.٢E9纨GJʂI1 **S?Uw'0i:O3]MEL ]mOg?6aB PƝ}r9Jw$Ct_ff̬[(6DA k4UKf^%tT4Q2tHW(%$*.M$b/fqa#5=,vC0.q1&Lx=#{a!#ju!h >tk (EQ-#lFLPG/$8lzlz+ܒxnr/ΓǤ9bH+PK?417./GenuineIntel/GenuineIntel0010676_Harpertown_CPUID.txtw{6^{4;{K%uLVRG>j_6 Xl/Ыfd}e}n1*C#?=>0$(e|=yjGzrLv#t-ߜuW5jq{F4+1zjU#D|LLtѝjZuQFpwbDpJ %AMA,:G-sk,v'eUlrJ  >@n=⺣uLo_b>$VnrЅw\קӣ>EguWoj7Vpꑵ{Y+RlC(,|i6ЧrS$SF[%UVuV6I>M|wlh6mdKOHxs_Tc~DapPU,0$LBHgVH*S0B΀=3&+9?虸1E)@% k g)I5yLp/VR虄5Z#}=S&[LY)0&IP<`֤셵|%+%l` gypSߣTDx`G➉yY% =!F`yF-h̪Ȁ+.{&﷔ܚY&b &{VRWnd8-Sm=BUc)`M 8,5ixO gQmfz ymy&'####pkr'####pkrf'####pkr'####pkrN3G`G`G`G,N{X8o=lQbpX$cSox"6$Mt%4J")Lw%;Ku%DA$Ldb"ºX9fD8l$Q$dIR-6!t%톱L YfzM'$C%YKKK+QӒ3 AW@[:B)W~ t=':)ϻ:DπٷwPu6 HOb}PK 3./GenuineIntel/GenuineIntel0010676_Penryn_CPUID.txtv6ǿ'; Aؠ:ET=Ȕ!ݻ97KرY6grgʝd6Aoě[p, Tq+wB/^lXWt],vg=[:@DJWJi(W$w,Հ=l}No`Hhуt bUhb%&*RR b/hhUq X'&qI1'!cxE(LKĝDn^D‰D shTI @zbduQ(eMIk ̍vM!-YF;m53"KDw" 2d7$Rd\#E(aH[]^" ,T"8C"R3S.C)%Z"'q9yFH"u(r7d"L*ZtBl<;gП&,gǶJgs /.uryJQ/.L;0;wxv?IU;I#_> D0_oܮu&.$*@#_GC4sE9k 7hP"D&.B:֑X_zA'L6S!A @z.A6ӥh au$(2]T~@vW5:HTG5@F.}D('J0h{-G66az [Nә)Jx-f+w~PK ;*6./GenuineIntel/GenuineIntel0010676_Yorkfield_CPUID.txtT]o0}pRnHHidiвv=px%&2NK͜0?s5^?E ^{(v >yaw# x؞g=2J͐zm||ێ=r7Ƴl)F,EYl%):KŠ9T*`ƤOL= W"4} ܱTۢ]mޏB`M>`QIO;!Cp!8sѨ9eK{!^ m!^/t`Bx))&(vjiIHNbl_i"O[ʓ@qEF-=`_C ݂&8wAu#386!˛F_KA"ץ0gP <^񺃦=mx8MjfF1Ke`-jК'}ٱDifHEN_j(xS.x>htʩhW&$^v<",KC8Jx u=/baaa-3:r*AaaTvu`ƞ|O:7NaSi3yk-_7==bRgyz<NRL} 4g7ϑ]9i,(*:XT̈&93m؉):8k0ZpōҝVphet:.sa סּ]HRD{梡9Ji$cAfHs`R3 V+7 *Rc{R[b *̦Hk8@VNv1ƴ\aE̐3 SŁxXtW ZGlSdH"֊6TS=q{2C&ZN  \5u "mM 3Gul;8H@ޡ }[3DX iA4!:EiE!&E 2Į]r)\ 9o0\0}Ǘ+$ܼGP835\ӫc7lgauȪWWGGAD $د߈FqrBlw:ZKH0nj/BQƄOOOAꧮK?n'._q_zjum8;ffMl|3~]@ t]hօ.p.OU^4]7{tcN盃=Zu9Q͞'pp{OPK3(GZ6./GenuineIntel/GenuineIntel0010677_Yorkfield_CPUID.txtrtQJM,.I-*V ((jZrA @A98P>,HafB6OƟ,2҃cb'[זI[1" Cٵ>iZZ'%]xx֦C2)96,L|M _zAS _>ʬˡܚ*@ gʡ*b֤ IIS[a "%6Jj* {OJrHS N'wKWLʚRڕzH. b9)nCg;UykVJ!vN0:k_L,6 ` `X0 ` `PK#E& 3./GenuineIntel/GenuineIntel001067A_Penryn_CPUID.txtrtQJM,.I-*V ((jZrA 9}8 P=૏qig:[CFX3G% hC~} W &ózH ҁfu(2,L vHFƦ/tjP ggEorgc\!ݙO4w%P1ST<&4O#-pI==2B^8C8PaDv*rk7+(EID hF4( w8Z(hPKg +4./GenuineIntel/GenuineIntel00106A1_Nehalem_CPUID.txtrtN70z.`'N p#@4P  lWbŃE!/d?ߍ OL EL9.y!y !@Ä'Ze1¶c1wH灎c PJZqGz+AwTMCҡ7@]͠C#p;{N4A7 9CQDՂPjyڪtO I#$q< jNF1$/gL${PXB{UuQ! N,v(r?;D PXPK6}87./GenuineIntel/GenuineIntel00106A2_Nehalem-EP_CPUID.txtn0+ HMI*! :41!!.Bm6i n, -Eؤ֮Xc]Zp!E2OvNu9@xse:Fl} :n%ܷ[ƗV(M .1-mFGʶݙpT`)"?ngAaē9(7~~w-IwwEa_v OD^섋N;-cþ/!B///dc yHC ۇ/bbB/bb"86|Ex@444xc C 4@c@c@#4@c@c@ ?6؏@c@c@c@c@c@s2>3y,r-_ f9}j> CM&:uD'v+]#JQì) kgNC! k첍hH w۝- !្(jJ;!!MZQ6֦ن EN]vk; %Ωeq:Q&-e:@Ml82¹,o)kC dv~PK"e7./GenuineIntel/GenuineIntel00106A2_Nehalem-DP_CPUID.txtn0+V#@IjT5m5iKݖ-!!]M*h!9C>! *]d WNM6}028 p.*|LnF;}j}l2mFp\ϫk ar* dj _0qp:7e5guM k4ʮ*4J*@)y:h@|Dz$aZCfN5n8kDI"4ĪPdm 1jB#z̋WKɝ] wӐSBOBQ=zN>:")A! :x{]D]RGKha(֐U^ a[kalЀBw݀g-n[!boT> ވ>Q&j`>=[.8;L(N 8$Ux_cwт?/7/tB_~|/t^W/.B:- MTZ3œZ,7ʿ0tb\0MU,E,l$;A |yIKɐO$H˷V&qImxY8 [x.q,Ӹ5 KAD6l)-Ƥ{5 eqjP͈ڌ""J;eLT_+L}el?YtjPidv`µA2^-PK+87./GenuineIntel/GenuineIntel00106A4_Bloomfield_CPUID.txtn0#V a Ҥ!]tꚶ4킥nFHGHgBcVJJ 98w\h,K~vUΊ5@pSe}Snz8>#ar9VQNo<|\<RVȂ.KLP9/#&t?Qf|v"av9Og`|by:M\>zn0YdrVLDټY>`2 V"dUpGa 2Lw eծ ! *%ygNW!x O_DF0r`]v-ₗH@~ w|O?ʲKU_ճϯipӛ8'P<zbn2>7-9\s&C]8v@oF i"jKy$P|]0' YIZ9i7)vJxb>D+&)Ma2F0d4&nLx=Z-&dz6iJEbXmn47*5Bb{v>٥eO  6^g"(_X[1 0QQI4Llɿ\r-EC\f3a2p&քՑ'MV{%0?Xu;c 0 pz-%b>,=z KNN,$=/*vbNɫcb/9B4_4_/d͗] yN0͗m ۄ/LEeB/\Ee7 ||5'҃(͖a@5h4h4x`  ]"44 hͮhL  m hL  ]"4h4h4&v444G8W"K"cs7ԗQ( TP*)U]K]-_jˀ$L1+Id8thEVJ&HS8.ۦOɰ5TIH]™Y# k/4[#kjp]Rv[uς+jJP۳0Q*~,E27@ ()~wp*f7" 'tR_ċhv~PK}9./GenuineIntel/GenuineIntel00106C2_Diamondville_CPUID.txtr6ǿߝaӯE!H*{I/ L$I@2IwS +N3yβ~W,=YɴكD;FGqHKO|ll(̲h4mx顂1P&)0ߜs(/j7I d:vD͠&I7OT=,a/6,/0%o8qLD,/0ͨX5s=߷!,'YrZZee3$SծƋ[/*q%~s(7QjZ}DD2`:wy킦ϷqhI Cy>pf8T|×L&r;$5 uvx>FےMd -[ȈW5'm0t!04$~=}r jM`DX=A]$jLG¸ 6^+bZS$xOkEVS@3_lDHJ_d?{CDCDA.4'lc9GjPzCz0WdaBڰsuBPͺ eL7EX,IH9L#KqspmO8+E Aq~H$qd7|G @ &?89/g4)#5)ȟijy0rV9,KnKnѻʯkIEL[1}?ފoŏxys6~jV2X j:ٜA&IP~6ݺu_uk>"mmymDyq^Xa\LiF@} L _D‹ .O8=ց Q'DPd-bGƢ4n# {KI"VVqE_F]LW!A68\qd7ۈDGS}hKReSJ*lir[jz4 P<-'PK?k=9<9./GenuineIntel/GenuineIntel00106C2_Silverthorne_CPUID.txtrpJ7)0s^@$˲]|#2uy6P0ZouJͲrQHw/b"AQ-JsZ{H7hJ>)ԑGH-"M~}$4# {"0 o"*W^^A $DXؑIcpDcaP6mHr@E(I~֕3}RB">&dKL@j (ٟH =EʤF i fBn:p%QGwZ,o ؎e|^SB<uBo'''[t,ԣcl3mgN/8^g4<5&kEBu3# 0  ),UNT-}eMZuzY,UGgKf02?We3]9|_#⪣ULoU LUVr]G:_T ;8;~p>=aGm3}ښoH1NDo _Q4|57kJԊ&Z/}U>guï`.aZ]Re׋Ǜo‰]Dp#9׃f 8#{0$LD}Id,T&Ȧuf&mj&/B@!zK^vO^& =9M!VKQLrS={ȥS^xlnM$_wGdD}AM` @P*s҃.h=$Lqf*?31L3^d~whu.ۃJ@Nb,1r3!MT R[mA_#r2#p8pbƫ6hWq yz.ȏ/4!&?Š`ЃA=44}4.Ӣ\?pj28ԃSN N*Ӝϝzp:*^+`K?wa҂N LvYX+ {e ϳk4IW.:DZ"T'R2 F`O}XqODm ڒaJd5$l$`ґ>Gf<~%v,,BIWD6` 8#;kaL"N0kIHF$mg'r:璦v$. HDJ<Nw-nK,9\C.&uR/k$\Opa,ŝ.Lf lW{PK\>6./GenuineIntel/GenuineIntel00106CA_PineviewD_CPUID.txt]O@I'ED^Ň8Xl+-ܲ&]QʝvfgDO<tr5דs'cx7Ǜ6nK=)|ŞxZЃf *D>SNeiEYփD2@J2 zC_0$,$e .MPHHij{!I oߓBH[-#+}JS)Ph!)d$R FZ)(aHAl  B6)=A| j"$^FwPJٟIKP43q䊥 %$SB2j Lأ`[+ 1F!g\Ww3Oו= ^5zgOss%3^d4 z0f}7=yY-/85zpxgNszpKp nlkΥ:O70l-LY,?Y5?:Cs+S `hsŤOrѽ#Kxӊ>4Qؕ+PUZf蓥+V؊$^T;YR#E2%d+uG"S+xPG  ?uYWJI):ZMߕՅ: HD)ܕ9AP~hJIkxԗ)\+86=fb3/PKYyʝ7./GenuineIntel/GenuineIntel00106D0_Dunnington_CPUID.txt]k0vBden˒UT.ӯ_?٪]mP^9BU TI3vyvz hqqCO!TBd:P9.wpY;K9w=W5\+x6%|x*cܴ֩VTFbl=,Y~xYr 3)mRE.Ta=Ͼ|h523wHl3K\TbF)mɍV|t~\vrZC1BcGR߀q4+K}'mzmnifi"Ձ:yp%M9a"U8bl8 0;5`5 q~b4ݢ/H dl+oK`_8 aچxD8b- ځܺ܁D a싺3];Ŀ 42G}L1u- I=[S4 g ywCD.w 뺘3 dE, +/q{6wB!| 1LBޔ,$eR(>z/0l$E 8R(ZYj9.uL;ΰgqBN>/vn10%?vPGqNL@R __H_et||Y/ _%͗ˁ/ˡr :}_|_4__v///˓ ˧їr_J*|vbя ŗ~ _Ţ|Y/qE?/r(c/ E@0s)d0 EA0(d0 90$ʥ$ f:03`f00 Vq N`N``N`&O'070 0̷`Wu/```9;" ` 3ZO~*2f+PL0 Xs*PL0*2V"<`f'0Tdc̫CE0 U @@ץ;zoFnQٸ-fNNo9fbz~r^,%QԼ! 7./GenuineIntel/GenuineIntel00106D1_Dunnington_CPUID.txtQo0w$I{Y;ώHH:4&U:Mx m0]}2dqy௓gBb!vdy_7aZ~/_,fCg?A\ê!||M )6I̶7캨˪Wb1f f$ ] q$J49#$Jv5%(X![%CQK*mֶ%d_&NL;1efJ 412Su$FT@D!G((89;  "!u!CS{@oLVòŶ=M'C#<(@@Y -ᾓ@;o?_bYOjp{u s8J+V\saJ `Ȗ~K!sňdkIM$|PJ|.xʟa^/ge)`Xx0)jY] n,|rZҋZђ^xٹc#a+Xm?S6} $BAJ\'jD ~{@fm [O p/ݕfrBail;p<}?hziˀp'c3d2,@F{2͍ ( V|%$߲HB0$ ~f@!#F Nd2<{Epȳ"K`BQG0D'A AlBYgiT$l_xXqK"q"SODxYI*wiɈ03q:R0JjVZo"e.e #A"o5 uFJVdX=4 q=eeHߑZP ȦE–Uf&Eb#LPK@Kv)6./GenuineIntel/GenuineIntel00106E0_Lynnfield_CPUID.txtrtpN/0@畺6`3B/Q\`\XgBl1Xǐ,6g?b8BMj;$4l`:4y B7au& 0HNfx#S7HwJЉ98f! th8'%ģt*w0"ԡvDy^4S~MB0If<+sJcn C`* q_l] KlUUB@,[r(|s@7,{4V!x'~۩"`g v~;"\.qrV%.7.qpq 7K\veˁK\&p9:\\%.\.WK\$pK\%.q%._%.?PKR;6./GenuineIntel/GenuineIntel00106E5_Lynnfield_CPUID.txtLQ]k0}]T v8[e05XS87܏s|c'⌟h62Iz8 B\l$f[6C&x>. Ҍ"SUeXa&IJ^O 3Q"YNY u=ҁi: -tnY1zU-g1M<>@mdN\Po6f,J_u|  Y~3ç"($p1a"ォI+IGvoEqe[ 6x'dV~&}>CI x{ʇMu1*DwΓhy!8Nt@Pp/݀Xo[PzQ.ef;2}G8Ǯˉ:^Qs?B٫cjSVh˦ײݷrJA*ײ.:p%Vs>[+YH9D+G"WJ;u#E.K4>24uz(0~G@і;=%-%P!KJqMdEPwhG@iG'g'Ʌx$:p%W)g3L)- ftFGYLj&{b)26fIÊhsvl#H=!dF!)@OX%|xz~?ͣFv%x8ɧs?|xzL>ԊmFo5$$ygCCCzy(y(y# 2ǠD?ck=%%%'A^B?yuEB[&1m`PG)Pxz T*xx :xz &bF)3?W?|>.oi[[w ^ _|ʏ20/ˆ PT)}$@# J-h[r@tAQH_%3dӑ|$5*ƪ #eqU֓r58}d#$UxQ<),]˱FDH0RhYr>^6wA{q{?хn}}tH}"Dzx×_PKp۩t)8./GenuineIntel/GenuineIntel00106E5_Clarksfield_CPUID.txtrpN790#v@4 *yB|1mzZxlV(bx6~ E؜*@X7m7Zڶdܡ> hXd3]u5!zlx m $rLS%nHW%hG9$}Jk$AgOF^?A'hk2K( -G%N෕: =ț~zkʈTNH2HD3ܤ'0q?MBEE6elJBQE JQ߰ ?K{⧝(:f`#H.GK\r \p%.W˅K\Vܸe%.+\\2T%.opy+\/K\u|\PK1c7./GenuineIntel/GenuineIntel00106F1_Auburndale_CPUID.txtrtQS&@G%<5%z";dB$rяFU8ZYnrd$3qkI9,SW;?هDX lH5|f{ cL<A+(U[.|~ֽjhhE7/xruZmܼ^㇙z|o ``F_Rɕwë9BFRpP qWD^N0&+X 8D=3cRB1h|nSB|ɇ!և>iAc>zA~P u6`Sy ,EkuNFgpfniaVq+ ז>EGuJ&7%ŭu,aTK\;),QmI,H -ZJTUaSB\^KZSKHےP/ *9D ;- mKH7 /94_# [+)W-ꉈK$6$ -"R I&?30Ḃ 8^?0Oe&&οPKÀ8 8./GenuineIntel/GenuineIntel0020661_TunnelCreek_CPUID.txtrtQJM,.I-*V ((jZrA @AI}H P=M>4R6_4nY}%~뫝Jb'.4Nq(mhV 4ڧ3tJB5J'B҈3 =WjVtJSe  `0S~*$Sӫ3,?o*sC)\_ˋsu*!=Rtj`gNI\4jorkB62 P dqbvhȣ͝bOU\eW ~`7̢d+F тl -PK|`Z5./GenuineIntel/GenuineIntel0020672_Medfield_CPUID.txtŲ0 u+#K2nefܕ> \'/ë5S*3F5Nl$^__~#3#Zpt)AA. 6ܚEk if$MZ6vr%Wk^̗RL)6qL*  0A6| Ϭ}P-r䑐W!iHPu|g|ovwvwNe^7s2xD e|r5R1Э:US&!UώKyslDwwyY,&Xĭ#?0@,?դcU04_\rQB%~%EjߍD6EUs{U[ΎUknM%| lD׿TYYco_7ET[>6hEwO2j)pDfI:^J\ή C:ε^=^^EȶD,,n# "F;׀nccDY $H3DA 6PAdm`BBU%aVW!ę Pmi!a@V`VӄDVM[M˝m wWOfC8uP͞k C(\MydOQ wu-J"Liydq%h1 {`a0]:LFl;6 kd@b%D+'b@0.owDiBN`ށ?&YZf?ܕxeģp "ZbS= }_d#w$Spw۸#qpw#+ȟ;8#厃;8#_qGqp6(;8rƹh'j-hg|蒫@60t%Lô0],V!Ne6/ekX^M~O>^ı\fu%Mrޕ8,RB`; %f>J0I{l'EHˍf!6Yg>Fߔ$ g aTG}Idfy q+zpܞ7?26WHz˥D % WzGE݄4Ȥ2 `Њ-Y% 5<[ww~PKW$S;@9./GenuineIntel/GenuineIntel00206A7_SandyBridge2_CPUID.txtLQ]o0}7?d/+4ƙe TlT~JGmzNǹ>2y8y,2I-" <_9&e;{S&C\R91gb\4_r#a(ne6`'?^ĄVV)*s|q[rUβ|.dĻ/I|"eMT""h܉G>tA+N#~ZЋdn$IP_~dGᯈK"좽]uox"GDFY_ =O/ff4_f1۰9`"&?=?ؽyb=5̼,OPKğC9./GenuineIntel/GenuineIntel00206A7_SandyBridge3_CPUID.txt\Q咜@}?C_}%.S0R[g m_{+sRVYA+%-[[exawzȂ]u4U4mk'4^睗 &2'd,]z'Wp$(J¼k3G1(\ tMۑi<82KRSu(-IMV=['&&'ω}I$!h"K[@/02**pis)I .d;F/I۔owf;vg0UK;:~oC&'5M349 6ö 3zOGvoldܩE8Ʒyq|S|a( N@sa,{}N F-GA Eu }Vak>ܼ9`Jd[7Ɔߌ#ppwNjTi>n u5#[;³7؏W7'&!i2ir4 c4 III+I\Hv1vdddǕ#-n=ɤu$$%M&M&M&Bĥ<ɎɎ`G1Ǝ"11q(DʤɤuФI444RT i R%;&;;dǕcc^̎}&&Az&ɤɤɤI'_{X|IlZ9ˮGa0m[*Y@^S^Y OAyUTgꟂz(RMptf!2a#3ʹ "SɺVAj!FHVq"FH#G*AcUe@Q1(ZiсEB}䃍JKUlqJ!)!J2<@D:@MJg 3OYm|sАȋǰ (mMUUH1XEa@?ݨbݢ`l{^^m?rpGӋݫMwfqj Ϊfpgb9 PK5,ue 9./GenuineIntel/GenuineIntel00206A7_SandyBridge4_CPUID.txtrtQJM,.I-*V ((jZrA @AI8 P=klg4N1$,|r͓eS6ȪjPT2 iӹܶͭ%]e UÌ2!(.CT/0aOг/QAqOޕ6:<(#0 <,gW[/T]e J94yb_+ 3Zn:% #DU.\׊?u$%˂K7=$⋧+O RJ0e]ie+HE6drP+vjlBc׹&ŹѰ+G܈܈hq>ZPK_ r5./GenuineIntel/GenuineIntel00206C1_Gulftown_CPUID.txtes8?_g$I먍vPk *W>bH>[I+ypymkؕ}}LؔݱI>xl+70O74ev އ^Ynj4+xoKpT Oa(uV.N wWIҭ#Ǹ<-ʼfL}k~D]upjoV:.ԤUvDR6?_x;n7ZMڕPDdBG4q.74K{fo2M&'M'qzv"" $NP"uQ`.@.^H q1rą$V 1#($ 1ą(q$56ƿOߓ#<Ϸyix1m&|׶ U,,u(#!@EEF)h74Bj. XCA,V<0bLQ^" R "KIaDvf*if*r`sHbY$BiL}fϾޗւ*+ûwa"̜PKXW5./GenuineIntel/GenuineIntel00206C2_Gulftown_CPUID.txt[o0ߑG H$$-LUi5*NHR|.&2*OV&YU[$[/2y_8GҧO PlΖѨr>c 7GUa 0ٻ|zP2<8W;3sB&6D&q@UYhF4 ArT4! BD¬Id8kD" ;hdU5f 6# s+Agg 3!Yu$h9)xݽ9T)dM5DiA4$oAԃ+.E#BdSsF11-\,…/YN)f.s _^2q1s n7 #[AM+G!t$҄?,Ô^5"@B9[*`=Oo6Y"Q@p)W0JRU+ 'q Wi2ON-+P8N C>Ӄ$˷ٵw+gٿ "Bo}pHq68pCVrHG2~6c~??^g6phCqȯ9C8%l$~g?'?5~f3(q68C8CC>Aa8g R!vkJH~Ï]~]g6phCqȯ9C8R(G:(6??Zg6hDف(@D@+䬲冁 ؃7sbmAǼ'ЭR 8tG9AWߏrCVf fsfIRd61^AM M\`7)`)\+»Dx ,‘N5J`)ִRt}#:D(7/%Bs] Al>6үxN鱯7V$z޼K;+N_ŧ&GNn^PKGۤ 8./GenuineIntel/GenuineIntel00206C2_Gulftown_01_CPUID.txtVrH*C_ހI%o7e-nDIG`!ڱNSc8Pi%q;;;4 ό:ЋOXeS&dwSlyDn$~K)vwx\d I`t yUe (i&m/ww*Y>O@.rI%t&->hjZzozR`2Tqp0C.`x /K,9efzy'q} $=3\R9jŧFݝQ)&K3Qyْ eIр 8jd+XDM W.a> g:U)F56X3US^|xYTA, `xmyY" !H-04FFxJXDS͵Mf8`?a &.%suB7xYx SuRiӮv Zf:8:MtA}"dӏ xIyZF8hcj\ 6 d)Tz a:st]Տ`2R.<Al[h%q‘j,?S'}hˑ6 iͽa{ozDQ6hN;&ݍEa1G6[!t`"lV*%y3CZm(89fHT[.պ٧Ts0]*Aھ&7c$rlٓp,Kg{mz[U㠷o_""~=5mn"O<&(|W 5a>Pi'#?&cDi x=ȤbrL`=$x-&گ31J*ֿb%T(m+U/JYoPKG[R>?" ܘH^yOVj@ݭ_ n-3Fj=1Z̧5mmZҷd_vӃ?/z\_6\ S P>naG#\pa;8h (.:CrsCE}/Q)dDldk:~?th&3)0S pP(o@˺ͲdytW~'ŪD=h$'I.s}zkڻ Q V(`y 4BNDrYp㣑:-*|=}{^^ހ^+ J蕉@\E\ՊZ^ܱ5^ J/B/z^]G\E@\"."ʉ; zzzWJ/B/)zm v3"n lqekqqOyqbWzzzB >ZW[E\EK^ܱ5^ J/B/ʖwMԮC.Bn@W^r!r!W^U#3bHUtV$$Όypmi@Cany{V}z]ގ;/bؕWGs]v % Cuݎ1rؒcLiǘ|n1,ujp\~ 棡36c r9vj_xJ̱)Y XR=KΠpČi-#doAO_ixƟ[,uq'B -s@Eqz6h!:>RVi!ZYg=嚙 LIS$gUdWMV#DXk_In2wŎkqeŅ/HB(]ҁCw#%ֲC G?%ȸҠ+sIbԶf$CŠ$X\N',R&f@2\R)9҉B `2q4 df"wAKm ^ D'x"PF $(_tR> >*ovHhEF2I6_Rp;0? W?Ww\~O pFY=Od 2HjAkPkSA A2HF&Rrj 'dF2H ' 먳; nVd A2*ɈsYdtNW0zKwho&d HFH1QI>pk4dd a$#" tUJ@n[O;H N2"2p, O|&d f2zDILFdbb'd A2Tb3Xԙ1R:qK\mfA3h ag쉖lf$g6f A3sY1v`apf#0ޘ2n,*A;)O)a$.Zbb"Vպ% <  [opP* !eDC1r69Bkb VeoqYޑ]mei "C+?EuP#ؤUBwg[, 5s7_("= ~Z?Y~~Gg~&OҧGٴ#IX&۰oa(oϚoPK :./GenuineIntel/GenuineIntel00206D5_SandyBridgeEP_CPUID.txtLR֣0_ye==.94m  cwI%e_*R. Пlyfͱ2E u.EFPeXYØFok9d68ؠk!O+b+kDM: բ 29ݢWZ=X<1fO<T.\(7XX:zvk \4SyP-K:ka*&_MLf̍xK.!y!%谥"阢y>xah]^Eɩ""2iڋtZJL,/cy/LY=rudֲkih7h{KGLCrao6eC-a:܋D mk~:*UPD`)+s2/_&ynElA٧2F)-&,_1E9a WD}Clb*]F9yyE55N0|W³zaʠ@ DGn[IթSA\A (~ԣ5pAdi-EZ4JLPrMN#D E BљeѠQP5C^\hݣ(rj[2"f<暁,h'Q4aHME9*#:'rܐAy3Nww8g`n/L9RrL1NN+- <–xQe]fJV!ƵaeE~jQeQ6n(Jp [Z[in_~_٫Ǘ;B1 `~s jER2'Ue~?߯;|_6&af, 8<'$,Z\'`Y%t<'\\%u|<&hK&6 K?ǥpxNHX9nPKsp/0b:. 9j-.o ZB'#9sGkIPMs‚c 8<'`q<&xO_/-7x,Ӕ#fp!g^n<}`8]6aK#MA|XY8:^9d)Rcyxm<#<y{DUY 1ic1-PÉg!T،8uN՚|Df)R fRsʤk) rbTjF$'F6Y./pH|'Ny@LnHR8bSni' KB UJeXc5zqw0 !OQFRF!qӅf(#L6Mb,mQ#sVF'F0,e&F܌I$@C 4ib+gIgĈAmBTy 2iˤj>!VWɑjNj;`I2NDJ[@J%_ȖSjF1Pq6ie b!b,͢Q{ _u4ȬCH޹~+pdex(djB=h~ow_}+čG||nƔʡh9\9:"B%#CvfJJ/F.E]_PK Yj9./GenuineIntel/GenuineIntel00206D6_SandyBridgeE_CPUID.txttQo0 +;XVjY6jTjI{ȁI`c1c?䏙QL~uh*8\ bgVDq*BYvoShS0:i;K6_յB%`gɑpƕF!iWM1$+=9J8*G1m,?!܋  $ @%m>܅["KVmc H jlh_@ m, u1؋7 syO_ " ++JKOolb%k"}lYjknl(ϕq+w- X QVy.9CYHcug:r;qb)}#_yz\NrH3 <ҜeW'i8 Ca~?@v]nM50 HLcOLut_U>Rg$X?zVZkz<6'oqg|9>_qr^qt"[dRdwz9 x& GGQmMA[E[hkhڢmqik- Ȃ,ȖEYY>dSK[E[mhh\ږ6Yd[ v?ih mm%.mkFiȂ#YY dٴNUmgD)-ڢ-.-KYAvI ۇljih;mmg((({" eQeQ|ʦ*p p{#ޯr p okg9W-fsB¹fɒdViw o6Wl.jv>tMZdz 1ׯg,\t!+vS Gخ\.z=BWx5/\|ŬG q_#@AU]jB q%Bq^.߼!n<}󗧟ءkɧ? P3/ vUmmKR*~PKZ R<./GenuineIntel/GenuineIntel00206D7_SandyBridgeE_00_CPUID.txtWmo8)aRIt͕:MM1,mo ycndi]t;,]gV&:N ҷHQ3qL"(6?{!\|`JQސ d ,^W&*l1sJOOqփv.pf*G,@fS/|r|ꗏ:qнA뇥1Q{.2zUUDiypZ7;_bˆۏ8-GE9I&S&(!k `$.ðGt;A"p*]Ƀ r$HMC .W 4EmxV('_RJ;&c[apb0KL1d:0|[YћTLH\.ؤru$|LTq+&n %O;e)4/ miG~W Q#ţD([:/:Ib(( ×?3/B?!ݹZ@m5ƿvO̗qҝr ?CÇK>X0~C_V .!8Q`pyk>$4k\eGPӤl>¶YC_u*:5 ՝5ҝWvִ)P-asgpt/Q G7if|aZh- +de38pmWm LlS9o|Ҡߋd@A'#磉1h2i rc0!#6Q54nݶELΈ92X3sqm6ܶm]P V"8p?8@bkJX~;4^&]'8aO7D3mxQ:P=2\+y"+vGKl<myOuԟ:fQNAbgߟܽɏ>S.?Vl{W/R0 D`[z "ӥƷ%_qV!ݎwX8 u{gUWUE=!mUIꁲMPm![W9t0MfRZ@A3_ڃ,Mgew)H5bO$N( iMx8u)H^vFoZ(Y$xlS(p (lO.[H$WLGUXweۚhjED.*I8ץ DuH|sH܇XAZ존RD*6^E͵ rA :!Db#FT$ZwdxbNĂr*{pw'vhI y=r=Ϩfzp0#A,R#@c jr?24ٞ;!jAO iM5KBNqIk-h2A>!A(Y ͳ =ydR&[#*t{ =ӢEc0:zF*`[ qYZم4TO`Jf mx @w|þ}H@ L쿤+`K T2?33 AkKZ{YAVdL&/7G-"J+4ZSȒO-/6 l6m<lm6(Wskqr`m`lm`[XGM-۴)6miҩk-m`~m`m`f`ۖmפdEHz rFWgcm`m`s'lۆlsm6^]m ljgo2ضeIyy6W3Օfz76 l6-Gml m6r0 ~6 CTg}m[lÑl6-#!Gmiȉy$1&m`mk'l۪v%m6ݹEe$umpV*nl]pm:H m)jW 6 n6z6-[{瀝Q DamilmD~g^o;hG?r^ô5Kφ[/;~ӆ]N ^`8[C.n;V+j1ADF&Pg]0awҨ#0 ' F9WXH"s;㌓+䊍W=)'(?oў!M>(7Wz?|s`hmH^չM@/bn*1ͤ# y'ڳRˢ(LLLa\e+r.7.qNܸ%.qy.O1k,WC%,WR.ri[(JT.q9Ⲣ\;RˊrK\K. %]reE%.W¥v`YQ.a ˝`\ږ#.K\Vpy.K\NK\6p%S.q9Re+RK\K#.K\Vpy.K\N?\Ⲁ ?\rK\6p%\~ˋK\6py./.q9 \7< =<Í*WRϙ?WYL η+IUN6LʾJUуs͠~D!i,#A>ٓP,J_ݡ0[dxQs !0=#̢@BZQPRw}zcbpoV^+{+?{G{=a{{?{a{ke7ߓ`ot}jٛǿZ&r{^{C?wz>q{܋^:Fǿw=u_{?/X}_{Z?q{F{D=q/X}_.➾=q{_zu\o=q{_ ?W^q?=j>q{ܻz>{}=E}?PKrc}Z^5./GenuineIntel/GenuineIntel00206F2_Eagleton_CPUID.txtrU60PpLKM,ζR0pN/ @@H][?T'!)\ ~!ix44liNe5ocTtQ o Jkin֢:Alu0s/6zXsJ-!:PbJ [(N/(Ћ-][yTVH!@.ߊ.ܩʗ(VA9$0wz+*Oz5,Ry2jP⅀rt~<sJ77+{Mf$Y-*@k/( ȓQ١]*X<~z<ËWvr8@4%n}5:%C& J (}E_@_m/Uo\/R_w]}S,}7^W}苾7f鋾 nE_RnE߷ U/JF_Y +v/jJ_/\}R,}㼾vN_E_OE_t}$,}W.W鋾)}ukUD_k/Y׮鋾)}}kv/FJߘ/n]軡/wK黡,}On*낾M_.;Kӯ]/WS*w7.}k)} }g{u[苾5y\o苾1>*v/jJ_/}B_k/YmUۯ/zJa}X_ }苾7f鋾۱Vo }wK;uC'[TI7}}7,}JUEvjJ_EYC}UJ5EvZJ_CYnV/S:P(]E_}Ku߷a}PU/WS*׎U}k)} }g{Y/}7"}}ѷ7w*җ }黥uRﻠ/v]2 u*}}ѷWw@ߨ}k)} }g{*}}ѷw!Nߕ꾋;L_UEvjJ_EYھQ/R]e}ѷҗ;LWL@_mo fuo?}nݢLA_dUEvjJ_EY=}U5EvZJ_CYnV/S:w=}NO/3}?=}WN_M;K_WP_C_m5f}ѷҗ;L7* EvFJ@YnR_^7җm;J_M/%;KߝJUEvjJ_EYG}T_C_m5JuEvzJ_GQɃ*~}ѷߩM>k*o;}5,}Aߨ}k)} }gZ}O_OKoRo/7Rw׊uC~n)}y݆E?M#;K߇m苾Ք]wk苾ݬZ_G_mu}ѷK黪UEvjJ_EYڭ*o;}-,}^7+חtaƭQo/7Ru[o?}n}TEnIF?AY޾nV/WS*wo;}-,}o_U/S:PKWb7./GenuineIntel/GenuineIntel0030651_Cloverview_CPUID.txtrtQJM,.I-*V ((jZrA @A)H a^QoB=$ԇ"Z(n7~V?IK E( ؤIq(mb ψIIyS)!EAZt8R[eM!̘<; #UT r Y>5Tz^)Ÿ^\|sʪLcfF*d 0) %,L HCyѢyRUQiVF1шY)e&ڭc"``Z ʬQ7@Uz t6vSBxLNh LJa[B1> ŢA; JIȞ+ 褪, uf5ɕO"v89F Ǜ,̢@uP  dDYYBdM*T UYnqW,d! Y?dPK^X7./GenuineIntel/GenuineIntel0030661_Cedarview2_CPUID.txto0'8Mq"! LZ BB<[m:tlI^+S9U#y>O2W|NpMRuBó:p#FpjL4~ź}6k0ܨeεQz A^:B8"n0v\ *A"=Wua/UyWbDq?)U]6?fEof-DF;!O`4pI\M?U!TPrtI3]mq'iU+MW82;\_[c̰da U6h wl=35lʼn5u2)@qAQ_ !9J H\ΉÍd̙=(;Nv%f?Y+1$an%w{7 Q|cDzPs0cJ-vPo[b=KU^}-5꿛AgqjE-!mA MԠS~jjEm l Ƨ |QSI &{arn5ùLRc{7\_#)K} 1+}hFı<%ޕ& jmI4IHbIQbr1 IG"I #NGwrL"n- !{K.$I`lo$Wڑ$#)YtW \ܖ)~й}UL'^Dr,w$Zg_a4rp4D0MJ. 3&wd 0?KMIЕ$Y it@\zv Z4O>@+b5Jk$`/_ ,*)M[5 4m_ulU>bX_,f1YPK- S7./GenuineIntel/GenuineIntel0030673_Silvermont_CPUID.txtrtQJM,.I-*V ((jZr8a [ayG%5-us> y W#UJ!1Xǐ,d%~+RĤ02}CkڎjkɺDu@.|Kd;&vyipӴ[0QCcDM||D+d[iji񳦻D*f`J$dJ gB}`D8c[yiQYwrlY'۹_l4;*JTZՅn,0mɨ I4Ba!14m7Ƌ*%R*gZZ1㖉 f{uG{5x:'Lj kfۻr;2ظux0̱PT` ]V&Τ.ZcWH [uj f)={ߦsif;3rv<1ECצU˭kG]= US_L12+ɫXNgv h)N4e3@]Vuc;νGAgBX}Q};hoh눭\Zf=a{v=(+G(9(з8 78(+G(sQG(qQGQr;a8([ˎ8(ų([OUmmDtMgB@LbLi ֓bJ@l G+reqy +K lo[-@YV\3t5oG9burv8u0 iW :lKS#G :xrqD!Hn-9#U2$$b~rs*D6!R@xp&rb7'*t(*m-,a TRPͬb B!BeHB.ۃPzxd!",J:t! G=_e-2m8QTFY6 yt;C %XDQ#CkG_0u!5bG f IqT^=tcՉt2yƐd5P'#.ɓ2IA"(C H̟\dJEhO )9JIxEe6HT0IS+[㨗.*$y ikh@Db$MJlHٽx- vix @YKaasUJȢXA.CY΢ٮ@*sؽ hu QԢTP_<l.MV(!oTVa DUP^!Xn6en0bk=W*qѫRt`Qܠ@dzo3 7Ok3EQqHz$Ӡ< ]Yb1r[BPʼ v,ú׳Sp^\r/r+r/{{{^{˽=roFPKI5*7./GenuineIntel/GenuineIntel0030679_Silvermont_CPUID.txt~0Ŀa˨t%mYEc2ӕ܋L;Qe$5?Ilu .~:_>oʣJt*,Z<^ @ *99l!;b\g3YͿ1k 5'MyRki&m}f9|kXHĺ&t= Og"Ͷ֖3fvlbv3S5,h)jZ}tqfr&أ-ytL:YIE_tѷ$OIgIWNjj$A _jqw$dӷ}fY98BE$-B=OדW#P.^EDZ@%wP~} Y=UZY[ OY7ǿ;gNE /Tpuv]x C<3s-p0~Vv,4R`HarW=$S٥%R gfw+BdHLHj\-ս/hkWRe3WC%i5َ:/GВ^TCZt(F672!ًj9 :t/ ~ӣӣg[hPnʒQYB%N*ABzYyztbhmI8fHBdYO,#2Bo}-/;p7봣xԴSMϙ ^qӀ8e^s/=e^F cJxWǴxG>tZϊRVIYTuՉXOb5ۺ]>fA4hRF2 $)a_N2nޥ|MBDg1}B"=f>!#.03!v~cDžwA9Cүi C3 7BRd!t3!Ѣ!1ۅtRq!$lbFg1dLd)Ldqv!T}Ȉpb*Adf;f dHFn8j6d6C|L68 9YBlsYme?ͷ;/Y:N N\)IJr O)d qEJ~̑Qң! 'Cf~&C ɧA cXњkg }ԼƘOYݓGן1-coMt'/qfv3)e%}}{[mq --Clmmm-]ȶxGZZddd"$[$[$[$+.!c=Ҋ%ضضVb[ ٖH+ ""Yydel"$[$.!c=Ҫ%ضضVb[ VV/AEEEHHHH\Bz5Kmm9Ķjbbb֙iZ,vߺc6qƙcT*8݂Dx9"Gt jV"[0 0J/ٗ/{mk݅yo-$|0u]Gjv]ȥU ;r)ҙl"ťh{Hf`%3`\ G*C p2ΑS" _e5;Q )bUT B)+2"'nZ IHs2dHcuih]צJQnH YIŸ-✫t %U Yʥ p IN#FTd6#1. bV%AAdU D:D ߣ.#:#7G`dDn%d]ifQ bdC'rnCF əƪ]d" &!TvQ $xcUԳU$#!ě BcUlAqwhA u&'kwO떱gէ˾'>=}?|Șgy $k/J!p^* W6_PKG>k/8./GenuineIntel/GenuineIntel00306A9_IvyBridgeWS_CPUID.txtrtQJM,.I-*V ((jZrA pRw)0'?Momxeė#mJZ{J{lߜי@ulk1h} 2UL&cP}=BBD]lx GF'H ӄx ٕNPA(Y5j%|G.oGޞߨ*`+Є%A/},J|'{zBivSE={b uyO &HBw^,!+R HEY^ 2(TI`BU*uf5s "v}'(BpKaE%9v(s+[0y&Z!>+&⿃#>H M7G_A|G|^AHGzۧ9? җH5JH[}++PK{f>65./GenuineIntel/GenuineIntel00306C3_Haswell2_CPUID.txtԅ0`1etN"D23s~ё::ߝnE&<#իkOo_]]~&kjwO?~zyӏ6hՆ v*q8veq)B<0 s<2X%MN`6:@c "LxXļ#"V1Fyk,vqgJM,21Q1ǜ7U4k}m;՞ޓ-T@!%!VS-2B@yXj4~Ri(PT(ikp{QT.[GVqw֞\' kՅw)}k8Ifp%Jޫ0JE)6yM1u vq>ʹ$[Nsx▊-s-j:Np۫wa+ŀ?OEJCDFxFc11Q|* mUeIwy6x‰K;|[ԀMO'&L|% L׷PmdԫM{/=lZ; λçk{ƽ֫9D{RQ jis8 uVNw:|%?7fGhB>E\0"b#@g+^|FYZל~LS(N`+.,gh"f1\@Y +[st;38c;kSi)l.TO&x<xWM51ѣDv(*6ZLՂ6"@#FoeŴ*ƬXDTLbnF1v/ AM i:Qv9344BnvdI{Yp/:ODa$L䏘X7pie7#A4DY1fGJY1~ - "T⒈4Cm^3}0MiŜ6PPر2\}wS} ;fj[wS9 "(:+r#H$Nnr*NI" ܼY7o}4}d^h*~[U_^~˛W_}Z*s|ݫw77IM/wj2T5QVhWԹT?x7꧛!KxsK{tRN!KTsRJSzI|Z|{w>'޹8Kx/Ow7uH%9KSzITWu%9nJ{x^T/^Rݞ궤8KT/NK]x/^ݝ{%ov~9}EWkV)1Gb\oТ K3E/P3x;r./nE!;Vv8ADpZY#~"hi#?č@D)&.K&2k \z@Yi(u5ek/Q3F,@,`B0vhw 2gމa"KV :+t, N H@^-BB4 s%G*xo83QF{:9BD|B.Djx߫&z:qZg]\*b+ڱkZ.t.HECUt!$M[ 88U;\?yV${O.J uEI @LXJN9 &m0  ten3ZSRsN2:"?Zmz5*KUZ%~oOY XR @Zkx/7Ua a!54Z ,ěтm!5u PBhǞ/h,~!-!ģB:.5CCRޓ!k#KQ fKNiO>zY繐Bͦ'Gِ[7p.3nkP:R[."!P<{$UșVov^Bk CcVzhf( !?NSG=3s qZCKzMCf2l.y(@r>t!t'ND{rs0WpSQ߿ɃVoOć WSWWg8ikuhszſW|WW=xxr,gggq{xxxv,^c,^^^iҁw>1xxx,ggggNxUǠעעW^ՁUK}ųųYg{xxxYXSZz z5^^^^nzX[<[<{ xgggg玽kQOk۾O10΄mШ MV!(3!Q5Y懠Ga=^U1Ux~v3!)}|VK9/!!n٠V0FXX܍7b#VisIp(EzvLeH'qTD&HB$!UZ% &C@0E1✚-vTC8~R(*;&&aF _a߉7+DHdȌNHZo'ڏr]-Abo (mZCr^Oi! 0WN,E 6"/ O $H"hYEuăe8i;l`BΨ[ޣ>#&#?G`bABlȻ>b`Pa-w-NqNQ4@*L͎ htR[TA"X_J:!A0HJZ Kwj;rUKJfJ;{]!.$Ndp'NWխӧ FLJ+ylx!|_|ܼ8TH|yꞨb` j0t|1T ujU]οju:PK:/;6./GenuineIntel/GenuineIntel00306D4_Broadwell_CPUID.txtlSn0}8^)!4J6RPCN\&Ǝ Y~@ru9zj/<0UdRT Vhamab WLfӱ|my.]0a-^dC]K>H>gaYQJŴd&d#F3lB^hJIgOwĜ/R埔vnnKv:eЁ+2w\TUZ&lYi7s' ە sJ[~5<<(jk^hZV)7LT`ƀ#hΚht?FdʊB*ؖMnn?:={4RBȜxKhC>x]hw;'9s$!bDV GW g w(ܳE=ɟ YUԛ6Ytv1Xh.q¯9%X35(;۷WI5h#alkW.-BP5(U96'[4Bu}YT{Xg+)Q3 - }8yIr#YJo4)f$9*F >(if}P0Y&9KaG]e9۹ TڙoqڶpT6>V/'$nϨ@@;kx7q9,e  $qXi@f'$gJ]R}[A8+6ѧbʋE<^9C dRZ(;X&\uݸ%-YlIy>V7A8nD85+aR?1h9!Nbcw-r4ݼg*ӕbY2bJMDr{ӽ"2>+ OO|tϧ[/bì\^q@竊Z̉Ba._M*Jj@;eejҌC pd&``WTaR3&qBLiEruQ{%E6+B fVWT4H0OocM=8:?y.ɤlU:XOUÇw3RypFjxZ)j 9w>>}7m"ljWD|6qM\mjWD&!"WwHCzpu;\WwC"&6qM`W&6qMX;σU~6UE8$bqA<5CElOGb^OS?P]ܹ{r[*<1\6ސ‹}-&>*1#(J?p2JoBCIwlh30غw#xl [#I-yލI2D!n8O $])2MYF1Ri(sYO [̬E*D ?bJ i2H ׯw%̰cL*&kh1olj2B`f#d6@Y:X,CC(8Mֶ^ C4b+"ǽ3BV ^F( $N[DR-Z﷜@5XfmР@I@۴G>ףfT@lt44C.fΣcBY33 ̊mRZCR܋t#%r\CL y6ȁVE=;Мn6 ΠO=%?eiRԥ!DfiJYS Y/椕&L'[VBPTDNR &dzTKVj6waYk!Š(f7 &qy'bRy XmI|g–\,9$r%J8iX+9 +=#]"A DE1*˕bE1MM3.^OOp7h))M |~xF~y-w 8'J|iAQ0D޶ʑ &oM4M+N=bcņ u*{NG'K=#rA 1s7ǝY E[^ DR@\.9u.nU;_l2U/4TWϿ孋/>RYnvwK-FjY/wdj>TūiA] x݀#_]wv~RCR\񔤈BR\פ&5)IJw|H5 )5 q k@\"֏פ&E>%)פ&5)IqMkR٥ Wc*8牃Gb,ysp ͺ` .0Ko^hT~.TErP}7De?|}F`#Cc_tibnTl @ջW)ľApҳdpQ ¤[2}#IU$]APƀ!CN $fz,#?W@j7!$bá^^hH==^zRtİhHs%XbZHl'N&(lar;I4GN!#]@_!H:H:cPVzt҅ٹ].8A Xq / q_-? aM\Νj4^pF9*J;Ϩ(;=8wF 0sF}LG[Pgbf.ݵD$fqҥAz/vMClץQ-Pj:'^d ]s D N"~A Q;@DEGvZ4˕ m#Xbۨ'(]8 XHSjmiog=lM bӃnR/YF9$ z F ,օ7n򽙷gJwV=Q10qnK_|7z xy0y=۞WUb,Jz_<*͆q.ߊLO" J\I7^x1`Eθ٩RmH7kNO Mhama&i]y~sqEw kPх#,K.'֯ilŊ\*9٢SNN]7__훯S~m9H=m n<>בn!E5+Z o/Dw$*` !Vi-lnmk!^A av좇Crla- ihRҜ>- ihRҜ>- ihRҜ>- ihRҜ>- i~M4i)iNs4'4i)hN=l4_iN5|49wAs|O4!iNSМ4?OHs-4cyBs'>-4syBs'>-4kyBs'>-4{yBs'>-4gyBs'>-4wyBs<5ܧ%}Zhh4PK}Ҩ8./GenuineIntel/GenuineIntel00306E4_IvyBridgeEP_CPUID.txtrtQ0N'u0 ax_G_;$?Rb@GCl)G](ypKkx(dSlM_J RJK-K]j43E0OuޢS93^YSnjZ'ʴS\_r4ew멢SA]@,Tnriӿ/O>t_ө}5o*)`Б h~y|yi\Nuܗ)Ğ?{.&Yt < drn*GN "NYS)t"B@-[ꔿw_NJ UzcSP )?BhΩ iܔ_zD|SG=Q?K=QQz/K/G:QFԯԣ[GQRzuԣ{DK=QQzG/GYG=QFԟԣWGQRzuԣwDK=QQz?O/G[G=QFԿԣSw8S|SG=Q?K=QwKD}z8GQ_|}QE8G}߁zQwGD}z8GQ_|}QE8G}߁zQwOD}z8GQAPK}Ҩ8./GenuineIntel/GenuineIntel00306E4_IvyBridgeEP_CPUID.txtrtQ0N'u0 ax_G_;$?Rb@GCl)G](ypKkx(dSlM_J RJK-K]j43E0OuޢS93^YSnjZ'ʴS\_r4ew멢SA]@,Tnriӿ/O>t_ө}5o*)`Б h~y|yi\Nuܗ)Ğ?{.&Yt < drn*GN "NYS)t"B@-[ꔿw_NJ UzcSP )?BhΩ iܔ_zD|SG=Q?K=QQz/K/G:QFԯԣ[GQRzuԣ{DK=QQzG/GYG=QFԟԣWGQRzuԣwDK=QQz?O/G[G=QFԿԣSw8S|SG=Q?K=QwKD}z8GQ_|}QE8G}߁zQwGD}z8GQ_|}QE8G}߁zQwOD}z8GQAPK@y6./GenuineIntel/GenuineIntel00306F2_HaswellE2_CPUID.txttSQo0~G? u4<- h JWFNfs|МDU(GvDɃ"` r>rP3";NW+Ny:,Bla)^eƗ>QGXКDRQ-.)vo!jpiBHqᬥNrK桇\w[~SӉ^ElzQ0h0lfxbmg'qj2|z6FÇ8p1S^HVV1̩}hHr^Pu 2¯o̼FaaYU=\e!bx٩PBY,`]`"Ur m)tJU(/Sͪr C<)`*m1(+i yqns& ;v<41؜¹ ~b~A#6#B펓*szRA[TjIMv4 AEfx #;@92HF H:TG\XCl*#ƶlTiqb6(M\̅2;Du 2AV )utz@lB*.fT`! n{ȜnaP,c/U4EEn@v{`B\!Aeѷ钢tg#A"+W*sJ@vTs{N  :AȯT^[)FȬ@:h Bsځ`58@L1[<*R`#Vlߩ(lU?ZKg͠T\{tuLu1Bav& WURġfTm%fY ԋci?1P`CEOn202}>fHTS__10L0m_~O?=sn89h"v78mnx61~ܻ9qKoŷ߿7 h10`g%`Zp CAP+PKYѴ[nj6./GenuineIntel/GenuineIntel00306F2_HaswellEP_CPUID.txtyo8B'\a{m!ӯ 1e{8yd??kDzєHUZٶGѢ,dUrW)'dIt<8pulx'7Sx{8āmK+HdgdJn@֢LTVY^VjB<]uGkZ~iWL8=709@T@@haQ\R/I{ L CSֿ2E~-N7[t.Kw6U) _ !t$髐o&@J0)T S "WKa) 3)fJR`)))))SSVVm1<]&|o$˖K}r.SZ8(Er ȁ$KOӠMq !7epf\퟽1?CFȰ((2(A#)gJ^>VQ:ˠCL&r&,zN % L hQ&ÑlGa´:Q =h#&Dq Y-fCٵz[B#{pK㬃!WBU!#ڃL]"0B'scòV:1stf(CZ</W]ZIktbb1o܏7V <#}q 3i~?+UT@MfJAg)1DN9@BJC,*Mì?²Azx&܇mD wy,AR'' ,o`-UU,D&V/\t>&yӏ41cizfB,i!yL(-cm0|W9!ODlj 毿(c###!rDr``fȹ,rv#<#a|CZ88|C8C;uHB1_ 9# 1_  3#rH \rpHq]$U i;U  )FW9CCW9C8C]$U i* |K#tpy<#!R!C1$-@2"   Y_F19"1IH#.#DB$gD$.#DB$DR\$HFF"!F|FHH|FHHߚH4b4"- D b4" "!2!FFHfD$N#DB$DR\$ǚHΌ4t " " R"6DG$DA$_D$ Im\k"ta taw!F +ɈĆHHdqzgVi#V) 4bJ$-DrFDbJ$DB$Ea}2҈ + +ȷ 4bJ$-DrGDbJ$DB$E273#ذH <ذHqm$V"i! + !"qF"p tt X!Z70iȑQAc8_ˊ+Ƅ8 )+98Jb$Y9J0%-F•;$o`r6B!Lb$̯p-FJ3$-F‘W.Zb$9LxLx?Yi>$I\[3B^b&qřP%fc~J0%%f• OH9ǚ_&-1\V|\9LcJ3$%fQ -q-1qŘ$%FB~rGBo ߸LmJ2$-F_#ʊ+ Ob"'+94$-FW.Bb$9P#ʝVcBK sW Obb"OV|\q$8 .+9Bb$o|\I&ıH8J1%-F•3&<{k0C?*pr\ThMd*n&=kS:a \/wi`Ql5Qm-^P~ڽ{ۼ|sT?o.>ݤ5Qx_:ĒV$%Q(2%N0݀) e Mwޅ^ z.0a]!N rBG2 ݓjNo$ЊM 2nf֣$̓DI 5% I;z06LBP(V,HHd Hg k1Ь^m#)+ QbE큌= ז AR1Fi9ANF9J39D`9A qjDK,6H$AhJ Nt(w_#IK_#{d1Z|IVz$t^cZԠɜ| b3+wP yd&X؞ےHk=XVqU;XpA;.r#I™(,p;{;g *lq?L'}AEp=ƟIvoO每6-?/W2Kl z@"D? ndeUNLVu@te ރ(lkj TF_]\֕a)O6^TB.ldNqNl/S7Z"n@L=yϙʰ޶;.y<_GS8ϒlU(~yi~^-)!V~1_`.uVɐ/2YzBm,mmW?b!RaHD]p2((đ&(%|E b.l,ݢq>RLFW";a&0g-m~;> [0` &Q@V Jh;Q@mԈaWv֖0ܒWqȯCϺ 3mAOL6Y$ɮ%1 4шwg;\oBy'Lp𕵆 |Yl^ܔF vk{X'AԅCmJ·D(l{@Ѵp~״#f.ضijln+ EA80JCx[yGg $>@ 9g"mF iM2xq/]PQwX+xe/X?z L6tHxț7Wi֦k"ESAw=C>C҃?&عAb)?9uzY< #<###<#_  9@22H*pqH*pppHVi1_  K 92H*pqH*ppȵᐬ0b $@rE@R| $@$@r/dfU;Ug!Ya|H䉀|HH]əFZW9CވCW9C8C dU /U  6_0_,>_I #|HdD@R| $@$@6_3H*pqH*pppHVi1_  W0b!rFR|!!rm8$+ \ Wߌ0b!rGR|!!l8$+ < W0b!FR|!!m8$+ | 0b6)D1. xwőw s|vy?w]rk/lMyZO-pN:a,&,3NX N-]'Gea- f% N:zK-K' &:ae8 X'lXzj9:,8 X'8,=NuBe *`0a٩%t| X'`{K-]'V2!,L| X'`G>NxjY:a ZNX L-G'K"w/v& +j?v8v{Uefx_p΂lI}+?ٽbO/|z<>9{f#:.QE/o.,\9%ĖX$.=ŦD~Jz =B-yqY@l#5!G'* $ 'ɈLRW$t*ZvAV2RϞlcD,E{YF=Byl)ja"%$*0 )^mGbӓu6ʡL,-=lDqSZHsܔ&Ĝ RɳLY:%FVׁA v5X#fP4$F.ɻ;a7 `^۾TKR6Q 4ibQgfTuÑ1b2!ҤPeDNN f]C ѓ6Ç߈{c< d5W`–`Ujk-*m! bߙmP*Èg?D&@&ogDKG IjO=.5t[gd~VaMДӌĩ+a@;B5?F $SjjE MɕސgeTs2R0Bu.zOEGxůwίN?s7]^(PVo?;_լ[!^/w_V7Y^ _WB4PɆF{zΔ/LWqQ|YPK^9./GenuineIntel/GenuineIntel00306F2_HaswellEP_01_CPUID.txtW]oF}p! /橀qZQEQ. p2MuG3眹s/`p#-z%Kn2ɋ S&f*j~7{E3Eө_]XuxU7SvE殺 BZm}9 L6d2\&gul+| 4 ('Wt_P+E5N[p0Y :/ Tkc%gv1x+­_IY?Ofi-WOyKwo6Op#n aznw29x2/2k"R>x|AtB ǥ4Y*>Uq:. N4+NxD>|_YF8dRp4/ E#lƶL^@#0J%} P QnJbaxֆ*&%D#xRֹ,~'d^~Й6qF3mô n+616vtWX #|-6qxu/xu˺dR٫'>%^hkVߺ:0Sql2M[g+aű\ _u_q clq6s܆ Yv+Q^ `.y+}87hοK ^`dbMG_{a+4,MCX陆%L_nWhyПY#'DF#F;D$;0"\%64à%6poNj'pt!*>tbGhtyIXĮm`yVb)+ĵ/8ZqwNʮ Z ^FY;Y2Jb-mnJ? AX!IxKwjBwl*ԫ#%m US -vlCXn[tJA !ڶ?s;މ:+.V_5^UTzj̣m괪3R7tnbXYގ`3FA ,e~>η]ćmA]ս I85n4@Ğknif'w;c 8aWJy:"z=(ѾXZ]?f/H.u{uQk߯!5ԃ(+6a/{wncIQХ_}86•IXP R<%?%,",Z D$hh(Pihhhih4XEXho(XEXEXtXMDh  Řhhκ"щEXE bEXEXEWED$hh(Pihhkh,XEXn(XEXEXXtLDh = Řhh޺"ыEXE bEXEXESr9Qpp(WC1!!¡UX&".J\EŘLC8C ~:1ue_.".J\qQ(D>P¡7!!¡ΡLq%.ZŘLP¡á]X&ڹ(qqQ)D%::1ue ŘOE3щ.!JP桟bCQc0HJd{cvO?nB:fս1{O"Icg-wr5Oy9o[vh]NRNN>,}܇NTnǟce&c}#JyIsoR'r;!E3Ln`chc8)w|K7ch11z#1gK>![v,d1yo1Yy >܇NK>O8a;"ђc}#Jyv (Wܷ=KSWɏ0#J-$]rּ4o%y%#x.nS#&nqD>)ȹ7?MŹeNס' IwC.!3 AE ՘V~ViGW$\z/!q@<|#M")yDxu CZ.K,?Qш?AB2ԁ#01;v ;2RӁT#S$6Y UtҝŤf " Eȵ;ȐG ;A@\dRsY >ᆬߧX!qCB.cd<͊S.nscC.:B!DD-WC($<I!Q"ݮ y\5BB]oTn5":$)"fw#Rj]h^! W憪BqPƽCC"ӡy6E2NjO%C3Oǝ&ӿ4zN!I"5ZǞ&'*7˧O? > X ;^0\H `n(]oO6œWd}a1W*Umk WEH@SOu5em Uӆ Y[@v5X֔u5d ։s{=eMYS֚)nYSBY_7kCKܧfm}',R_$k6눽vGYڂ'`)ʺzG֔5eMY+e})dȱA֩@W H;S6YgͲH 8a$Y)k^rG֔5eMYgY7H]kzjY]!BYY%u)%a.5eMYSmYS֔5e].eMYG-cA#eEI:˜$kC+ʚ)k36[)z-k:cw_ȹ3 +-B~E֔YghS 'Yg"rϕ5eMYS=YS֔5e.eMYK=˞YKZ֐5׿ l00+ !XYS֔5e=Һ#kʚ6҈5K9oDC5Cݲ;!mA 3&IEZ֬ X;FXʹ֤ 0vh-+o쮬֤5i\ZOkhMZ֤u5i;, scXT'hmhH_yF>OZljMZϥIkҚkZZOP#i>UkGO+k?OkҚZP2C8ZQr MkҚ~0[&IkZij=Nպ#6-hMZsԺ S|!FҚ&5К՚kc Kp铴&Iz%Қ&o:?K(i1"СcSBiU6uJ)FY5iMZ?֥iMZַh-״&@:N ABuAHր9HkҚ~, iMZַh״&f ^hѽ ,9t;OƐ_uQE9ljֆ}հIkҚ~,[WIkҚΗ&D(Pg>Z;Tx 5i;̎>v-IZ֤cim֤5i}'[몖R= ݺ>B!iyUHiz~kݺf\IkҚޛ&I[&u@z}#<X7Ij.5iMZ?}֤5i;ӓ0 2۷];phtHd7Of4) }+\_ˀzRwyVeU=鄴;KX]쑊s1dDGyNiOj *y]}*TJ~T}RIxOT*e④ťDP_x[Ţm c%v*!S!ҵ޴D_GtxK]>&$s~>.'Q^^ocHj{MGK%GwXð }YۆVrr6JNJKDRiJ96 ]Gl 6t6ێ~ǚ V=Z+8:L#=}*RpD!{  ) 0@ )RXH7)H!R8H RxH(>k3 m΀> 3wD7n^6F4}a)tEw=^t@*ԓhJt%}Dg3*ԙLu:3PKP8II57./GenuineIntel/GenuineIntel0040651_HaswellULT_CPUID.txtrpR70z.`'6Htj5'O6-mw/䫗0&?M#&ۭ.KK]jMH!U,VjUҹ%P?$d+`,L8d+_ 6%f6aABPD[+-L"\⶜|rNtP=Є%NEF{hDsRC }@Nc-ymq'aj'bTDF_)īl+&t4|D -jJQ + (n6ZyOSuQx[^&ک`Vfo MܻӠ9$yBs4o\Bs4|p ;p[_PK\յ_8./GenuineIntel/GenuineIntel0040661_CrystalWell_CPUID.txtlSo0~G8i/ Ah`yZ]A"UVB[iڃձ㴴lLΟsL DT~`8ȤK\u1 ^/0}D`AxqXn65qu006I56Ɨ \N?\&BMVt6 f3t??DN"4nČW&  ceޒ2ճUGZƮmpHRּV)`KĘiL M&XYk]7ZÓ5~Oc oz )3.T#rbH8ݏ><_4o9ݮ>{J$m6B(@aưI]0.޸ַsPsVyW8Uu-nODI-?>AN#X5fVӦ6ՓxZQ1{

9Q)k[~4d~/Cqf\^^i'uQ{QfծQ.j/j/jߴͣԮaobbbM>nڋ7v{mQ{Q{Q^~YB3"hTs8 rx!VICPZ'Ux -AOz!>3bf!Iخg09R.޽o~v}xE\f Uݠ:0 Ҭ]=W#N"ʭvҹd[MJJfi C|"$*Af%\)ZK$[fvJ$fHUzo vvחPi,^p+҄]oN1iЁ}RïUҺ¼鉶9'dhvw{;+[?;AW.i2e>?I2a.Wu% 3n,+ ˎrri?i.ՁD"X&,ˌeby`ٰ ~t{ډꕭ]bl6(1>8 4 3'TWwU#kùF-@&tH_!|kvjyNҵsW:Lw0~*ne 0aWDS@k:t`yA ˃K0nڌ䖛N,pxAk驈# 8k 8% +ܓqL$Umk7  Zoldwdc)^YLbrIGHN*MeTojYhoZ[9UST!e0Az P3..nmcJd[ 04MƔ9_dD ~'—0!ц8/%,Y;ށӈ4ܥy>58dǁv9@\XҐ)gzdB#R65d_U#TXЃ ZiU}w5 d,FI`t}rƕ]0/X3ToŌ-7<+( f 0Ì_!*_rI/ $u ^E~5 <1/,333~<5AqV8ƵBݝ'2pc @,.CS2,eP҄{Aq@[d $1ģJu꥖i,,Raж0M` #l;oa ,¦NB=\R$(j>"(@rd4aȗ[ Kw\+G\MA=@;,͝ódaJfK> 48h B:\:\b_G 5UU)4J;A@Km5nRsllA@f> :f1i+ʑVSQۋNj[ؔ7gX,5;ӱ#{O_=?S&u)ǿ׏O_?󝲢;h}ϟ4{ViHH M_{Sۛԍ_}{7 (8uyׁ, Vq[?R[THTHm6HTHTHrHWHm/6eS6eӞigS6eS6eS6-gqgӧ:B*B u@*B*B*CBj3))ΌM'))i9;>  R!RW R!R!R!RRNj@݁MٔMtglٔMٔMٔMi z2H= o[Lgk{սw%(&(1rFxᏏŦ7_-n>6I bu鏡Nɘ%c%ԝTd"UndZI[PZTu :K+u &S1*T`d[K[Ȏkwn7=xpJ 1u~$3d`_;p\M0GD GWL1Z};>(v|~OC_,C)X-KaZjI,.-:ն)4PVFuH!5xJ2&$tu. zGؐNiڽ_iLoD;׻ʵ]^7MDƠCWI)%lb6۽|zxd;W[SW{\NT 9gRNkvښxbIN*f5S) =UoV*vR)*X-~ruѪ#:j%xUOdyrXU]{s'yb|emY~cdrcM18}~C爎7{:nt/6Z6G?`58q,.W+|| q˖ATX8Z+y>˸)+@ϛ{NBp+0pD>?hM~C<_<|)]6>6N)X:,uG-{qfrr2bXnX,Cʀleewk)"X:,Kerr2b̷1)Ť#RdóTKaXz, +˄erò`YlXZ?5&壟2"UJwj~FFygZ?#Ԅerò`Yl&3ePKJ,)8./GenuineIntel/GenuineIntel00406C3_CherryTrail_CPUID.txtz8@.W`YNp+U>a' G$C \]&gMNdM7| A$Z-9j.Цb{2L HS j>kA6ʄCTDTedl,('boIV@*FX̐X4#ŵ "Ow#@Ґ0;)"0zIEtGHΞH]7IVGH_ DOk5f&}=XlgO:W_ӼG {ssa NXE*i䬢.9\o"Hx[w$ $]|x>)Hx'Czx;γg }}Fh'mwRጀD}5o&s@H5I3\!Aػ*G*.Ӭ@`8wRKS 7l&L6317Vrc)mjF,H5{6LLJ"]MrͮNx eMtMEr.pU$=@ΰ:Uǧ!I$!KҠ; 5s22$ 'DISpy/u/ PKl[=5./GenuineIntel/GenuineIntel00406C3_Braswell_CPUID.txtlSo0~᤽i!D+M+x56rU律|GT5mjAѓAb  d4 jz}5AQ˥fa&oSwOƶ' RkP G%pDq zQ ~[%֝*Eͮ9OR|S1󙉃O&VM.~ki2:fLllfF$ƵZLyn Q4L#=a1.{{%NFlr?f܊"`@>}ij/(ubb3v 7Pk 붒ujW氒{|kb7y錊ٻ+#v5-^[Y L7XTq;!9]|㌂;G^cz}_nQ*ݷ0 n9$%vF0P6\3gjC.2"IZ*/t:7iLVbsGt$G]PrHS-|l2o@yr'ycLPoC5жRHQEJ= `G+Rw'R&= |yIk~w!*3(B1ZCQlF a 1 \rLQvm%Ag*-CB ESYTRY ܀D!fcbS <)[ ߒ( )9)FY"u "s Y-`F iרH;^#?Fu0F s'Bn3[PوFz CFld[`ܞ Q夃a'4cwJh;IC3:qHHvbXUr&-gykf$A }ΎSC6"=](TÐgiQ>FPvPܺ/f>G KAJ!|}Xݩ1 !5G4Jjeb )bQ}n~^,RB )B uDaf# @ːBC|_ xl_-^Md\1nw2Ņ !.F.ODupjqx(D܃x(Ċr,7c_ 4@.vĺH`xܲU*&ur0[|nۓ 64B.\6( #ĥ?n忸A7 rއKݤv"/cX&,3ˊeòȱ9N &l5ΧX,-Ke2bX,+ ˾Kw, 291'Fa4XZ,ˀe2a,XV,ˁzQI,LscO-n? whϧ{>&{>%gi3ˊeòc9vYd\PKn13m"+5./GenuineIntel/GenuineIntel00406D8_Rangeley_CPUID.txtrtQJM,.I-*V ((jZrAӃAWbxRAcNzYrڍC -SjS̖z*UaO?~zyӏ]|V!u @]fh!CF' C+4vjpH_d-:p lt(; 8\JKp˦Xh0E^ 9mIu!vϘ?`fLѧ%U :clV1w4Rtb+vbO/-P1E_-_2(TwS]S]ݸ2[UwYf !mWfmd&L5|*h MVՅ1.h M 9q ѡUNG+'w㷯< ĻS#(V FqXG'Y;0p6G3#aF3 xbow0ZV"Bto]E=RoZ{.LӰVBQ_WQ. _?[: N͋*\‡߾ w>/jfZԲQO\jr[{Vޥiwijҧn=a$(^%WH(K+͔fqm$գ@5PM6jjY*T&2, KҬYaiXaiXt|j^ռfT@5P T@5PrA-9}3D|~{S+@uhUjsgڙ&Bs(uz} ܵ3O9\{<"$J;ff ﺒKx 3&Røn*^w `:R+t(*w}Mjo{ze=r#ߜRa@ HH MR=@a<9,P˅T@ s3Dnds 3hlZ,[Si|5 q^\@Ǜ⽲7iH &grL,YRD ~4]&Ɨd3>FeKj䱢O):E*`M wYVK'x\j;_ 2 B+`LT5St(:SF&bnR= C➨deZ%K|(nHJU=m 0xLLiFafT$bF NξcMЇ[S!|09v'"ݐ ѦP$!FxtB=!Qpk .,.sTMB >A67g= 7l1)6CR=2gqx ˤ,O'^.SP[dӌSBIO3$_'_ΚxY%.CLsSjUfYJ jH2 V1\w^BKB'QPKn0i 7./GenuineIntel/GenuineIntel00406F1_BroadwellE_CPUID.txttSQo0~p^)P(a<*ҴWcGZ_?cjOww?KpOdI/GTąAz<_=MaN*< OPClמVfLaEL~ VD+@C:} Fn 86쵙K/1kRG! CFS8ֳw9)? k^VΫւt I,ߛ@ŘlL}L1%he %.%[5sPW%$> LS0]ă*1V˜4e~Ĭ+%`UGA|A!R mtv1x4ǹvBxxP}!P3MXG1A`6o,B}O܂c!bҸ?^ Q!R{a4JX+|T+T1rhkTqPHTY1jY0_nSb%58"hR@> X8;sOwzŜ%ֲ=mlC" p GVf=Z xQs& +A sEGI#E.|Lq9N\G:S\`"lRl3lGEc8!\s~r&"xTg*.#X*AbcӦ.nP9'+>kc^d\` H{S[nJ94ڴkL6J!3hia-GbDr[ƛ+s VN f~w v$;Ofû2Ҧ1HvH+&k"FSDKE;j(")Җ]ˆ%  A|qE' fq/ȓAs ( HMZ0eoquof{'DH0# # {oYhhǚR .{lC FHfWѳ%H:EboCC3n<45e*7q1F LDt5'kLO/K kD  DAL_NWt荒DC2l%t7 z)ipe-#]A%)E6e=OGzaAD9$֡7eS$+#mDg1\2@ ]8̑vBQH;I&wY.H*UxVY. b#8~UeCm"}lqq?|ˋ_?l?_x:S Jsْgokko>>#gu;\Uw__Ͽ~ 0`^N`cUXT.Vw9 ;r%Ɖg߹r5Wtt;vFv|vVvrv=XPF-zI nXs"x.NٲKȸd$J,hkWV,dЋ͓_R'Nquvlu&U&Sms l?SoTٵ;sȎ.)wo}{6F'̆Ұ:lFBz%lbĕqW)r^iør"۳.V+ Hц}E)`x:+xȫD:/ԋ.7|?WfQG#,R zat_3\'_Փo0>s& j%\/)L埃 >XeSj, v¢@:|Le2bX,+ Z &~j d߀}jbX,# ˌebyiEN&.OerೝT`itXz,˄eƲ`YlXv,{i>^T_F g?ӧɽ9Ӊ9 9[ܧX,+ ˎe!rcPKvi._`|8./GenuineIntel/GenuineIntel0050654_SkylakeXeon_CPUID.txtՖ1 ;nK2^]ffffx:lwΆu3j`x>'m(/vHYgF*٘GioY Z79֨{^|3xhL۰HV@q`=ӆ&MyT)2S_9JR_C@  "p+ u$T1ubS9V84.a 8M,3%yӀ@rYy)Mu}Ү5ɡk}Z[ڬIyRS\/S,+s;`g,GsEJ8o}?T@ۓ55HT9V1wbAK7*5L8Th]LJ+T-EKˠeeuk䵺"wu))]`ƕI9 rx?4*rmlh UÊ4KP |dM\_=n1cEIaGp ,l`MW>W s%{pm\Vn2ԕ˴U,; _16<9Tu"HH[-HHHH? W)ig)))H =+HR R R ұi;>R R R R {*H/HHHH5H *HR R R { =H R # HHHt.AڎA:+HtF@:HHHYoS@ OO2)))i|V@"@ @ @ږ @*HE@ڲHHH@ڎ A @# @ @ @ @<5 -yjR =# MwjR R R ]<5)HӝHHHNM%A HӝHHHWvSSIiS))Էԩ$H4ݩ HHHtuj;@ڏ R GR R R թiniR iKR R R Ҿ85c H{E)H{6))).NM}Hϊ R =# =HHHtqj{@:*HtD@:HHHtqj{@CZ@4]HHHԎ= !- R " M!R R R }?5M !- R # M!R R R }?5M A @:# @ @ @ @~j@T) @ @ @ vY@zFNMgS))멩iR iKR R R 4vW)ig)))i{Ғ& 3t& R R viS鈀4ݩ HHHԷԩ$HiS))۩ilSSIiS))۩inSSIiS))PK'p 5./GenuineIntel/GenuineIntel0050654_SkylakeX_CPUID.txt՚8 e2$&yL~]pύyT%n@͏Ÿ_>{M3n6Z@x4am >ξYDFXmj2*S s9qw;F9hCQ"f:WttuJ"$ 0GKMq!.`d#UW$ $!J( &S+˘]e?e-bPD$;B& k{eڥ%rWydY>heD* ry%&;&zVH7>c ۍ1+RMer0\%1߈&),1,M ϻ5ilmp>;˭ VvV EOM&q0faT\2cH&Pc1ߧ]z[H*ٱs#*>L!^+Xof)z& HR0#zpke7NI>$ ^Q\\KJXibB h}rywM˸c.sK`䜭qσ>˅8yX쥰)˽;xOb2 $7WMm/`؜4P5Ͷ` d⼹kNC0J{y^;՟KKqkח4|55ǚf8Mt~z_Ayٻw-ݻW P a]2X=*>\{{WpWpWpWpW1Wc00 0 8C+9\ggWpWpWpWpW\1Wk00 0 C8*=\wwWpWpWpWpW<1Wg00 0 xC8+;\ooWpWpWpWpW|1Wo00 0> X[HWAXXX-5XXXXŊ2]5AA+#DAAAA?].G, ,,,,,,JňA7aƑFA7aaaaFT 3.n +ta=BqeeMAAA{t£{,ˣ,,,,4]ta<attaaaa._Ep x3r b(M#6݄A_Fun ]f:@~}K3c(,.3zWtfsrL}EcΜƯuKh*G*GY.?U.>cc*7|R{ /|Qwcʽ$'X9F(1NQzcc Rʣ$ǠST 1*GI>ᨏ`S 61"/\A؏/F;*.hv8}?$9 Ы XT`9IŋGX5&CS^Y|zI,N/ &[?ٿϋR#bOԓKpVM'~|$?Ct.&. &[vbUͅ(Rl2 $+nd",KLK9GV#')L n2Q[9Hԙ4N>II~֏JEaf 5 raML(E`DRPjBIUHEVDgiUn)waQMs|L2; jP)LP!y\*{ Ӵ3ˎ؀ j[+!HkD"YӢH#(,y͍ z UɥL\Rd\LjH{p~e")rkAtހ%KUݣFܺGףܓ;=R!m`RP,k^rb01)bvr'FS<&eL!k-)*v5Q$k&}_ߗ'Ev"DF(ua\ؓ✃$u2}G2[E-r-ĐE 2nЖ&f\?wɶ*KEM>ZxB+|Wrą{P$LMcwNPGD4'_PK{,W ;./GenuineIntel/GenuineIntel0050654_SkylakeXeon_20_CPUID.txtws8^) .WqI3y؊3$>-ʘC,?mSq T"Rkڭvk&d[kDW(aDƹ h\vkȳz<5텾soE_ԁX,d' F F\P\>}vz]xΣGטX)EJR6݂!jt;pW;\r5Oci[ѐBKė] %fGjoQ*:l^SN23v)[k^D:6'v"[Y%2%W5*^xZMNB?BL䙹Le/3բP&j 1ˊ'Ѕr<+DM3,3\-4w7GUmv߁Rrqz@ Hk,7d5l/vv O.s8Q'7pu=riq8&#'.0-.Weu RQPa'54ov6@4ZelPVy]lY֥aÐA/J($4_K+ |BKŮ-6lŁ =e-ג%ܱT,+Mch''8 W@S-Yz(u>:^P5VֶWṦ:o'4PoWd[Ck佱Rt U@ RR'PvA3BTG&lID&ܚ3iVcDDw§ǕwhED.ZDz' b1OL[ * w꽉4GWTӉC`d 4K@5h%gPf.-6N! q3@'A ꓂ )J-FQHXP$t"'VZDEqukVIݺ9o*ˈiHk=d#6WّWdlI#j˲ .P`r~hP6M0wN~l`tSzz"Ww]j2Bɸ Paa^R] )W7afKWĒ<)CAn0}=`@ <Ibn#7s *$T$u1Dvzk#Q~kA eM#nfQ~=2Zz \kk wKͻ!]B\f'e`A_IOt1 !U uC @ @ @ @ Į%k ΅"K_/////Zss1bkbk;@ @ @ @ @lKA있Bmm////=A @,^11111;R{&"/_G_Gk4N1 !vV vX;@ @ @ @ ĮމBU/////s;1111'u'==00007 {C[-1#1#1#1#1։ 0_`vؚh}HHHkm9mv- Z v؞d]k(1#1[+[%Fb$Fb$Fb$Fb$FbGNbDm! llkIVJHvؕ1QaG00;*;`````w`v#1#"]b$Fb$Fb$Fb$Fb$$vNT v؛hݡHHH=KNbD=! iIVJHފvؖ=Qa``00000ۓ/}}#1#1#1#1##'g%K`00000;{ %Fb$FbkEbkHHHHHI읨-mm0000; C^.1#1#1#1#1{Rۖ ;BQ00000{3#1#1#1#1#wIl+]]00005 C].1#1#1#1#1r&* ``O`O; lOlPb$Fb$V$KHHHHĎ 0_`vؙh}$Fb$JH#1#1#1#1#.?r;\@>0`r t+@_`aafQ C+$Mb`쏛8WPb5m9gq{3RXiw*{jpcq^[{oE˴Kcjq]ooQ| +KV_~ϋ#81F ˺~?xOXSPp|piT۵֊ *j'bs bu/)@ZTF;m |Vf6F8t%l17*A.39)# xB8])Hf DAb(Ib@FrBi) @jGJ++H@l@0P3O۝4JCSQlƒKx[u" \#_ Y(eޗ1+`JNwNe8HI[C15JDWr.~󆈷R0TyAHnV,I﷬ٿSxOoSMe;5Lp^aÂfF Q?QIq Wz=ݣO bNvv'Bd&!I Qe){/McCd"zdeX6ҡWd'^f Aq l/$#*Tvl{Gˈå>X&@)L->~ PF4Kɾ+KAY:cpzޣN9 [AB嶡@mIsKlʔDL{Oyv8", ⑈-[AԮA<s'ە(f A T$r :I;"w8:WD@5Է/ TX!Mt{?Dt+^7IIEՍ{{ S#&)CG'TjP{TeTnHT-+W܏\+6J%\UN҆+ƕ|?W \+p8\+ \pekR͐:t}+J^oኁ+pWĕf1\)q+pW~Ja]眽J^KM4W Ep29+wspe\$JHɴ2 hW \YÕ6#\+p\?sQ̶.R̜%W \+p%9ʰnPW\6C(xM]r2\+pWpej+p+y+ԕLڼJ#Jl<1\+p}8+Cp+p%lj_W\}lmiwp%/qW \:OJ3}Wk~ ^6s+L 72;JWW ^+x|WyWm^+x؟W,U6VL|W,^+x%WrW^:ː>j3!E1%ʣ_+xe+!{N_ɭGI+DsV,WW ^+xEc]_WJ+;}eb%PS1J+xzgwW1/ ^+xE+6#&_I1MYŏ[ ^+x/yE{=+ٗ{^bHRF뾒l̃=+xWMx$rW^_)aq!+7G{W ^IJ^+xdW5YắY ^kzW+x2:+Î{R}i5u_icTu=W ^+ѺtW ^+`9Q+EF,h0W ^+x% =+kGxeW+;}eĸ2ʨmIO]JW ^+_J tk˽W ^qxgdqX+d~4)G{W ^+x%rWƗ{wB_%xW^+xh4/^+xҭkr+ڛJ\Z+x% 5x%rWt+4 ^ﯔҫ-^1xWʗ;+ф{wJWuRJ뤯W ^yW3$?_WJ }Ŗ%Z͸+$fhW ^+x%zWr/ ^+x%x2M2kYJ]1W ^yWbxrWʖWx^R¥WXe ^+xh7J ^rW }eYuK޷7jd}W ^ie˽W ^;^ޭ?,QuW ^+x<+c2}W ^+$k9/:ں~>$W ^+x|+٤tWf/ ^+xxң2R]2{W ^+7Q_WJ+?{Ŋ&\yJuaW ^+V=+Z۽WxmRJWRtU4W ^+x<+9c^+xDsL](FN++nNxW핦zW|i/ ^+x%xƩd/%6 ^+xG{e{W(/ ^+x%㕝`ZzܺJdnJ+x-܏JrWʎW+a/O}%"ΛW ^+x<+9wWR+x`vB_iɱW1T ^+x<+!cs~W ^+v+X%>\<^+xh$SJ^+x-JM^)RG3+xWڰxW ^WܖWl?y%^;^Ԓu_#D!_ ^+xW ^+W~J⺗L+&%&wW+xWj<+W˽;^$Ӓ\u_ɳW ^yW|xeMW ^yWW+..=WF'}{W ^+xE;+ڎW ^yWҎW+O+6xWZ/azW ^+x<+ٛcW^`וWFʲ }{x%~+#)Y3^+xq^MzMq?y[?{% {ǽoW ^);^+*}t#i+xW핑^9Wxh 7ڵWF]zqzWJ(xWʗZ+xcbB_Is=~JIzXj(^+x|+W ^+xmyRC\h¾=}W+xsⷼWW)k,7f^oW ^+xE+xcvWZ V+Q.JbWʣW1^P;\+9'̌W ^+x<+5W ^+x%xhCʬ++"e ^+xG{WW ^+x%x8ߺܵWFE|`xW9 ^+x}\{eᕄW ^+xJ6m?+xbq}~+1/i*^+xh ^+xDJWo_apWʣW1^[^Z$dM޷wE[W ^yWR+x#xe^Tq~zxXmWrc7x%tW*^+x+W9}oyFJ#I1+xW+^+x㕰J.i1,ދ+xh̚ ^+xW).^{P% ^+x'{X?+xW^;^+ t\{e:Ō5JxWʗM ^+x嘾vWli]|aV|W_+xVkW+#_J ^^J! ^+x/yW+6B_)[^Rf>Z+xW핞3^+xdB_qHJ_}I1`_+x%, ^+xbJػK+x(^+x|+*^+xlR{.4{x}WxrWW^iVq}-W ^+x^W1^ xg$I-`èUEW ^yWrxrWt+̃ ^%fYA^+xh45W DWz%xջ+.g Wʣ2+xcJ ^1NY-+sv1˹'{W ^+x ^+xo|>+3+x&^CۼW ^)[^ԐZbxWʣW ^+$oz%WҸ*JoW ^+x^I!W)}%k͐J/qW ^)uW ^+nݯzx08m+.%L{W<+ Wʿꕞ^+xWW5]{G[eU ^+xG{eW ^+x%x8V+WIMW ^yWWnyVFP: ^zW ^+xXoW ^a%+q+x%b[^#w^%pϘ`xR}OyJ }%+kWf=zB_+xi^+x㕼R+D ^+x<+ԂW ^+xlybW2, `̃WoW ^a,ubvW\KHs貲W ^+њSW ^W%չR[S~W `x?+xV_Iu?9d7ǣ<^+x1^+xWmRV2׬ ^+x2=+xʎWrA+Q]|6rW ^+x;^&cW ^+W~JC+\ysHʳ¾=^+xİz%W+c,b(.AT3Ilk̜NL^[lufp-tfn #v_n) t]Cx}LJЅ|[DY0VyY`] T"=%S4U!c}O)6Sl$ITJs4cǖ,=vfD$b7M NgQx:}i%.?&xђBg0n&f]a=;S?PJxu_Qy1;A0|NBA#)56D=9Fsrqް\/Ot_:)k {5q!}!}-tM\?} qmxﯶ5:7[ W[x#F_ą:WcA\+>qIJ|}^Fx7F @(%k@ ]t{>t!0V8 WUL0V8 WUL0V8 WUL0V8 WU0V8 WU0V8 WU= Ca*,p«)ԙwTX [(\WS3Q Sa)l?PK%u h:./GenuineIntel/GenuineIntel0050656_CascadeLakeSP_CPUID.txtղ:K&%[")ffffh@ya%2v O<_Jw:%ҖzqRWv=y''~~Nֆak%@ m }; yT g hM,NI)ACt-"%b8 ֥Q)bZUkg6ǴNو؅R2 i h\5bJ*۶W Ί=l;~]Zm,8WmE'iEinjm4˭t4)xs x}b4Fgda91111u]3a4Fgdt0hhhh}a4Fgda51111,]FohGhhhѥ6O茌~Fhhh]{.F032a 111g`ct7FctFF#~c4Fc4Fc4Fc zF0џ?=F132a111g`atY0, ]˂300athathhh:ކ0b4Fgdt0b4Fc4Fc4Fc :nCb4Fgda0vò a[Fc4Fc4Fc4Fr:;FctFFF==1>0320hhhY F}F}b4Fc4Fc4Fc n]1n"n=[FA0320hhh}2zFctFF?"~`4Fc4Fc4Fc >o1=2/茌~Ehhh}1b1:#F1111zFQ`4Fgd'Fc4Fc4Fc4Fr6_茌FhhhPKN, 9./GenuineIntel/GenuineIntel0050657_CascadeLakeW_CPUID.txte6?ÔQڟ13%,Gb5x <8;fn&(>^uw_>LOr[Oۛan9K:(BzQ`MjCJd2:-3x҅ w}4 {(ٛ5ܸ(vTn&`^ YqQjȘ{F-&SJtw8]Jwp"0l-p}qwU?q c)BN]Ph9 y8"꺐첩|jQf2EduJYL/o{ocT*R(0|PJ*A0AFo#sVAӥV_]} ૼ.2=(g2ʁn N yuHnᄒ_e}\CQOv6sj׿,;/`tt7it/Вsq 7͎{t|Mhj674Kiӡ4_Ba{gwX=;7u,һ.g@%S0jEBBP P P P NdFXEX6",",",",֞hfP PkPkjjjjj)jmuD",""KXEXEXEXEXu5YgD-B-:+:ZZZZZWZDf]aaaaa9afQ P .jjjjj֓1YO$,",z*zEXEXEXEXEXoNXFB-BBZZZZZ.)k  *k#b!b!b!b!b9bv'kk}*YXXXXFB,BoX6b!b!b!b!b!֞#hg"kk֯b_XXXXXHYu XXR ֺ     &;k]#kkZf-b-b-b-b-ֺRz&:kXX[X[    kvb-֊WkkkkVމ: +"Q!ցXXXXXmz묓X"kkZZZZemIYk]&>b,bXWXc1c1c1c1ckk.n؂-؊uWullllV։z+2S1XXXXXmƚ ` "ll[[[[Ն#m"+2_XXXXXf3olVO[؂-؂-؂-؂-j֕>Z_b,ƊXXXXXmƺƚ llEU-؂-؂-؂-؂6l=9l-Xk[ b,b,b,b,j3֛7Xhm+llEZ+Za ` ` ` ` [9Zc1cE*XkXslV` ` ` ` ڰuMXXb,b,b,b,j3֞7\h` ``llllll9luEb,bbXXXXXu5Zw-؂-غ+غ۰[[[[[W[Dh=i3c1c1c1c1cycͅa ` 6lllll֓;Zb6c1c1c1c1c1֛7\h}"ll֧O` ` ` ` `XRږFb,boX6c1c1c1c1c1֚7\h"ll֯_` ` ` ` `kak} XXR0־Bk_#llZچ-؂-؂-؂-؂-:r&BkXX[X[k.[[Wa ` ` ` ` :"c1c1Q1f,b,b,b,b,ƺƚ 3lllm؂-؂-؂-؂-؂'c"XXuUu޼B뎰[[w[w` ` ` ` `\r:'B뉌XXOXOkk.[[Va ` ` ` ` XXcBa ` >l}ڰ[[[[[G[Dh}#c1c1ַbok.~` `W` ` ` ` fAJ!rg. T)yu;~ʺFr=U>o+;n|=<=xg 㜑'}TϬ=KExճk0D37 WLtrF(C="ϘmlX 6gŭ)u^o+x8fzF1ų1cgT|8fL?-:рm 8GSFDx8fz`3B1X x=3☱=qƛDOƻ WϮ=aЉf wHō.ckOpR<2z`3x:ќ'1#MxꁉN]NtDg8gȅۚ}$na^;A調 3j9m_&eæHC>:)?]74wYY\_I|1˗AuOϳ_io lB [b&楧>nv%,!L-ǛK I 8.Y}dQk,F*dSHjհ"a%c->PNt aKV$Tcbn$:,n{E]dv$cR$Q(HFIQd*ג+2nqJXI94'"&ID$M˅e Bgg ϼ+tOdxJWMK7^_Hq$P乖L9S!9lYڦH^5 >XrvX)ꫠ XHM)U9M)27iL(bS\O1j5f% QwdTyEܖܚ-ߒoQ)rw(xON9io/aNu;!˖]@nߣ~ԣ%=RāɍY6[sĞ"tە;"û<&eLJeT%|1LFyS$TչGd(b+bJ a|8&- X&bS#2S&E-4`%1Nv6 E@QxHtU^T$enي Qm8*gRn ݄4&y8Ķ Iİ>G1TV$OcҎHz?PKpi=./GenuineIntel/GenuineIntel0050657_CascadeLakeXeon2_CPUID.txt՚0;jfDUmUffffx*Y9Z~+7ͫW~_ %v{]iM=OJglovv8m{+;YW_~˳~0kCM0Hx@І зLpl*ĝӨbxruJ+] HI/BŪ5Kp3cZ]l€ sMx4&3P W!=l;X_CZmI5Q94tIYp:%E'ǩ47mi+sE,i2FZED#"-"-"-"}#~3cEZH9"-"-"-"-ҭ>-cEZ[$mHHHHՍt+cEZH/i""-"-eFzGHH?"~iiii.H~fH3iiiڋtYD1"-үH_sDZEZEZEZ^H3FZE{HHHH֋6"ҟiD"#"-"-"-""FD1"-HsDZEZEZEZN2 eIi"]9"-"-"-"-g'uHKHHHiii։6$5cEZk$uHHHHՉt5cEZH)"-"-"-"-utYDzi-mHHHHtt=cEZH9"-"-"-"->ۘH#-"}D"}iiii^#Di3sHHHHv鲌tit#"-"-"-"F1"-W$iii6۠H?2FZEcHHHHy6(όi~F"#"-"-"-""]A~eH+iii.uT#-"D=EEZEZEZEz]"'cEZ?H戴HHHHHQfH7iiiiPK'Q?x<./GenuineIntel/GenuineIntel0050657_CascadeLakeXeon_CPUID.txtU: {Ţڣ8Oṵ:$19Olh]<9}ˁ7cԟugg0Kio]xgVK*u7y|ͧǯngeIҀ>6c!;cNE m: Cxt9J@  %pBݼxŦ581Ʊ1xN1ئ,'@r3UGNYq䀠 )oҔV[Ru<))p^cVMYo4[h(: Pjo;kJx~*JpSļ.m EJxZWƾ˜ "^bU-SSe׳ZI!^֥"f+5TP*MyKM.]`jvc1 k,*laY뤜,q@/ԉޅR \W!1@+;T*K\]tBӪk߾6sWqaVyLn :o>VT#% XkS4. euD!~eMJe)+~]T1]`Ҡ]1 l "kmzvٖfi.Kfifi,,n?thift,,,,^3ZYzXz,,,,-][e4KtXMcifififi-]o-Yi,,,,-g4K>YYYYtfi>">4K4K4K4K[K-,#XYYY[K>3ZYX,,,,][K~d4K#b4fifififrk>όfi~F,,,,,],]~e4K+b4fifififu-,X=YYYYY tYZY,KeK4K4K4Kvg>%YKeK4K4K4K~c鲌thift,,,,}X,k4fififif~c6-Y[mK4K4K4Kyc>[FK4KoKoXYYYrm ,{4fifififrm:GFK4KKXYYY뵥KfiKi,,,,뵥K-,}F,}Ncifififin.K?2ZYcK4K4K4Kvi:όfi~F,,,,,_Z +Y_K4K4K4K4K,hifwi,,,,ec$4Kt]4fifififuKFK4K,fifififute,5b:YYYY\Y,k4fifififza鲌thift,,,,^X,[4fifififva6{FK4KKXYYY Ka>2ZYX,,,,[,,3ZYG,ݧ4K4K4K4K_uόfi>#>4K4K4K4KoKq~d4K#b4fififif3YK?g4K4K4K4KegWFK4K"~Mcifififi._-hifwi,,,,m%Y%`u,,,,~Ythift,,,,>-]-,]#XYYYOKב^3ZYzXz,,,,Zthift,,,,}|Z,[4fifififa鲌,{4fifififufi>">f4K4K4K4KoˇPKfiKi,,,,}όfi>#>4K4K4K4K׿-]~d4K#b4fififif3YK?4K4K4K4K-Z,ү_XYYY?>fi~G,fififif?PKC@c8./GenuineIntel/GenuineIntel0050662_BroadwellDE_CPUID.txtvL;n:3 uՈRff1(]Yu4"1y7ۅksy|mym9,d ܁ ǽl 07nU=܏_86&2S&cc?{O{>hԇFcX (4M0ME&axHjv2)"YMT!*bX$>|dF̭\eDb2aSbb=( (GAf<=i˓i]o$LuZ:vn6,d|ل JՑ |ƸX0R-1ye Ӎwy<V],ִdZA쮵uxk%N֊8,F5kMF69]"UUDnNן<&oqwGT8Ѩ:;70gI9]`wg,ZVIXDHfTv`ĂB P,ۨ+kAAՈI[[~DqvAu(|q]A7Nm0J|:|W' iy?m4ksS-mzm~oM~|z`Mp?(s!?928xL0صDL..}C:lA}D=!!a2V&bb L"L011811G:t8Ft8!!!fp*aՉ8a"&) 11sqnAtHsDsrVK LDL\"L\1q1tHtFtfp+aDL--Gqox{;!!a:2V݈'rb N<"N<899ӝ9qO<xxFxx!!!p(aՍxq"'+ċ9991݉cxy8F|p"'GĉNDNDN'#~;yno"wfsICW/@BYX{dU:HW@Xxc!ƞxbs" YuvUUO܌@ U]d;PA.L!6q;-\lՅ\!vuq?q 16pnGPX5TѴ# xWGϟm}CG^?KΓwx['#\kƇ#p%?i#ClbCƘJ$- s,T4|J &pZܔy1gMna>'A]FN]~S.ɴ" 2U}+lR"6 mI L[bPx^%.! e.A&,(: 횹0Ǜ1i%_ѿ)ڟtUUR+tgwm6ZmfvX6m2ՠ]f_MIf{ b*Cn4301 42O.\1#!DJ2r $K˨P(Q˝]X`Jbre%yyF8/%uJBt^8BV:~lA$rR@sm@1pWl2,yķyr\tw癿;rFѩxVg3k0MZ.8%E V2xgxgx33y ϔ# yf{%EC4DɈDC4DC4DC4Gh3ߒ!fD !!!hڀ|f=+Bd@f=Yz!3 Y!2 3DC4DC4DMݢiͣhhA4DC4DC4Duf@>-)!oF4 !!flSEȀ lS2 2 2 2G/d3\R4DC4sF4s   ќݢiM+)!M !!![4E ͒B4DC4DC4٧{F3kIȀ ȬȬ2 2 2 3wCf@> ͖DC4DC4DC4[4򙽤hhh !!YE3 9JhȈ!!!hY2 2g2g Ȁ Ȁ lݐ\%EC4DseDs  -̣hhU Ȁ>% O2 2 2 Bf@>%EC4D3gD3  -{Ѵ!iѴ !!ٺE^4KI ,,A4DC4DC4D5"YKBd@f@f 2򙭤hhh !!9E3 Khfψf!!![4򙣤hhh!!9MF3gIȀ ȜȜ2 2 2 3wCf@>s ͕DC4DC4DC4C4GI <2y  M!a̳hh* W2/ : 3,y ;#7  |Jh͇hhhh g%EC4D͈K4DC4DC4A4=Ѵ1U Ȁ1% sL 2 2  su@fT>s%EC4D3gD3  ͟h[4i%EC4D2iDC4DC4DD3wfh!Y2Yhh&2"YKBd@f@f2򙭤hhh6!! Y;D3,Khfψf'!! C4򙣤hhh!! fϜ%!2 sf s Ȁ ȀLaUR4DC4WF4  ќ|ii&f Ͱ[4H4 iH4H4HI#: yL%C2$yL$C2$C2$%stHfTBKifΐfFAAH4i%I4H2iH4H4HIsuf=iAY2Yii&ffЬ%%C2$f$ ɐ ɐL!a V4H4[4 DҴ KhA3ّii&f Ͱ(IA#Ciii"i{G$4gIɐ ɜɜ$C2$C2$%uHfXBs$ ͕!ͅ4H4H44{i%4AydH@AAH4gI <3y" M$y4LjUR2$C2d^$C2$C2$%suHfXB.IAw4oAA ٦ Kh>%I4Hɐ4H4H44si%4ߒAfHEAAHv4瀄9U ɐsJH9 ɐ ɐL!Q s.IA9Ciii"inҴߓ$ Mː! M$MYJifɐfAAAHi ZR2$C2kF2+ɐ ɐ Dl%I4HeH! M$Aa ^4H4{4; D\%I4HsdHs M >":HhΒ!939IdHdH&Jf̰*IA+C iii"iZi%4AydH@AAH4gI <3yF z4UR2$C2d^Q2$C2$C2$uKf@B.IAw4HAAٻI3 $ 'CO$ ݤ|Ki!7iii{iTQ2$C2)!%C2$C2$C2Wd$4$ii i@AA9nҴߓ$ MːE MYJifɐfAAAv4ˈf-)!5#5JdHdHdn HhA2"iiif&̀f/IA=C=iiin HhA929"iiifGuDBs ɐ̙%C2$C2$C2Gd$4WI \\4H4H4Hsvf@B(IAG4HAAI3 y$ 3Cg Ҝ=l#WIɐ ɼ2yEɐ ɐ ɐ- ͻ$iiҼ#iiiuf@B)IAO4HAAYI3 $ 7Co$ ҬHHhSEɐ ɼdS ɐ ɐ lм璤A3#iiif&M=iZI Ҵ iZ$ ݤY~O$ii iHAA9Ь%%C2$f$Fɐ ɐ ɐ- V4H4[4[ \S7i$4{I 4H4H4H3wf@Bs$ ͑!I4H4H4i g(!ϔg!!!W2\4H4s4s$ Ҭݤi'M+IA!MAAA4I$ ͒!I4H4H4=\#dHd֌d(!!9%3 JifːfAAA4$ii iHAAI3 9JiȐ M M[٦ YR2$C2gF2g ɐ ɐ ݒ\%I4HseHsE M&̀Q4H4 i4H4H4Htf@B,IAg4HAAYfмJJdH救+JdHdHdn Hh%I4HΐI4H4H4{7i$4AdHAAA4oI |3F y4m@B*JdH;%$dHdHdH̀;$ ͜!H4H4H4M{ҴAiҴHAAI4KI ,,4H4H4HfЬ%%C2$f$Fɐ ɐ ɐ- V4H4[4[$ Ҭݤ%I4HgHG M Q4H4G4G$ HHhΒ!939dHdHdH̀*IA+C+iiin Hh%I4HȐI4H4H4W7i$4ϒAyfH AAA6#6"y ɐ+#W ɐ ɐ ݒмKi!;iiiZ7i$4AdHAAA4oI |3F z4f JdHfdi!!!W2i.IA9C9iiinҴߓ$ MːE MYJifɐfAAAi ZR2$C2kF2k ɐ ɐ \ݒl%I4HeH 2uf@B$ ͞!I4H4H4s7i$4GI 4H4H4HSEɐ SB2%C2$C2$C2Kd$4\4H4s4s$ Ҭݤi'M+IA!MAAA4I$ ͒!I4H4H4=\#dHd֌d(!!9%3 JifːfAAA4$ii iHAAI3 9JiȐAAAuE}М%%C2$sf$sFɐ ɐ ɐ- U4H4W4W$ Ҵn Hh%I4HȐI4H4H4K7i$4ϒAyfHAAAi ͫdHd^ɼdHdHdHf̀]4H4 iޑ4H4H4Hwf@B)IAO4HAA9I3 $ 7Co$ ҜH$4m(!6%$Ӧ(!!z%3 isI ́4H4H4HMݤi'M+IA!MAAA4I$ ͒!I4H4H4i ZR2$C2kF2k ɐ ɐ ,ݒl%I4HeHE M ^4H4{4{$ lݤ%I4HsdHs "?//(ao{_g9E`P@R4ms=o0K·8:a"gNpy9f9lr|NV㳴:Cry6g:,O$gu ,uzyg9αNS\r|\,ręEr r|\,r::IN)rRއYng'9>U'Y:$gsYl$9N[Iuz L9grtvY:i)P\S d|̜d:9չNp˲řr pN;Y΋&K-u:IN3)rR,U:?vNYn::ՁݜetlqbYu:{8y9gyKNu'ឋY^|ܜ:e9,[nYZ͎2v\|os3,ԁ̒2sΒN[')uՁݜet~ܜlu.;.Q\q6|,Oa朥:i$')9)΁{.fy9giuev\wg9:?nY:1Yzsׯfy9gT':Ŏet>nY:sqY:It̜-$9NXIu{ Lܜ:͎2̯wm@_/]ޒ̃epj%12LwVNN'ۜGؿΞ9E;^\3(D .!ˉȉ #=~i;'aKtJ. :11%t{{$5LIHˤ62&Eգ "2iZp4a$x~KXd$~@[cOB0Z^?S2R=KI"29IA:b 9)JZa6 Q:&zZF6cN6zW0r4:d$/.r83?.@''fWNhtM7FIAb$ITUh a .FؤFO IY*DZ;#4AtWpy|G9)i֩ (L^d$Io"Āh)q &(&r5#&VLx1 b$I"&ULt) &(&ZLHLX1qb$RsN+4~_ ĬZ]ޝJY]9d%'(*$ppQo@?.*sJw~@}UVۿUw_h"kyjHCvqkUohUvjUV=Z䷨wzjKjH[Eh^^*ZEhz_DVPVIU?U'F?kU*ZEhUYb_j5Z qȘucBh Zu&ZEh>VZE6dNZ&i4*ZEhV٣ZEhՌVk)xj^F[eV*Z ),V*Z}Tjt]bV*Z@hGZ}d;[A|UV/h5*ZEhQ\\ K~U WUpWjp)C?q53p\U W\up>W6WlU W 6]pU,W=\Ho8UZMW*\p*\pUz{]*\gZrU W#\9Y'&{H]p^t^*\p&zWl'&ĂK W*\vp{j+^Ň W?jOW{d1U WlUU WjhAv,Oj8Z9W*\pՋw W*\~՚%oM'!sW*\j>ۣ\pUp>WSwWmI3U W\pUpۉ=9*\pW}UU W᪃Iv[rwWpj,W*\pڒ=:$TqU뻟ZU WjwǺrp\MqW W*\RWZW99kV^p^jqѽU W*\Mp8qU&ZU Wopug*\pfz~i{WÜq W*\pUZsf?T\-9=*\pnKpU*W}հX火qmi;{خUWW*\r}U?a4Y} \S+ Wꌺ*\pU\,zcH+i_*\pX\pUwp5&ƩZ*U W궢pU*W\N\]l W*\?j]*\pU/ʧVErhL0]*\pJU W_jpjd/pU W}vU W_jU5!\p\pWj Ҽ''upXpWZ*aOW*\ Usu\mmOZ?*\-MƜ<%U Wj{U Wu5}XH̸s*\ppUJ]]Oj WcҶ?~j4-s*\p*\pպ>*\ [fX%/pU Wg*\p/ʧVC|Ք\.pU W U W_jlW9 nU W*\]sD W*\}RWw1>]edpUsF*\pY WrUj W*\}dEwj2 \U W]Z U W_jUV5We:WW*\W*\]Mr~UjIzi \p8 U W_Q?*\Uf>p ޕypUZbpU*W>Wuj9q.z2\pV#\pUW1˚u꣉m\*\p6W6\pUWsȚzcJL=^*\ppU>*\Ieθ.pU WǮ#U W ur5/D5#W̹=\p^ܻU W_*u5/aͲpGXUBU W/puW*\r5Z\-Yu\p&27\pW?jIlWsU W: U W_jpu5WWS\U W zU WjRzwYہ7{ W*\` W*\}W]evS]mQV1\pWU W_媃p5WWS[F]pJp~UNIO\Ҷ3W9gpUz% W*\}W?jԧ#WD sU Wopz*\pUFznEqWLR9 W*\=\pWsvV?p-/b W*\՞SpW?*u՜{JcU W+\pWs'aR 2p.]U W_jpUMz?^ke W*\qCV>X%W\5Ň\u2\pWU W_*u5\H3L_ϹJ]pfT\pUWsm'WR_U Wopչ*\pUzz޲XÁA6uUz *\pYz6,#uUz!ۆpW}tR遫1 W*\՘뀫pW}:g?(uW*\U\p Wx5%a RkpUzL W*\}~%zjF0 W*\RRpWZ}T.WgYmt>p^jӑ*\pWբp8橮.%Lp\\p~U~U:d\٢U Wopu4pW}U6iWۂp \:\pUWmN\QB U W/pu*\pUW˔N\QU W 5+\p~]M5r5ZCls\p4*\ru"U*\pW]OUW!gSfW]ۑAz׹*\7U W*u|U.$-}2\p^j:*\pUJ]*q PU W/p5NS W*\}U}ZW [U Wop5*\pU\/4eJU Wop*\pU:vպU-ժU W\pUWs\]m_sU W6pU,W\` TjUMUR]pjU W\p)=qTqa4 W*\њpW%EWՈW{LvvXJ[oyuO{UfUWj«#JZjAO UW/xu*^ūxYfW^]G?*^ūx6UWjWGW>WǍ~U\W*^ūxu^m5f^xZtjiW*^ū7pxUWS*^Q^u>:/xW*^ +^ūx0«$p^Tm_*}UxUW}խ^f;xu$.NǽW*^ū9W*^ūj^xܖa޷E{UoxUZbxgJ_ x.wxՙ24 ^^ūx8*^ūxY^b:%:*;txUZnxUW^«QbU۲_~UT*^ūx]zW[T$DW*^ūW*^ūz5*^#J^]m=^*{W#UW^׽Wuu1Wu!٬^*^ūx ^ūx>ՄW?j-B'./~vxUHxUW3^xëxUݹ -9Q`rhS5 [IW^=>jAjU;4a~cܫxUD{ xUl_mxd}uHXUWW}>UW_jrx 9}WϐbxU^ūx>Ux9 kWWUW-GxUW^e/^3UF8UW flxUW^=VӽǺdU*^ūxW*^}׫Qen^uAxUZSxUW^ūQUw:W*^ūx*^ūxYf{3ūgoEW*^ūxuW*^ūz|URj}b4*^ūx^ūx~/+֫_MݭW[۽,W*^]5W*^ū֫ &xj˽W*^ū;W*^ū3*^ZC^UWO\UW~Uzq~}dE*^ūx^ݢZ ^ūx>UoUNv2]NXҋ^ūx^ūx>`US炙xuw.xUWCOUWj4*^5Uس W*^ūόW*^ūz5}Uj/fHz槁W*^ūx5Y*^ūxYfW[ʺyuW)xUZ™xUW ^,|YY\xUZcHxUWW-Jk^G^=UW<UWjE^.tJ_ūx5*^ūx^-E\zIJ_*^ūxu4UW{jQWST)ݫWٯUWWUW7*^ uf ?{5<^UWw UWj0*^հ|ڥexUsqnW*^}֫ޫxUO?rxէ,cnUW*^U-UWjx9W UWjUWj6*^8)kUmN*^ūx5*^ūxYsUuKUoWϔ4*^ūx<7^ūx>Wjs\7.bUW*^1 W*^}֫ ,é޼ĕW*^ūx*^ūxUVgU}xuwxUW*^ūxs??{We~U:$Ʋ{(bUW*^ms8W*^}/Wͫs\ W*^ū}W*^ūz5|Uj̭xU:xUWW,KzՕ޶W*^ūxueW*^ūxY&sUwNWc1*^ūx\*^ūx]Ww=vy5}Wڜ8UWjWƛWs)xUW5W*^ūz{/^axUW}HUWjRdt7UgUWjtUW^m _̛WCϱ*^ūxT*^ūxYWjKv^^ūxռJƫxgWO2soUoUWjY3UW^ ^ū.Y=`,XxUWk UWjx5uqWpN1*^ūxv2^ūx>Wj^u7 UWUW9W{IN^^ū#'Zū3U!VUW,iUW}|U2j2^ūxJīxgZ?*^KjXv7*^ūx'^ūx>Wj*z7*khUW*^=s*^ūx>UW~JO٫&{5Wェ⚆W*^֫jUq{i;K_MKxUWW*^ūx눿ǫ^\.^թ2ìxUjG^ūxVvW^ūijQo^K|nUW z yUW^xܫ^]٫(~W*^ū^M:W^Wͽo%*^ūx9W*^ūz5U{ŝ 0UWWKUWj^U%4.^ՒdP*^ūxΎW*^ūzU{&M$͓x/UjzëxgWU}5W)}lW*^5Գ*^ūxUë^uKܼERoUW-yU=+=֫W1UQ*}]?xgJ_xޫ9-W٢5*^ūx' ūxg>*}{1WݞZ?*^ūxzq^ūx>Wj{.W&Z*^ūx«eLjW*^ūz5}U:WjXRכWkyUWW{W^m_xVѺիNv:*^ūx2^ūxUW6'=xٯUWWwSW*^}׫WMf-W<^ūxxxUcx5V9Aͫ-nܫ*^ūA\wUW\n^^ UW 3UW[FjUG%t.ġ/jxU ^ūxYW^^ZiU;[UW SQW*^}֫Te:n^IUW xUW^ūaԚo^U'۽*^ū^'UW^xޫ=;+WG\UW-ZxUW^ep={%J_ūxx*^ūxUWPzKx>>ǫxgx&5Oy&38xU^ūx>UW:2h_ūxxuS*^ūxYJ_]K|>U IUWUWy*Hkc֫Ֆ7/^u/UWWOHxwJ_Mx(ۍ~/@sUWjwfxgWG)ҼWg+W*^W*^}֫{UT.^8 UjPWƫxgZWݎn7-~L rUxUW^wMrU_hWW*^ū^M)UW*br^{u-rlI/j8xU UWQ*^ūxx*^ūxYWGڮ9VW*^5jz*^ūxYWk wxUj>xgWߒgR}W*^5OW*^+/g[/~Ut}uI)Q߻W*^}+W*^ūxu}~ՌWAuZUW uNW^eP*}5H_+UWWUWjū^e]ڊR~ͫW^M*}nc[_]UUW ZkxUW7^ū1~ ^ūxx*^ūxY&jU)-^^ūxxum^ūxPKiY7./GenuineIntel/GenuineIntel00506A0_Moorefield_CPUID.txtӻN@Aw+bcHDQ@B뉍(+Lqs}N{q~>t[-tdUvۿw5< a dz:mzj雾/.p+ Cv(DV;n0 nxE,nż[6%'[b)j"@I 3BũWsꀢ$t31֒/} 3NN1#^<$.Brj!}rZɭICד@?/.A5v3hHNdm v|o?*"#2 Q<=(?uدPKQ=|>5./GenuineIntel/GenuineIntel00506C9_Goldmont_CPUID.txt\RՖ@;|u@rոzdr/_}6VNV~e+''-0[u]ŕVUKUCBv~ a[QA5VjB+jbU4'K{-n20|B CM ˏp>U 1 (=a)»Ln=}trzh,U/e KgSKNaIN m>aX_0nM XX9VQxoxg N2$;Vܥ_oŜ_K? s0vEb!X1 ?{&)/#o,嶁0*>\=3#T6HmayZBm|h1ZxU)Lctʙo?Mnd9pf@@ P74@?()j;D2Δ!"}!X&T1MlX\rS`ԉ/7ː)ZlR "|f#zv"nޮ9]Gi;DWȀDv&֏=xLӛ݈^!JA2HU6/0-˝" jߙ33aQH)W\5jAɔI-GrV$l"nb^u=Y=45M ´6Tŵ4w!X%+)$HJyA@vV'>b@"y;VVʪrl&-ΒTdFE bEL8ٕHWGSsj[S4w=Z|?*|.o_{| {XRI5E'~O]`qSܬý,%oxţX<:y7[oxś-ex_bf7[*F}>xߍZ>BH:CGn"YcSg}[D|ǬPPU-+P(m-֐0pT ]Z 6Eu *IƐN=HrJ"ql&$cúI5 g < HGq4Vi'+`x:\P7̢';?d!hCRe t`& MP<趇HJ->4rn?> u"(jɎOe!"m%@8$-bIc*KJ讱KR6Yr@̐!bhЗ b](]QGBXW vp$KY |V!h{:@FJP+j{0yX>`G bG]!3 3!@_RB%C:@=@u2AiMTMmd- ">YҫڇԂT "+SCdRĴ6$U3垤>A-65Y&-fVATZfwf4~_b 6j|HFH܏P! ;1 Z)t]AV̧lDF )وe#Tlf# iوg#FlDF ce4; #8G6AM ~TWgo[w^[7c??Ɩ6h8wpn]Wŕu|-7Eu۷E!@}uT11%{X~}x&VGWΜFpKsf^=iw偲1_]|"ԁH͔XH-3[^PKQU"B6./GenuineIntel/GenuineIntel00506C9_Goldmont2_CPUID.txtl_o0#;DJZk2547bldg 6?,DT~d:I8J\nʃgߺFlitֻA,h{R2qz-2-Sx[|mq I1aD _\8Ayl}Q\҄`Lr#)͓A>]h;7޽oHUQ~4]Etu#ۼư'v]WN,W[--]%vY+gxWPܮ!}yJ"#BI%ҮEO`[>ۼL`VI*Hb^0;3/\k̸769Em NR8p}&eQ${QHw_ #eE$>~6մ;nGKnxIFk$?jRBegjdhIq [*BjI3I17ҁ$d3׽:}]Y+ HZЊQ"kU9V9NqGc_4[1cyDr,dd'Ip(Gh a}P%\M಄/:&Y0b5ټڠ MC#=B%j{iU[߳՟S,oa@@o[/Z߷>ѧFM{bSI&q q8=\,PrL#;|XǏAwQLA+Ƃ!Kr(>S.V2 HHL@\F KہJ TVrOFNH+EDM2NK" 2ۑ0?ԛjn*.2n#v0C$)$A6rEӢrrbwdCF , tH"YY= &bb#}wj;\}#IuP? 6*悶yfA˽E@AD=$[AV햗NBפUg CV R X $Kɍ ` !O)4gX[ ԒVj3h/_[ V?5N]t{-q{ۛ襺nov{ۛh/G[f7=>Ku{ۛf7ɽܞ|nO%nov{Ӈ=f7nov{ͥ{N;No}o#ƁFX@̣b*@%Y}qڃɲ,^o,?g__Tw·C=C)"U0D@Ƴpw?]e8f5g؝Q_$Ek^zTK2AH&Yxzl!yq$A:!BIB4Yw)B"T]iLv89@@DF# r﷈NT(z)AƐ`cwН ڙr@̐"X8CĬQ:zx*AQt6ETgYN}Nh}Gh)#3{g=CHD L1 BOV̄ Eqz)C2GcL7t!kQli2,HhsHv}'#}|yɋ7Ylp+;N.{ be|Z+2ilzy2ޓt%HS,-EF ZV&{ɠ ATJѺI,ie1ň*Ft1R#HSň+Fb/F|)RC1#bD#I^܏w>]{;Ϫ/*dM h#C~:iꝳ7UA޽6HUsvvAU )``~3E:U`7zG e9?Dч 7"M:b?#qu$h⍧QA!78 ˢbD,isyL͜]K{wwZe#y BW#e#1.VSb#09PKxpTR2./GenuineIntel/GenuineIntel00506D1_SoFIA_CPUID.txtMK@أ~$'т(JI/z @R~d~X/NSE)U (1$+" y>{kF@\2 d ˼TM.i Eh4Nc~riV!6؎b!p=y׬`X,~ 2@`Ps@ ,WQ3S1-(I ULLϴX2`p;Oyb0$A} еMa]P_ɵPmSz=vЋ%hD@Zh֥<$/O݇4 %#$!;XwM`~&t;Im.EUo۾݁IS#^7U5#ن( I2G]5l_/#/q"K5mU[Qn g.9 oάCw4#8rBw&$3Ya9Hg>Κ=#Źo)0aYSw~FN?7M>%VTxPaEZy>ᝲ5WiËK"3X\ceʄJ=H;ǦlӍƶ3Bds7^Z:Dl(Kϵzֱ<7mB DmѰEe!8mp'W Nx|OŔe[<>(EBL9PT*9.hrg\X8U[d&B_ASQyުxwtEh~dusyfqmemo^OY2@PД1HDt_5(@i[+ *Ddb RV0j.٥TI1͊qṞ1} ŦBۊ'ưۍؤkN $"!X?ݼ%+avK!(7xJd$6j IŬe@s':du'tu<]n*!]+%JsNϨ&fV0)T0#]>BdtLtLrye]ϕ~{S`B{by͖n\9eб"/E# Dӛ*5JdulNS|c)6`Xu#c mly1DfDn#2@VG SW+U}\ߏ5wr*X]_|_U_ѱ^o7TRS|x>ߩ)5ϪPU'iF=q/A8h:AwЋ^8A/r/4zqЋc4}8A/zqЋ^^ m8Ac+zqЋ^8AnU"xj۪{:_Ө󨘦Ŧ'b3;rzpqumi&>i|CPwhh6}d}͂eYq)tm,lQT'v.sL0C.H`2  ؏,¶* x\adb玬8LXc“bd.44`2H9䲄j,ݎdN;f"BDìi9@d/r쓸}'IfSGfE-Ӛ-D"i."kYkQ4ٓH9ja35B0a%Lj-%E=dQYV^ Tsf804OrUV nr)[P#X-Y.@p/ϫr[/Pf2:wϕ'%ꓛ7/Uq~~Re,fb}lo&jǼL|=F=a XF,˂eŲaٱXNN:67`itXz,˄eR,H>]òc9X.,H>ݖVRNrm~iuR܋!sm mJˑ> D>}r`9\"mPKy% 6./GenuineIntel/GenuineIntel00506F1_Denverton_CPUID.txtlw6G=< Ό[_K 8a]YLHDC9kp0,\k =Q-PFo|Cb &ئgV8u'~cF nAk6X,dف3Y.(&/wy霓3<5ιwG& D- jy ;7 {x$cq"(n\h9%e-h8xdM+EՕV}?M2 Ȳo oQWW^ֳ]m._"1 ^1{U&pM40VVXl 7meQpgoeM$-虽2~drn\ݝל6CWS d]K3 1G_[*1NrS W#80"]eH'mr#P}$h $d19vG:';Q"h 9p8tx_$>g?ًOVs3?ɏ_^{W{$݁>٭tC u]^{rC6wǶ0EWdY/ , x.ۿ8v8s,ql8s,r,r,rc{ȱ}cGr,ǎcr,r,r,.99Yı˱3ɱ˱˱˱K!ǎ8c98XXX%Ǟ!Ǟ;{q,rqXXXX!}8c98Yr,r,r,r,~ñor,ǾǾKXXX+kc[~,rlc~c9c9c9c?!~v8q,rl8s,r,r,.9c[W!A$[D##ٱ&Y%Y%Y%Ym1ɶ$KE$;3k%Y%Y%Y%l!ًdIdd5ɒ,ɒ,ɒ,ɒC7ɒlk%Y%Y%Y%!Y%Y"'#Y%Eɒ,ɒ,ɒ,ɞ1ɞ;$%KU$f$%,ɒ,ɒ,ɒu$A *@ȸDžTH+%Jv_f6֠gx89rN2G^syӹ=M ȣ'sBx.%4d @ U 5&L"'_8i1_AlG2ߪ) Da;:QaiO"lq@I5L2O$_RlԳ)Ti wS dY b FP+5yR݂DvYK }7oN!P鑁{It&&d7)nRݤ&ML/MMD7Inbn'_N%.@: 嚌1 (Gwض=<@**D& 9aq'618֮{?xzȬer{T'X`k"d:z]lH@hnڋD s nّy0Yu0E Boy13|t5/](Qi %4*XQ~2tg,[f-kt Mk:Z ;g+PKJMg 3./GenuineIntel/GenuineIntel00606A6_ICX_04_CPUID.txtrpZGɍ0 0K-vN-eEAVXlJŞϖ aP !_e} '# G-]4HvFH??(1^AfLjJVTF&?[i9Eh ȫ 0d/D(,r^k.R(% ϚgiAe2bWzD _GV#R C̞*RqyYTD㕮븽2'⟈!j_wb ;_FKdζs13'A\#1L#.b""F4h\Y@λw{" zx%P>,\oi>$` RZgqP>Sٗ͢_e//_%_%_%_K˱˱|ɗ|ɗ|ɗ|9%/rrKKK_ K+|ɗ|ɗ|ɗ|ɗK///_%_%_%_K˵˵|ɗ|ɗ|ɗ|%_&rrKKK_|ɗ +///_e//KKKlɗ|˳˓////|y%_&KKK_|ɗ +///O///_%_%_%_K˷˷|ɗ|ɗ|ɗ|%/_%_%_%_ %_+r5////_%__ KKK1|ɗcŗc////rJ%_TKKKK|ɗ|9W|97////_%_._. KKK5|ɗkŗk////rK%_VKKKK|ɗ|W|%_%_%_6/__ KKK˓/2gŗg////KLUKKKK/|yW|y7////_>_> KKK˗/2oŗo////KLWǗ|ɗ|ɗ|ɗǗ|Wk%_%_%_%_|ɗ *|ɗ|ɗ|ɗ|ɗ#_e/NJ/_%_%_%_ė|˩˩|ɗ|ɗ|ɗ|9%_&rrn%_%_%_%_.|ɗ \*\|ɗ|ɗ|ɗ|ɗ+_e/׊/_%_%_%_Ɨ|˭˭|ɗ|ɗ|ɗ|%_&rro%_%_%_%_|ɗ <*<|ɗ|ɗ|ɗ|ɗ'_e/ϊ/_%_%_%_ŗ|˫˫|ɗ|ɗ|ɗ|y%_&n%_%_%_%_>|ɗ |*||ɗ|ɗ|ɗ|ɗ/_e/ߊ/_%_%_%_Ǘ|˯ˏ////ߗ/2Ǘ|ɗ|ɗ|ɗ |ɗ|9T|9%_%_%_e/_%__|ɗ|ɗ|ɗ|)|ɗSŗ_%_%_%_6rN%_\̗|ɗ|ɗ|ɗ \|ɗ|T|%_%_%_e/_%__|ɗ|ɗ|ɗ|-|ɗ[ŗ_%_%_%_6rO%_^Η|ɗ|ɗ|ɗ <|ɗ|yT|y%_%_%_e/_%__|ɗ|ɗ|ɗ|+|ɗWŗ_%_%_%_6N%_]͗|ɗ|ɗ|ɗ ||ɗ|T|%_%_%_e/_%__|ɗ|ɗ|ɗ|/|ɗ_ŗ_%_%_%_/_//_ˏ////|9$/rrKKK_ K+///S///'KKKlK˹˙////|$/rrKKK_ K\+\///[///7KKKlK˽˝////|y$/KKK_ K<+uO:gmi iϭ1 9& R<J PeY0?x (- PKf$l9./GenuineIntel/GenuineIntel00706A8_GoldmontPlus_CPUID.txtokFw(@ jm%K905QsSzO_I  W$UW0aVCLxși">`W3jd*LY}aVAyW-@{ {8oEUjF{4E">Z!<ضr0,a~MOò{l.aj#VUk@_EBS!;x(B<dCLᏔݦ~:"}GRw# ^r*톐%JD"[eSӐm%ΏbH0sy_T-7{P~~47T [ΏLkҐ)=y!Q$!25'ɆDU f%v^5=,F>ܧI~H| +3 ~8ww!gw>϶ h)Crx4z/u`(E}ǻ5Mcvjq$Tţ ꖦ hyKKs['p=}x9e$PFe:-@B0~ Y8V;8ٙD|F 2uF6259i&iCI^]U\mhAЂ|P^ZyP*m"A [| BjlL<pzxQ~aD҃_Y )!nB-ƬY֪ԫ{>#GZvTWUZs+8AHx Xo);ֲuVTH x7a<+4ce`Ô⤘ş;| "X$=duFΧ;Kɚ\9_^ShZz`W2"jىpL,Ӥ`?8 #z]AgY kxMHT:aUՠ127 UUa.U,];cY!>g}@n޹ZAt)"|K%, ɒ|on@:)AG Ŀvt\v!iÖNxY`z!g!?]Md! YRD+:'$h?o_к>tKHRp&usPb}نFH1c$aGoxC@-VXl91}XBWQ/&,a+I!=؀y7O3yه:9V{gk9 5s/Tq66mlc%(1$>)I(Q`$@]\v ?|9?~8/ڿ&Ҁ&ܙ>(Cs&6d4Q2OLnT#I$UA}u"ephD$<m)K%hj3⏦1RQ30ȃnS%}ڎP0I< =Ԅb dUa.ECP(nM=DEJlUQ= YApf7oV5 3`|)\Wجi#}ɍWj6*,>}@d\PWK2+o[$4oE/a:Va0ŠW(a\1PHrFH(b͕p뎙|͕ ¶;(HfM_%`f>1Sc7J|.^Ms ེL#)r{E-@4x*gWåh(i^20)0&2 6 â}WP&n`/f.ۮ+A\BJCS 5uxWn45(N{r 2g2I25h ^1fC&w7ao6!)$vϗP_%92wV6K3m N&PȐ;5KTW ݸuF)m IAm_zv޹P)u>=]mhGQR;'bڜ*]F<]M USO \|صb(WdfA 37~Z~O0{Hl Ҍ 6`l 6 s@H ϐ@@H $@Hҹ@m 6Pfll 6`l 6Pl Ԙ@uZ@H $@ , ll h1`l 6`l C6PVv$@L  $@H $1X:8` 36p_`l 6`l <>.U^)|}O$-O}~Cehwr'w3J|S;[^@_%/0Ҍ5Y27>m&<;hOpc7v>Kc8sO?8}B^J.K.zje<mGFbE+wm{Z^.)z0\w†LM*-mYrЊI&u^%v|H8H`194MyԵL"M:tyj  D|M0_' 20 $BfS2 $y$!h!ނ¬Ro|/K uy>І0IH)BV)?ijYv,e!-#Q/ D3 j#Qx_@R`/FIوX\fA>ZTbBU{['Q4SI#3R=7?%@@/@?T_D$ޓ2)W }FZF8 XdQugf3J#<h:}vis]y#,Ӛ59&"YH|L$MމQ$b.W$K1*56nG'mXV/H6~AHZ|vI=ə lcK̜F29(P2tW Ӌ'Ig1,&eG+oeV5o>vEZ_r]3G׽N7YyFNEy $Vvb;]XGÉq&33|}Jmsf;f}p#|ᛈ/ĶN[+{;w0 }3C{̌Y9^'ژi,MM?rh>wrtddxTZJk+33~t@x$6GEe7[`-pbdi莰$̜l).Z>MѡEj10OUc@)2LJBU&a lQ1K n3]`cys޸fo:o4BƱg3N9O{|^ ܟ>sAAX⊟?)~RYgϊ+~?(?*o}qZyqP8*CrXP5R?)|chWYr1s1sc.tEPKFa^d6./GenuineIntel/GenuineIntel00806A1_Lakefield_CPUID.txtբHWޡֵg6ÞaĚ(9U5܃3CZWޗoI8 A|M.gq XzۄOޖ` 7QXqc2a0VP w|zYy| r H R(QyQ3#Gcn N(m2 $E3];_y e֚x&3Myd}l`5Y9%]~2K] .tD:mB1L;t]dFG]؏,ŜK!Y|Ds$}A YU44u3lVr օBmiF`3HC샵 ߒ91ՊkFkqxT&<2Pćˇ+ nf2{s:*: Ks3"v0H[`Y4jAD548 ֽvUF2dia٫mn`Ձ:ܤh e{Urt:MnwV"$VABfv&WQV쌆{߯1yG I9HR9EpHPȨFTZ'sB?G#ISVܫ@':5N}D8~:XfV A$#c:7 @يtx8O}y1~R< ħ ޽{5o0J} 竗eCyh/hJ7$[i@hÖ`Pf;L}`|,gZa9۶K,/l9,rXa9,!#,Ua9,ۖrrzaa9,rXa\~ۖrrXa9,Srzٖ4-r&[[lmA~ :rfrAv)RDYۋ=D9K;/8lrJ5ʅ)Xh \}۵G$T9sVr0~}Hfe.} XdKs_y>-4Ev 7O<UCV~Ʃ~㢍~\e7\6qՉ7'wgH9c4_Ƌ_|wA}`$ Glz1dtC O_|xǍ _?t#‘b]V i":YGzMeg$ ĊuI=dP)!d=q?~!q儓t!;UdF6A#E!筝W'$@d-Uj]ÐlV uB*L!jސY#DGd$*!!E_rzq!qD`JNW$@c )bHQ99Q(Nb-nZb,"NXQېf/"P:b{UGok>TjmDIh&:N\ۋ]ӻŮUM+6VpŖ5M+H@j:]M]ӻUM15MWЮhpմ5kz״5,Z@bq}MLe]Ӹks{5nkZ֩M7PKFa^d6./GenuineIntel/GenuineIntel00806A1_Lakefield_CPUID.txtբHWޡֵg6ÞaĚ(9U5܃3CZWޗoI8 A|M.gq XzۄOޖ` 7QXqc2a0VP w|zYy| r H R(QyQ3#Gcn N(m2 $E3];_y e֚x&3Myd}l`5Y9%]~2K] .tD:mB1L;t]dFG]؏,ŜK!Y|Ds$}A YU44u3lVr օBmiF`3HC샵 ߒ91ՊkFkqxT&<2Pćˇ+ nf2{s:*: Ks3"v0H[`Y4jAD548 ֽvUF2dia٫mn`Ձ:ܤh e{Urt:MnwV"$VABfv&WQV쌆{߯1yG I9HR9EpHPȨFTZ'sB?G#ISVܫ@':5N}D8~:XfV A$#c:7 @يtx8O}y1~R< ħ ޽{5o0J} 竗eCyh/hJ7$[i@hÖ`Pf;L}`|,gZa9۶K,/l9,rXa9,!#,Ua9,ۖrrzaa9,rXa\~ۖrrXa9,Srzٖ4-r&[[lmA~ :rfrAv)RDYۋ=D9K;/8lrJ5ʅ)Xh \}۵G$T9sVr0~}Hfe.} XdKs_y>-4Ev 7O<UCV~Ʃ~㢍~\e7\6qՉ7'wgH9c4_Ƌ_|wA}`$ Glz1dtC O_|xǍ _?t#‘b]V i":YGzMeg$ ĊuI=dP)!d=q?~!q儓t!;UdF6A#E!筝W'$@d-Uj]ÐlV uB*L!jސY#DGd$*!!E_rzq!qD`JNW$@c )bHQ99Q(Nb-nZb,"NXQېf/"P:b{UGok>TjmDIh&:N\ۋ]ӻŮUM+6VpŖ5M+H@j:]M]ӻUM15MWЮhpմ5kz״5,Z@bq}MLe]Ӹks{5nkZ֩M7PKpv6./GenuineIntel/GenuineIntel00806C1_TigerLake_CPUID.txtlTQ6~_0R_@$,EU,#^p71NLx3וPOwja0x9!<ʽk6ȋ̸a|r1Sțԛ.wYBUiUpk\<'ԣWa7H(;/ 0 ;Rl`Cվ6Ɇ`M( HC?X̠Ul_f92 a`7nj/&ûQr\Kn/\呟au%$az'ztCS'PD8ҶIe6=eUNfD @1P wJu*U1oq)ge@dZɐt|6%ub t*G͝wTwWmRHӝ/jݫ{ObフJm/Ss僁޶4L[ZIRwX$$'R2f^Ycb|;cNHaiI!EԂZj2jѨԂZP jA-MWj*EVX3XaV X+`MwXQZ,"PQA-ԂZP jA-ożR^Q,&" +`V X+`obźÊbEԂZZ,jA-ԂZP jA-xS-ZbV VlX+`V X+`x+VdԂZP jA-ԂZ|rO#N@1 >`HsmL!vCB1G;`!cC0FnK;ag c#0EnK;ag!cc0G>$8a^e.$Dp&:sy?ӓՀi簩T3~S|ҍ1r>p.op>oz|Z <ʖX@Okw-A-wooڅ\kIZ.DH.2"T#ZK ̩EAUg3Xjlv^ڂ[*!wIy V&3!O] HPYT$l'&4#zgHm#j"1!te-vP"PΚU>㌃MIY"tP1ہp0b D=Q h!SÕ!E@Zy!3 \lMU$uGek 5K)5z:q5j5J# 8Y#EAE"0;E첰;+"Lt$ICR5}-aO=ɫ(zc&8k"4rŜ~Xmd,̍2Ģ4y"i59òt"b[֝]Å[eNYϊ"2!$ P~𺖴ļKJ_XBlډҨH31ֈw܆ov%8n$4)DYM(B1!HC;&3Yy 16XR+V֝ 1I{ bXx>f fy<k[E?鮌^~}PwK:n^{5 9D-(oN hh{ߤBԿ IqJ'PEXql#*kaTzf4G؍?˱[Hblȱ3UaX8F9F 3a=ŒMtYkϞzCv%"Dh E5d}(SiHCa8=w|vg/j ٨7?}Xn7_Բ.~kQѫ V*mf߶.k&3g$/գj"&Q T@5P T@5Ojj5aiX4oҰ4, KҰ4, KtnjZA@5P T@5P To9|F0_$5 lAi.܈a0_e/$&_MON Ȣ zWc0qg3y}et3I( J'∝BR<&ŐԈp:[\/ن+[I2AMcnR#±kJ'ݗY2D$MIINJcsR<׳96_%lH'!uAIIJ'ߥ' &_I/b*HPѻ-_̤*Dv;Vn!ڐG^'bb߈)tRZeV<7KT;Nq_FoHG fHrfRq %4$ ETR@+jIdC 2;j2"0tgz H2@2MK@xTou8DKN31t5:̋ ,'(l65 6q6'DRrH])H)dZk3>g(qK;% ҴA^>2Fٰ:d|:rFz%u<)նG[& I|ręش@4,>8~NmfeYR5nYN6$)@*$-d yC1 J-YnDL~D=I,.̺Y6 yAJ2EPKbA7./GenuineIntel/GenuineIntel00806E9_AmberLakeY_CPUID.txte8IФ^ڔaӟGǧ9S|r&CU= ޙu9x]|`y#@ uDDND<_PɈ4&֬ RQHDp"81"uI];oy"%zB'9 9Iatm'm'^9pOZm+=Rpak:W"$'H"kMFʏ[cCΈu>\G/>BaBebɦd1kD4y)؋b?YmAڵӢ-;A|vo-H{-p6$k $ZɉUzjS0k@S`._uUك,1%nR2Q7.ߤ`$g~Wum1x?ZhKSpfWc,Lc-RF/47& %ĉD<#CC@JK̓F/~5m}y]c*C&Px*/MyWx~}!Od~, t/[nssucLuB9eƏ.,vWf'E?w&_ і>y5}uUZ>~.OuyFY6bNŶ L'LRu(Cl촲"o:F=xp>+ mC2"cZUV-©]B,9?8${)v@ CD!q?dJw;fMgL+", yytޓ/D=l]2u[ԗ"3d,ӷ ˰-m!PRچ~%9{Ow2$/C^EU$$#O-Ta!Ҥ4箤n ,;n;q!֑N.3?,v_i/AF% Q $!gbfl+ MI"f䳊8̀|%L" KbV2x%HYܺuORe@ F=dB' \2bkF˨]IMF@"˩"g_+FG ฌ\'{ Dr mH@2~I*2LcPfE{O;-2PtC\?HPbJ*9<`֏Ree ןLlJ|>N bLQ,L/J0VQ>.KN6 d{F$HRY:D}λw^I9u{UZ%7<RCLJL-$֚['!@J9PK}f:./GenuineIntel/GenuineIntel00806E9_AmberLakeY_02_CPUID.txtw{6 =$ENKS.5QsNקhELKkwx"/Aу_ >a;>g wwفo |Uf޼vZvp}r0vs";9>+ǯl0xx]FTyg*Q/UdBmG|p4\E+D0ۗ]"W+u#qu% 8%&[~%LMSeѕصc*,=J;-*HZJs[ZI촒UaS0o`7#(mtDUG%&\ceuVnu+V)W?t5b.ˇBkt^#9H>m 0tP=fT@>b>amTcF\->ĉDOiߓۚ@>n}-;Ђp;6" 6SfPΘa؉v7qi4מ >V1II*>؏;??g$Iw1T'g+9<9?wj5T b^ fZjז@!<M.? 8p4@iрG 8p4;~%!A|{p A ohG uh@iрG 8p4;ͩ57$1F؜hRNM9u˻)MCe\t˻˨G"zMO0ǮA6)W3quN"#6SL"+0F1NڇOWDr &$Fdv̎RN{,NtT S=O~e>A0t5]4WR`xP[٤*Eg HzQ`z@а@6-TEY%{V ;/1T%mZDnJrAҮ$%ČYm򅑤@#(~3IkHj ,DDJ*R@VeuۅXC(]2/<i{]`O^O|^x D&e2q*JNE)t3 #?IF`̞$\I++ ﻔ.#H.ޢzè6E~XCTHhz=YdH`M]`8c~H ~p;r!@;@MH@L{$BxGzĞ`-57r=ù[~([T m Q$$?6QdDz-CY4ՔX&g"=0h&Hv]ˡL&t@8DٰkY\*Cfu iBD X&d +6>F)^@)H11zT뱼a[w#01v:I9}а@V"*TmȠPܬD^#}Y1#u혤=ֈ+^h/Xc`۽Rnju嵑I+Xa+V>@^c0+2h>>>?[UnY B:ruk64'7 v:Q3PXxVqAs Sٹb.T  5s`a8%iŁ0]4?2W~2MȡZ x$9(A#L "`Pxxϣ"ǒ@Ys< {Af'"Dh  &5J)$!ʯc| o>??tȎ(2I*}x^> ׋kݽj֦ҪSm `]zpMo=bS}>JJs 1 0M;; rиڍY[-YYYY_Y^؈=B자؈؈؈؈=Gk6kk6k6k6k'vg{Yg/f ^k/fmfmfmNh}e7b#vb7b#6b#6b#6b'$#>}">ڬڬڬ!gq! 2C"|u YAbk>蔍kt覱]E7S{(Qe54ר.{_xs5 G5,-5_f1oqnl/2,E<ğ,sd~ghD74ΖFd)Yz"T Ab[(Ue:p^:oqb]V/(02Hc˰,<̴(E+XR]zØJ] WJ`) RjLK)_򈢬w CݞH>:!YRcìߕ)WFbv DS|/ZD&i ɭ_;o QU<,Dc: ^ Fb^|GI!]@d}ߗ@*],ػrGFJJ׊o$r !̑ $7@=qg^LHA2i>D5R78t@YS% ~=qS:g3{Rx2# eѓ/q黩B H<}8n^ 1H )Hߓl)3D%f7;^Jm~*3*p9B md[i$J^4m ^ve2~Q~ Ł+a$. P(7Z4T4OdlYg 9/ˊDe/ :ˬ RĈyA"%f@uڌ^W$J//oO믟|q}gB %(ߨ>L޷ݦ}Ԋ]cPgc ưf\̳$*.(b]DEWU 5E,QU#nŸۛ'k"ObM/?瘝4&dRIe욆!a@HW"Gx/AH_x]'Bg7 ;hhp2$"S1 I{ &d\(C#r`r JCAC^dtJ{Đ>!E? .h4:%4h`ȸ^("jS$4%PK5 ';./GenuineIntel/GenuineIntel0090661_ElkhartLake_02_CPUID.txtrpZwɪ0r6|o6_ҥʩ^j&~KK4'[,͖\m-V:DwTЌ1'hD^)`e)CX"6CRQGz $j%h&@~Ei+'KK "f侓tfBz|dOyCi%b1}D.9VKO4<Tk4})o-忣KHHKq},\KbvPbASbI+ℌbɤCZ;!HEhjV=ӳȰN=D~މv(? = 0N"re-ppwp\N\^\vppp;WpW8PKS* L09./GenuineIntel/GenuineIntel0090672_AlderLake_02_CPUID.txtTao08i_@"4)F-"v%9es&M;T%|Oڭvk. {AQGSeRo !n)_Clczb<+˫rEQ sPov] $v&hU;ׁeM&|q=z Džhح D9#U(ϨyVZ39B cv9j0p`|k:Ox)ꨚIJ>? ^=Hө}cYzkH}ui!I ㆬQP-GƩadOk+w 4u{I\7b`T(w;WS6~9ORqK<gW(l_,][csONDum0мdDz:i3g`qOÅQR b|nX5Sr@/NAfd%][t^0.T5cvK%@;]I0B# -Pdg_ʐyx:\AD G3AL,_b*M&zCg[+vuFUœ˩˩K +_,~PP$UXH+ɼ]F R ߐ5/h#V]pEK˯W k4jx7܎ò w566_#pgx:T Xk%W%㎊BWQ.fygV 7%U]z IK(̢Ct BD`0p-$òΏEs3YC)Lam\Q'=#6LYn۰eϑt,wDm +rEbYd9F=CV;jtrz;Oh !=r':sVHKowa } Yt5aJ8Jl^<=dz>ē+R R aˇd22P fdC G7sVz6]* l'Z qGzFxf_"J]pFBƓ%D=0U4/*Rb<@t+8@:`!4BDB Yc"}0@\CTyF1 ]"vcY}Z>TQK*S _O{x!!FE0#?Dt Qb'QX#z} %1$(3a+OX!bT QdKpiϾa,Bd6 "xt4I+MM辶⚖}MӤG01pF J "~⻶Bo ״h&50Bp*f=x \BcionnhM˦iR9GQH0rKlzHVMMi4MjZ5\p4mh7CӮiii5YM3j)g@njiizc5mIM˄YJF"{XjM7M7Mom1GO"qfM;VMMiw4/9iqDiiiz5yAD*-iػi<<<}cNwiҵ7u꥽ORʥnֽk_{Qe -7?A_һs[Fw~x~z?O/ci1hANᅲw=NnHrN)ߡRfzd/r^u X a8ngzkf!\H)Y+TFfwĸ'=aC QJul~{L>HF*MW(T{J4@*yK!<^42UdhK )2Q[w^H-s%}kj{G=?룺{hOr劎Tw\6L]T7HIiioA>!p쬞=k.~p!D;!ߢ%Ef%Ɋ|5Ő 8 BJXAR؟߿>!z@$DMM6f; 'e ]CHʈBLYuG HF )򜽐\?!: of ;ZLPpb9ΐ4#)eRfґFд!u=2j3H"ݡ5myt_=mOn 86Q;㿒U#xf 9 r '|d$ 8vċs${yn{mO}لYq볏tl%HUTYĉ[MY닇A\U'7N\xgfFS;"Ut}xXQ]Er !|Sg`kE uy'Fke~RBߗ'<(w|rZK3+)vR^Zvh ]W|Ce 5/cWi/ atJx4eu1\eW,}U&S*3UeLL2TP*Ce 2T>&2TP22yE"c1ƴ4c`|10cZcڮc` 90fi"ӧ 2TGTW*Ce 2TP*#*ө UeLR 10<c`LN 3c` 10Ӯc` yØLSUP*#* 2UP*Ce ɻ 2TRcE"cc ii1c` 10ƴƴ]1sØL2TPQ>_e 2TP*CeLLUe 2mHeD70X1%0c` 10cJ `LIb 10aD*Ce UP*Ce 2T]UP*˼hdCch˃5ƴƴCch 14CcZDcڶCch c4SY`,#, 2X`,e ۲ 2X ̹ 9gkLzA9Ә5欟Ҙ61=;Ŝ!A1H9ҫbP ib׏Q2bjbF%QL[_^/P\7(&e%?}X3K ^,qK`R{%Jm18g,1,QXDX<%XK` ,%J%ʶ,%C,VDXK`alXK` ,%۲Xe% 8X⌰lXK` ,%8#,qnXK`s%rZ\`-.%\Kp .".Ѷu .%e% s .%5g\Kp .%5m]Kp .\p<\K".q{Kp .%\K".q%}%.q\Kp{%v .%\Kp{%\Kp .qwHBY G1*`u '>U6e-_TiDv1qi2;m'}0'cX_BxapIVW%Ɓ(q"!Z[Y]QsOF0bf(Y^͒X'֬tR,Rݗ I\A '*̰ ߥ:yHx<(Q h,P+ iM2 &&|!\6H)H6ND8_+T^"c%'_"c5Gi%%tIK@&@ʄz&1:!/I~. QQz|!UԻG"4Rv@7oǿێXYg@m8G2jR^pļ1Sfq6K `qb{&D Ȼ'r^4bBMbށ_Id ̎=$c [P% ;1ʬڀm{k; FN=jCأ>Q9ē,פ~]l̛naL؀,DeMꚼ;⌢lF5HD8h-.5 - _">eb]$eK eMݔIEy2l|&.a.dŸ܇2yW`]q/ra@t3tb$#B['D$BYwu$!L"\I zyS>D>6 Hj9f $̢]҃^ћ%^~7K?`sbSI+JC2) `q@7V>fH(NN8`q01+Gͼ8OtҧuGJRSI.m2N7V`q0qz^g8q"yl&d'td'%N8ޭLsq 8`q0o'a}Ղ.Irxρ1[QU8oq0d3a1chQnq\oCB-m\rq08`u8ŗ猃q0 䬄J؃FVr ~!j;r@9  rVN e)sc0sVQr99 r@9Yrr@ r@9+%z6t{ѷ)9ær@)y,!"dث?9,1IQ]!gHiKJ9mA#_ rD9#SYCo@NSIrYfYrlZOvr̿sr@9 >אr;9 xRr(VׇbJ{ӳr@95$r@9 'Żg{Sȱ? gr@c5ށD9 'd]1rRhSir7+9v*9 Tsk9ȩIrYANSqHqN#Ŗ %w.r(9 rtk9i\>9l!v1JAcrb99 rlk9ș.9 䀜PKOxa:./GenuineIntel/GenuineIntel00906A2_AlderLakeP_01_CPUID.txtb8_{^;3 `k{}Kؒ^8+FiT㱘SxXnUG!\ۻ[F݁4%O6S_l|,Jt{<>(MMWqcG"YDy%* ebwkqS9*?4w',)k'6VdvbٙHb="ÐJ戊r4- «Gk M[ٛ&n 9h @1eZURK:]N-WP BBFF4ɢ,6AI7$X|2atLrasҹnLV QSxtz2cI %1ƨW*:&[vכ؛Ax1F|L-ċjN^t&@b:W1+F|4 )hZ+V`O]kvE0pᓠ°,y„><3l ,0y0aV!iDGm̡pʴ[vQW3ENg \"[Q9F cuAD8(?C;Xpp+d;2 J`.E5Y]U5.lm~ 8^NZX/V5`DZT{lyWS4Sl dUsjp)2=; b(ɒDQ2 O*("fLxE| ub o<= qj*oľGtNbX, [>55ڬѥg.Wͱ/W"2^f{'Wب7:$rr<0- ȋ2&1 iqݍ8Nʿ VnW;eC9<:r:Q1Έs+|Z]}}}4IJ1 IbXa_r x|-9F@Ix{>F}#!n=X*813,14IJcЊ q]ƣ;mO2EIⱌG=q- q]M\%|fe7fƓ\ WWjQC%uD3dM5Igۢ-q,A>C/i҉%0Tԃ 64U2쨆w)Q_UlTRFϑr H|P#9 e@esr4؍I%9,tx9bQ&/eLzIv]ؖ v"H;v#z*kJ e5$ ػgN?@ύhLP~vlg^?KWn!Q(՝ÖoĘ'4]_Uވ|+;O>9{ZtرP@$!\Q|i {% CD:ϯ;+ Fl)}i|ew@IV(s'=B웑'@ʺG{F=wx# i#>l=<7M'.N\ـ,o&ǚ7|q܉84Z%Sru/@iԤoF%b{H\GI_~.59fLgX< [`je`=|Ճ /Ogqܖ$`?K :ZYDDX$;RuDg] e?ˊ0颈5 xREQ {I" (FiGYhiMi^r\a(Hiuq+γr힦xȣY=oV0>fVP[n&ڐis1xQGeŶm?Ռ3beJ}K,ϻadaqq8IUUJ8^\%e}8w3N8`q08q<ƹ7NmnWiRnc3Ʃuq`q0Ne8]~8`pgSS4ֿ6Ό^Js*;r8eگq0q08':`88'O'>.-}m6xA z818`q0yqܷcǵ?iq3K Ce84,fY!Ln)fq08yqBvbņ"Jfr4V4>Bݒxo$]rU[)H(#%Z$735\T~byp%K.VpcͫPx(!!#d^EH,M6Jcat2a32Em(h!d@J$bQlT:4x0^kbgyW7a!8i (#fuwmJAƬ4hՂ\1F_]o:]*> _@0 w? :?qֽp%ö0O;dLL؅պ5^fPWh(⫄+:_d5nfe%SZ];ܨF $xAjUEq#GJ ѮZA,5V%W:z(K5o03Ńrw6EհY-Mmتphk~s8ۡa+Y ڇMyQ(l?W

)3_/-Sٔb>0`ڇ63 65ۨDu2ɥ`ޑK`QNxtyĦO?ǿ{DԶGtBG=). *uyuGq#x((y^^˿K0RCRqǛ߿ϾA$">|8>FU\81"⾊1X#8=4ⶊk1)Wc0#^aGDQDw+"Gă3xD<8x<Fȸp8~u.Q5+[:AD4o3ī~%ҍu5"X"ZPR[$/fcy{o}Y9i:du=K,kxʨʈY\A + x IO `Hʰ޹6N5eXK1OoR"%Nv_=ʺSRx'܈<3<9yI'<MAv\N_WR#Ƕ$udsHArIH1(1e;#kH@bQzArZh?7Y3]CJY۱+ 6yGa8vD!Ww[cdilwy2oN;qekrIyʤ5SJ{=!t#L1 *[Oܓ:JZ}Ikr̺LgXr[ͤR->aLd#/ /Ogx-'J1ᶾ$($$ Hw+#Yw;Jov80Kq`w8f8 ,Nj1Ɓq`q㌸`/I8k 8L82N!L&|q80808^i9k=0NgpY^80808uƁqfj38 G R8\H&rϛӢ7ƑƁq`;ob`U^:őhZ$oqH-1NE8y{Ɓq`28Ƴ>80vGo1NqNc2S7N-F21HqUq`Ɓq/4aw'S9-;'95T)wC9@9@9rv '"E)8S* 5"-mrd!G r g|r/9@"i9aQd. K"~ފt :!'54{d}9@9@ܮCSB9s?r)r96%!ǜTPNI !G$r r gr9r҆aARͮ{cM|%ry9@uA]K9@SNP4H&>h {+|99@9År:ߐ䄿#g|훜V)r5K*.uD#D1 {(r r 9@NO "ȱS9$jت jq%yrLzM9@9@|r&ǟRWC]mCZ=G3IVvHI Lr2s%rr ȱ?CށnBPKi8k:./GenuineIntel/GenuineIntel00906A4_AlderLakeP_00_CPUID.txttT06&aH9қbtY\{cXv]}gxGe/kވI06xÃpgS*"=<QE7Fgp21>z [Uoog|*.Z̈eRL9ؖmm ZT{{c*OW:g0}eϳK&q| Q˩ԥK Cowx!RBR`^8h96\UaHQ1̧T„n\!✨3!; WD1 ^(iIA)nw >t Ivs@q7q?!"|uF2T>=WS]ɂV WKhL뤭J`^0^5|jCa$ y:\\r,)\K̺OSx(STQEBuȕǧׂ\AJK* &l.i^UQ7p` k8=Oa ߐ !T 祂NoOj-vo:К>kW$lx>m(hkNJBv=\-߇Et,+SHBA[K9ƖWpQ(xF3B`PH9ۈ [h"^5NCղ'yG1ׂЌ}2b^s͙Ba؉Yg3IvNfT?؋JH璒)ؿI1 5A   4ƹ_hhڅrK .+q7} *)t 6R70;ɥߕZ rv= `9Wvv]j"<:m",i %P5N!qx v%؊s$aMgVBQք @#0.67 [YȺ\Zr[.]jSi^%@Ijul p9dƎDIl*ղ `Fm8I  c %C\U=d";4IۆZ&k3$pa%ulDF6#vm̓EV`Y. @%̦¦dtW\ݴ@6]utupM._I!%4Yc#0KN%ゆBZP^Z.'_53 7˰d*KU:w&}8)eHA:Ն׼#B5_taYNw3 ݈#ø`5Q2c<<ö\̨MMج̀lc\2E<8$.^R`3X'KA풒%[~bA.õf--[̑G -P?,spR\6fT=ͣL^e 292@(e 2Pʬ292@(sP)]((ȴ,ŰŰŰbX a1,ŰvPa1, }kAfZe 2SeQ@(e 2PL2P@څ2eLNNʿY3ֿYp鳘_! zN@ 1 Ĵ 1raXbjb_N; h ~/u肘 㐔?'ץPٓPrd^(Q~Fj; JtBJ(}b (qׅ(QC (%DD%PJ@ (%J%AQJ@ (1vD%z(%[PJ@ (%DD=(J@ (%N](qJPbĸ5J@ (%PJPJ@օ(ѠW(%Z%(%PJ@ ("(PJ@ %N{ļJ@ (%J[PJ@ (%A(%ȩK%*qYO%J\V *A%TJPKD%.GU *A%DRiTJP[D%n[TJP *A%-TJP *1?oI ]m r`8 cјI0z6YtߡÇyx!|Vz+o3Ysi9Nmq_x׿?uT[и(>nQn,m|0 MWm_qu?nqSgq6>:7SNGs;lU=:/]v'qWZKA^%D;I/$Ⱥ/?ֻ%?n] -IDJ8C6Q ve1tdԠMr+!R`g0(֗!+N8Ɓq80Ԓf|qd~C8㱌o1N_3Nn+`W36%U&%x8nL!n8 8OfƁqA`Ɓq;ct.Q J^L29P6$ T1GPTU@PT&TUѾUjTUh$5߆DIvKr˟ BLUrې^XRܢnnn1L,lvKrKvKq:^UGX1ge}efєu}P:hYN(AZ)X_g=Xփ`}qX+d=X?()m Ԟ`=X X-fը֏M%Fe>ײzǜYz~e=6ދB>Rۋ4y2փ`=X`JQ%Z9lW O z~[>zޢe=67HXzc/?\qZ9p}C^Bp=\p=\"K8zŸ'Ű1kPJ!gs=\c. t_vY { +}Uhmz빧eu=땳ozW\?gn@-̈K=ή +kΝsݯ{W_}Bɑ>srndcG !=Y|wדfN6wWē?VHR =T*QtV̽ʪ^89N|Jfݕ<.x &<2ऱ}gNw)bBd1M˸gE"AK:kք:TnkmLۺoIÚ7)@.|o[&g~~P\KK 91;lAgnXWR7B0J@v7Sڰ>']y1lɳ S:;"'8Nsf'b4(fGlc-ır8I#ӏL?  &+_1WLf5ӯ~07Le-o~;1w C,\rA/ ?BK '+NY1ӌ6p'?sx>v9l9V92gZl˜k-sem?)l~=^_OJrn91D,ċv雀a&۝_gC Щ,˱|||.lDhIX_m6Ϻ.}7}o<,Og2?(0:ld!qBƇQ5nԚ=p6P&lRoASjd,s hUBBG"GbD`Pд˞X5md q|7:Qxlgԁbͤ:æF Qg5Dѷ$u{9\{}: "̪J*HApIZF?X1/䑶 n+h `)0Az0ٲOLԫsFݦ)0a˨%-SڂmO9.q ))uN0N$$l܆T6@b蝾E7AAt'"/ٲ~ݓ$Oal7킸,C I֖فӗT&ɞ 5mNGu,σRMi%~qXr.DU豠DH3\3p5{5jO%, ;ЭLIޮ2ҝ.M+B̞9ӳv%Qa67攩Ƶr,glő x(|^"(.`(O' uqY*R3o/7~Ӏ lse9ȱ-۶Xg6~Glfh4 ۉ";V qv;.eH N/)f6 &2oM:ff&%]3ϔ0"m MCk ,w}m6isj::usV ۜ- q 'PRMB (v dt}qd. W5a,Ю)fm"1]:.sa z\lD~ݻ V,"@SqcCwƑ\sjҵlW}!Qp*hAI]֦NA$niݶ1MT0j)ib @RTc-N-*ҸƺݩSܸ mI HU9 FֲpP{񞌶kGú GCzE{m4cc<~/ǿ׏O_w;9MN ><"@t!B#o:0~ݲF.]bHu >eS`s}^NRGwI SSS#Rԩԩԩԩԩԩԩԩԩ]RoCԩԩԩ#Rg?SSSSSSSSS3wIyRwNNN:^HJJJJJJJJJ]o\?|Z,m< ۭ˝=64Om*hzgbo260;Pz(y"1$ }Au> Mƌp0/Yf4-6٫b@#B=D,f8)ta+dwPZIlV'RwQ"ѭ_@XT>ݖb+E"e#LL lGM!9b&ߌ»E - A #jqwk({\Tȶ [ b#H̀n3@^g <'hQ`L$|] K?#DWD ZK'&-v""#@D.eti&uBϹ/@sG=sԮ_QѲEH P <}A`dUslh{#eyJb`\-[pE,C1u@XbNF)F"?I$Xۤ4hä@}VF6!̝dU ŝ̺eq[$`'2㋞;k f=$3ѓbr<" gbJSѓby17 k ׁPMԓf!TwN  0:R8N,˱|||3~09i!b9``qi~8& ͯH$:.4:)oT i ą'X"p^8Pg ^,333~IFndoe; ַk߫~Ai*im⺉M ԡhӠJ2$`!G/5d'HisN<,bT*c9XZ~cJa)#C~@Kr uiuxKn}lTs (<$CͶ'j :19ʫ"ps R o/eݚs #iX&59Q0e0L3, W W?105֛D1pdw>)c9gC_Z7 eNh"UR&nǃ,t Յ֖k\Qau+VG, # @^Y6`8`5vގv0E6, O\sNsZDa'CՀlYu2鏧}ER\n>#>?s,ȫ/_4;?hԲNN҅N[cӦ>2~?v䄁XMg0,6zvm΀v۰ ۰ ۰ ۰]]Nv`lf1v،،،،}4[l6lۍ؆m؆m؆m؆z"{c36cflflflfoc=2`a{D=n6l6l6l6l-l=3{F=o46c36c36c36c}c ۰ +u aaaav n0+*>Iק@zϧ-ػ6CpxE^fA]zz~a0~io1KVr&F2*`݂̒e+jAe*Bu :K֭䪅>S*ndɦ\+nv7{l0k_G ?t;o}9"u;E[L~XVZPАIf'9MŽ~Wh%'녚$I&112\vBaH &tjQ߰1X nS<>#{%G#☳Ԅ@%o~, ȑ)GsqgD2dn`X**=#qFwapݏ,&B3&GF(Y {.GjN$LSltET&"WAN)gD2dGG&vFd( *bnML8FgH\I GC QCHZE~!-*® zÐ>GG#!be8H#,TJM2&DGS;!F 25H\PZ1Gֈ!=` U}=Ȕ,ԓbAɐVyp Sq!s  QjicVKE6a*iyLͫ}fn&D}E1Z2a="&mӜdSJ1LeŨa4͆!CəcX+29Hɉ#=hd 62-"SSA@m+;Fd[VUM%br)632У!fa};/ӱ~΋7X:Z^tʝ>Ow[.UW.2=jZHJ)a#h0IN!mt߿>TOM.y -3x* sͮm-8D9 a,5L#.EU`t~ :HHhA2i' 9et{7|%K 1У4T3>@ulGPtyG Lh#]{—IEdy_qW$.h1_ytʔ3SGT)M>1$'m׺qry)C|ss)B чTT @M ,PbdiM!o9a[5M7eR)$ٚx4qU תY%JJ+Q&WM@0Pڊs"epBF3P&nO݋7z T;ySL_|5>8szFiP=&J9aSV!ϿsKTypH;woz[3墸2g)>}E~hN"JErW Lz=|Z1O͏߫M% ?AN_ 8ldOl}dOӓa\&Ɵ|j*)vzv,|$qVjWrq;I((-V*B*B*4B*4B*Q dU 0* °* 2*,²*,1*±*ܬ =zQq/Az j|I(Ib⚉L\1O1ogJL~ěxUw e,BNPK~RyP6./GenuineIntel/GenuineIntel00906E9_KabylakeG_CPUID.txtrU600PpLKM,ζR00@ \@URBm 2H3؉C23=}P6#G2Ck; s_\ך{?|ߞ{ZA3Zyk⼋]ef!^@IEt.FJA/P*J'z@bArl7xZ+,%vyR [KDăIC3砭7loއ~scmHjT@5!6 Mf0hYVނ*rP(Y]9c 00e+XxhϏ8 &Q%((Vr:LsƺCJ.^$x&ne5勺+ ]+[\H^Wh&FLL{J ^}dr>0Μkyp9[ei| $H3 *ι9:&͕M%I$sF.);c.+SusP5+% @ouN1 /d ]\O YY* EXذ sXXX_X8Yر +GXsXXXX8^Xp`!Vdሰp`!b!b!pY~,XY8#,XXX9,\w|.,Š,\.,B,B,; g> wEb! w    ϝO> OEb! Ϸ,B,B,B,PK]L6./GenuineIntel/GenuineIntel00906E9_KabylakeX_CPUID.txt =0WπУ5]~T:Z_oAcϟ{@OjִשkV;cֈ6XĎx;Y՝{٩_W2<رh0mmY`ˀIEhM:*P*J%@P$纺ԝ+gWԋ5"XbZ9M0ƿ0ENFΔ[vfCS7I9jwowU6@}OP/GYa#E0YnWΔ5gá Txa:"mJP|\_bMj*1%32WV0@bЉ&`sjǭS FBMeE5q Qcvd0ƨ;ӻUف6@faǎFZ4 Z cRWN;'pS%H*iBPqre8qwͺJ\]X@-['E 0)gY8?Ҳ3u588k583838ˍyg"zg rl|콎gpVg#gpgpgq68k8pgq6#8pgpgpg댳~g "Vg rlq6lWَl=gqTٓgpgpgpPKˎ ̰7./GenuineIntel/GenuineIntel00906EA_Coffeelake_CPUID.txtT[o0~G?i{$NµhdC t7M%a;6Rσ;--煐YO7Z6&g;  8ow;vk=-؄ٮ]HzVx2\`t t6FlP)ʦJˤܟ-`e5eu7sH2H.y  yhx4OnT/ka(k e:wNʤ6F &YQe~?VohKZǟ[$C}ti>Cv_TFpG&YvXeyy˜g.a ؎Ӫ]S1"i;>c} DmM:rIFh,L>fX`S*Ӝs s;C ( bv"\s;œO q(o*v4 OO`/H]>(#ϫt۳T]YݮŎ̫Af%6(RW1joځFy٬MUCSBOʢb LT[Q"px x|,}|ߊ^LԵ"J8Ap:[/xD(ћ|L`͇vh !ww!&(1K#ņ|*9#d~(`vjiks|&j"eY ʸuHkxqj|d*7Ohj`Z,2$?-KjTC=Nj*`)Հ2G'V%j2|%j/TBDʍXoHuX.fl6s|s=K 痎%<#C{E<:.Uw]V}j?{)B`4Fꍆ=uB(qcDz>rMRό. FZ}8qM$P[2K](9~$76%Y؇e~,",36Ŵyc>4 SlFD!$H gi>)vo\k)LIS3m z@@r'hkd  1)5"f_nF8ŅăRs#/9%&Ŕy6b.b,5<P2PWs5c@!]trMsea˫+5w$@ܸHՅe Zo"z$OQGib05š(Hikp.#;hPcznfg[j5;ncct˗#c9XJ#W#n*ޜ#",HrM@M@ t^yMT{?Imjϯ/?덲ϲ>/ k*Mׯ ZZ![^-\ͱqʱ7~?tʎ]mJ|CX!, y|a؆m؆m؆m؆esF^:{{hlflflfl^nj؆m^#^+baaa!l/A{`lf-b쭢{3vj;`a{`{m؆m؆m؆m>fflflflfsةAm؆3"aaaaflƾ"ƾ*1ca؆m؆m؆m؆yQȆl~"~J"!!!1d&i߈"ڦmڦmڦmڦ?~3{f}WP܆d$s9`o ^O>ooƔBO܏vc=}C`YCe9*Ce =oץ|,ky-5k'ߣ10gHژ;#R0!'(H'I T8݉&I{V u2t(b,C10dнr,,K ﵭ^-7n1dB #Ii(3b%D/n:2uTH2du38b@ZiD606~ hQP8Gz(5|P?n蹂>xz5zU9ɐ# N !c'@fS1&64 $Ŵ ) E@K S ƘMf!G< {J ,Cqk s$ƝC9"0vyEZ.@= 19PR(TȐFaF rbn9!F 1'*< ,;o&4 Qfs' dzES!}\a ^1dBB0Gm? k siIĔI G˫5w A_D|vGkN2#CQT!X:}r9*'5yp`2g rf!}irTpH׸L$#Pld {d,2TSōi>k/-?^spGNu4說͵J\Ӧϧ7=k1iЁ~JJ ۨ-@s)z.hiڴ]7./GenuineIntel/GenuineIntel00906EB_Coffeelake_CPUID.txtwwFN^nʲ, ^O/r飆A"=)=:73 kOM>V>-|8:x||ӐMώ|0p=U8}ij @ʤ&ɔ)^ s{ϋF ԈdB$DBz.IJ\Ĺ1rT9(He4 J RDML JIE@| R:a- kKJfK &Wf KEiTEfbl@f q2 nX%&칥Įsu Ѣ JJN:4aFZvbu_B4ۼX6ab׵R\rհ sg璑NX7l-%PcԀ 7LIgZcQě˛+댫]V0h'ι N:`2)pY C5ѵG.ĖPFv*x aj:R֤*d0*4[j|qˉ|qRsbAD) Dr_kDPid 0e% wYG șhFա8ЧϜ}]V N(\މ ;9T /@?Co=+Ka|`ի 0ZyG^8??:pkoˠخh̔KiY,\dشcplޱyc{;wlޱy%ñc{֛8':wlޱc{[Vrl;;wlcc{;wlޱ{É_z0shc^m\:8u\u;ݸqӎK^mҍp?/3C, c8q<:̟zh.?JuY6 )eq]OU SlbZb;sCeaYNQUY8fq#[)v8 *{HL1-<3LWYsZ ùwbk~![M`C$"1ȘVDB'> ( !5<%Ɍlɲ%$eMb$4} N_It/ Al|2I)HN}ԗ?[h˚dȴcL QaE,N!pK `h3 y$;4{{;j {"%%_{rD0lR5ן k-+ m]Bb2i@N3Y}g63bь$gmuO4Փ qc u"1j$x e@.s/#1z;R]ԗ#SH.3qJ̵D}xOe|Pҁy}{g:/m?fp6Y(n{2vLY 2ۼiY*lK fZ1H/I^8$e%Df$aQ_. C;`N$5rz9FQtE5b ~m6"PK`>7./GenuineIntel/GenuineIntel00906ED_CoffeeLake_CPUID.txt_o0w$I{٤ΟjL/hNߧ_BB Y8"|,6cӇ|.^^ p0S Kz؇U|_e-` "-+\h31aȔ"g˧|],[6kDh&cH!$q"q%yHTF!aX" "2IXFfiŲS+f%k\[XY2V5mMu\G P "bI=d*$s6DFָ ^I&>1F "#!CIFbqj#vs-z_0cc1 7S%7Dz (ۊU'flI.u?&ԣQ$)WSS.6-~A(n.W]$^~S/1YwwPH؜(l]ڷI!$cN i)Cc"V$C05^֒F~*FZkJˉ*y0۽+x T_;,!sAnEAw&Ca Sbu 6gqSIx{F<]߲0,>\g0͗Y/i/-jγ?ZjSij_xWh2]z88x=WS}>|~Jٱ* XS5K`]b ;'lllySF\\\=G\=s5Ws5Ws5WsuW/cNlllusF\\\F\r5Ws5Ws5WsuWocN7lll}KF\\\G\Wq5Ws5Ws5Ws5WN*lllskF\\\}F\}Vq5Ws5Ws5Ws5W_N*lll琰;kkk2`Z׏&l~D l&l&l&2žgX? 1X _a !aukwokkk.m ֩u l&OD؟Da6a6a6a믮K믶|WOv#K*}Hq ,'U2$XP#&:%rGkq>y иc,}cA=F˃V>>q܇/OJ<[-1r1\G٢^}9jQhc,}1_~q_y_v!<—k&k{KOnr$;AH "T {i1;>SƜ SsY ;@ZIыÎevlLy. : ƫs$o8+w=I2Y#x H×I֞HZRm>[IҾ$A$@Yj Jr'T[@:4KOՊ L'i~^%K>Z-.4R2oD#m#[6:B%&̜ 3 Ls`nߘL܉5"Z2+ I@[*A8uI ƅCѺ*Hida+Fvf @mFFhJO ly딳[lI=zAH-#gcEAW$F 2: ٦r&>6GA\gE,H4.:B>6PZU .0uCziA|qVmA>qmdtrHq !lb2TQ瓼" GeM&w(CA@yNJO␬.NIy3° "yvӝ@W|.!PK_I6./GenuineIntel/GenuineIntel00A0654_CometLake_CPUID.txt0 wl'hͨW9).HcS IS29[Xb܎jTی?ԋ4"(1Qm绀$[={\)TYVa4N*b`, ݧrڑeD[kc뵳8QB1/o6VWW{8VTT^Ҙ{koc% eu6YanS EF7\EPc>‚Gj .ʶ0Y!jj bOk Qfm5&#δ#OgDbL) 3ic hfuOH9\V3J:R(q3dJUSzWPvB Vn\~fm\@5m>L-a;# )"A-n~+ZWxW+ZWxWxWxWxW^\^^=^^^^?8.\^ssWxWxWxWxW,WW,_^D^$|WxWxWxWx:~EkWxWW _^^^^_\+++ ǯ8^^{{WxWxWxWxWWW_^qD^q$|WxWxWxWx9|EgWxWW^^^^^Ѧ+^ gτ hW7U^+^ _^^^^Gh xW|Wx;wWxWxWxWxẈW;^ O XFXxŷ++W|++++b E^K m66|WxEhSWxWxWxWxWW[^*+E^++++b++z=++++++[^1W|WxyŜ^^^^PK W&6./GenuineIntel/GenuineIntel00A0655_CometLake_CPUID.txtTa6_@eQU5E%{tv`#ܲ;q5ѩZKѼ&o&vf OL\3NU2Wh1A^"1_'7vԅ9Ӵۙ3w2g.2V6jF û(pYZ/ ⼧>+fb3[@6gcLD&dY# 6ra@&[ `I>vU7ӵskrEŹN9I7F[ K0#zqa kd$_ ;Uc@ dEeU>l6ȵe6x<-^7皃`+ߘ,g'*+|$Ȍ%uq Rz,US,5,dʲZzA*oi=X^$̥,5DBS*pe^`c^1U-T~YD_`$3VpscTD5ၟJ^ѭB|DE[|{|r҃Q `3q.?=bXn]Z ZŹ|b8-B Ԋf-"#H?pa?k*6;iy79OiQ!iZ<-M_i΀ ;b42'Z׵uͮ/)f8WD%3; cf~)ָ}jenvƮmcR{:ܾ3 ]P밪 h  AbpdS70Fi%T.GX^e$H]&5ߘI8r&Zݙ+2r ڨ-^e;*nUL] l ..K%quntn@dr)"BY WlC`a7`f߸@" ؓ=@ғCY$֨J^ܺY4]A^OMo SYT;c5`(;a`=VFgeQHKSҕ)ajsq…5s],C09vXDʖ@ ?!"@BM A]7%yhG6hY!o:Rͣ'/W]7S~ŗ/zg3eE˱s?5&_={dlG(ͻts \dۣٳSI`- m((((rV1q p m\%\%\%\%\r\R'((rfr V'%\%\re\rq p p p psIi ʝ (((((^1' LL䙁LLLLLF &uPP^PPPPe 娨&`&` &`&`&`&`&k &uPP>|PPPPe 嬨&`&` &`&`&`&`&{ &uPP~PPPP *0d<00000>09c01&B!B! B!B!B!B#+$N LLdd0000;:Y'B!B!5#PPPPg`}۶ p\D5zںɎ\@q\([(E:D!j:/7ōq6''=QHԓ֞YQS֞U֞]az'1Lqsq-I=p39NqFUz8g4vw9C~coLJy|w]6PaŽj+Ir_0Zv2pr]ޞ].OzU_~_Oh LNd%"g?#LrģgUcb[3nѿ! BIwb4Jj3z3¸yN`.n#")^y]"+[xHEjBi$-ig⽔>YmNEʶx;BP59 ?e1Y|6j0I³=uTdϊ5߃-<+A֏ab1~\**GDAJ4SoEcڍСH6nu"XYN.YҚ")w@D#C4:E"n&]R{P$h)* NtnH0dHǨyjL.Hi@w]׷Csz(:"ޛHZK "e 8Kqli2r Њ5jlKyOZ 7DWB|k[UX*$2gg_zNLo0P|#SPq*}p=sLUeAt92I HGKExUYQ/[E&Lܼ"qiOܒ!E8B A*~"C!EKؓ"w/)@WT C]@H2jx8ʷN(v/- mDnl]}FϹ#]UtTJ˓*|ߙC{h5 Ɔ7͊j_QKy@tB't2ʍ:A'>m7$^tr҉/U\NMMvl6|VzH'nM'3uN :A'tb <9DR]XÐ6SÓlw<'xO\7p' ON< >o˴9mғ7k <'x<"O <' ON<Ō6ӓYk2{'1='u] <'$Ob25ǯy40C縞xO < n <"O <'xBGڤ'9JȲ= <'x $yO 66͔aƚJwGGQ9˨><\csƴ8 ~ p>&f6lz9 ~ Q$pp^'swןNBЯ~#FBo<_s8 ϑC#@p#WqH>iqSӨY{GShF8ONb~O_sC*aJ8ZLJǵ)fNꊔ:BL mcP!yC k5v0^ _WrVqlCHMi1΋q^Ÿ,qӧ*dx#;f>PKݜ <{#4./Virtual_CPU_/Virtual CPU 001067F_Snap835_CPUID.txtY]o0}G?\i/T2 M@W4BYeSՇ ܒ ݯpM Ӷ$Hʽ\_,Zz)q1T+ʀG_4m7m:e22a6}> 'v0 0 j8Y[QRp5F/(.P1@L, d`u05H^I]Jskp"5gkw=K;Yt8I" Y\{< F;w1 0$Yrpdϥ* E*^bA٤@.:!D~r$< G(p4pI V<e@kB? \._-E *-6e,Y[`$Z /Jf|>}В{M뾻y0?clK"o޲NHEޙi4 vJ?OiR]֐@tKe6^LJ_+*. Њ`6E5L>Qw#+c{ɉƭ>jEoO/ &r_2@r#E|=8Tov+\ 55t]Ae!ݲc3n+q]D+v\b3 "@uD #Qu7ȀeSA*QAxǙTM?A:xdgҁllγnOll1k"JHM58ei?Y Qd悜gj ŞeG?p)-J[gmQA GS fA(mQzVA(Q~c.-J[8ڢc(Q9Oٷ ͅN:xC4 éMJ- [5 G;|K1 N׷ /]p8d$/ZhrdMexٚqL^ FqhN1y\}'Yd1R|K-X#x.E ~ ?H%*iiTİ2&VNDb\{nw{b▞@##khUʜ Ïa4XKi ^C{k{qJ%+t<Cht(7Dy i~mh,OY^X\ F?161BzNJ0 ݟØD|6R~ iWH '$Em"ZA!hy^ȓ(^s~cU}Mhø!'+'װ`PKfm(Q#U7 ,BCse=XeEk7jF))VBfLZ2qC78^CZ`\縍݈-.F>XjC4'adM m$% $eBn ïb0N)3}, H'p$#{\iXڽzpfP:T)Ep(7z~4|>Y3ʭK-c, *(AaWt~@AB@d@E Ձ+Adui['O֬Asne_6QN;,]U\E,V)Q,?0GX2H+ *8v_)4d5HW*P|H`pޝNeʚp*CSѩԶ9Wr*o©NESTQɩ 9NESe%&*Tt*:NUpjSѩTt*:UWrn©mNESѩTSɩ 8NES˳+ ze9?1 ,W?88qy>.Hei\*kq\q&+_Z$Ƿw7^kc~o___>O럡S2]N롳7.f,ߐrof7}lgH5tc>A$p)2i^qwܭN~ K c/ %F?;CS$TUSxD<Fw)V~4WE< FY$S&#Փd.Yug/L$"oPK^cl04./Virtual_CPU_/Virtual CPU 0000F4A_Snap850_CPUID.txtŒ0ExUY;xaffffHNE~pQg =0x}{u _`|p{-OV5?ndⶄ] v*\n)anpǭ_uƫz -4SRH)6nEëW3.CՆJi1 uN(Ҏ걡z5Cq 9ʁtdr3΁z XBVa?bzYav#߿MN]09+]XnzQTj%%CvGl{,rF_0Bru ESX#/u`òcv?$e-yQ2#masSfiKhQ˨e2j%iYjZF-yKhQ˨e2jY$iYEjZF-eKhYQ˨e2jY%iYUjZF-uKhYQ˨e2j]{uNݶgC >N8Ǚ8q.㸬Ǖ8q:SIϲ'34a `D#3hPK ll>k0./Genuine__RDC/Genuine RDC0000586_RDC_CPUID.txtstQ0+P\@ $f˅Lf2P PKʁ0./RiseRiseRise/RiseRiseRise0000504_mP6_CPUID.txtuQ喛@9í;EbPO.sfo`H:R{2.O0C!yUJz\uRA 6f~uB?[Tubɲ}@up{d)] I#. { A? 079|lc$j^bW]gJh)cTmϠqpYZ9eJ {Ǧoh;F~'s:k ]y837σB-t"**L =?SIƏwZjڶmt3fqcI>* NJ+_aPD`AӰvvvr OcGo:EȰ!Wwwi0~6&F~H rx[umpHp'e0ٍ} _ʯC)3AuqL {[TBs8AU~Lf{{E*P+-PT4Y㓓KH j{ xXY4u؍,3pz|zΙjhRDMOI-_ua2]z{'p# e)E e!uƐP:5B'< b`7尗PKEW2./RiseRiseRise/RiseRiseRise0000580_mP6II_CPUID.txteP@#3y >۶ucoi7x2%1IGUT%#Qkptxwx?5K׌U]W={pq4sB1ؿyNſ)B7kpqf+'\Z7!v¢},iTIQT˿Vr˗}z$6B2dWs5;=jUݑY)e_H; #<{ʞuu^WM6U$!V wF0" 2s!tFY,!!R ?GdD6P#RDs9 béVVgɔT|~p7.G?6wWyPKUD5 5./GenuineTMx86/GenuineTMx860000F24_Efficeon_CPUID.txtew8WC5sn<u簙v c~(rx.;$&RgsztztķIp~Z]n~@D„HdD+vOPp(7:nGq{?7YSCDFz3-_Lj:U7AV,O33ʳZ~~ܬ-|DgA0 q΃LM MƉK*yqyP[>w [Y vQϧ`maM+a%J 0L+͗Xp4bꚏ+ |'u$Rբ|aCi| D̙Y%UM͞(*8Bg`jZ*jG'MM PRrAFLzRD&ũB @=,Y_Q}G)bv"Ss_ݫDb0@ q /mQ0уcxzQ'ҲnehtaNg=n-xP x1c);,} 0)Rb r!lq=Kb&)c|{vzB= 됝g7n$?7+΍vSt0R@lkd1*n!v] Gq#taG8"5?&qo(4~bMD!&'pC`& MPK!%:h7./Vortex86_SoC/Vortex86 SoC0000522_Vortex86DX_CPUID.txtstQ0+PLH[[rh2j252҅044PK!y:h7./Vortex86_SoC/Vortex86 SoC0000586_Vortex86MX_CPUID.txtstQ0+PLH[[rh2j20Ӆ044PKeG$8./Vortex86_SoC/Vortex86 SoC0000611_Vortex86DX3_CPUID.txt픃PEc &epm[ѪŹI7bx7lJ7ᬚ'%(3h(^*%kmWd1M"jwF:/S~7 [%A ip@ӉJpJ.L5>Ttq[}`AQ#At{GXURrM& 'N@bQ2?(T\b\PpBhN{paCLbb쑛DC+Ⱦwvɓ9+!\wlb g8[ۛ+3lPKgpY VP/./AuthenticAMD/AuthenticAMD0000500_K5_CPUID.txtPKYR/./AuthenticAMD/AuthenticAMD0000501_K5_CPUID.txtPK/I./AuthenticAMD/AuthenticAMD0000511_K5_CPUID.txtPKg</V./AuthenticAMD/AuthenticAMD0000514_K5_CPUID.txtPK6 /./AuthenticAMD/AuthenticAMD0000524_K5_CPUID.txtPK޳/ ./AuthenticAMD/AuthenticAMD0000534_K5_CPUID.txtPK]w-/ ./AuthenticAMD/AuthenticAMD0000562_K6_CPUID.txtPK 3/ ./AuthenticAMD/AuthenticAMD0000570_K6_CPUID.txtPK2P}E7C./AuthenticAMD/AuthenticAMD0000580_K6_Chomper_CPUID.txtPKmH $v:./AuthenticAMD/AuthenticAMD000058C_K6_ChomperExt_CPUID.txtPK y).:./AuthenticAMD/AuthenticAMD0000591_K6_Sharptooth_CPUID.txtPKat4./AuthenticAMD/AuthenticAMD00005A2_GeodeLX_CPUID.txtPKȉM{4./AuthenticAMD/AuthenticAMD00005D0_K63Plus_CPUID.txtPK`!4 ./AuthenticAMD/AuthenticAMD00005D4_K62Plus_CPUID.txtPKreR5p./AuthenticAMD/AuthenticAMD0000612_K7_Argon_CPUID.txtPK7 "5Y./AuthenticAMD/AuthenticAMD0000622_K7_Pluto_CPUID.txtPK4؊ 8./AuthenticAMD/AuthenticAMD0000630_K7_Spitfire_CPUID.txtPKO';D"./AuthenticAMD/AuthenticAMD0000644_K7_Thunderbird_CPUID.txtPK(<8$./AuthenticAMD/AuthenticAMD0000662_K7_Palomino_CPUID.txtPK6YG6V'./AuthenticAMD/AuthenticAMD0000670_K7_Morgan_CPUID.txtPK< <V(./AuthenticAMD/AuthenticAMD0000680_K7_Thoroughbred_CPUID.txtPKnP69*./AuthenticAMD/AuthenticAMD0000681_K7_Applebred_CPUID.txtPK"OF6y-./AuthenticAMD/AuthenticAMD00006A0_K7_Barton_CPUID.txtPKnh :x../AuthenticAMD/AuthenticAMD0000F4A_K8_Clawhammer_CPUID.txtPK=W<1./AuthenticAMD/AuthenticAMD0000F51_K8_Sledgehammer_CPUID.txtPKQh^<4./AuthenticAMD/AuthenticAMD0000F5A_K8_Sledgehammer_CPUID.txtPKTA:7./AuthenticAMD/AuthenticAMD0010FC0_K8_Winchester_CPUID.txtPKӚR79./AuthenticAMD/AuthenticAMD0010FF0_K8_Palermo_CPUID.txtPK[:J:./AuthenticAMD/AuthenticAMD0020FB1_K8_Manchester_CPUID.txtPKO7=./AuthenticAMD/AuthenticAMD0020FC2_K8_Palermo_CPUID.txtPK- 6@./AuthenticAMD/AuthenticAMD0020FF0_K8_Venice_CPUID.txtPKR!,7C./AuthenticAMD/AuthenticAMD0040F33_K8_Windsor_CPUID.txtPKu.7OG./AuthenticAMD/AuthenticAMD0050FF3_K8_Orleans_CPUID.txtPK~!8H./AuthenticAMD/AuthenticAMD0060FB1_K8_Brisbane_CPUID.txtPK)R4K./AuthenticAMD/AuthenticAMD0070FF1_K8_Lima_CPUID.txtPK+wlQ;:+M./AuthenticAMD/AuthenticAMD0100F21_K10_Barcelona_CPUID.txtPKEn#!6P./AuthenticAMD/AuthenticAMD0100F22_K10_Agena_CPUID.txtPK9f7 5T./AuthenticAMD/AuthenticAMD0100F23_K10_Kuma_CPUID.txtPKE >=:FV./AuthenticAMD/AuthenticAMD0100F2A_K10_Barcelona_CPUID.txtPK ]KGy?9Z./AuthenticAMD/AuthenticAMD0100F42_K10_Shanghai_CPUID.txtPKV<9z_./AuthenticAMD/AuthenticAMD0100F42_K10_Callisto_CPUID.txtPKx]75 a./AuthenticAMD/AuthenticAMD0100F42_K10_Heka_CPUID.txtPK@\y_"6b./AuthenticAMD/AuthenticAMD0100F42_K10_Deneb_CPUID.txtPKuv^.:g./AuthenticAMD/AuthenticAMD0100F42_K10_DenebTWKR_CPUID.txtPKPH̾6h./AuthenticAMD/AuthenticAMD0100F62_K10_Regor_CPUID.txtPK\b ŵ 7l./AuthenticAMD/AuthenticAMD0100F62_K10_Sargas_CPUID.txtPKl{ 6p./AuthenticAMD/AuthenticAMD0100F63_K10_Regor_CPUID.txtPK{\9r./AuthenticAMD/AuthenticAMD0100F80_K10_Istanbul_CPUID.txtPKU~YS7w./AuthenticAMD/AuthenticAMD0100F81_K10_Lisbon_CPUID.txtPKodB/;y./AuthenticAMD/AuthenticAMD0100F91_K10_MagnyCours_CPUID.txtPK(]47|./AuthenticAMD/AuthenticAMD0100FA0_K10_Thuban_CPUID.txtPKfU8_./AuthenticAMD/AuthenticAMD0200F30_K11_Griffin_CPUID.txtPKxx&6./AuthenticAMD/AuthenticAMD0300F10_K12_Llano_CPUID.txtPK|!~7./AuthenticAMD/AuthenticAMD0500F01_K14_Bobcat_CPUID.txtPK镖1L8./AuthenticAMD/AuthenticAMD0500F10_K14_Bobcat2_CPUID.txtPK-4L8./AuthenticAMD/AuthenticAMD0500F10_K14_Bobcat3_CPUID.txtPK1QJ7/./AuthenticAMD/AuthenticAMD0500F20_K14_Bobcat_CPUID.txtPKe7Ս./AuthenticAMD/AuthenticAMD0500F10_K14_Bobcat_CPUID.txtPK]':./AuthenticAMD/AuthenticAMD0600F01_K15_Bulldozer_CPUID.txtPK%P/M:3./AuthenticAMD/AuthenticAMD0600F12_K15_Zambezi6C_CPUID.txtPKО u:ۚ./AuthenticAMD/AuthenticAMD0600F12_K15_Zambezi8C_CPUID.txtPKbF y7D./AuthenticAMD/AuthenticAMD0600F12_Interlagos_CPUID.txtPKQxBg8./AuthenticAMD/AuthenticAMD0600F20_K15_Vishera_CPUID.txtPK+l';ڵ./AuthenticAMD/AuthenticAMD0610F01_K15_Piledriver_CPUID.txtPKd|~B9./AuthenticAMD/AuthenticAMD0610F31_K15_Richland_CPUID.txtPKP洡B75./AuthenticAMD/AuthenticAMD0630F01_K15_Kaveri_CPUID.txtPKװp@F:+./AuthenticAMD/AuthenticAMD0630F01_K15_BaldEagle_CPUID.txtPK:@&R:./AuthenticAMD/AuthenticAMD0630F01_K15_Berlin_00_CPUID.txtPKr!V79[./AuthenticAMD/AuthenticAMD0630F81_K15_Godavari_CPUID.txtPKU./AuthenticAMD/AuthenticAMD0A20F10_K19_Vermeer2_CPUID.txtPK':P./AuthenticAMD/AuthenticAMD0A20F12_K19_Warhol_00_CPUID.txtPKL'~ {=.T./AuthenticAMD/AuthenticAMD0A40F41_K19_Rembrandt_01_CPUID.txtPK@H=a./AuthenticAMD/AuthenticAMD0A40F41_K19_Rembrandt_03_CPUID.txtPK؉K {;h./AuthenticAMD/AuthenticAMD0A50F00_K19_Barcelo_00_CPUID.txtPKb. b?;>t./AuthenticAMD/AuthenticAMD0A60F12_K19_Raphael_01_CPUID.txtPKt};r./AuthenticAMD/AuthenticAMD0A60F12_K19_Raphael_02_CPUID.txtPKeNty Z;d./AuthenticAMD/AuthenticAMD0A60F12_K19_Raphael_04_CPUID.txtPK'cZ6~./Virtual_CPU_/Virtual CPU 0000F4A_BCM2837B0_CPUID.txtPKQxu6./CentaurHauls/CentaurHauls0000541_WinChipC6_CPUID.txtPKh~S8./CentaurHauls/CentaurHauls0000541_WinChipC6_2_CPUID.txtPKQ+r6@./CentaurHauls/CentaurHauls0000542_WinChipC6_CPUID.txtPKH.|:./CentaurHauls/CentaurHauls0000585_WinChipC6Plus_CPUID.txtPKO\6T./CentaurHauls/CentaurHauls0000587_WinChip2A_CPUID.txtPK!RX:./CentaurHauls/CentaurHauls000058A_WinChipC6Plus_CPUID.txtPK{ב}6./CentaurHauls/CentaurHauls000058A_WinChip2B_CPUID.txtPKŧ 7G./CentaurHauls/CentaurHauls0000660_C5A_Samuel_CPUID.txtPKNHtՇ7#./CentaurHauls/CentaurHauls0000662_C5A_Samuel_CPUID.txtPK-j 7./CentaurHauls/CentaurHauls0000663_C5A_Samuel_CPUID.txtPK n}8ګ./CentaurHauls/CentaurHauls0000673_C5B_Samuel2_CPUID.txtPKg8"5./CentaurHauls/CentaurHauls0000678_C5C_Ezra_CPUID.txtPKVx5ή./CentaurHauls/CentaurHauls000067A_C5C_Ezra_CPUID.txtPK߅7./CentaurHauls/CentaurHauls0000689_C5N_Ezra-T_CPUID.txtPK&y:s./CentaurHauls/CentaurHauls0000691_C5XL_Nehemiah_CPUID.txtPK>?΍E:a./CentaurHauls/CentaurHauls0000693_C5XL_Nehemiah_CPUID.txtPKչM~:F./CentaurHauls/CentaurHauls0000694_C5XL_Nehemiah_CPUID.txtPK3̑<:./CentaurHauls/CentaurHauls0000695_C5XL_Nehemiah_CPUID.txtPKs:9./CentaurHauls/CentaurHauls0000698_C5P_Nehemiah_CPUID.txtPK+h7<./CentaurHauls/CentaurHauls00006A9_C5J_Esther_CPUID.txtPKl;p7./CentaurHauls/CentaurHauls00006D0_C5J_Esther_CPUID.txtPK_^7./CentaurHauls/CentaurHauls00006F1_CNA_Isaiah_CPUID.txtPKz7Ӽ./CentaurHauls/CentaurHauls00006F2_CNA_Isaiah_CPUID.txtPK*j 70./CentaurHauls/CentaurHauls00006F8_CNB_Isaiah_CPUID.txtPK-Z 7./CentaurHauls/CentaurHauls00006FA_CNC_Isaiah_CPUID.txtPKb:L 7./CentaurHauls/CentaurHauls00006FC_CNQ_Isaiah_CPUID.txtPK@OyV+7i./CentaurHauls/CentaurHauls00006FE_CNR_Isaiah_CPUID.txtPKހ)F37./CentaurHauls/CentaurHauls00307B0_6640MA_CPUID.txtPKa<3./CentaurHauls/CentaurHauls0040672_CNS_04_CPUID.txtPK 'HPx1c./CyrixInstead/CyrixInstead0000520_6x86_CPUID.txtPKHMx1./CyrixInstead/CyrixInstead0000530_6x86_CPUID.txtPKL 5./CyrixInstead/CyrixInstead0000540_MediaGXm_CPUID.txtPK:'Kdc0./CyrixInstead/CyrixInstead0000600_MII_CPUID.txtPKffe0z./CyrixInstead/CyrixInstead0000601_MII_CPUID.txtPKG~6../Geode_by_NSC/Geode by NSC0000540_Geode_GX1_CPUID.txtPKp M6%./Geode_by_NSC/Geode by NSC0000551_Geode_GX2_CPUID.txtPK6)./Geode_by_NSC/Geode by NSC0000552_Geode_GX2_CPUID.txtPK`[H2+./HygonGenuine/HygonGenuine0900F02_Hygon_CPUID.txtPKjz@e5./HygonGenuine/HygonGenuine0900F11_Hygon_01_CPUID.txtPK./GenuineIntel/GenuineIntel00006F7_Kentsfield_DDR2_CPUID.txtPK;<B./GenuineIntel/GenuineIntel00006F7_Kentsfield_DDR3_CPUID.txtPK^kr^%'5F./GenuineIntel/GenuineIntel00006F9_Tigerton_CPUID.txtPKo-0 3J./GenuineIntel/GenuineIntel00006FB_Conroe_CPUID.txtPKB:'N./GenuineIntel/GenuineIntel0000F0A_P4_Willamette_CPUID.txtPK2La:\O./GenuineIntel/GenuineIntel0000F13_P4_Willamette_CPUID.txtPKFc9R./GenuineIntel/GenuineIntel0000F24_P4_Northwood_CPUID.txtPK8'E :T./GenuineIntel/GenuineIntel0000F25_P4_GallatinDP_CPUID.txtPK4ӎ8W./GenuineIntel/GenuineIntel0000F25_P4_Gallatin_CPUID.txtPKd@Z./GenuineIntel/GenuineIntel0000F27_P4_NorthwoodCeleron_CPUID.txtPKPn\g8X]./GenuineIntel/GenuineIntel0000F27_P4_Nortwood_CPUID.txtPK9`./GenuineIntel/GenuineIntel0000F29_P4_Northwood_CPUID.txtPK~'%6b./GenuineIntel/GenuineIntel0000F34_P4_Nocona_CPUID.txtPK,B8md./GenuineIntel/GenuineIntel0000F34_P4_Prescott_CPUID.txtPKHq 8e./GenuineIntel/GenuineIntel0000F41_P4_Prescott_CPUID.txtPKFD 8i./GenuineIntel/GenuineIntel0000F41_P4_Cranford_CPUID.txtPKl2/d 9pj./GenuineIntel/GenuineIntel0000F43_P4_Irwindale_CPUID.txtPK*10e 8m./GenuineIntel/GenuineIntel0000F43_P4_Prescott_CPUID.txtPKS -+ :|q./GenuineIntel/GenuineIntel0000F43_P4EE_Prescott_CPUID.txtPKzH% :u./GenuineIntel/GenuineIntel0000F44_P4_Smithfield_CPUID.txtPK% U58vx./GenuineIntel/GenuineIntel0000F48_P4_Paxville_CPUID.txtPK1Zz9!z./GenuineIntel/GenuineIntel0000F4A_P4_Irwindale_CPUID.txtPKv5S77}./GenuineIntel/GenuineIntel0000F62_P4_Presler_CPUID.txtPK$7z./GenuineIntel/GenuineIntel0000F64_P4_Dempsey_CPUID.txtPK d 9Ђ./GenuineIntel/GenuineIntel0000F65_P4_CedarMill_CPUID.txtPK~; 5./GenuineIntel/GenuineIntel0000F66_P4_Tulsa_CPUID.txtPKCy-5Q./GenuineIntel/GenuineIntel0000F68_P4_Tulsa_CPUID.txtPK 4ш./GenuineIntel/GenuineIntel0010650_Tolapai_CPUID.txtPKVM d 4./GenuineIntel/GenuineIntel0010661_ConroeL_CPUID.txtPK?417ˍ./GenuineIntel/GenuineIntel0010676_Harpertown_CPUID.txtPK 3T./GenuineIntel/GenuineIntel0010676_Penryn_CPUID.txtPK ;*6./GenuineIntel/GenuineIntel0010676_Yorkfield_CPUID.txtPK3(GZ6./GenuineIntel/GenuineIntel0010677_Yorkfield_CPUID.txtPK#E& 3Ɵ./GenuineIntel/GenuineIntel001067A_Penryn_CPUID.txtPKg +4\./GenuineIntel/GenuineIntel00106A1_Nehalem_CPUID.txtPK6}87΢./GenuineIntel/GenuineIntel00106A2_Nehalem-EP_CPUID.txtPK"e7./GenuineIntel/GenuineIntel00106A2_Nehalem-DP_CPUID.txtPK+87 ./GenuineIntel/GenuineIntel00106A4_Bloomfield_CPUID.txtPK}9./GenuineIntel/GenuineIntel00106C2_Diamondville_CPUID.txtPK?k=9<9./GenuineIntel/GenuineIntel00106C2_Silverthorne_CPUID.txtPKլ8J;./GenuineIntel/GenuineIntel00106C2_DiamondvilleDC_CPUID.txtPK\>6)./GenuineIntel/GenuineIntel00106CA_PineviewD_CPUID.txtPKYyʝ7./GenuineIntel/GenuineIntel00106D0_Dunnington_CPUID.txtPKO> 7./GenuineIntel/GenuineIntel00106D1_Dunnington_CPUID.txtPK@Kv)6./GenuineIntel/GenuineIntel00106E0_Lynnfield_CPUID.txtPKR;6 ./GenuineIntel/GenuineIntel00106E5_Lynnfield_CPUID.txtPKp۩t)8t./GenuineIntel/GenuineIntel00106E5_Clarksfield_CPUID.txtPK1c7s./GenuineIntel/GenuineIntel00106F1_Auburndale_CPUID.txtPKwՂ 6+./GenuineIntel/GenuineIntel0020652_Clarkdale_CPUID.txtPKÀ8 8./GenuineIntel/GenuineIntel0020661_TunnelCreek_CPUID.txtPK|`Z5./GenuineIntel/GenuineIntel0020672_Medfield_CPUID.txtPK#]Ufb8K./GenuineIntel/GenuineIntel00206A2_SandyBridge_CPUID.txtPKTD08./GenuineIntel/GenuineIntel00206A6_SandyBridge_CPUID.txtPK#8F./GenuineIntel/GenuineIntel00206A7_SandyBridge_CPUID.txtPKW$S;@9;./GenuineIntel/GenuineIntel00206A7_SandyBridge2_CPUID.txtPKğC9./GenuineIntel/GenuineIntel00206A7_SandyBridge3_CPUID.txtPK5,ue 9./GenuineIntel/GenuineIntel00206A7_SandyBridge4_CPUID.txtPK_ r5./GenuineIntel/GenuineIntel00206C1_Gulftown_CPUID.txtPKXW5./GenuineIntel/GenuineIntel00206C2_Gulftown_CPUID.txtPKGۤ 8./GenuineIntel/GenuineIntel00206C2_Gulftown_01_CPUID.txtPK : ./GenuineIntel/GenuineIntel00206D5_SandyBridgeEP_CPUID.txtPK Yj9./GenuineIntel/GenuineIntel00206D6_SandyBridgeE_CPUID.txtPKZ R<./GenuineIntel/GenuineIntel00206D7_SandyBridgeE_00_CPUID.txtPKd4M,./GenuineIntel/GenuineIntel00206E4_Beckton_CPUID.txtPK إ4r0./GenuineIntel/GenuineIntel00206E5_Beckton_CPUID.txtPKu43./GenuineIntel/GenuineIntel00206E6_Beckton_CPUID.txtPKrc}Z^56./GenuineIntel/GenuineIntel00206F2_Eagleton_CPUID.txtPKWb7^>./GenuineIntel/GenuineIntel0030651_Cloverview_CPUID.txtPK,"a6@./GenuineIntel/GenuineIntel0030661_Cedarview_CPUID.txtPK^X7A./GenuineIntel/GenuineIntel0030661_Cedarview2_CPUID.txtPKxQc6wF./GenuineIntel/GenuineIntel0030669_Centerton_CPUID.txtPK- S7.H./GenuineIntel/GenuineIntel0030673_Silvermont_CPUID.txtPK7)8J./GenuineIntel/GenuineIntel0030673_Silvermont3_CPUID.txtPK7P./GenuineIntel/GenuineIntel0030678_Silvermont_CPUID.txtPKI5*7*S./GenuineIntel/GenuineIntel0030679_Silvermont_CPUID.txtPKJ uH6Y./GenuineIntel/GenuineIntel00306A9_IvyBridge_CPUID.txtPKG>k/8`./GenuineIntel/GenuineIntel00306A9_IvyBridgeWS_CPUID.txtPK{f>65Tb./GenuineIntel/GenuineIntel00306C3_Haswell2_CPUID.txtPKUV M[4 e./GenuineIntel/GenuineIntel00306C3_Haswell_CPUID.txtPKJ8n./GenuineIntel/GenuineIntel00306C3_HaswellXeon_CPUID.txtPK:/;6%v./GenuineIntel/GenuineIntel00306D4_Broadwell_CPUID.txtPK hC7N~./GenuineIntel/GenuineIntel00306D4_Broadwell2_CPUID.txtPKn88./GenuineIntel/GenuineIntel00306E3_IvyBridgeEP_CPUID.txtPK}Ҩ8./GenuineIntel/GenuineIntel00306E4_IvyBridgeEP_CPUID.txtPK}Ҩ8./GenuineIntel/GenuineIntel00306E4_IvyBridgeEP_CPUID.txtPK@y6./GenuineIntel/GenuineIntel00306F2_HaswellE2_CPUID.txtPKYѴ[nj6՚./GenuineIntel/GenuineIntel00306F2_HaswellEP_CPUID.txtPKdNhl r7./GenuineIntel/GenuineIntel00306F2_HaswellEP2_CPUID.txtPK^9E./GenuineIntel/GenuineIntel00306F2_HaswellEP_01_CPUID.txtPKP8II57x./GenuineIntel/GenuineIntel0040651_HaswellULT_CPUID.txtPK\յ_8P./GenuineIntel/GenuineIntel0040661_CrystalWell_CPUID.txtPK2& 7o./GenuineIntel/GenuineIntel0040671_BroadwellH_CPUID.txtPKJ,)8./GenuineIntel/GenuineIntel00406C3_CherryTrail_CPUID.txtPKl[=5./GenuineIntel/GenuineIntel00406C3_Braswell_CPUID.txtPKn13m"+5./GenuineIntel/GenuineIntel00406D8_Rangeley_CPUID.txtPKus<4./GenuineIntel/GenuineIntel00406E3_Skylake_CPUID.txtPKn0i 7c./GenuineIntel/GenuineIntel00406F1_BroadwellE_CPUID.txtPKvi._`|8!./GenuineIntel/GenuineIntel0050654_SkylakeXeon_CPUID.txtPK'p 5 ./GenuineIntel/GenuineIntel0050654_SkylakeX_CPUID.txtPKXF< r5s./GenuineIntel/GenuineIntel0050654_SkylakeD_CPUID.txtPK{,W ;!./GenuineIntel/GenuineIntel0050654_SkylakeXeon_20_CPUID.txtPK%u h:M./GenuineIntel/GenuineIntel0050656_CascadeLakeSP_CPUID.txtPKN, 9LT./GenuineIntel/GenuineIntel0050657_CascadeLakeW_CPUID.txtPKpi=c./GenuineIntel/GenuineIntel0050657_CascadeLakeXeon2_CPUID.txtPK'Q?x<;j./GenuineIntel/GenuineIntel0050657_CascadeLakeXeon_CPUID.txtPKC@c8xs./GenuineIntel/GenuineIntel0050662_BroadwellDE_CPUID.txtPKo73K;{./GenuineIntel/GenuineIntel0050671_KnightsLanding_CPUID.txtPKiY78./GenuineIntel/GenuineIntel00506A0_Moorefield_CPUID.txtPKQ=|>5./GenuineIntel/GenuineIntel00506C9_Goldmont_CPUID.txtPKQU"B6&./GenuineIntel/GenuineIntel00506C9_Goldmont2_CPUID.txtPKxpTR2./GenuineIntel/GenuineIntel00506D1_SoFIA_CPUID.txtPKI Q4./GenuineIntel/GenuineIntel00506E3_Skylake_CPUID.txtPKy% 6B./GenuineIntel/GenuineIntel00506F1_Denverton_CPUID.txtPKJMg 3./GenuineIntel/GenuineIntel00606A6_ICX_04_CPUID.txtPK)h 7s./GenuineIntel/GenuineIntel007065A_Spreadtrum_CPUID.txtPKf$l9./GenuineIntel/GenuineIntel00706A8_GoldmontPlus_CPUID.txtPKN׃ :5./GenuineIntel/GenuineIntel00706E5_IceLakeY_CPUID.txtPKFa^d6./GenuineIntel/GenuineIntel00806A1_Lakefield_CPUID.txtPKFa^d6./GenuineIntel/GenuineIntel00806A1_Lakefield_CPUID.txtPKpv6 ./GenuineIntel/GenuineIntel00806C1_TigerLake_CPUID.txtPKu3<5A0./GenuineIntel/GenuineIntel00806E9_Kabylake_CPUID.txtPKbA76./GenuineIntel/GenuineIntel00806E9_AmberLakeY_CPUID.txtPK}f:=./GenuineIntel/GenuineIntel00806E9_AmberLakeY_02_CPUID.txtPKZLl5E./GenuineIntel/GenuineIntel00806EA_Kabylake_CPUID.txtPK7G`8L./GenuineIntel/GenuineIntel00806EB_WhiskeyLake_CPUID.txtPK5 ';Q./GenuineIntel/GenuineIntel0090661_ElkhartLake_02_CPUID.txtPKS* L095T./GenuineIntel/GenuineIntel0090672_AlderLake_02_CPUID.txtPKfލ9a./GenuineIntel/GenuineIntel0090675_AlderLake_01_CPUID.txtPK.5^9se./GenuineIntel/GenuineIntel0090675_AlderLake_00_CPUID.txtPKAW2a:h./GenuineIntel/GenuineIntel00906A2_AlderLakeP_00_CPUID.txtPKOxa:8y./GenuineIntel/GenuineIntel00906A2_AlderLakeP_01_CPUID.txtPK44x4da:./GenuineIntel/GenuineIntel00906A3_AlderLakeP_00_CPUID.txtPKi8k:./GenuineIntel/GenuineIntel00906A4_AlderLakeP_00_CPUID.txtPKH/k U:./GenuineIntel/GenuineIntel00906C0_JasperLake_01_CPUID.txtPK-eS gx5c./GenuineIntel/GenuineIntel00906E9_Kabylake_CPUID.txtPKJ9i$ y8./GenuineIntel/GenuineIntel00906E9_KabyLake_01_CPUID.txtPK~RyP6<./GenuineIntel/GenuineIntel00906E9_KabylakeG_CPUID.txtPK]L6./GenuineIntel/GenuineIntel00906E9_KabylakeX_CPUID.txtPKˎ ̰7./GenuineIntel/GenuineIntel00906EA_Coffeelake_CPUID.txtPKu >7./GenuineIntel/GenuineIntel00906EB_Coffeelake_CPUID.txtPK`>7E./GenuineIntel/GenuineIntel00906ED_CoffeeLake_CPUID.txtPK_I6W./GenuineIntel/GenuineIntel00A0654_CometLake_CPUID.txtPK W&6./GenuineIntel/GenuineIntel00A0655_CometLake_CPUID.txtPK d5 ./Virtual_CPU_/Virtual CPU 0000F4A_FT2000_4_CPUID.txtPKݜ <{#4N./Virtual_CPU_/Virtual CPU 001067F_Snap835_CPUID.txtPKyy54./Virtual_CPU_/Virtual CPU 0000F4A_Snap835_CPUID.txtPK^cl04Z./Virtual_CPU_/Virtual CPU 0000F4A_Snap850_CPUID.txtPK ll>k0./Genuine__RDC/Genuine RDC0000586_RDC_CPUID.txtPKʁ0./RiseRiseRise/RiseRiseRise0000504_mP6_CPUID.txtPK @"Qr0j./RiseRiseRise/RiseRiseRise0000521_mP6_CPUID.txtPKEW2 ./RiseRiseRise/RiseRiseRise0000580_mP6II_CPUID.txtPKČ.i3 ./SiS_SiS_SiS_/SiS SiS SiS 0000505_SiS550_CPUID.txtPKq;3!./GenuineTMx86/GenuineTMx860000543_Crusoe_CPUID.txtPKUD5 5`$./GenuineTMx86/GenuineTMx860000F24_Efficeon_CPUID.txtPK!%:h7'./Vortex86_SoC/Vortex86 SoC0000522_Vortex86DX_CPUID.txtPK!y:h7E(./Vortex86_SoC/Vortex86 SoC0000586_Vortex86MX_CPUID.txtPKeG$8(./Vortex86_SoC/Vortex86 SoC0000611_Vortex86DX3_CPUID.txtPKSSzN*cpuid-2.2.6/testdata/getall.go000066400000000000000000000025071452220130700162350ustar00rootroot00000000000000//go:build ignore package main import ( "archive/zip" _ "bytes" "fmt" "io" "net/http" "os" "strings" "golang.org/x/net/html" ) // Download all CPUID dumps from http://users.atw.hu/instlatx64/ func main() { resp, err := http.Get("http://users.atw.hu/instlatx64/?") if err != nil { panic(err) } node, err := html.Parse(resp.Body) if err != nil { panic(err) } file, err := os.Create("cpuid_data.zip") if err != nil { panic(err) } defer file.Close() gw := zip.NewWriter(file) var f func(*html.Node) f = func(n *html.Node) { if n.Type == html.ElementNode && n.Data == "a" { for _, a := range n.Attr { if a.Key == "href" { err := ParseURL(a.Val, gw) if err != nil { panic(err) } break } } } for c := n.FirstChild; c != nil; c = c.NextSibling { f(c) } } f(node) err = gw.Close() if err != nil { panic(err) } } func ParseURL(s string, gw *zip.Writer) error { if strings.HasSuffix(s, "CPUID.txt") { fmt.Println("Adding", "http://users.atw.hu/instlatx64/"+s) resp, err := http.Get("http://users.atw.hu/instlatx64/" + s) if err != nil { fmt.Println("Error getting ", s, ":", err) } defer resp.Body.Close() w, err := gw.Create(s) if err != nil { return err } _, err = io.Copy(w, resp.Body) if err != nil { return err } } return nil } cpuid-2.2.6/testdata/go.mod000066400000000000000000000001751452220130700155430ustar00rootroot00000000000000module github.com/klauspost/cpuid/testdata go 1.19 require golang.org/x/net v0.0.0-20220926192436-02166a98028e // indirect cpuid-2.2.6/testdata/go.sum000066400000000000000000000003171452220130700155660ustar00rootroot00000000000000golang.org/x/net v0.0.0-20220926192436-02166a98028e h1:I51lVG9ykW5AQeTE50sJ0+gJCAF0J78Hf1+1VUCGxDI= golang.org/x/net v0.0.0-20220926192436-02166a98028e/go.mod h1:YDH+HFinaLZZlnHAfSS6ZXJJ9M9t4Dl22yv3iI2vPwk=