Chameleon

Chameleon Svn Source Tree

Root/trunk/i386/libsaio/smbios.c

1/*
2 * SMBIOS Table Patcher, part of the Chameleon Boot Loader Project
3 *
4 * Copyright 2010 by Islam M. Ahmed Zaid. All rights reserved.
5 *
6 */
7
8
9#include "boot.h"
10#include "bootstruct.h"
11#include "smbios_getters.h"
12
13#ifndef DEBUG_SMBIOS
14#define DEBUG_SMBIOS 0
15#endif
16
17#if DEBUG_SMBIOS
18#define DBG(x...)printf(x)
19#else
20#define DBG(x...)msglog(x)
21#endif
22
23#define SMBPlist&bootInfo->smbiosConfig
24/* ASSUMPTION: 16KB should be enough for the whole thing */
25#define SMB_ALLOC_SIZE16384
26
27
28//-------------------------------------------------------------------------------------------------------------------------
29// SMBIOS Plist Keys
30//-------------------------------------------------------------------------------------------------------------------------
31/* BIOS Information */
32#define kSMBBIOSInformationVendorKey"SMbiosvendor"
33#define kSMBBIOSInformationVersionKey"SMbiosversion"
34#define kSMBBIOSInformationReleaseDateKey"SMbiosdate"
35
36/* System Information */
37#define kSMBSystemInformationManufacturerKey"SMmanufacturer"
38#define kSMBSystemInformationProductNameKey"SMproductname"
39#define kSMBSystemInformationVersionKey"SMsystemversion"
40#define kSMBSystemInformationSerialNumberKey"SMserial"
41#define kSMBSystemInformationFamilyKey"SMfamily"
42
43/* Base Board */
44#define kSMBBaseBoardManufacturerKey"SMboardmanufacturer"
45#define kSMBBaseBoardProductKey"SMboardproduct"
46
47/* Processor Information */
48#define kSMBProcessorInformationExternalClockKey"SMexternalclock"
49#define kSMBProcessorInformationMaximumClockKey"SMmaximalclock"
50
51/* Memory Device */
52#define kSMBMemoryDeviceDeviceLocatorKey"SMmemdevloc"
53#define kSMBMemoryDeviceBankLocatorKey"SMmembankloc"
54#define kSMBMemoryDeviceMemoryTypeKey"SMmemtype"
55#define kSMBMemoryDeviceMemorySpeedKey"SMmemspeed"
56#define kSMBMemoryDeviceManufacturerKey"SMmemmanufacturer"
57#define kSMBMemoryDeviceSerialNumberKey"SMmemserial"
58#define kSMBMemoryDevicePartNumberKey"SMmempart"
59
60/* Apple Specific */
61#define kSMBOemProcessorTypeKey"SMcputype"
62#define kSMBOemProcessorBusSpeedKey"SMbusspeed"
63
64//-------------------------------------------------------------------------------------------------------------------------
65// Default SMBIOS Data
66//-------------------------------------------------------------------------------------------------------------------------
67/* Rewrite: use a struct */
68
69#define kDefaultVendorManufacturer"Apple Inc."
70#define kDefaultBIOSReleaseDate"11/06/2009"
71#define kDefaultSerialNumber"SOMESRLNMBR"
72#define kDefaultBoardProduct"Mac-F4208DC8"
73#define kDefaultSystemVersion"1.0"
74
75// defaults for a Mac mini
76#define kDefaultMacminiFamily"Macmini"
77#define kDefaultMacmini"Macmini2,1"
78#define kDefaultMacminiBIOSVersion" MM21.88Z.009A.B00.0903051113"
79
80// defaults for a MacBook
81#define kDefaultMacBookFamily"MacBook"
82#define kDefaultMacBook"MacBook4,1"
83#define kDefaultMacBookBIOSVersion" MB41.88Z.0073.B00.0903051113"
84
85// defaults for a MacBook Pro
86#define kDefaultMacBookProFamily"MacBookPro"
87#define kDefaultMacBookPro"MacBookPro4,1"
88#define kDefaultMacBookProBIOSVersion" MBP41.88Z.0073.B00.0903051113"
89
90// defaults for an iMac
91#define kDefaultiMacFamily"iMac"
92#define kDefaultiMac"iMac8,1"
93#define kDefaultiMacBIOSVersion" IM81.88Z.00C1.B00.0903051113"
94// defaults for an iMac11,1 core i3/i5/i7
95#define kDefaultiMacNehalem"iMac11,1"
96#define kDefaultiMacNehalemBIOSVersion" IM111.88Z.0034.B00.0903051113"
97// defaults for an iMac12,1
98#define kDefaultiMacSandy"iMac12,1"
99#define kDefaultiMacSandyBIOSVersion" IM121.88Z.0047.B00.1102091756"
100
101// defaults for a Mac Pro
102#define kDefaultMacProFamily"MacPro"
103#define kDefaultMacPro"MacPro3,1"
104#define kDefaultMacProBIOSVersion" MP31.88Z.006C.B05.0903051113"
105// defaults for a Mac Pro 4,1 core i7/Xeon
106#define kDefaultMacProNehalem"MacPro4,1"
107#define kDefaultMacProNehalemBIOSVersion" MP41.88Z.0081.B04.0903051113"
108// defaults for a Mac Pro 5,1 core i7/Xeon
109#define kDefaultMacProWestmere"MacPro5,1"
110#define kDefaultMacProWestmereBIOSVersion" MP51.88Z.007F.B00.1008031144"
111#define kDefaulMacProWestmereBIOSReleaseDate"08/03/10"
112//-------------------------------------------------------------------------------------------------------------------------
113
114
115#define getFieldOffset(struct, field)((uint8_t)(uint32_t)&(((struct *)0)->field))
116
117typedef struct {
118SMBStructHeader *orig;
119SMBStructHeader *new;
120} SMBStructPtrs;
121
122struct {
123char *vendor;
124char *version;
125char *releaseDate;
126} defaultBIOSInfo;
127
128struct {
129char *manufacturer;
130char *productName;
131char *version;
132char *serialNumber;
133char *family;
134} defaultSystemInfo;
135
136struct {
137char *manufacturer;
138char *product;
139} defaultBaseBoard;
140
141
142typedef struct {
143uint8_ttype;
144SMBValueTypevalueType;
145uint8_tfieldOffset;
146char*keyString;
147bool(*getSMBValue)(returnType *);
148char**defaultValue;
149} SMBValueSetter;
150
151SMBValueSetter SMBSetters[] =
152{
153//-------------------------------------------------------------------------------------------------------------------------
154// BIOSInformation
155//-------------------------------------------------------------------------------------------------------------------------
156{kSMBTypeBIOSInformation,kSMBString,getFieldOffset(SMBBIOSInformation, vendor),kSMBBIOSInformationVendorKey,
157NULL,&defaultBIOSInfo.vendor},
158
159{kSMBTypeBIOSInformation,kSMBString,getFieldOffset(SMBBIOSInformation, version),kSMBBIOSInformationVersionKey,
160NULL,&defaultBIOSInfo.version},
161
162{kSMBTypeBIOSInformation,kSMBString,getFieldOffset(SMBBIOSInformation, releaseDate),kSMBBIOSInformationReleaseDateKey,
163NULL,&defaultBIOSInfo.releaseDate},
164
165//-------------------------------------------------------------------------------------------------------------------------
166// SystemInformation
167//-------------------------------------------------------------------------------------------------------------------------
168{kSMBTypeSystemInformation,kSMBString,getFieldOffset(SMBSystemInformation, manufacturer),kSMBSystemInformationManufacturerKey,
169NULL,&defaultSystemInfo.manufacturer},
170
171{kSMBTypeSystemInformation,kSMBString,getFieldOffset(SMBSystemInformation, productName),kSMBSystemInformationProductNameKey,
172NULL,&defaultSystemInfo.productName},
173
174{kSMBTypeSystemInformation,kSMBString,getFieldOffset(SMBSystemInformation, version),kSMBSystemInformationVersionKey,
175NULL,&defaultSystemInfo.version},
176
177{kSMBTypeSystemInformation,kSMBString,getFieldOffset(SMBSystemInformation, serialNumber),kSMBSystemInformationSerialNumberKey,
178NULL,&defaultSystemInfo.serialNumber},
179
180{kSMBTypeSystemInformation,kSMBString,getFieldOffset(SMBSystemInformation, skuNumber),NULL,
181NULL,NULL},
182
183{kSMBTypeSystemInformation,kSMBString,getFieldOffset(SMBSystemInformation, family),kSMBSystemInformationFamilyKey,
184NULL,&defaultSystemInfo.family},
185
186
187//-------------------------------------------------------------------------------------------------------------------------
188// BaseBoard
189//-------------------------------------------------------------------------------------------------------------------------
190{kSMBTypeBaseBoard,kSMBString,getFieldOffset(SMBBaseBoard, manufacturer),kSMBBaseBoardManufacturerKey,
191NULL,&defaultBaseBoard.manufacturer},
192
193{kSMBTypeBaseBoard,kSMBString,getFieldOffset(SMBBaseBoard, product),kSMBBaseBoardProductKey,
194NULL,&defaultBaseBoard.product},
195
196{kSMBTypeBaseBoard,kSMBString,getFieldOffset(SMBBaseBoard, version),NULL,NULL,NULL},
197
198{kSMBTypeBaseBoard,kSMBString,getFieldOffset(SMBBaseBoard, serialNumber),NULL,NULL,NULL},
199
200{kSMBTypeBaseBoard,kSMBString,getFieldOffset(SMBBaseBoard, assetTagNumber),NULL,NULL,NULL},
201
202{kSMBTypeBaseBoard,kSMBString,getFieldOffset(SMBBaseBoard, locationInChassis),NULL,NULL,NULL},
203
204
205//-------------------------------------------------------------------------------------------------------------------------
206// ProcessorInformation
207//-------------------------------------------------------------------------------------------------------------------------
208{kSMBTypeProcessorInformation,kSMBString,getFieldOffset(SMBProcessorInformation, socketDesignation),NULL,NULL,NULL},
209
210{kSMBTypeProcessorInformation,kSMBString,getFieldOffset(SMBProcessorInformation, manufacturer),NULL,NULL,NULL},
211
212{kSMBTypeProcessorInformation,kSMBString,getFieldOffset(SMBProcessorInformation, processorVersion),NULL,NULL,NULL},
213
214{kSMBTypeProcessorInformation,kSMBWord,getFieldOffset(SMBProcessorInformation, externalClock),kSMBProcessorInformationExternalClockKey,
215getProcessorInformationExternalClock,NULL},
216
217{kSMBTypeProcessorInformation,kSMBWord,getFieldOffset(SMBProcessorInformation, maximumClock),kSMBProcessorInformationMaximumClockKey,
218getProcessorInformationMaximumClock,NULL},
219
220{kSMBTypeProcessorInformation,kSMBString,getFieldOffset(SMBProcessorInformation, serialNumber),NULL,NULL,NULL},
221
222{kSMBTypeProcessorInformation,kSMBString,getFieldOffset(SMBProcessorInformation, assetTag),NULL,NULL,NULL},
223
224{kSMBTypeProcessorInformation,kSMBString,getFieldOffset(SMBProcessorInformation, partNumber),NULL,NULL,NULL},
225
226//-------------------------------------------------------------------------------------------------------------------------
227// Memory Device
228//-------------------------------------------------------------------------------------------------------------------------
229{kSMBTypeMemoryDevice,kSMBString,getFieldOffset(SMBMemoryDevice, deviceLocator),kSMBMemoryDeviceDeviceLocatorKey,
230NULL,NULL},
231
232{kSMBTypeMemoryDevice,kSMBString,getFieldOffset(SMBMemoryDevice, bankLocator),kSMBMemoryDeviceBankLocatorKey,
233NULL,NULL},
234
235{kSMBTypeMemoryDevice,kSMBByte,getFieldOffset(SMBMemoryDevice, memoryType),kSMBMemoryDeviceMemoryTypeKey,
236getSMBMemoryDeviceMemoryType,NULL},
237
238{kSMBTypeMemoryDevice,kSMBWord,getFieldOffset(SMBMemoryDevice, memorySpeed),kSMBMemoryDeviceMemorySpeedKey,
239getSMBMemoryDeviceMemorySpeed,NULL},
240
241{kSMBTypeMemoryDevice,kSMBString,getFieldOffset(SMBMemoryDevice, manufacturer),kSMBMemoryDeviceManufacturerKey,
242getSMBMemoryDeviceManufacturer,NULL},
243
244{kSMBTypeMemoryDevice,kSMBString,getFieldOffset(SMBMemoryDevice, serialNumber),kSMBMemoryDeviceSerialNumberKey,
245getSMBMemoryDeviceSerialNumber,NULL},
246
247{kSMBTypeMemoryDevice,kSMBString,getFieldOffset(SMBMemoryDevice, assetTag),NULL,NULL,NULL},
248
249{kSMBTypeMemoryDevice,kSMBString,getFieldOffset(SMBMemoryDevice, partNumber),kSMBMemoryDevicePartNumberKey,
250getSMBMemoryDevicePartNumber,NULL},
251
252
253//-------------------------------------------------------------------------------------------------------------------------
254// Apple Specific
255//-------------------------------------------------------------------------------------------------------------------------
256{kSMBTypeOemProcessorType,kSMBWord,getFieldOffset(SMBOemProcessorType, ProcessorType),kSMBOemProcessorTypeKey,
257getSMBOemProcessorType,NULL},
258
259{kSMBTypeOemProcessorBusSpeed,kSMBWord,getFieldOffset(SMBOemProcessorBusSpeed, ProcessorBusSpeed),kSMBOemProcessorBusSpeedKey,
260getSMBOemProcessorBusSpeed,NULL}
261};
262
263int numOfSetters = sizeof(SMBSetters) / sizeof(SMBValueSetter);
264
265
266SMBEntryPoint *origeps= 0;
267SMBEntryPoint *neweps= 0;
268
269static uint8_t stringIndex;// increament when a string is added and set the field value accordingly
270static uint8_t stringsSize;// add string size
271
272static SMBWord tableLength= 0;
273static SMBWord handle= 0;
274static SMBWord maxStructSize= 0;
275static SMBWord structureCount= 0;
276
277/* Rewrite this function */
278void setDefaultSMBData(void)
279{
280defaultBIOSInfo.vendor= kDefaultVendorManufacturer;
281defaultBIOSInfo.releaseDate= kDefaultBIOSReleaseDate;
282
283defaultSystemInfo.manufacturer= kDefaultVendorManufacturer;
284defaultSystemInfo.version= kDefaultSystemVersion;
285defaultSystemInfo.serialNumber= kDefaultSerialNumber;
286
287defaultBaseBoard.manufacturer= kDefaultVendorManufacturer;
288defaultBaseBoard.product= kDefaultBoardProduct;
289
290if (platformCPUFeature(CPU_FEATURE_MOBILE))
291{
292if (Platform.CPU.NoCores > 1)
293{
294defaultBIOSInfo.version= kDefaultMacBookProBIOSVersion;
295defaultSystemInfo.productName= kDefaultMacBookPro;
296defaultSystemInfo.family= kDefaultMacBookProFamily;
297}
298else
299{
300defaultBIOSInfo.version= kDefaultMacBookBIOSVersion;
301defaultSystemInfo.productName= kDefaultMacBook;
302defaultSystemInfo.family= kDefaultMacBookFamily;
303}
304}
305else
306{
307switch (Platform.CPU.NoCores)
308{
309case 1:
310defaultBIOSInfo.version= kDefaultMacminiBIOSVersion;
311defaultSystemInfo.productName= kDefaultMacmini;
312defaultSystemInfo.family= kDefaultMacminiFamily;
313break;
314
315case 2:
316defaultBIOSInfo.version= kDefaultiMacBIOSVersion;
317defaultSystemInfo.productName= kDefaultiMac;
318defaultSystemInfo.family= kDefaultiMacFamily;
319break;
320default:
321{
322switch (Platform.CPU.Family)
323{
324case 0x06:
325{
326switch (Platform.CPU.Model)
327{
328case CPU_MODEL_FIELDS:// Intel Core i5, i7 LGA1156 (45nm)
329case CPU_MODEL_DALES:// Intel Core i5, i7 LGA1156 (45nm) ???
330case CPU_MODEL_DALES_32NM:// Intel Core i3, i5, i7 LGA1156 (32nm) (Clarkdale, Arrandale)
331case 0x19:// Intel Core i5 650 @3.20 Ghz
332defaultBIOSInfo.version= kDefaultiMacNehalemBIOSVersion;
333defaultSystemInfo.productName= kDefaultiMacNehalem;
334defaultSystemInfo.family= kDefaultiMacFamily;
335break;
336
337case CPU_MODEL_SANDY:
338case CPU_MODEL_SANDY_XEON:
339defaultBIOSInfo.version= kDefaultiMacSandyBIOSVersion;
340defaultSystemInfo.productName= kDefaultiMacSandy;
341defaultSystemInfo.family= kDefaultiMacFamily;
342break;
343case CPU_MODEL_NEHALEM:
344case CPU_MODEL_NEHALEM_EX:
345defaultBIOSInfo.version= kDefaultMacProNehalemBIOSVersion;
346defaultSystemInfo.productName= kDefaultMacProNehalem;
347defaultSystemInfo.family= kDefaultMacProFamily;
348break;
349
350case CPU_MODEL_WESTMERE:
351case CPU_MODEL_WESTMERE_EX:
352defaultBIOSInfo.version= kDefaultMacProWestmereBIOSVersion;
353defaultBIOSInfo.releaseDate= kDefaulMacProWestmereBIOSReleaseDate;
354defaultSystemInfo.productName= kDefaultMacProWestmere;
355defaultSystemInfo.family= kDefaultMacProFamily;
356break;
357
358default:
359defaultBIOSInfo.version= kDefaultMacProBIOSVersion;
360defaultSystemInfo.productName= kDefaultMacPro;
361defaultSystemInfo.family= kDefaultMacProFamily;
362break;
363}
364break;
365}
366default:
367defaultBIOSInfo.version= kDefaultMacProBIOSVersion;
368defaultSystemInfo.productName= kDefaultMacPro;
369defaultSystemInfo.family= kDefaultMacProFamily;
370break;
371}
372break;
373}
374}
375}
376}
377
378/* Used for SM*n smbios.plist keys */
379bool getSMBValueForKey(SMBStructHeader *structHeader, const char *keyString, const char **string, returnType *value)
380{
381static int idx = -1;
382static int current = -1;
383int len;
384char key[24];
385
386if (current != structHeader->handle)
387{
388idx++;
389current = structHeader->handle;
390}
391
392sprintf(key, "%s%d", keyString, idx);
393
394if (value)
395if (getIntForKey(key, (int *)&(value->dword), SMBPlist))
396return true;
397else
398if (getValueForKey(key, string, &len, SMBPlist))
399return true;
400return false;
401}
402
403char *getSMBStringForField(SMBStructHeader *structHeader, uint8_t field)
404{
405uint8_t *stringPtr = (uint8_t *)structHeader + structHeader->length;
406
407if (!field)
408return NULL;
409
410for (field--; field != 0 && strlen((char *)stringPtr) > 0;
411field--, stringPtr = (uint8_t *)((uint32_t)stringPtr + strlen((char *)stringPtr) + 1));
412
413return (char *)stringPtr;
414}
415
416void setSMBStringForField(SMBStructHeader *structHeader, const char *string, uint8_t *field)
417{
418int strSize;
419
420if (!field)
421return;
422if (!string)
423{
424*field = 0;
425return;
426}
427
428strSize = strlen(string);
429
430// remove any spaces found at the end
431while ((strSize != 0) && (string[strSize - 1] == ' '))
432strSize--;
433
434if (strSize == 0)
435{
436*field = 0;
437return;
438}
439
440memcpy((uint8_t *)structHeader + structHeader->length + stringsSize, string, strSize);
441*field = stringIndex;
442
443stringIndex++;
444stringsSize += strSize + 1;
445}
446
447bool setSMBValue(SMBStructPtrs *structPtr, int idx, returnType *value)
448{
449const char *string = 0;
450int len;
451
452if (numOfSetters <= idx)
453return false;
454
455switch (SMBSetters[idx].valueType)
456{
457case kSMBString:
458if (SMBSetters[idx].keyString)
459{
460if (getValueForKey(SMBSetters[idx].keyString, &string, &len, SMBPlist))
461break;
462else
463if (structPtr->orig->type == kSMBTypeMemoryDevice)// MemoryDevice only
464if (getSMBValueForKey(structPtr->orig, SMBSetters[idx].keyString, &string, NULL))
465break;
466}
467if (SMBSetters[idx].getSMBValue)
468if (SMBSetters[idx].getSMBValue((returnType *)&string))
469break;
470if ((SMBSetters[idx].defaultValue) && *(SMBSetters[idx].defaultValue))
471{
472string = *(SMBSetters[idx].defaultValue);
473break;
474}
475string = getSMBStringForField(structPtr->orig, *(uint8_t *)value);
476break;
477
478case kSMBByte:
479case kSMBWord:
480case kSMBDWord:
481//case kSMBQWord:
482if (SMBSetters[idx].keyString)
483{
484if (getIntForKey(SMBSetters[idx].keyString, (int *)&(value->dword), SMBPlist))
485return true;
486else
487if (structPtr->orig->type == kSMBTypeMemoryDevice)// MemoryDevice only
488if (getSMBValueForKey(structPtr->orig, SMBSetters[idx].keyString, NULL, value))
489return true;
490}
491if (SMBSetters[idx].getSMBValue)
492if (SMBSetters[idx].getSMBValue(value))
493return true;
494#if 0
495if (*(SMBSetters[idx].defaultValue))
496{
497value->dword = *(uint32_t *)(SMBSetters[idx].defaultValue);
498return true;
499}
500#endif
501break;
502}
503
504if (SMBSetters[idx].valueType == kSMBString && string)
505setSMBStringForField(structPtr->new, string, &value->byte);
506
507return true;
508}
509
510//-------------------------------------------------------------------------------------------------------------------------
511// Apple Specific
512//-------------------------------------------------------------------------------------------------------------------------
513void addSMBFirmwareVolume(SMBStructPtrs *structPtr)
514{
515return;
516}
517
518void addSMBMemorySPD(SMBStructPtrs *structPtr)
519{
520/* SPD data from Platform.RAM.spd */
521return;
522}
523
524void addSMBOemProcessorType(SMBStructPtrs *structPtr)
525{
526SMBOemProcessorType *p = (SMBOemProcessorType *)structPtr->new;
527
528p->header.type= kSMBTypeOemProcessorType;
529p->header.length= sizeof(SMBOemProcessorType);
530p->header.handle= handle++;
531
532setSMBValue(structPtr, numOfSetters - 2 , (returnType *)&(p->ProcessorType));
533
534structPtr->new = (SMBStructHeader *)((uint8_t *)structPtr->new + sizeof(SMBOemProcessorType) + 2);
535tableLength += sizeof(SMBOemProcessorType) + 2;
536structureCount++;
537}
538
539void addSMBOemProcessorBusSpeed(SMBStructPtrs *structPtr)
540{
541SMBOemProcessorBusSpeed *p = (SMBOemProcessorBusSpeed *)structPtr->new;
542
543switch (Platform.CPU.Family)
544{
545case 0x06:
546{
547switch (Platform.CPU.Model)
548{
549case 0x19:// Intel Core i5 650 @3.20 Ghz
550case CPU_MODEL_FIELDS:// Intel Core i5, i7 LGA1156 (45nm)
551case CPU_MODEL_DALES:// Intel Core i5, i7 LGA1156 (45nm) ???
552case CPU_MODEL_DALES_32NM:// Intel Core i3, i5, i7 LGA1156 (32nm)
553case CPU_MODEL_NEHALEM:// Intel Core i7 LGA1366 (45nm)
554case CPU_MODEL_NEHALEM_EX:// Intel Core i7 LGA1366 (45nm) 6 Core ???
555case CPU_MODEL_WESTMERE:// Intel Core i7 LGA1366 (32nm) 6 Core
556case CPU_MODEL_WESTMERE_EX:// Intel Core i7 LGA1366 (45nm) 6 Core ???
557break;
558
559default:
560return;
561}
562}
563}
564
565p->header.type= kSMBTypeOemProcessorBusSpeed;
566p->header.length= sizeof(SMBOemProcessorBusSpeed);
567p->header.handle= handle++;
568
569setSMBValue(structPtr, numOfSetters -1, (returnType *)&(p->ProcessorBusSpeed));
570
571structPtr->new = (SMBStructHeader *)((uint8_t *)structPtr->new + sizeof(SMBOemProcessorBusSpeed) + 2);
572tableLength += sizeof(SMBOemProcessorBusSpeed) + 2;
573structureCount++;
574}
575
576//-------------------------------------------------------------------------------------------------------------------------
577// EndOfTable
578//-------------------------------------------------------------------------------------------------------------------------
579void addSMBEndOfTable(SMBStructPtrs *structPtr)
580{
581structPtr->new->type= kSMBTypeEndOfTable;
582structPtr->new->length= sizeof(SMBStructHeader);
583structPtr->new->handle= handle++;
584
585structPtr->new = (SMBStructHeader *)((uint8_t *)structPtr->new + sizeof(SMBStructHeader) + 2);
586tableLength += sizeof(SMBStructHeader) + 2;
587structureCount++;
588}
589
590void setSMBStruct(SMBStructPtrs *structPtr)
591{
592bool setterFound = false;
593
594uint8_t *ptr;
595SMBWord structSize;
596int i;
597
598stringIndex = 1;
599stringsSize = 0;
600
601if (handle < structPtr->orig->handle)
602handle = structPtr->orig->handle;
603
604memcpy((void *)structPtr->new, structPtr->orig, structPtr->orig->length);
605
606for (i = 0; i < numOfSetters; i++)
607if ((structPtr->orig->type == SMBSetters[i].type) && (SMBSetters[i].fieldOffset < structPtr->orig->length))
608{
609setterFound = true;
610setSMBValue(structPtr, i, (returnType *)((uint8_t *)structPtr->new + SMBSetters[i].fieldOffset));
611}
612
613if (setterFound)
614{
615ptr = (uint8_t *)structPtr->new + structPtr->orig->length;
616for (; ((uint16_t *)ptr)[0] != 0; ptr++);
617
618if (((uint16_t *)ptr)[0] == 0)
619ptr += 2;
620
621structSize = ptr - (uint8_t *)structPtr->new;
622}
623else
624{
625ptr = (uint8_t *)structPtr->orig + structPtr->orig->length;
626for (; ((uint16_t *)ptr)[0] != 0; ptr++);
627
628if (((uint16_t *)ptr)[0] == 0)
629ptr += 2;
630
631structSize = ptr - (uint8_t *)structPtr->orig;
632memcpy((void *)structPtr->new, structPtr->orig, structSize);
633}
634
635structPtr->new = (SMBStructHeader *)((uint8_t *)structPtr->new + structSize);
636
637tableLength += structSize;
638
639if (structSize > maxStructSize)
640maxStructSize = structSize;
641
642structureCount++;
643}
644
645void setupNewSMBIOSTable(SMBEntryPoint *eps, SMBStructPtrs *structPtr)
646{
647uint8_t *ptr = (uint8_t *)eps->dmi.tableAddress;
648structPtr->orig = (SMBStructHeader *)ptr;
649
650for (;((eps->dmi.tableAddress + eps->dmi.tableLength) > ((uint32_t)(uint8_t *)structPtr->orig + sizeof(SMBStructHeader)));)
651{
652switch (structPtr->orig->type)
653{
654/* Skip all Apple Specific Structures */
655case kSMBTypeFirmwareVolume:
656case kSMBTypeMemorySPD:
657case kSMBTypeOemProcessorType:
658case kSMBTypeOemProcessorBusSpeed:
659/* And this one too, to be added at the end */
660case kSMBTypeEndOfTable:
661break;
662
663default:
664/* Add */
665setSMBStruct(structPtr);
666break;
667}
668
669ptr = (uint8_t *)((uint32_t)structPtr->orig + structPtr->orig->length);
670for (; ((uint16_t *)ptr)[0] != 0; ptr++);
671
672if (((uint16_t *)ptr)[0] == 0)
673ptr += 2;
674
675structPtr->orig = (SMBStructHeader *)ptr;
676}
677
678addSMBFirmwareVolume(structPtr);
679addSMBMemorySPD(structPtr);
680addSMBOemProcessorType(structPtr);
681addSMBOemProcessorBusSpeed(structPtr);
682
683addSMBEndOfTable(structPtr);
684}
685
686void setupSMBIOSTable(void)
687{
688SMBStructPtrs *structPtr;
689uint8_t *buffer;
690bool setSMB = true;
691
692if (!origeps)
693return;
694
695neweps = origeps;
696
697structPtr = (SMBStructPtrs *)malloc(sizeof(SMBStructPtrs));
698if (!structPtr)
699return;
700
701buffer = malloc(SMB_ALLOC_SIZE);
702if (!buffer)
703return;
704
705bzero(buffer, SMB_ALLOC_SIZE);
706structPtr->new = (SMBStructHeader *)buffer;
707
708getBoolForKey(kSMBIOSdefaults, &setSMB, &bootInfo->bootConfig);
709if (setSMB)
710setDefaultSMBData();
711
712setupNewSMBIOSTable(origeps, structPtr);
713
714neweps = (SMBEntryPoint *)AllocateKernelMemory(sizeof(SMBEntryPoint));
715if (!neweps)
716return;
717bzero(neweps, sizeof(SMBEntryPoint));
718
719neweps->anchor[0]= '_';
720neweps->anchor[1]= 'S';
721neweps->anchor[2]= 'M';
722neweps->anchor[3]= '_';
723neweps->entryPointLength= sizeof(SMBEntryPoint);
724neweps->majorVersion= 2;
725neweps->minorVersion= 4;
726neweps->maxStructureSize= maxStructSize;
727neweps->entryPointRevision= 0;
728
729neweps->dmi.anchor[0]= '_';
730neweps->dmi.anchor[1]= 'D';
731neweps->dmi.anchor[2]= 'M';
732neweps->dmi.anchor[3]= 'I';
733neweps->dmi.anchor[4]= '_';
734neweps->dmi.tableLength= tableLength;
735neweps->dmi.tableAddress= AllocateKernelMemory(tableLength);
736neweps->dmi.structureCount= structureCount;
737neweps->dmi.bcdRevision= 0x24;
738
739if (!neweps->dmi.tableAddress)
740return;
741
742memcpy((void *)neweps->dmi.tableAddress, buffer, tableLength);
743
744neweps->dmi.checksum= 0;
745neweps->dmi.checksum= 0x100 - checksum8(&neweps->dmi, sizeof(DMIEntryPoint));
746
747neweps->checksum= 0;
748neweps->checksum= 0x100 - checksum8(neweps, sizeof(SMBEntryPoint));
749
750free(buffer);
751decodeSMBIOSTable(neweps);
752}
753
754void *getSmbios(int which)
755{
756switch (which)
757{
758case SMBIOS_ORIGINAL:
759if (!origeps)
760origeps = getAddressOfSmbiosTable();
761return origeps;
762case SMBIOS_PATCHED:
763return neweps;
764}
765
766return 0;
767}
768
769/* Collect any information needed later */
770void readSMBIOSInfo(SMBEntryPoint *eps)
771{
772uint8_t *structPtr = (uint8_t *)eps->dmi.tableAddress;
773SMBStructHeader *structHeader = (SMBStructHeader *)structPtr;
774
775int dimmnbr = 0;
776Platform.DMI.MaxMemorySlots= 0;
777Platform.DMI.CntMemorySlots= 0;
778Platform.DMI.MemoryModules= 0;
779
780for (;((eps->dmi.tableAddress + eps->dmi.tableLength) > ((uint32_t)(uint8_t *)structHeader + sizeof(SMBStructHeader)));)
781{
782switch (structHeader->type)
783{
784case kSMBTypeSystemInformation:
785Platform.UUID = ((SMBSystemInformation *)structHeader)->uuid;
786break;
787
788case kSMBTypePhysicalMemoryArray:
789Platform.DMI.MaxMemorySlots += ((SMBPhysicalMemoryArray *)structHeader)->numMemoryDevices;
790break;
791
792case kSMBTypeMemoryDevice:
793Platform.DMI.CntMemorySlots++;
794if (((SMBMemoryDevice *)structHeader)->memorySize != 0)
795Platform.DMI.MemoryModules++;
796if (((SMBMemoryDevice *)structHeader)->memorySpeed > 0)
797Platform.RAM.DIMM[dimmnbr].Frequency = ((SMBMemoryDevice *)structHeader)->memorySpeed;
798dimmnbr++;
799break;
800}
801
802structPtr = (uint8_t *)((uint32_t)structHeader + structHeader->length);
803for (; ((uint16_t *)structPtr)[0] != 0; structPtr++);
804
805if (((uint16_t *)structPtr)[0] == 0)
806structPtr += 2;
807
808structHeader = (SMBStructHeader *)structPtr;
809}
810}
811
812

Archive Download this file

Revision: 877