Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/platomav/CPUMicrocodes
Intel, AMD, VIA & Freescale CPU Microcode Repositories
https://github.com/platomav/CPUMicrocodes
Last synced: 2 months ago
JSON representation
Intel, AMD, VIA & Freescale CPU Microcode Repositories
- Host: GitHub
- URL: https://github.com/platomav/CPUMicrocodes
- Owner: platomav
- Created: 2018-01-10T16:08:33.000Z (about 7 years ago)
- Default Branch: master
- Last Pushed: 2024-10-27T23:25:22.000Z (3 months ago)
- Last Synced: 2024-10-28T03:31:22.129Z (3 months ago)
- Homepage:
- Size: 102 MB
- Stars: 865
- Watchers: 68
- Forks: 105
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- awesome-hacking-lists - platomav/CPUMicrocodes - Intel, AMD, VIA & Freescale CPU Microcode Repositories (Others)
README
# CPUMicrocodes
**Intel, AMD, VIA & Freescale CPU Microcode Repositories**[CPU Microcode Repositories News Feed](https://twitter.com/platomaniac)
[CPU Microcode Repositories Discussion Topic](https://winraid.level1techs.com/t/intel-amd-via-freescale-cpu-microcode-repositories-discussion/32301)
[MC Extractor: Intel, AMD, VIA & Freescale Microcode Extraction Tool](https://github.com/platomav/MCExtractor)
[MC Extractor Discussion Topic](https://winraid.level1techs.com/t/mc-extractor-intel-amd-via-freescale-microcode-extraction-tool-discussion/31555)
This is a collection of **Latest Production** Intel, AMD, VIA and Freescale CPU microcodes. You can use [MC Extractor](https://github.com/platomav/MCExtractor) to check instantly whether a microcode is already at the repository. Please report any microcodes which are missing from the [MC Extractor](https://github.com/platomav/MCExtractor) database at the [CPU Microcode Repositories Discussion Topic](https://winraid.level1techs.com/t/intel-amd-via-freescale-cpu-microcode-repositories-discussion/32301) instead of opening an issue here.
Collecting CPU microcodes is important for upgrading purposes, for creating universal tools that can help people understand what microcode they use, for research on how the general technology works, for developers with no vendor representative who want to work on a given platform etc.
**Disclaimer: All the microcodes below come only from official BIOS/UEFI updates, Intel/AMD Linux Microcode Updates, Linux Distributions, Windows Updates etc which were provided and made public by various manufacturers!**
All microcodes are checked by [MC Extractor](https://github.com/platomav/MCExtractor) to verify their health, size etc. Please check [MCE's README](https://github.com/platomav/MCExtractor/blob/master/README.md) to learn more of its features and capabilities.
It is generally advised to request and/or wait for your OEM/OS to release newer fixes. **Latest is not always better or tested.** Manufacturers and OS mainteners usually have some insider/confidential info from microcode vendors on what got changed/fixed at newer microcode releases so if they ship older microcodes, it could be that newer versions have not been thoroughly tested, have been retracted/downgraded by the microcode vendor or not contain anything important enough to warrant an update. The microcodes here are gathered and provided with the sole purpose of helping people who are out of other viable solutions. Thus, they can be extremely helpful to those who have major problems with their systems for which their manufacturer refuses to assist due to indifference and/or system age.
## File naming explanation
All microcodes at the repositories have some common attributes and are categorized based on them as follows:
cpu[CPUID]_plat[PlatformID]_ver[Revision]_[Date]_[Release]_[Checksum].bin
### Examples:
Intel: cpu906EB_plat02_ver0000007C_2017-12-03_PRD_5046D998.bin
AMD: cpu00800F11_ver08001129_2017-07-14_4F426450.bin
VIA: cpu10690_ver00000001_sig[BJ_10690.020]_2017-01-09_A8B24DC2.bin
Freescale: soc8360_rev2.1_sig[Soft-UART]_3725F40B.bin### Field descriptions
- **CPUID**
- This value encodes info such as Family, Generation, Model and Stepping.
- Examples: Intel 0x000906EB, AMD 0x00810F10, VIA 0x00010690, Freescale 0x8323.
- **Platform** (Intel only)
- Provides information about the supported sockets (LGA775, LGA1366 etc) or platform types (Desktop, Mobile etc) depending on CPU generation.
- Up to 8 supported Platforms, encoded in Little Endian binary form (bitfield).
- Examples: 0xC0 = 0b11000000 = 6,7 ; 0x03 = 0b00000011 = 0,1 ; 0x76 = 0b01110110 = 1,2,4,5,6.
- When updating to another microcode, ensure that at least the same or more Platforms are supported. You can use [MC Extractor](https://github.com/platomav/MCExtractor) to check each Intel microcode's supported Platforms.
- Example: Changing from 0x5C (2,3,4,6) to 0x5D (0,2,3,4,6) is okay, due to the additionally included platform "0".
- To not risk losing socket/platform support, avoid reducing the supported platforms.
- Example: Changing from 0x5C (2,3,4,6) to 0x58 (3,4,6) might not be okay due to the missing platform "2".
- If you cannot find the exact CPUID & Platform combo at the repository, as the one you currently have, it might be because there is another microcode with the same CPUID but with more supported Platforms.
- Example: Microcodes with CPUID 0x906E9 & Platform 0x22 (1,5) were superseded by CPUID 0x906E9 & Platform 0x2A (1,3,5) in order to add LGA2066 socket/HEDT platform type support at KBL(-X).
- Null Platform (0x00) is implicitly the same as single Platform (0x01), since at least one platform must be supported.
- Example: At CPUID 0x633, Platform 0x00 = 0x01 = 0
- **Signature** (VIA and Freescale only)
- Human readable CPUID and Update Revision.
- Example: "BJ_6FE_0205" (VIA) ; "MPC8569 QE Microcode Rel_B6900155" (Freescale).
- **Revision**
- Microcode update revision counter. Increased when fixes are applied.
- Example: 0xA0B < 0xA0E.
- For Intel & AMD, only the latest microcodes of each CPUID are included in the repositories.
- **Date**
- Date of its public release in ISO8601 (YYYY-MM-DD) format
- Example: 2018-01-02 ; 2016-12-09.
- **Release/Type** (Intel only)
- Specifies the status of the microcode. This can be either Production (PRD) or Pre-Production (PRE).
- `PRD` microcodes are to be valued higher than `PRE` due to stability & testing.
- Only `PRD` microcodes are included in this repository.
- **Checksum**
- Used for quick integrity validity checks during transmission to system manufacturers.
- All Freescale & AMD microcodes with CPUID >= 0x00500F00 lack an official Checksum, thus [MC Extractor](https://github.com/platomav/MCExtractor) generates its own.