ESXi-palvelimet saattavat pysähtyä purppuraan diagnostiikkanäyttöön (PSOD) MCE (machine check exception) -virheiden vuoksi. MCE-virheet johtuvat laitteisto-ongelmista.
MCE Purple -diagnostiikkanäytössä näkyy useita asioita. Näistä MCi_STATUS rekisteri on hyödyllinen ongelman virheenkorjauksessa.
Rekisterin tiedot:
Bitit ja niiden merkitys:
63 | 62 | 61 | 60 | 59 | 58 | 57 | 53-56 | 38-52 | 32-37 | 16-31 | 0-15 |
KELVOLLINEN merkintä - Jos määritetty, tiedot kelpaavat. | OVERFLOW-lippu - Jos asetus on määritetty, se saattaa tarkoittaa, että lähellä toisiaan on esiintynyt useita MCE:itä | UNC-lippu - Jos määritetty, CPU ei voinut korjata virhettä. | FI lippu | MISCV-lippu - Jos määritetty, MISC-rekisteri sisältää lisätietoja. | ADDRV - Jos asetettu, ADDR-rekisteri sisältää virheen tapahtumapaikan. | PCC-lippu - Jos asetettu, se tarkoittaa, että prosessori on saattanut vioittua. | Arkkitehtoninen, jos bitti 11 on asetettu, muuten "muuta tietoa". | Arkkitehtoninen, jos bitti 10 on asetettu, muuten "muut tiedot". | Muita tietoja | CPU:n mallikohtainen virhekoodi | Koneen tarkistuksen virhekoodi |
Virheen virheenkorjauksen kannalta MCi_STATUS rekisterin alhaiset 16 bittiä ovat tärkeitä. Nämä bitit ilmaisevat yksinkertaisen tai yhdistetyn virheen.
Vaihtoehto 1: Automaattisen työkalun käyttäminen
Vaihtoehto 2: Manuaalisten vaiheiden käyttäminen
0000 0000 0000 0000 -- No Error reported to this bank of error-reporting registers. 0000 0000 0000 0001 -- Unclassified - Error has not been classified. 0000 0000 0000 0010 -- Parity error in internal microcode ROM. 0000 0000 0000 0011 -- External error-BINIT# from another processor caused this processor MCE. Happens only if BINIT# observation enabled during power on. 0000 0000 0000 0100 -- Functional redundancy check master/slave error. 0000 0000 0000 0101 -- Internal parity error. 0000 0000 0000 0110 -- SMM handler tried to execute outside the ranges specified by SMRR. 0000 0100 0000 0000 -- Internal timer error. 0000 1110 0000 1011 -- I/O error. 0000 01xx xxxx xxxx -- Internal unclassified error. Atleast one X must be equal to 1.
000F 0000 0000 11LL - Generic Cache Hierarchy error. 000F 0000 0001 TTLL - {TT}TLB{LL}_ERR. TLB errors. 000F 0000 1MMM CCCC - {MMM}_Channel{CCCC}_ERR - Memory controller errors. 000F 0001 RRRR TTLL - {TT}CACHE{LL}_{RRRR}_ERR - Cache Hierarchy errors. 000F 1PPT RRRR IILL - BUS{LL}_{PP}_{RRRR}_{II}_T_ERR - Bus and Interconnect errors.
0 – Normal Filtering
1 – Corrected Filtering
Suodatus tarkoittaa, että joitakin tai kaikkia tämän rakenteen merkinnän myöhempiä korjauksia ei kirjata.
Ilmaisee tapahtuman tyypin:
00 - Instruction
01 - Data
10 - Generic
Ilmaisee muistihierarkian tason, jolla virhe ilmeni
00 - Level 0 - L0
01 - Level 1 - L1
10 - Level 2 - L2
11 - Generic – LG (It is shown only when processor cannot determine the hierarchy level)
0000 - Generic Error - ERR 0001 - Generic Read - RD 0010 - Generic Write - WR 0011 - Data Read - DRD 0100 - Data Write - DWR 0101 - Instruction Fetch - IRD 0110 - Prefetch - PREFETCH 0111 - Eviction - EVICT 1000 - Snoop - SNOOP
00 - SRC - Local processor originated request 01 - RES - Local processor responded to request 10 - OBS - Local processor observed error as third party 11 - Generic
00 - M - Memory Access 10 - IO - I/O 01 - Reserved 11 - Other transaction
000 - GEN - Generic undefined request 001 - RD - Memory read error 010 - WR - Memory write error 011 - AC - Address/Command error 100 - MS - Memory Scrubbing error 101-111 - Reserved
0000-1110 - CHN - Channel number
1111 - Channel not specified
Tässä on esimerkki MCE: n violetin diagnostisen näyttökuvan analysoinnista:
1111 1110 0010 0000 0000 0000 0100 0000 0000 0000 0000 0001 0001 0001 0110 0110
0001 0001 0110 0110
Vertaa sitä yhdistelmävirheisiin. Tässä tapauksessa kyseessä on välimuistihierarkiavirhe (tyyppi 4).
F = 1 RRRR = 0110 – Prefetch TT = 01 – Transaction type - Data LL = 10 – Level 2 cache
Johtopäätös: