Merge pull request #155 from sickcodes/custom-identity
Custom Serial Numbers (iMessage/iCloud security analysis)pull/157/head
commit
27efe6658d
@ -0,0 +1,885 @@
|
|||||||
|
<!-- This file is modified from https://github.com/kholia/OSX-KVM/tree/master/OpenCore-Catalina -->
|
||||||
|
<!-- All credit for this file https://github.com/kholia/OSX-KVM/blob/master/CREDITS.md -->
|
||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
|
||||||
|
<plist version="1.0">
|
||||||
|
<dict>
|
||||||
|
<key>ACPI</key>
|
||||||
|
<dict>
|
||||||
|
<key>Add</key>
|
||||||
|
<array>
|
||||||
|
<dict>
|
||||||
|
<key>Comment</key>
|
||||||
|
<string>add DTGP method</string>
|
||||||
|
<key>Enabled</key>
|
||||||
|
<true/>
|
||||||
|
<key>Path</key>
|
||||||
|
<string>SSDT-DTGP.aml</string>
|
||||||
|
</dict>
|
||||||
|
<dict>
|
||||||
|
<key>Comment</key>
|
||||||
|
<string>Fake EC and USBX Power</string>
|
||||||
|
<key>Enabled</key>
|
||||||
|
<true/>
|
||||||
|
<key>Path</key>
|
||||||
|
<string>SSDT-EC.aml</string>
|
||||||
|
</dict>
|
||||||
|
<dict>
|
||||||
|
<key>Comment</key>
|
||||||
|
<string>USB 2.0 Injection</string>
|
||||||
|
<key>Enabled</key>
|
||||||
|
<true/>
|
||||||
|
<key>Path</key>
|
||||||
|
<string>SSDT-EHCI.aml</string>
|
||||||
|
</dict>
|
||||||
|
<dict>
|
||||||
|
<key>Comment</key>
|
||||||
|
<string>CPU AGPM Plugin=1</string>
|
||||||
|
<key>Enabled</key>
|
||||||
|
<true/>
|
||||||
|
<key>Path</key>
|
||||||
|
<string>SSDT-PLUG.aml</string>
|
||||||
|
</dict>
|
||||||
|
</array>
|
||||||
|
<key>Delete</key>
|
||||||
|
<array>
|
||||||
|
<dict>
|
||||||
|
<key>All</key>
|
||||||
|
<false/>
|
||||||
|
<key>Comment</key>
|
||||||
|
<string>Delete CpuPm</string>
|
||||||
|
<key>Enabled</key>
|
||||||
|
<false/>
|
||||||
|
<key>OemTableId</key>
|
||||||
|
<data>Q3B1UG0AAAA=</data>
|
||||||
|
<key>TableLength</key>
|
||||||
|
<integer>0</integer>
|
||||||
|
<key>TableSignature</key>
|
||||||
|
<data>U1NEVA==</data>
|
||||||
|
</dict>
|
||||||
|
<dict>
|
||||||
|
<key>All</key>
|
||||||
|
<false/>
|
||||||
|
<key>Comment</key>
|
||||||
|
<string>Delete Cpu0Ist</string>
|
||||||
|
<key>Enabled</key>
|
||||||
|
<false/>
|
||||||
|
<key>OemTableId</key>
|
||||||
|
<data>Q3B1MElzdAA=</data>
|
||||||
|
<key>TableLength</key>
|
||||||
|
<integer>0</integer>
|
||||||
|
<key>TableSignature</key>
|
||||||
|
<data>U1NEVA==</data>
|
||||||
|
</dict>
|
||||||
|
</array>
|
||||||
|
<key>Patch</key>
|
||||||
|
<array>
|
||||||
|
<dict>
|
||||||
|
<key>Comment</key>
|
||||||
|
<string>_Q11 to XQ11</string>
|
||||||
|
<key>Count</key>
|
||||||
|
<integer>1</integer>
|
||||||
|
<key>Enabled</key>
|
||||||
|
<false/>
|
||||||
|
<key>Find</key>
|
||||||
|
<data>X1ExMQ==</data>
|
||||||
|
<key>Limit</key>
|
||||||
|
<integer>0</integer>
|
||||||
|
<key>Mask</key>
|
||||||
|
<data></data>
|
||||||
|
<key>OemTableId</key>
|
||||||
|
<data></data>
|
||||||
|
<key>Replace</key>
|
||||||
|
<data>WFExMQ==</data>
|
||||||
|
<key>ReplaceMask</key>
|
||||||
|
<data></data>
|
||||||
|
<key>Skip</key>
|
||||||
|
<integer>0</integer>
|
||||||
|
<key>TableLength</key>
|
||||||
|
<integer>0</integer>
|
||||||
|
<key>TableSignature</key>
|
||||||
|
<data></data>
|
||||||
|
</dict>
|
||||||
|
<dict>
|
||||||
|
<key>Comment</key>
|
||||||
|
<string>_Q12 to XQ12</string>
|
||||||
|
<key>Count</key>
|
||||||
|
<integer>1</integer>
|
||||||
|
<key>Enabled</key>
|
||||||
|
<false/>
|
||||||
|
<key>Find</key>
|
||||||
|
<data>X1ExMg==</data>
|
||||||
|
<key>Limit</key>
|
||||||
|
<integer>0</integer>
|
||||||
|
<key>Mask</key>
|
||||||
|
<data></data>
|
||||||
|
<key>OemTableId</key>
|
||||||
|
<data></data>
|
||||||
|
<key>Replace</key>
|
||||||
|
<data>WFExMg==</data>
|
||||||
|
<key>ReplaceMask</key>
|
||||||
|
<data></data>
|
||||||
|
<key>Skip</key>
|
||||||
|
<integer>0</integer>
|
||||||
|
<key>TableLength</key>
|
||||||
|
<integer>0</integer>
|
||||||
|
<key>TableSignature</key>
|
||||||
|
<data></data>
|
||||||
|
</dict>
|
||||||
|
</array>
|
||||||
|
<key>Quirks</key>
|
||||||
|
<dict>
|
||||||
|
<key>FadtEnableReset</key>
|
||||||
|
<false/>
|
||||||
|
<key>NormalizeHeaders</key>
|
||||||
|
<false/>
|
||||||
|
<key>RebaseRegions</key>
|
||||||
|
<false/>
|
||||||
|
<key>ResetHwSig</key>
|
||||||
|
<false/>
|
||||||
|
<key>ResetLogoStatus</key>
|
||||||
|
<false/>
|
||||||
|
</dict>
|
||||||
|
</dict>
|
||||||
|
<key>Booter</key>
|
||||||
|
<dict>
|
||||||
|
<key>MmioWhitelist</key>
|
||||||
|
<array/>
|
||||||
|
<key>Quirks</key>
|
||||||
|
<dict>
|
||||||
|
<key>AvoidRuntimeDefrag</key>
|
||||||
|
<true/>
|
||||||
|
<key>DevirtualiseMmio</key>
|
||||||
|
<false/>
|
||||||
|
<key>DisableSingleUser</key>
|
||||||
|
<false/>
|
||||||
|
<key>DisableVariableWrite</key>
|
||||||
|
<false/>
|
||||||
|
<key>DiscardHibernateMap</key>
|
||||||
|
<false/>
|
||||||
|
<key>EnableSafeModeSlide</key>
|
||||||
|
<true/>
|
||||||
|
<key>EnableWriteUnprotector</key>
|
||||||
|
<true/>
|
||||||
|
<key>ForceExitBootServices</key>
|
||||||
|
<false/>
|
||||||
|
<key>ProtectMemoryRegions</key>
|
||||||
|
<false/>
|
||||||
|
<key>ProtectSecureBoot</key>
|
||||||
|
<false/>
|
||||||
|
<key>ProtectUefiServices</key>
|
||||||
|
<false/>
|
||||||
|
<key>ProvideCustomSlide</key>
|
||||||
|
<true/>
|
||||||
|
<key>ProvideMaxSlide</key>
|
||||||
|
<integer>0</integer>
|
||||||
|
<key>RebuildAppleMemoryMap</key>
|
||||||
|
<false/>
|
||||||
|
<key>SetupVirtualMap</key>
|
||||||
|
<false/>
|
||||||
|
<key>SignalAppleOS</key>
|
||||||
|
<false/>
|
||||||
|
<key>SyncRuntimePermissions</key>
|
||||||
|
<false/>
|
||||||
|
</dict>
|
||||||
|
</dict>
|
||||||
|
<key>DeviceProperties</key>
|
||||||
|
<dict>
|
||||||
|
<key>Add</key>
|
||||||
|
<dict>
|
||||||
|
<key>PciRoot(0x1)/Pci(0x1F,0x0)</key>
|
||||||
|
<dict>
|
||||||
|
<key>compatible</key>
|
||||||
|
<string>pci8086,2916</string>
|
||||||
|
<key>device-id</key>
|
||||||
|
<data>
|
||||||
|
FikA
|
||||||
|
</data>
|
||||||
|
<key>name</key>
|
||||||
|
<string>pci8086,2916</string>
|
||||||
|
</dict>
|
||||||
|
</dict>
|
||||||
|
<key>Delete</key>
|
||||||
|
<dict>
|
||||||
|
<key>PciRoot(0x0)/Pci(0x1b,0x0)</key>
|
||||||
|
<array>
|
||||||
|
<string>MaximumBootBeepVolume</string>
|
||||||
|
</array>
|
||||||
|
</dict>
|
||||||
|
</dict>
|
||||||
|
<key>Kernel</key>
|
||||||
|
<dict>
|
||||||
|
<key>Add</key>
|
||||||
|
<array>
|
||||||
|
<dict>
|
||||||
|
<key>Arch</key>
|
||||||
|
<string>Any</string>
|
||||||
|
<key>BundlePath</key>
|
||||||
|
<string>VoodooHDA.kext</string>
|
||||||
|
<key>Comment</key>
|
||||||
|
<string></string>
|
||||||
|
<key>Enabled</key>
|
||||||
|
<true/>
|
||||||
|
<key>ExecutablePath</key>
|
||||||
|
<string>Contents/MacOS/VoodooHDA</string>
|
||||||
|
<key>MaxKernel</key>
|
||||||
|
<string></string>
|
||||||
|
<key>MinKernel</key>
|
||||||
|
<string></string>
|
||||||
|
<key>PlistPath</key>
|
||||||
|
<string>Contents/Info.plist</string>
|
||||||
|
</dict>
|
||||||
|
<dict>
|
||||||
|
<key>Arch</key>
|
||||||
|
<string>x86_64</string>
|
||||||
|
<key>BundlePath</key>
|
||||||
|
<string>Lilu.kext</string>
|
||||||
|
<key>Comment</key>
|
||||||
|
<string>Patch engine</string>
|
||||||
|
<key>Enabled</key>
|
||||||
|
<true/>
|
||||||
|
<key>ExecutablePath</key>
|
||||||
|
<string>Contents/MacOS/Lilu</string>
|
||||||
|
<key>MaxKernel</key>
|
||||||
|
<string></string>
|
||||||
|
<key>MinKernel</key>
|
||||||
|
<string>12.0.0</string>
|
||||||
|
<key>PlistPath</key>
|
||||||
|
<string>Contents/Info.plist</string>
|
||||||
|
</dict>
|
||||||
|
<dict>
|
||||||
|
<key>Arch</key>
|
||||||
|
<string>x86_64</string>
|
||||||
|
<key>BundlePath</key>
|
||||||
|
<string>VirtualSMC.kext</string>
|
||||||
|
<key>Comment</key>
|
||||||
|
<string>SMC emulator</string>
|
||||||
|
<key>Enabled</key>
|
||||||
|
<false/>
|
||||||
|
<key>ExecutablePath</key>
|
||||||
|
<string>Contents/MacOS/VirtualSMC</string>
|
||||||
|
<key>MaxKernel</key>
|
||||||
|
<string></string>
|
||||||
|
<key>MinKernel</key>
|
||||||
|
<string>12.0.0</string>
|
||||||
|
<key>PlistPath</key>
|
||||||
|
<string>Contents/Info.plist</string>
|
||||||
|
</dict>
|
||||||
|
<dict>
|
||||||
|
<key>Arch</key>
|
||||||
|
<string>x86_64</string>
|
||||||
|
<key>BundlePath</key>
|
||||||
|
<string>WhateverGreen.kext</string>
|
||||||
|
<key>Comment</key>
|
||||||
|
<string>Video patches</string>
|
||||||
|
<key>Enabled</key>
|
||||||
|
<true/>
|
||||||
|
<key>ExecutablePath</key>
|
||||||
|
<string>Contents/MacOS/WhateverGreen</string>
|
||||||
|
<key>MaxKernel</key>
|
||||||
|
<string></string>
|
||||||
|
<key>MinKernel</key>
|
||||||
|
<string>12.0.0</string>
|
||||||
|
<key>PlistPath</key>
|
||||||
|
<string>Contents/Info.plist</string>
|
||||||
|
</dict>
|
||||||
|
<dict>
|
||||||
|
<key>BundlePath</key>
|
||||||
|
<string>AGPMInjector.kext</string>
|
||||||
|
<key>Comment</key>
|
||||||
|
<string></string>
|
||||||
|
<key>Enabled</key>
|
||||||
|
<true/>
|
||||||
|
<key>ExecutablePath</key>
|
||||||
|
<string></string>
|
||||||
|
<key>MaxKernel</key>
|
||||||
|
<string></string>
|
||||||
|
<key>MinKernel</key>
|
||||||
|
<string></string>
|
||||||
|
<key>PlistPath</key>
|
||||||
|
<string>Contents/Info.plist</string>
|
||||||
|
</dict>
|
||||||
|
<dict>
|
||||||
|
<key>BundlePath</key>
|
||||||
|
<string>USBPorts.kext</string>
|
||||||
|
<key>Comment</key>
|
||||||
|
<string></string>
|
||||||
|
<key>Enabled</key>
|
||||||
|
<true/>
|
||||||
|
<key>ExecutablePath</key>
|
||||||
|
<string></string>
|
||||||
|
<key>MaxKernel</key>
|
||||||
|
<string></string>
|
||||||
|
<key>MinKernel</key>
|
||||||
|
<string></string>
|
||||||
|
<key>PlistPath</key>
|
||||||
|
<string>Contents/Info.plist</string>
|
||||||
|
</dict>
|
||||||
|
<dict>
|
||||||
|
<key>Arch</key>
|
||||||
|
<string>x86_64</string>
|
||||||
|
<key>BundlePath</key>
|
||||||
|
<string>MCEReporterDisabler.kext</string>
|
||||||
|
<key>Comment</key>
|
||||||
|
<string>AppleMCEReporter disabler</string>
|
||||||
|
<key>Enabled</key>
|
||||||
|
<true/>
|
||||||
|
<key>ExecutablePath</key>
|
||||||
|
<string></string>
|
||||||
|
<key>MaxKernel</key>
|
||||||
|
<string></string>
|
||||||
|
<key>MinKernel</key>
|
||||||
|
<string>19.0.0</string>
|
||||||
|
<key>PlistPath</key>
|
||||||
|
<string>Contents/Info.plist</string>
|
||||||
|
</dict>
|
||||||
|
</array>
|
||||||
|
<key>Block</key>
|
||||||
|
<array>
|
||||||
|
<dict>
|
||||||
|
<key>Arch</key>
|
||||||
|
<string>Any</string>
|
||||||
|
<key>Comment</key>
|
||||||
|
<string></string>
|
||||||
|
<key>Enabled</key>
|
||||||
|
<false/>
|
||||||
|
<key>Identifier</key>
|
||||||
|
<string>com.apple.driver.AppleTyMCEDriver</string>
|
||||||
|
<key>MaxKernel</key>
|
||||||
|
<string></string>
|
||||||
|
<key>MinKernel</key>
|
||||||
|
<string></string>
|
||||||
|
</dict>
|
||||||
|
</array>
|
||||||
|
<key>Emulate</key>
|
||||||
|
<dict>
|
||||||
|
<key>Cpuid1Data</key>
|
||||||
|
<data>
|
||||||
|
VAYFAAAAAAAAAAAAAAAAAA==
|
||||||
|
</data>
|
||||||
|
<key>Cpuid1Mask</key>
|
||||||
|
<data>
|
||||||
|
////AAAAAAAAAAAAAAAAAA==
|
||||||
|
</data>
|
||||||
|
</dict>
|
||||||
|
<key>Force</key>
|
||||||
|
<array>
|
||||||
|
<dict>
|
||||||
|
<key>Arch</key>
|
||||||
|
<string>Any</string>
|
||||||
|
<key>BundlePath</key>
|
||||||
|
<string>System/Library/Extensions/IONetworkingFamily.kext</string>
|
||||||
|
<key>Comment</key>
|
||||||
|
<string>Patch engine</string>
|
||||||
|
<key>Enabled</key>
|
||||||
|
<false/>
|
||||||
|
<key>Identifier</key>
|
||||||
|
<string>com.apple.iokit.IONetworkingFamily</string>
|
||||||
|
<key>ExecutablePath</key>
|
||||||
|
<string>Contents/MacOS/IONetworkingFamily</string>
|
||||||
|
<key>MaxKernel</key>
|
||||||
|
<string>13.99.99</string>
|
||||||
|
<key>MinKernel</key>
|
||||||
|
<string></string>
|
||||||
|
<key>PlistPath</key>
|
||||||
|
<string>Contents/Info.plist</string>
|
||||||
|
</dict>
|
||||||
|
</array>
|
||||||
|
<key>Patch</key>
|
||||||
|
<array>
|
||||||
|
<dict>
|
||||||
|
<key>Base</key>
|
||||||
|
<string>_cpu_topology_sort</string>
|
||||||
|
<key>Comment</key>
|
||||||
|
<string>algrey - cpu_topology_sort -disable _x86_validate_topology</string>
|
||||||
|
<key>Count</key>
|
||||||
|
<integer>1</integer>
|
||||||
|
<key>Enabled</key>
|
||||||
|
<true/>
|
||||||
|
<key>Find</key>
|
||||||
|
<data>
|
||||||
|
6AAA//8=
|
||||||
|
</data>
|
||||||
|
<key>Identifier</key>
|
||||||
|
<string>kernel</string>
|
||||||
|
<key>Limit</key>
|
||||||
|
<integer>0</integer>
|
||||||
|
<key>Mask</key>
|
||||||
|
<data>
|
||||||
|
/wAA//8=
|
||||||
|
</data>
|
||||||
|
<key>MaxKernel</key>
|
||||||
|
<string>20.99.99</string>
|
||||||
|
<key>MinKernel</key>
|
||||||
|
<string>17.0.0</string>
|
||||||
|
<key>Replace</key>
|
||||||
|
<data>
|
||||||
|
Dx9EAAA=
|
||||||
|
</data>
|
||||||
|
<key>ReplaceMask</key>
|
||||||
|
<data>
|
||||||
|
</data>
|
||||||
|
<key>Skip</key>
|
||||||
|
<integer>0</integer>
|
||||||
|
</dict>
|
||||||
|
<dict>
|
||||||
|
<key>Base</key>
|
||||||
|
<string></string>
|
||||||
|
<key>Comment</key>
|
||||||
|
<string>algrey - cpuid_set_cpufamily - force CPUFAMILY_INTEL_PENRYN</string>
|
||||||
|
<key>Count</key>
|
||||||
|
<integer>1</integer>
|
||||||
|
<key>Enabled</key>
|
||||||
|
<true/>
|
||||||
|
<key>Find</key>
|
||||||
|
<data>
|
||||||
|
MduAPQAAAAAGdQA=
|
||||||
|
</data>
|
||||||
|
<key>Identifier</key>
|
||||||
|
<string>kernel</string>
|
||||||
|
<key>Limit</key>
|
||||||
|
<integer>0</integer>
|
||||||
|
<key>Mask</key>
|
||||||
|
<data>
|
||||||
|
/////wAAAP///wA=
|
||||||
|
</data>
|
||||||
|
<key>MaxKernel</key>
|
||||||
|
<string>20.99.99</string>
|
||||||
|
<key>MinKernel</key>
|
||||||
|
<string>17.0.0</string>
|
||||||
|
<key>Replace</key>
|
||||||
|
<data>
|
||||||
|
u7xP6njpXQAAAJA=
|
||||||
|
</data>
|
||||||
|
<key>ReplaceMask</key>
|
||||||
|
<data>
|
||||||
|
</data>
|
||||||
|
<key>Skip</key>
|
||||||
|
<integer>0</integer>
|
||||||
|
</dict>
|
||||||
|
</array>
|
||||||
|
<key>Quirks</key>
|
||||||
|
<dict>
|
||||||
|
<key>AppleCpuPmCfgLock</key>
|
||||||
|
<false/>
|
||||||
|
<key>AppleXcpmCfgLock</key>
|
||||||
|
<false/>
|
||||||
|
<key>AppleXcpmExtraMsrs</key>
|
||||||
|
<false/>
|
||||||
|
<key>AppleXcpmForceBoost</key>
|
||||||
|
<false/>
|
||||||
|
<key>CustomSMBIOSGuid</key>
|
||||||
|
<false/>
|
||||||
|
<key>DisableIoMapper</key>
|
||||||
|
<false/>
|
||||||
|
<key>DisableLinkeditJettison</key>
|
||||||
|
<true/>
|
||||||
|
<key>DisableRtcChecksum</key>
|
||||||
|
<false/>
|
||||||
|
<key>DummyPowerManagement</key>
|
||||||
|
<true/>
|
||||||
|
<key>ExternalDiskIcons</key>
|
||||||
|
<false/>
|
||||||
|
<key>IncreasePciBarSize</key>
|
||||||
|
<false/>
|
||||||
|
<key>LapicKernelPanic</key>
|
||||||
|
<false/>
|
||||||
|
<key>PanicNoKextDump</key>
|
||||||
|
<false/>
|
||||||
|
<key>PowerTimeoutKernelPanic</key>
|
||||||
|
<false/>
|
||||||
|
<key>ThirdPartyDrives</key>
|
||||||
|
<false/>
|
||||||
|
<key>XhciPortLimit</key>
|
||||||
|
<false/>
|
||||||
|
</dict>
|
||||||
|
<key>Scheme</key>
|
||||||
|
<dict>
|
||||||
|
<key>FuzzyMatch</key>
|
||||||
|
<true/>
|
||||||
|
<key>KernelArch</key>
|
||||||
|
<string>x86_64</string>
|
||||||
|
<key>KernelCache</key>
|
||||||
|
<string>Auto</string>
|
||||||
|
</dict>
|
||||||
|
</dict>
|
||||||
|
<key>Misc</key>
|
||||||
|
<dict>
|
||||||
|
<key>BlessOverride</key>
|
||||||
|
<array/>
|
||||||
|
<key>Boot</key>
|
||||||
|
<dict>
|
||||||
|
<key>ConsoleAttributes</key>
|
||||||
|
<integer>0</integer>
|
||||||
|
<key>HibernateMode</key>
|
||||||
|
<string>Auto</string>
|
||||||
|
<key>HideAuxiliary</key>
|
||||||
|
<false/>
|
||||||
|
<key>PickerAttributes</key>
|
||||||
|
<integer>1</integer>
|
||||||
|
<key>PickerAudioAssist</key>
|
||||||
|
<false/>
|
||||||
|
<key>PickerMode</key>
|
||||||
|
<string>External</string>
|
||||||
|
<key>PollAppleHotKeys</key>
|
||||||
|
<true/>
|
||||||
|
<key>ShowPicker</key>
|
||||||
|
<false/>
|
||||||
|
<key>TakeoffDelay</key>
|
||||||
|
<integer>0</integer>
|
||||||
|
<key>Timeout</key>
|
||||||
|
<integer>0</integer>
|
||||||
|
</dict>
|
||||||
|
<key>Debug</key>
|
||||||
|
<dict>
|
||||||
|
<key>AppleDebug</key>
|
||||||
|
<false/>
|
||||||
|
<key>ApplePanic</key>
|
||||||
|
<false/>
|
||||||
|
<key>DisableWatchDog</key>
|
||||||
|
<false/>
|
||||||
|
<key>DisplayDelay</key>
|
||||||
|
<integer>0</integer>
|
||||||
|
<key>DisplayLevel</key>
|
||||||
|
<integer>2147483650</integer>
|
||||||
|
<key>SerialInit</key>
|
||||||
|
<false/>
|
||||||
|
<key>SysReport</key>
|
||||||
|
<false/>
|
||||||
|
<key>Target</key>
|
||||||
|
<integer>3</integer>
|
||||||
|
</dict>
|
||||||
|
<key>Entries</key>
|
||||||
|
<array/>
|
||||||
|
<key>Security</key>
|
||||||
|
<dict>
|
||||||
|
<key>AllowNvramReset</key>
|
||||||
|
<true/>
|
||||||
|
<key>AllowSetDefault</key>
|
||||||
|
<false/>
|
||||||
|
<key>ApECID</key>
|
||||||
|
<integer>0</integer>
|
||||||
|
<key>AuthRestart</key>
|
||||||
|
<false/>
|
||||||
|
<key>BootProtect</key>
|
||||||
|
<string>None</string>
|
||||||
|
<key>DmgLoading</key>
|
||||||
|
<string>Signed</string>
|
||||||
|
<key>EnablePassword</key>
|
||||||
|
<false/>
|
||||||
|
<key>ExposeSensitiveData</key>
|
||||||
|
<integer>6</integer>
|
||||||
|
<key>HaltLevel</key>
|
||||||
|
<integer>2147483648</integer>
|
||||||
|
<key>PasswordHash</key>
|
||||||
|
<data></data>
|
||||||
|
<key>PasswordSalt</key>
|
||||||
|
<data></data>
|
||||||
|
<key>ScanPolicy</key>
|
||||||
|
<integer>0</integer>
|
||||||
|
<key>SecureBootModel</key>
|
||||||
|
<string>Disabled</string>
|
||||||
|
<key>Vault</key>
|
||||||
|
<string>Optional</string>
|
||||||
|
</dict>
|
||||||
|
<key>Tools</key>
|
||||||
|
<array>
|
||||||
|
<dict>
|
||||||
|
<key>Arguments</key>
|
||||||
|
<string></string>
|
||||||
|
<key>Auxiliary</key>
|
||||||
|
<false/>
|
||||||
|
<key>Comment</key>
|
||||||
|
<string>Not signed for security reasons</string>
|
||||||
|
<key>Enabled</key>
|
||||||
|
<true/>
|
||||||
|
<key>Name</key>
|
||||||
|
<string>UEFI Shell</string>
|
||||||
|
<key>Path</key>
|
||||||
|
<string>OpenShell.efi</string>
|
||||||
|
</dict>
|
||||||
|
<dict>
|
||||||
|
<key>Arguments</key>
|
||||||
|
<string>Shutdown</string>
|
||||||
|
<key>Auxiliary</key>
|
||||||
|
<true/>
|
||||||
|
<key>Comment</key>
|
||||||
|
<string>Perform shutdown</string>
|
||||||
|
<key>Enabled</key>
|
||||||
|
<true/>
|
||||||
|
<key>Name</key>
|
||||||
|
<string>Shutdown</string>
|
||||||
|
<key>Path</key>
|
||||||
|
<string>ResetSystem.efi</string>
|
||||||
|
</dict>
|
||||||
|
</array>
|
||||||
|
</dict>
|
||||||
|
<key>NVRAM</key>
|
||||||
|
<dict>
|
||||||
|
<key>Add</key>
|
||||||
|
<dict>
|
||||||
|
<key>4D1EDE05-38C7-4A6A-9CC6-4BCCA8B38C14</key>
|
||||||
|
<dict>
|
||||||
|
<key>DefaultBackgroundColor</key>
|
||||||
|
<data>AAAAAA==</data>
|
||||||
|
<key>UIScale</key>
|
||||||
|
<data>AQ==</data>
|
||||||
|
</dict>
|
||||||
|
<key>4D1FDA02-38C7-4A6A-9CC6-4BCCA8B30102</key>
|
||||||
|
<dict>
|
||||||
|
<key>rtc-blacklist</key>
|
||||||
|
<data></data>
|
||||||
|
</dict>
|
||||||
|
<key>7C436110-AB2A-4BBB-A880-FE41995C9F82</key>
|
||||||
|
<dict>
|
||||||
|
<key>SystemAudioVolume</key>
|
||||||
|
<data>Rg==</data>
|
||||||
|
<key>boot-args</key>
|
||||||
|
<string>-v keepsyms=1 tlbto_us=0 vti=9</string>
|
||||||
|
<key>run-efi-updater</key>
|
||||||
|
<string>No</string>
|
||||||
|
<key>csr-active-config</key>
|
||||||
|
<data>ZwAAAA==</data>
|
||||||
|
<key>prev-lang:kbd</key>
|
||||||
|
<data>ZW4tVVM6MA==</data>
|
||||||
|
</dict>
|
||||||
|
</dict>
|
||||||
|
<key>Delete</key>
|
||||||
|
<dict>
|
||||||
|
<key>4D1EDE05-38C7-4A6A-9CC6-4BCCA8B38C14</key>
|
||||||
|
<array>
|
||||||
|
<string>UIScale</string>
|
||||||
|
<string>DefaultBackgroundColor</string>
|
||||||
|
</array>
|
||||||
|
<key>4D1FDA02-38C7-4A6A-9CC6-4BCCA8B30102</key>
|
||||||
|
<array>
|
||||||
|
<string>rtc-blacklist</string>
|
||||||
|
</array>
|
||||||
|
<key>7C436110-AB2A-4BBB-A880-FE41995C9F82</key>
|
||||||
|
<array>
|
||||||
|
<string>boot-args</string>
|
||||||
|
</array>
|
||||||
|
</dict>
|
||||||
|
<key>LegacyEnable</key>
|
||||||
|
<false/>
|
||||||
|
<key>LegacyOverwrite</key>
|
||||||
|
<false/>
|
||||||
|
<key>LegacySchema</key>
|
||||||
|
<dict>
|
||||||
|
<key>7C436110-AB2A-4BBB-A880-FE41995C9F82</key>
|
||||||
|
<array>
|
||||||
|
<string>EFILoginHiDPI</string>
|
||||||
|
<string>EFIBluetoothDelay</string>
|
||||||
|
<string>LocationServicesEnabled</string>
|
||||||
|
<string>SystemAudioVolume</string>
|
||||||
|
<string>SystemAudioVolumeDB</string>
|
||||||
|
<string>SystemAudioVolumeSaved</string>
|
||||||
|
<string>bluetoothActiveControllerInfo</string>
|
||||||
|
<string>bluetoothInternalControllerInfo</string>
|
||||||
|
<string>flagstate</string>
|
||||||
|
<string>fmm-computer-name</string>
|
||||||
|
<string>nvda_drv</string>
|
||||||
|
<string>prev-lang:kbd</string>
|
||||||
|
</array>
|
||||||
|
<key>8BE4DF61-93CA-11D2-AA0D-00E098032B8C</key>
|
||||||
|
<array>
|
||||||
|
<string>Boot0080</string>
|
||||||
|
<string>Boot0081</string>
|
||||||
|
<string>Boot0082</string>
|
||||||
|
<string>BootNext</string>
|
||||||
|
<string>BootOrder</string>
|
||||||
|
</array>
|
||||||
|
</dict>
|
||||||
|
<key>WriteFlash</key>
|
||||||
|
<true/>
|
||||||
|
</dict>
|
||||||
|
<key>PlatformInfo</key>
|
||||||
|
<dict>
|
||||||
|
<key>Automatic</key>
|
||||||
|
<true/>
|
||||||
|
<key>Generic</key>
|
||||||
|
<dict>
|
||||||
|
<key>AdviseWindows</key>
|
||||||
|
<false/>
|
||||||
|
<key>MLB</key>
|
||||||
|
<string>{{BOARD_SERIAL}}</string>
|
||||||
|
<key>ROM</key>
|
||||||
|
<data>
|
||||||
|
{{ROM}}
|
||||||
|
</data>
|
||||||
|
<key>SpoofVendor</key>
|
||||||
|
<true/>
|
||||||
|
<key>SystemProductName</key>
|
||||||
|
<string>{{DEVICE_MODEL}}</string>
|
||||||
|
<key>SystemSerialNumber</key>
|
||||||
|
<string>{{SERIAL}}</string>
|
||||||
|
<key>SystemUUID</key>
|
||||||
|
<string>{{UUID}}</string>
|
||||||
|
</dict>
|
||||||
|
<key>UpdateDataHub</key>
|
||||||
|
<true/>
|
||||||
|
<key>UpdateNVRAM</key>
|
||||||
|
<true/>
|
||||||
|
<key>UpdateSMBIOS</key>
|
||||||
|
<true/>
|
||||||
|
<key>UpdateSMBIOSMode</key>
|
||||||
|
<string>Create</string>
|
||||||
|
</dict>
|
||||||
|
<key>UEFI</key>
|
||||||
|
<dict>
|
||||||
|
<key>APFS</key>
|
||||||
|
<dict>
|
||||||
|
<key>EnableJumpstart</key>
|
||||||
|
<true/>
|
||||||
|
<key>GlobalConnect</key>
|
||||||
|
<false/>
|
||||||
|
<key>HideVerbose</key>
|
||||||
|
<false/>
|
||||||
|
<key>JumpstartHotPlug</key>
|
||||||
|
<true/>
|
||||||
|
<key>MinDate</key>
|
||||||
|
<integer>0</integer>
|
||||||
|
<key>MinVersion</key>
|
||||||
|
<integer>0</integer>
|
||||||
|
</dict>
|
||||||
|
<key>Audio</key>
|
||||||
|
<dict>
|
||||||
|
<key>AudioCodec</key>
|
||||||
|
<integer>0</integer>
|
||||||
|
<key>AudioDevice</key>
|
||||||
|
<string>PciRoot(0x1)/Pci(0x1,0x0)/Pci(0x0,0x1)</string>
|
||||||
|
<key>AudioOut</key>
|
||||||
|
<integer>0</integer>
|
||||||
|
<key>AudioSupport</key>
|
||||||
|
<false/>
|
||||||
|
<key>MinimumVolume</key>
|
||||||
|
<integer>20</integer>
|
||||||
|
<key>PlayChime</key>
|
||||||
|
<false/>
|
||||||
|
<key>VolumeAmplifier</key>
|
||||||
|
<integer>0</integer>
|
||||||
|
</dict>
|
||||||
|
<key>ConnectDrivers</key>
|
||||||
|
<true/>
|
||||||
|
<key>Drivers</key>
|
||||||
|
<array>
|
||||||
|
<string>VBoxHfs.efi</string>
|
||||||
|
<string>OpenRuntime.efi</string>
|
||||||
|
<string>OpenCanopy.efi</string>
|
||||||
|
<string>#AudioDxe.efi</string>
|
||||||
|
<string>#OpenUsbKbDxe.efi</string>
|
||||||
|
<string>#UsbMouseDxe.efi</string>
|
||||||
|
<string>#Ps2KeyboardDxe.efi</string>
|
||||||
|
<string>#Ps2MouseDxe.efi</string>
|
||||||
|
<string>#HiiDatabase.efi</string>
|
||||||
|
<string>#NvmExpressDxe.efi</string>
|
||||||
|
<string>#XhciDxe.efi</string>
|
||||||
|
<string>#ExFatDxe.efi</string>
|
||||||
|
<string>#PartitionDxe.efi</string>
|
||||||
|
<string>#CrScreenshotDxe.efi</string>
|
||||||
|
</array>
|
||||||
|
<key>Input</key>
|
||||||
|
<dict>
|
||||||
|
<key>KeyFiltering</key>
|
||||||
|
<false/>
|
||||||
|
<key>KeyForgetThreshold</key>
|
||||||
|
<integer>5</integer>
|
||||||
|
<key>KeyMergeThreshold</key>
|
||||||
|
<integer>2</integer>
|
||||||
|
<key>KeySupport</key>
|
||||||
|
<true/>
|
||||||
|
<key>KeySupportMode</key>
|
||||||
|
<string>Auto</string>
|
||||||
|
<key>KeySwap</key>
|
||||||
|
<false/>
|
||||||
|
<key>PointerSupport</key>
|
||||||
|
<false/>
|
||||||
|
<key>PointerSupportMode</key>
|
||||||
|
<string>ASUS</string>
|
||||||
|
<key>TimerResolution</key>
|
||||||
|
<integer>50000</integer>
|
||||||
|
</dict>
|
||||||
|
<key>Output</key>
|
||||||
|
<dict>
|
||||||
|
<key>ClearScreenOnModeSwitch</key>
|
||||||
|
<false/>
|
||||||
|
<key>ConsoleMode</key>
|
||||||
|
<string></string>
|
||||||
|
<key>DirectGopRendering</key>
|
||||||
|
<false/>
|
||||||
|
<key>IgnoreTextInGraphics</key>
|
||||||
|
<false/>
|
||||||
|
<key>ProvideConsoleGop</key>
|
||||||
|
<true/>
|
||||||
|
<key>ReconnectOnResChange</key>
|
||||||
|
<false/>
|
||||||
|
<key>ReplaceTabWithSpace</key>
|
||||||
|
<false/>
|
||||||
|
<key>Resolution</key>
|
||||||
|
<string>1920x1080@32</string>
|
||||||
|
<key>SanitiseClearScreen</key>
|
||||||
|
<false/>
|
||||||
|
<key>TextRenderer</key>
|
||||||
|
<string>BuiltinGraphics</string>
|
||||||
|
<key>UgaPassThrough</key>
|
||||||
|
<false/>
|
||||||
|
</dict>
|
||||||
|
<key>ProtocolOverrides</key>
|
||||||
|
<dict>
|
||||||
|
<key>AppleAudio</key>
|
||||||
|
<false/>
|
||||||
|
<key>AppleBootPolicy</key>
|
||||||
|
<false/>
|
||||||
|
<key>AppleDebugLog</key>
|
||||||
|
<false/>
|
||||||
|
<key>AppleEvent</key>
|
||||||
|
<false/>
|
||||||
|
<key>AppleFramebufferInfo</key>
|
||||||
|
<false/>
|
||||||
|
<key>AppleImageConversion</key>
|
||||||
|
<false/>
|
||||||
|
<key>AppleImg4Verification</key>
|
||||||
|
<false/>
|
||||||
|
<key>AppleKeyMap</key>
|
||||||
|
<false/>
|
||||||
|
<key>AppleRtcRam</key>
|
||||||
|
<false/>
|
||||||
|
<key>AppleSecureBoot</key>
|
||||||
|
<false/>
|
||||||
|
<key>AppleSmcIo</key>
|
||||||
|
<false/>
|
||||||
|
<key>AppleUserInterfaceTheme</key>
|
||||||
|
<false/>
|
||||||
|
<key>DataHub</key>
|
||||||
|
<false/>
|
||||||
|
<key>DeviceProperties</key>
|
||||||
|
<false/>
|
||||||
|
<key>FirmwareVolume</key>
|
||||||
|
<false/>
|
||||||
|
<key>HashServices</key>
|
||||||
|
<false/>
|
||||||
|
<key>OSInfo</key>
|
||||||
|
<false/>
|
||||||
|
<key>UnicodeCollation</key>
|
||||||
|
<false/>
|
||||||
|
</dict>
|
||||||
|
<key>Quirks</key>
|
||||||
|
<dict>
|
||||||
|
<key>ExitBootServicesDelay</key>
|
||||||
|
<integer>0</integer>
|
||||||
|
<key>IgnoreInvalidFlexRatio</key>
|
||||||
|
<false/>
|
||||||
|
<key>ReleaseUsbOwnership</key>
|
||||||
|
<false/>
|
||||||
|
<key>RequestBootVarRouting</key>
|
||||||
|
<true/>
|
||||||
|
<key>TscSyncTimeout</key>
|
||||||
|
<integer>0</integer>
|
||||||
|
<key>UnblockFsConnect</key>
|
||||||
|
<true/>
|
||||||
|
<key>ConnectDrivers</key>
|
||||||
|
<true/>
|
||||||
|
</dict>
|
||||||
|
</dict>
|
||||||
|
</dict>
|
||||||
|
</plist>
|
@ -0,0 +1,184 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
# ____ __ ____ ______ __
|
||||||
|
# / __ \____ _____/ /_____ _____/ __ \/ ___/ |/ /
|
||||||
|
# / / / / __ \/ ___/ //_/ _ \/ ___/ / / /\__ \| /
|
||||||
|
# / /_/ / /_/ / /__/ ,< / __/ / / /_/ /___/ / |
|
||||||
|
# /_____/\____/\___/_/|_|\___/_/ \____//____/_/|_| GEN BOOT DISK
|
||||||
|
#
|
||||||
|
# Repo: https://github.com/sickcodes/Docker-OSX/
|
||||||
|
# Title: Mac on Docker (Docker-OSX)
|
||||||
|
# Author: Sick.Codes https://sick.codes/
|
||||||
|
# Version: 3.1
|
||||||
|
# License: GPLv3+
|
||||||
|
|
||||||
|
help_text="Usage: generate-specific-bootdisk.sh
|
||||||
|
|
||||||
|
General options:
|
||||||
|
--model <string> Device model, e.g. 'iMacPro1,1'
|
||||||
|
--serial <filename> Device Serial number.
|
||||||
|
--board-serial <filename> Board Serial number.
|
||||||
|
--uuid <filename> SmUUID.
|
||||||
|
--mac-address <string> Used to set the ROM value; lowercased and without a colon.
|
||||||
|
--output-bootdisk <filename> Optionally change the bootdisk output filename.
|
||||||
|
--custom-plist <filename> Optionally change the input plist.
|
||||||
|
|
||||||
|
--help, -h, help Display this help and exit
|
||||||
|
|
||||||
|
Example:
|
||||||
|
./generate-specific-bootdisk.sh \
|
||||||
|
--model iMacPro1,1 \
|
||||||
|
--serial C02TW0WAHX87 \
|
||||||
|
--board-serial C027251024NJG36UE \
|
||||||
|
--uuid 5CCB366D-9118-4C61-A00A-E5BAF3BED451 \
|
||||||
|
--mac-address A8:5C:2C:9A:46:2F \
|
||||||
|
--output-bootdisk OpenCore-nopicker.qcow2
|
||||||
|
|
||||||
|
Author: Sick.Codes https://sick.codes/
|
||||||
|
Project: https://github.com/sickcodes/Docker-OSX/
|
||||||
|
"
|
||||||
|
|
||||||
|
PLIST_MASTER=config-nopicker-custom.plist
|
||||||
|
|
||||||
|
# gather arguments
|
||||||
|
while (( "$#" )); do
|
||||||
|
case "${1}" in
|
||||||
|
|
||||||
|
--help | -h | h | help )
|
||||||
|
echo "${help_text}" && exit 0
|
||||||
|
;;
|
||||||
|
|
||||||
|
--model=* | -m=* )
|
||||||
|
export DEVICE_MODEL="${1#*=}"
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
--model* | -m* )
|
||||||
|
export DEVICE_MODEL="${2}"
|
||||||
|
shift
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
|
||||||
|
--serial=* )
|
||||||
|
export SERIAL="${1#*=}"
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
--serial* )
|
||||||
|
export SERIAL="${2}"
|
||||||
|
shift
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
|
||||||
|
--board-serial=* )
|
||||||
|
export BOARD_SERIAL="${1#*=}"
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
--board-serial* )
|
||||||
|
export BOARD_SERIAL="${2}"
|
||||||
|
shift
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
|
||||||
|
--uuid=* )
|
||||||
|
export UUID="${1#*=}"
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
--uuid* )
|
||||||
|
export UUID="${2}"
|
||||||
|
shift
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
|
||||||
|
--mac-address=* )
|
||||||
|
export MAC_ADDRESS="${1#*=}"
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
--mac-address* )
|
||||||
|
export MAC_ADDRESS="${2}"
|
||||||
|
shift
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
|
||||||
|
--output-bootdisk=* )
|
||||||
|
export OUTPUT_QCOW="${1#*=}"
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
--output-bootdisk* )
|
||||||
|
export OUTPUT_QCOW="${2}"
|
||||||
|
shift
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
|
||||||
|
--custom-plist=* )
|
||||||
|
export INPUT_PLIST="${1#*=}"
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
--custom-plist* )
|
||||||
|
export INPUT_PLIST="${2}"
|
||||||
|
shift
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
|
||||||
|
*)
|
||||||
|
echo "Invalid option. Running with default values..."
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
done
|
||||||
|
|
||||||
|
|
||||||
|
download_qcow_efi_folder () {
|
||||||
|
git clone --depth 1 https://github.com/kholia/OSX-KVM.git
|
||||||
|
cp -ra ./OSX-KVM/OpenCore-Catalina/EFI .
|
||||||
|
mkdir -p ./EFI/OC/Resources
|
||||||
|
# clone some Apple drivers
|
||||||
|
git clone --depth 1 https://github.com/acidanthera/OcBinaryData.git
|
||||||
|
# copy said drivers into EFI/OC/Resources
|
||||||
|
cp -a ./OcBinaryData/Resources/* ./EFI/OC/Resources
|
||||||
|
# EFI Shell commands
|
||||||
|
touch startup.nsh && echo 'fs0:\EFI\BOOT\BOOTx64.efi' > startup.nsh
|
||||||
|
}
|
||||||
|
|
||||||
|
generate_bootdisk () {
|
||||||
|
[[ -e ./config-nopicker-custom.plist ]] || wget https://raw.githubusercontent.com/sickcodes/Docker-OSX/custom-identity/custom/config-nopicker-custom.plist
|
||||||
|
[[ -e ./opencore-image-ng.sh ]] || wget https://raw.githubusercontent.com/sickcodes/Docker-OSX/custom-identity/custom/opencore-image-ng.sh && chmod +x opencore-image-ng.sh
|
||||||
|
# plist required for bootdisks, so create anyway.
|
||||||
|
if [[ "${DEVICE_MODEL}" ]] \
|
||||||
|
&& [[ "${SERIAL}" ]] \
|
||||||
|
&& [[ "${BOARD_SERIAL}" ]] \
|
||||||
|
&& [[ "${UUID}" ]] \
|
||||||
|
&& [[ "${MAC_ADDRESS}" ]]; then
|
||||||
|
ROM="${MAC_ADDRESS//\:/}"
|
||||||
|
ROM="${ROM,,}"
|
||||||
|
sed -e s/{{DEVICE_MODEL}}/"${DEVICE_MODEL}"/g \
|
||||||
|
-e s/{{SERIAL}}/"${SERIAL}"/g \
|
||||||
|
-e s/{{BOARD_SERIAL}}/"${BOARD_SERIAL}"/g \
|
||||||
|
-e s/{{UUID}}/"${UUID}"/g \
|
||||||
|
-e s/{{ROM}}/"${ROM}"/g \
|
||||||
|
"${PLIST_MASTER}" > ./tmp.config.plist || exit 1
|
||||||
|
else
|
||||||
|
cat <<EOF
|
||||||
|
Error: one of the following values is missing:
|
||||||
|
|
||||||
|
--model "${DEVICE_MODEL:-MISSING}"
|
||||||
|
--serial "${SERIAL:-MISSING}"
|
||||||
|
--board-serial "${BOARD_SERIAL:-MISSING}"
|
||||||
|
--uuid "${UUID:-MISSING}"
|
||||||
|
--mac-address "${MAC_ADDRESS:-MISSING}"
|
||||||
|
|
||||||
|
EOF
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
./opencore-image-ng.sh \
|
||||||
|
--cfg "${INPUT_PLIST:-./tmp.config.plist}" \
|
||||||
|
--img "${OUTPUT_QCOW:-./${SERIAL}.OpenCore-nopicker.qcow2}" || exit 1
|
||||||
|
rm ./tmp.config.plist
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
main () {
|
||||||
|
download_qcow_efi_folder
|
||||||
|
generate_bootdisk
|
||||||
|
}
|
||||||
|
|
||||||
|
main
|
||||||
|
|
@ -0,0 +1,287 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
# ____ __ ____ ______ __
|
||||||
|
# / __ \____ _____/ /_____ _____/ __ \/ ___/ |/ /
|
||||||
|
# / / / / __ \/ ___/ //_/ _ \/ ___/ / / /\__ \| /
|
||||||
|
# / /_/ / /_/ / /__/ ,< / __/ / / /_/ /___/ / |
|
||||||
|
# /_____/\____/\___/_/|_|\___/_/ \____//____/_/|_| SERIALIZER
|
||||||
|
#
|
||||||
|
# Repo: https://github.com/sickcodes/Docker-OSX/
|
||||||
|
# Title: Mac on Docker (Docker-OSX)
|
||||||
|
# Author: Sick.Codes https://sick.codes/
|
||||||
|
# Version: 3.1
|
||||||
|
# License: GPLv3+
|
||||||
|
|
||||||
|
help_text="Usage: generate-unique-machine-values.sh
|
||||||
|
|
||||||
|
General options:
|
||||||
|
--count, -n, -c <count> Number of serials to generate
|
||||||
|
--model, -m <model> Device model, e.g. 'iMacPro1,1'
|
||||||
|
--csv <filename> Optionally change the CSV output filename.
|
||||||
|
--tsv <filename> Optionally change the TSV output filename.
|
||||||
|
--output-bootdisk <filename> Optionally change the bootdisk qcow output filename. Useless when count > 1.
|
||||||
|
--output-env <filename> Optionally change the bootdisk env filename. Useless when count > 1.
|
||||||
|
--output-dir <directory> Optionally change the script output location.
|
||||||
|
|
||||||
|
--help, -h, help Display this help and exit
|
||||||
|
--plists Create corresponding config.plists for each serial set.
|
||||||
|
--bootdisks [SLOW] Create corresponding boot disk images for each serial set.
|
||||||
|
|
||||||
|
Example:
|
||||||
|
./generate-unique-machine-values.sh --count 1 --model='iMacPro1,1' --plists --bootdisks
|
||||||
|
|
||||||
|
The above example will generate a
|
||||||
|
- serial
|
||||||
|
- board serial
|
||||||
|
- uuid
|
||||||
|
- MAC address
|
||||||
|
- ROM value based on lowercase MAC address
|
||||||
|
- Boot disk qcow image.
|
||||||
|
- config.plist
|
||||||
|
|
||||||
|
Notes:
|
||||||
|
- Default is 1 serial for 'iMacPro1,1' in the current working directory.
|
||||||
|
- Default output is CSV, whereas setting the TSV option will output as tab-separated.
|
||||||
|
- CSV is double quoted.
|
||||||
|
- If you do not set a CSV filename, the output will be sent to the output-dir.
|
||||||
|
- If you do not set an output-dir, the current directory will be the output directory.
|
||||||
|
- Sourcable environment variable shell files will be written to a folder, 'envs'.
|
||||||
|
- config.plist files will be written to a folder, 'plists'.
|
||||||
|
|
||||||
|
Author: Sick.Codes https://sick.codes/
|
||||||
|
Project: https://github.com/sickcodes/Docker-OSX/
|
||||||
|
"
|
||||||
|
|
||||||
|
MACINFOPKG_VERSION=2.1.2
|
||||||
|
PLIST_MASTER=config-nopicker-custom.plist
|
||||||
|
|
||||||
|
# gather arguments
|
||||||
|
while (( "$#" )); do
|
||||||
|
case "${1}" in
|
||||||
|
|
||||||
|
--help | -h | h | help )
|
||||||
|
echo "${help_text}" && exit 0
|
||||||
|
;;
|
||||||
|
|
||||||
|
--count=* | -c=* | -n=* )
|
||||||
|
export SERIAL_SET_COUNT="${1#*=}"
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
--count* | -c* | -n* )
|
||||||
|
export SERIAL_SET_COUNT="${2}"
|
||||||
|
shift
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
|
||||||
|
--csv=* )
|
||||||
|
export CSV_OUTPUT_FILENAME="${1#*=}"
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
--csv* )
|
||||||
|
export CSV_OUTPUT_FILENAME="${2}"
|
||||||
|
shift
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
|
||||||
|
--tsv=* )
|
||||||
|
export TSV_OUTPUT_FILENAME="${1#*=}"
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
--tsv* )
|
||||||
|
export TSV_OUTPUT_FILENAME="${2}"
|
||||||
|
shift
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
|
||||||
|
--output-dir=* )
|
||||||
|
export OUTPUT_DIRECTORY="${1#*=}"
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
--output-dir* )
|
||||||
|
export OUTPUT_DIRECTORY="${2}"
|
||||||
|
shift
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
|
||||||
|
--output-bootdisk=* )
|
||||||
|
export OUTPUT_QCOW="${1#*=}"
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
--output-bootdisk* )
|
||||||
|
export OUTPUT_QCOW="${2}"
|
||||||
|
shift
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
|
||||||
|
--output-env=* )
|
||||||
|
export OUTPUT_ENV="${1#*=}"
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
--output-env* )
|
||||||
|
export OUTPUT_ENV="${2}"
|
||||||
|
shift
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
|
||||||
|
--model=* | -m=* )
|
||||||
|
export DEVICE_MODEL="${1#*=}"
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
--model* | -m* )
|
||||||
|
export DEVICE_MODEL="${2}"
|
||||||
|
shift
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
|
||||||
|
--plists )
|
||||||
|
export CREATE_PLISTS=1
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
--bootdisks )
|
||||||
|
export CREATE_QCOWS=1
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
|
||||||
|
*)
|
||||||
|
echo "Invalid option. Running with default values..."
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
done
|
||||||
|
|
||||||
|
|
||||||
|
build_mac_serial () {
|
||||||
|
export MACINFOPKG_VERSION="${MACINFOPKG_VERSION:=2.1.2}"
|
||||||
|
wget -O "${TARBALL:=./MacInfoPkg.tar.gz}" \
|
||||||
|
"https://github.com/acidanthera/MacInfoPkg/archive/${MACINFOPKG_VERSION}.tar.gz"
|
||||||
|
tar -xzvf "${TARBALL}"
|
||||||
|
cd "./MacInfoPkg-${MACINFOPKG_VERSION}/macserial" \
|
||||||
|
&& ./build.tool \
|
||||||
|
&& cd -
|
||||||
|
mv "./MacInfoPkg-${MACINFOPKG_VERSION}/macserial/bin/macserial" .
|
||||||
|
rm -f "${TARBALL}"
|
||||||
|
rm -rf "./MacInfoPkg-${MACINFOPKG_VERSION}/"
|
||||||
|
chmod +x ./macserial
|
||||||
|
stat ./macserial
|
||||||
|
}
|
||||||
|
|
||||||
|
download_vendor_mac_addresses () {
|
||||||
|
# download the MAC Address vendor list
|
||||||
|
[[ -e "${MAC_ADDRESSES_FILE:=vendor_macs.tsv}" ]] || wget -O "${MAC_ADDRESSES_FILE}" https://gitlab.com/wireshark/wireshark/-/raw/master/manuf
|
||||||
|
}
|
||||||
|
|
||||||
|
download_qcow_efi_folder () {
|
||||||
|
git clone --depth 1 https://github.com/kholia/OSX-KVM.git
|
||||||
|
cp -ra ./OSX-KVM/OpenCore-Catalina/EFI .
|
||||||
|
mkdir -p ./EFI/OC/Resources
|
||||||
|
# clone some Apple drivers
|
||||||
|
git clone --depth 1 https://github.com/acidanthera/OcBinaryData.git
|
||||||
|
# copy said drivers into EFI/OC/Resources
|
||||||
|
cp -a ./OcBinaryData/Resources/* ./EFI/OC/Resources
|
||||||
|
# EFI Shell commands
|
||||||
|
touch startup.nsh && echo 'fs0:\EFI\BOOT\BOOTx64.efi' > startup.nsh
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
generate_serial_sets () {
|
||||||
|
[[ -e ./config-nopicker-custom.plist ]] || wget https://raw.githubusercontent.com/sickcodes/Docker-OSX/custom-identity/custom/config-nopicker-custom.plist
|
||||||
|
[[ -e ./opencore-image-ng.sh ]] || wget https://raw.githubusercontent.com/sickcodes/Docker-OSX/custom-identity/custom/opencore-image-ng.sh && chmod +x opencore-image-ng.sh
|
||||||
|
mkdir -p "${OUTPUT_DIRECTORY}/envs"
|
||||||
|
export DATE_NOW="$(date +%F-%T)"
|
||||||
|
export DEVICE_MODEL="${DEVICE_MODEL:=iMacPro1,1}"
|
||||||
|
export VENDOR_REGEX="${VENDOR_REGEX:=Apple, Inc.}"
|
||||||
|
|
||||||
|
if [[ "${CSV_OUTPUT_FILENAME}" ]] || [[ "${TSV_OUTPUT_FILENAME}" ]]; then
|
||||||
|
[[ ${CSV_OUTPUT_FILENAME} ]] && export CSV_SERIAL_SETS_FILE="${CSV_OUTPUT_FILENAME}"
|
||||||
|
[[ ${TSV_OUTPUT_FILENAME} ]] && export TSV_SERIAL_SETS_FILE="${TSV_OUTPUT_FILENAME}"
|
||||||
|
else
|
||||||
|
export SERIAL_SETS_FILE="${OUTPUT_DIRECTORY}/serial_sets-${DATE_NOW}.csv"
|
||||||
|
fi
|
||||||
|
|
||||||
|
touch "${SERIAL_SETS_FILE}"
|
||||||
|
echo "Writing serial sets to ${SERIAL_SETS_FILE}"
|
||||||
|
|
||||||
|
./macserial \
|
||||||
|
--num "${SERIAL_SET_COUNT:=1}" \
|
||||||
|
--model "${DEVICE_MODEL}" \
|
||||||
|
| while IFS='\ \|\ ' read -r SERIAL BOARD_SERIAL; do
|
||||||
|
# make a uuid...
|
||||||
|
UUID="$(uuidgen)"
|
||||||
|
UUID="${UUID^^}"
|
||||||
|
|
||||||
|
# get a random vendor specific MAC address.
|
||||||
|
RANDOM_MAC_PREFIX="$(grep -e "${VENDOR_REGEX}" < "${MAC_ADDRESSES_FILE:=vendor_macs.tsv}" | sort --random-sort | head -n1)"
|
||||||
|
RANDOM_MAC_PREFIX="$(cut -d$'\t' -f1 <<< "${RANDOM_MAC_PREFIX}")"
|
||||||
|
MAC_ADDRESS="$(printf "${RANDOM_MAC_PREFIX}:%02X:%02X:%02X" $[RANDOM%256] $[RANDOM%256] $[RANDOM%256])"
|
||||||
|
|
||||||
|
# append to csv file
|
||||||
|
if [[ "${CSV_SERIAL_SETS_FILE}" ]]; then
|
||||||
|
echo "\"${DEVICE_MODEL}\",\"${SERIAL}\",\"${BOARD_SERIAL}\",\"${UUID}\",\"${MAC_ADDRESS}\"" >> "${CSV_SERIAL_SETS_FILE}"
|
||||||
|
fi
|
||||||
|
|
||||||
|
# append to tsv file
|
||||||
|
if [[ "${TSV_SERIAL_SETS_FILE}" ]]; then
|
||||||
|
printf "${DEVICE_MODEL}\t${SERIAL}\t${BOARD_SERIAL}\t${UUID}\t${MAC_ADDRESS}\n" >> "${TSV_SERIAL_SETS_FILE}"
|
||||||
|
fi
|
||||||
|
|
||||||
|
OUTPUT_ENV_FILE="${OUTPUT_ENV:-"${OUTPUT_DIRECTORY}/envs/${SERIAL}.env.sh"}"
|
||||||
|
touch "${OUTPUT_ENV_FILE}"
|
||||||
|
cat <<EOF > "${OUTPUT_ENV_FILE}"
|
||||||
|
export DEVICE_MODEL="${DEVICE_MODEL}"
|
||||||
|
export SERIAL="${SERIAL}"
|
||||||
|
export BOARD_SERIAL="${BOARD_SERIAL}"
|
||||||
|
export UUID="${UUID}"
|
||||||
|
export MAC_ADDRESS="${MAC_ADDRESS}"
|
||||||
|
EOF
|
||||||
|
|
||||||
|
# plist required for bootdisks, so create anyway.
|
||||||
|
if [[ "${CREATE_PLISTS}" ]] || [[ "${CREATE_QCOWS}" ]]; then
|
||||||
|
mkdir -p "${OUTPUT_DIRECTORY}/plists"
|
||||||
|
source "${OUTPUT_ENV_FILE}"
|
||||||
|
ROM_VALUE="${MAC_ADDRESS//\:/}"
|
||||||
|
ROM_VALUE="${ROM_VALUE,,}"
|
||||||
|
sed -e s/{{DEVICE_MODEL}}/"${DEVICE_MODEL}"/g \
|
||||||
|
-e s/{{SERIAL}}/"${SERIAL}"/g \
|
||||||
|
-e s/{{BOARD_SERIAL}}/"${BOARD_SERIAL}"/g \
|
||||||
|
-e s/{{UUID}}/"${UUID}"/g \
|
||||||
|
-e s/{{ROM}}/"${ROM}"/g \
|
||||||
|
"${PLIST_MASTER}" > "${OUTPUT_DIRECTORY}/plists/${SERIAL}.config.plist" || exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ "${CREATE_QCOWS}" ]]; then
|
||||||
|
mkdir -p "${OUTPUT_DIRECTORY}/qcows"
|
||||||
|
./opencore-image-ng.sh \
|
||||||
|
--cfg "${OUTPUT_DIRECTORY}/plists/${SERIAL}.config.plist" \
|
||||||
|
--img "${OUTPUT_QCOW:-${OUTPUT_DIRECTORY}/qcows/${SERIAL}.OpenCore-nopicker.qcow2}" || exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
done
|
||||||
|
|
||||||
|
[[ -e "${CSV_SERIAL_SETS_FILE}" ]] && \
|
||||||
|
cat <(echo "DEVICE_MODEL,SERIAL,BOARD_SERIAL,UUID,MAC_ADDRESS") "${CSV_SERIAL_SETS_FILE}"
|
||||||
|
|
||||||
|
|
||||||
|
[[ -e "${TSV_SERIAL_SETS_FILE}" ]] && \
|
||||||
|
cat <(printf "DEVICE_MODEL\tSERIAL\tBOARD_SERIAL\tUUID\tMAC_ADDRESS\n") "${TSV_SERIAL_SETS_FILE}"
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
main () {
|
||||||
|
# setting default variables if there are no options
|
||||||
|
export DEVICE_MODEL="${DEVICE_MODEL:=iMacPro1,1}"
|
||||||
|
export SERIAL_SET_COUNT="${SERIAL_SET_COUNT:=1}"
|
||||||
|
export OUTPUT_DIRECTORY="${OUTPUT_DIRECTORY:=.}"
|
||||||
|
cat <<EOF
|
||||||
|
DEVICE_MODEL: ${DEVICE_MODEL}
|
||||||
|
SERIAL_SET_COUNT: ${SERIAL_SET_COUNT}
|
||||||
|
OUTPUT_DIRECTORY: ${OUTPUT_DIRECTORY}
|
||||||
|
EOF
|
||||||
|
[[ -d "${OUTPUT_DIRECTORY}" ]] || mkdir -p "${OUTPUT_DIRECTORY}"
|
||||||
|
[[ -e ./macserial ]] || build_mac_serial
|
||||||
|
download_vendor_mac_addresses
|
||||||
|
download_qcow_efi_folder
|
||||||
|
generate_serial_sets
|
||||||
|
echo "${SERIAL_SETS_FILE}"
|
||||||
|
}
|
||||||
|
|
||||||
|
main
|
||||||
|
|
@ -0,0 +1,164 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
|
# https://github.com/kraxel/imagefish
|
||||||
|
|
||||||
|
######################################################################
|
||||||
|
# defaults
|
||||||
|
|
||||||
|
iso=""
|
||||||
|
img=""
|
||||||
|
cfg=""
|
||||||
|
|
||||||
|
######################################################################
|
||||||
|
# create work dir
|
||||||
|
|
||||||
|
function msg() {
|
||||||
|
local txt="$1"
|
||||||
|
local bold="\x1b[1m"
|
||||||
|
local normal="\x1b[0m"
|
||||||
|
echo -e "${bold}### ${txt}${normal}"
|
||||||
|
}
|
||||||
|
|
||||||
|
function do_cleanup() {
|
||||||
|
msg "cleaning up ..."
|
||||||
|
if test "$GUESTFISH_PID" != ""; then
|
||||||
|
guestfish --remote -- exit >/dev/null 2>&1 || true
|
||||||
|
fi
|
||||||
|
sudo rm -rf "$WORK"
|
||||||
|
}
|
||||||
|
|
||||||
|
WORK="${TMPDIR-/var/tmp}/${0##*/}-$$"
|
||||||
|
mkdir "$WORK" || exit 1
|
||||||
|
trap 'do_cleanup' EXIT
|
||||||
|
|
||||||
|
BASE="$(dirname $0)"
|
||||||
|
|
||||||
|
######################################################################
|
||||||
|
# parse args
|
||||||
|
|
||||||
|
function print_help() {
|
||||||
|
cat <<EOF
|
||||||
|
usage: $0 [ options ]
|
||||||
|
options:
|
||||||
|
--iso <iso-image>
|
||||||
|
--img <disk-image>
|
||||||
|
--cfg <clover-config>
|
||||||
|
EOF
|
||||||
|
}
|
||||||
|
|
||||||
|
while test "$1" != ""; do
|
||||||
|
case "$1" in
|
||||||
|
--iso)
|
||||||
|
iso="$2"
|
||||||
|
shift; shift
|
||||||
|
;;
|
||||||
|
--img)
|
||||||
|
img="$2"
|
||||||
|
shift; shift
|
||||||
|
;;
|
||||||
|
--cfg)
|
||||||
|
cfg="$2"
|
||||||
|
shift; shift
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
done
|
||||||
|
|
||||||
|
######################################################################
|
||||||
|
# guestfish script helpers
|
||||||
|
|
||||||
|
function fish() {
|
||||||
|
echo "#" "$@"
|
||||||
|
guestfish --remote -- "$@" || exit 1
|
||||||
|
}
|
||||||
|
|
||||||
|
function fish_init() {
|
||||||
|
local format
|
||||||
|
|
||||||
|
case "$img" in
|
||||||
|
*.raw) format="raw" ;;
|
||||||
|
*) format="qcow2";;
|
||||||
|
esac
|
||||||
|
|
||||||
|
msg "creating and adding disk image"
|
||||||
|
fish disk-create $img $format 384M
|
||||||
|
fish add $img
|
||||||
|
fish run
|
||||||
|
}
|
||||||
|
|
||||||
|
function fish_fini() {
|
||||||
|
fish umount-all
|
||||||
|
}
|
||||||
|
|
||||||
|
# disabled by sick.codes to allow unattended image overwrites
|
||||||
|
######################################################################
|
||||||
|
# sanity checks
|
||||||
|
|
||||||
|
# if test ! -f "$cfg"; then
|
||||||
|
# echo "ERROR: cfg not found: $cfg"
|
||||||
|
# exit 1
|
||||||
|
# fi
|
||||||
|
# if test -f "$img"; then
|
||||||
|
# if test "$allow_override" = "yes"; then
|
||||||
|
# rm -f "$img"
|
||||||
|
# else
|
||||||
|
# echo "ERROR: image exists: $img"
|
||||||
|
# exit 1
|
||||||
|
# fi
|
||||||
|
# fi
|
||||||
|
|
||||||
|
######################################################################
|
||||||
|
# go!
|
||||||
|
|
||||||
|
msg "copy files from local folder"
|
||||||
|
BASE="$(dirname $0)"
|
||||||
|
cp -a $BASE/EFI $WORK
|
||||||
|
find "$WORK"
|
||||||
|
|
||||||
|
#msg "[debug] list drivers in EFI/OC"
|
||||||
|
#(cd $WORK/EFI/OC; find driver* -print)
|
||||||
|
|
||||||
|
export LIBGUESTFS_BACKEND=direct
|
||||||
|
eval $(guestfish --listen)
|
||||||
|
if test "$GUESTFISH_PID" = ""; then
|
||||||
|
echo "ERROR: starting guestfish failed"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
fish_init
|
||||||
|
|
||||||
|
msg "partition disk image"
|
||||||
|
fish part-init /dev/sda gpt
|
||||||
|
fish part-add /dev/sda p 2048 300000
|
||||||
|
fish part-add /dev/sda p 302048 -2048
|
||||||
|
fish part-set-gpt-type /dev/sda 1 C12A7328-F81F-11D2-BA4B-00A0C93EC93B
|
||||||
|
fish part-set-bootable /dev/sda 1 true
|
||||||
|
fish mkfs vfat /dev/sda1 label:EFI
|
||||||
|
fish mkfs vfat /dev/sda2 label:OpenCoreBoo
|
||||||
|
fish mount /dev/sda2 /
|
||||||
|
fish mkdir /ESP
|
||||||
|
fish mount /dev/sda1 /ESP
|
||||||
|
|
||||||
|
msg "copy files to disk image"
|
||||||
|
cp -v "$cfg" $WORK/config.plist
|
||||||
|
fish mkdir /ESP/EFI
|
||||||
|
fish mkdir /ESP/EFI/OC
|
||||||
|
fish mkdir /ESP/EFI/OC/Kexts
|
||||||
|
fish mkdir /ESP/EFI/OC/ACPI
|
||||||
|
fish mkdir /ESP/EFI/OC/Resources
|
||||||
|
fish mkdir /ESP/EFI/OC/Tools
|
||||||
|
fish copy-in $WORK/EFI/BOOT /ESP/EFI
|
||||||
|
fish copy-in $WORK/EFI/OC/OpenCore.efi /ESP/EFI/OC
|
||||||
|
fish copy-in $WORK/EFI/OC/Drivers /ESP/EFI/OC/
|
||||||
|
fish copy-in $WORK/EFI/OC/Kexts /ESP/EFI/OC/
|
||||||
|
fish copy-in $WORK/EFI/OC/ACPI /ESP/EFI/OC/
|
||||||
|
fish copy-in $WORK/EFI/OC/Resources /ESP/EFI/OC/
|
||||||
|
fish copy-in $WORK/EFI/OC/Tools /ESP/EFI/OC/
|
||||||
|
|
||||||
|
# Note
|
||||||
|
fish copy-in startup.nsh /
|
||||||
|
|
||||||
|
BASE="$(dirname $0)"
|
||||||
|
fish copy-in "$WORK/config.plist" /ESP/EFI/OC/
|
||||||
|
|
||||||
|
fish find /ESP/
|
||||||
|
fish_fini
|
Loading…
Reference in new issue