diff options
Diffstat (limited to 'custom')
| -rw-r--r-- | custom/config-nopicker-custom.plist | 885 | ||||
| -rwxr-xr-x | custom/generate-specific-bootdisk.sh | 184 | ||||
| -rwxr-xr-x | custom/generate-unique-machine-values.sh | 287 | ||||
| -rwxr-xr-x | custom/opencore-image-ng.sh | 164 |
4 files changed, 1520 insertions, 0 deletions
diff --git a/custom/config-nopicker-custom.plist b/custom/config-nopicker-custom.plist new file mode 100644 index 0000000..6166234 --- /dev/null +++ b/custom/config-nopicker-custom.plist @@ -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> diff --git a/custom/generate-specific-bootdisk.sh b/custom/generate-specific-bootdisk.sh new file mode 100755 index 0000000..e87bf3c --- /dev/null +++ b/custom/generate-specific-bootdisk.sh @@ -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 + diff --git a/custom/generate-unique-machine-values.sh b/custom/generate-unique-machine-values.sh new file mode 100755 index 0000000..4b2409a --- /dev/null +++ b/custom/generate-unique-machine-values.sh @@ -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 + diff --git a/custom/opencore-image-ng.sh b/custom/opencore-image-ng.sh new file mode 100755 index 0000000..56eaa45 --- /dev/null +++ b/custom/opencore-image-ng.sh @@ -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 |