Chameleon Svn Source Tree


1- Added cpu_intel_amd.c (not by default, you need to edit the makefile in the libsaio directory to compile it)
2- Implemented a stack_protector (seems to work)
3- Sync'd libsa with Xnu
4- Removed lcc_kext dependency from the make file
5- Fixed some bugs
7- Updated the default theme to v 1.1 (credit to blackosx)
8- Updated LogintoLion with he haiku device logo (credit to blackosx)
9- Updated for the gui
10- Chameleon can now boot the Lion Auto-Installer partition (additionally, on a GPT disk this enable the option "Localize my Mac" of iCloud)
11- Added a first version of amlsgn (NOTE: This tool can can sign an aml file for your machine (with the UUID) or for your machine model, this can be useful
12 with multiple machines w/o an identical model, combined with acpicodec and the option "LoadSignedAmlOnly", you can make sure that Chameleon will load the
13 good aml files for your machine (even if you have for example about 50 dsdt files named differently in your Acpi directory and each one for a different machine) )
14- Applied Guerrero's patch on gui.c (
15- Added a theme compatible with the OS detection/Volume feature (credit to Enzo for LoginToLion, see for more.)
16- Fixed a mistake with the smbios.plist loading process
17- Reworked the OS detection/Volume (NOTE: now embedded into the core and executed much earlier )
20- Added Haiku support (credit to scorpius)
21- Added EXFAT (FAT64) support (credit to dmazar)
22- Added JrCs fixes (see trunk v1716 v1719)
23- Gui can now detect the darwin version of each volumes
24- Applied some underthehood fixes and enhancements
26- Added an option to the check Oem revision of aml files, can be useful with multiple machines (a command line tool able to patch the aml files will be available soon)
27- Improved smbios support for some Intel Xeon models
28- BETA : Sync'd ati engine with the trunk
30- Small security fixes
31- Added a mechanism to strip the madt table
32- Ported the serial number randomizer to smbiosgetters,
33 Warning: smbiosgetters (and also the Gui module) still don't work when built with Xcode4.
35- Implemented a serial number randomizer in smbiospatcher
36(can be useful for icloud registration problems, especially when the serial number is already used by another machine,
38DISCLAIMER: Please read the iCloud License ( carefully before using this option.
39By using this option, you are agreeing to be bound by
40the terms of the iCloud License ( If you do not or cannot agree to the terms
41of the icloud License (, please do not use this option.
45- Chameleon (or at least this branch) can now boot OSX on Parallels Desktop 7, with full acpi and smbios support
46 (note: you will need to embed at least acpicodec and smbiosgetters since virtual machines don't like our module system),
47 see this vid ;-) :
48- Added a mechanism to boot the real Lion installer partition (with baseSystem.dmg as root device), you will just need to edit the kernelcache
49 for you platform, step 2 of the installation process (booting from the kernelcache in the "Mac OS X Install Data" folder) is still in progress
51- Added a simple mechanism to embed a module into the core of the bootloader (useful for virtual machines
52 or for modules not yet compatible with xcode4), see internal_modules.h for more info.
53- Added JrCs's Keylayout support in Keymapper
54- Fixed an issue in AcpiCodec where the highest cpu frequency may not be added in the pstate package on some configurations
55- Improved detection of nb of core(s) and thread(s) for AMD processors
56- Updated keymapper ...
57- Applied scorpius's patch (to get an unstretched boot screen for nVidia cards on DVI) in boot0.s , disabled by default,
58 see -,2158.msg10345/boardseen.html#new - for more info.
59- Applied Vladimir Zidar's hibernate patch on hibernateEnabler.
60- Applied "Intel HD Graphics 3000" patch to gma.c (credit: ???) ,
61 found at - -
62- Added AMD support (most of the code is derived from the trunk, MUST BE ENABLED BY HAND IN CPU.C) see - -
63- Improved Core Ix support in AcpiCodec
64- Improved c-states support in AcpiCodec
66- Sync'd nvidia.c and gma.c (see GraphicEnabler module) to the trunk
67- Improved compatibility with xcode4 (afaik only the modules gui and smbiosgetters will not work with xcode4, even if they are built without any errors)
68- Applied JrCs's path for more protection against buffer overflow in some case (trunk v1449)
69- Added a mechanism to detect extra mkexts/kexts before loading the kernelCache
70- Moved smp code to Erich Boleyn's smp-imps (not fully implemented yet)
71- Added the UseKernelCache option only for compatibility with the trunk ("Yes" have no effect, since it's the default),
72 the Flag "-F" which do the same things is still valid
73- Re-worked SSDT generation, and merged with the Bits's code
74- Removed aml_generator from AcpiCodec, now use acpicode.c to generate aml file
75- Added YellowIconFixer module
76- Merged fsb detection with Bits's code in cpu.c (slightly faster)
77- Fixed a bug related to ACPI in AcpiCodec (thanck to StephN666 for testing)
78- Fixed a bug related to ACPI and the machine with a rsd table revision > 0 (acpi_tools.c) (thanck to StephN666 for testing)
80- Applied Andy Vandijck's Nehalem (i5/i9) spoof to kernelpatcher
81- Fixed an issue with kernelPatcher, it seems that kernelPatcher is unable to patch the kernelCache
82- Applied some fixes from the trunk
83- Applied many under the hood fixes
84- Added Andy Vandijck's Server spoof
85- Added a Patch from Andy Vandijck in SMBiosPatcher and SMBiosGetters
86- Added a Patch from Netkas in GraphicEnabler (ati.c)
87- Fixed an issue where the GUI module couldn't find the themes directory
88- Fixed an issue where the GUI module failed to display the GUI
89- Added AcpiCodec module
90- Re-wrote ACPI code in fake_efi.c
91- Fixed a bug with AcpiPatcher when built with xcode4
92- Optimized AcpiPatcher code
93- Minor change of SMBIOS code in fake_efi.c
94- Applied some changes to the CPU detection
95- Fixed Pict-FailedBoot allocation
96- Board-id fix is now handled by the smbios modules
98- Added boot-args in the device tree
99- Added BootCLUT and Pict-FailedBoot
100- Added Board-id spoof
101- Fixed kernelcache loading with 10.5, 10.6 and 10.7
102- Added Lion Compatibility
104- Re-enabled Ignore Boot File Flag option , now "-B"
105- Fixed a bug in get_PM_Profile(), where the function return the profile 0 = 'Unspecified' when the facp is incorrect or not found, and so, override the
106 PM type set by the cpu features
107- Added new drop acpi table mechanism, now it's really able to drop any tables
108- BootHelp is not anymore embed by default in the bootloader core, if you need the help at boot time, just install your BootHelp.txt in /Extra/ (for now GUI module still embed it)
109- Fixed the HelloWorld module (broken since i have increased module hook arguments number)
111- "-F" now mean do not use prelinked kernel
112- Fixed embedtheme resolution, random theme chooser now also include embedtheme in the list (if the GUI is compiled with the embedtheme option),
113 also fixed a potential memory leak in randomTheme()
114- Fixed a bug in modules.c introduced in the previous versions, the booloader should now load correctly
115 with or without modules
116- Boot helper support (raid) is now an option (992 bytes saved)
117- Fixed an issue where the prelinked kernel can't be found (the bootloader should now be fully compatible with the kextcache command line tool).
118 (Also merged both adler32 function previously located in drivers.c and boot.c into one (adler32) located in boot.c)
119- returned to malloc by default, instead of safe_malloc, safe_malloc(+1280 bytes) is now an option (as in revolution 616+)
120- APM support is now optional (704 bytes saved)
121- Fixed add_symbol function
122- Increased module hook arguments number to 6
123- Added Kabyl's pci subsystem id patch
124- Added Kabyl's smbios implemention (SMBiosGetters, see Kabyl's branch.) as a module (legacy smbios implementation (SMBiosPatcher) have been also rewritten as a module)
125- Added valv's experimental amd support in CPUFreq module (untested)
126- Added Slice's smbios_patcher fix
127- Increased Booter Log size according to the chameleon trunck (thanck to Azimutz)
129- Added BSD (OpenBSD and FreeBSD) support (Credits to: nawcom, valv)
130- moved hibernation and ramdisk into modules
131- Added a keyboard mapper module
132- Added CPUFreq module (Credits to: valv, cparm)
133- Added a random theme chooser in the GUI module
134- Added Slice's mobile detection fix
135- Added mozodojo's coreI fix in acpi patcher
136- Applied many fixes and optimizations to the core
137- Moved to meklort's core architecture
138- Added Andy Vandijck's Full ACPI tables override and ACPI V1 to V4 conversion patch
141- Added Booter Log Dump Tool
142- Added Booter message Logging (":/boot-log" ioreg property)
143- Removed obsolete -f option, use -x instead
144- Removed -x32 option, use arch=i386 instead
145- Added automatic SMBusspeed detection for lga1156 core i5/7 cpus
146- Added new iMac11,1 sbios default model for lga1156 core i5/17 mobos
147- md0 code. Notified xnu when an md ramdisk is specified
148- Added rollover image support for selected device icons.
149 Use device_<type>_o.png in theme folder. Credits goes to Blackosx.
150- Revisited theme resource embedding. Using the device_<type> icons are optional with
151 the exception of device_generic.
152- Optimized memory detection speed
153- Added displaying source device and partition number for file read operations.
154- Increased boot2's maximum size from 383.5k to 447.5k.
155 Updated stage 1 loaders for handling the new size limit.
156- Added alternate format for setting the default partition. The user can specify the selected
157 volume UUID for the "Default Partition" key.
158- Implemented SPD memory automatic detection and injection,seems to work really great ...
159- Factorized code to prepare a dynamic memory detection algorithm ...
160- Optimized smbios table address search
161- Optimized cursor spinout in textmode if no verbose mode is set
162- Added ram table structures definitions
163- Added getSmbios() a param permitting to select between orig and new smbios entries
164- Changed "Default Partition" behaviour to accept only native system volumes or foreign partitions.
165- Added NVIDIA new NVCAP customization support and support for ION gfx cards from aserebln
166- Added ATI new framebuffers support and new cards from PCEFI10.6
167- improved ACPI file search algo by implementing a cache.
168- Nvidia injection fix
169- pciroot would not always return correct uuid in autodection mode
170- Fixed the hibernation problem in boot2/resume.c
171- Fixed all new booter versions with SystemType would override the facp value even if correct,
172 now keeps the facp value if correct and no override has been done, implemented a best effort algo.
173 for maximizing the chance to get the most correct value before we decide to use a fixed value (1=desktop)
174- Fixed display cosmetics of UUID, now a convert.c file contains all
175 conversions api, to be completed by function that we should reuse.
177- Fixed SystemType would be always forced to a value, now optionally changed
178 only if ovveriden
179- Kept SystemID as the only option to change manually the system-id
180 For theses reasons, SystemId from bootConfig and SMUUID from smbiosConfig aer now DEPRECATED.
182- Integrated JrCs fadt patch (kept for RC5 the existing DSDT.aml retry algo that disapeared in his patch, should be more discussed for RC6)
183- Added JrCs modified convention name change to coding_standards
184- Now malloc (ex. MALLOC in Asere patch) is renamed malloc(size) and is an alias
185 to safe_malloc(size, file, line) with _FILE_ and _LINE_ prerocessor definitions
186- Added a new 'Rename Partition Feature', now permitting to rename partition
187 like 'System reserved' to a more meaningful name
188- Added SystemID option permitting to change the System UUID to a fixed value.
189- Added the PciRoot autodetection feature imported from pcefi10.5
190- Added automatic "system-id" injection from dmi bios, also compatible
191 with SystemID boot option and former SMUUID from smbios,plist
192- Added "system-type' automatic injection (1=Desktop) plus override possibility
193 with the new system-type option in bootConfig
194- Added SMserial and SMproductname new options for smbios.plist
195- Merged with asere patch, while keeping my fake_efi.c changes, and adding a new
196 stringForKey() API, also changed the DT__XXXX() set of functions
197 to handle const char * values instead of char*.

Archive Download this file

Revision: 1804