[
  {
    "path": ".github/ISSUE_TEMPLATE/config.yml",
    "content": "blank_issues_enabled: false\ncontact_links:\n  - name: Discussions\n    url: https://github.com/LongQT-sea/OpenCore-ISO/discussions\n    about: For general questions, tips sharing, and community help\n  - name: Dortania OpenCore Guide\n    url: https://dortania.github.io/OpenCore-Install-Guide/\n    about: Comprehensive OpenCore documentation and troubleshooting\n  - name: Proxmox VE Forum\n    url: https://forum.proxmox.com/\n    about: For Proxmox-specific questions and issues\n  - name: Intel iGPU Passthrough Guide\n    url: https://github.com/LongQT-sea/intel-igpu-passthru\n    about: Guide for Intel iGPU passthrough configuration"
  },
  {
    "path": ".github/ISSUE_TEMPLATE/feature_request.yml",
    "content": "name: Feature Request\ndescription: Suggest a new feature or improvement for OpenCore-ISO\ntitle: \"[FEATURE] \"\nlabels: [\"enhancement\"]\n\nbody:\n  - type: markdown\n    attributes:\n      value: |\n        ## Thanks for suggesting a feature for OpenCore-ISO!\n        Your ideas help make this project better for everyone.\n        \n        **Have you starred this repo yet?** Show your support by giving it a star!\n\n  - type: checkboxes\n    attributes:\n      label: Prerequisites\n      options:\n        - label: I searched existing issues - this hasn't been requested\n          required: true\n        - label: This relates to OpenCore-ISO specifically\n          required: true\n        - label: I've starred the repo ⭐ (or will star it later!)\n          required: false\n\n  - type: textarea\n    attributes:\n      label: Feature Description\n      description: What would you like to see?\n    validations:\n      required: true\n\n  - type: textarea\n    attributes:\n      label: Problem It Solves\n      description: What issue does this address?\n    validations:\n      required: true\n\n  - type: textarea\n    attributes:\n      label: Proposed Implementation\n      description: How should this work?\n    validations:\n      required: false\n\n  - type: textarea\n    attributes:\n      label: Additional Context\n      description: Any other details or alternatives?\n    validations:\n      required: false\n\n  - type: checkboxes\n    attributes:\n      label: I can help with\n      options:\n        - label: Testing\n        - label: Documentation\n        - label: Implementation"
  },
  {
    "path": ".github/ISSUE_TEMPLATE/help_support.yml",
    "content": "name: Get Help & Support\ndescription: Get help with OpenCore-ISO setup or configuration\ntitle: \"[HELP] \"\nlabels: [\"question\", \"help wanted\"]\n\nbody:\nbody:\n  - type: markdown\n    attributes:\n      value: |\n        ## Need help with OpenCore-ISO?\n        Before asking for help, please check:\n        - The [README](https://github.com/LongQT-sea/OpenCore-ISO#readme) and its troubleshooting section\n        - [Existing issues](https://github.com/LongQT-sea/OpenCore-ISO/issues) for similar problems\n        - [Discussions](https://github.com/LongQT-sea/OpenCore-ISO/discussions) for community solutions\n\n        **Have you starred this repo yet?** Show your support by giving it a star!\n\n  - type: checkboxes\n    attributes:\n      label: Prerequisites\n      options:\n        - label: I have read the [README.md](https://github.com/LongQT-sea/OpenCore-ISO?#about)\n          required: true\n        - label: I have searched existing issues and discussions\n          required: true\n        - label: I've starred the repo ⭐ (or will star it later!)\n          required: false\n\n  - type: dropdown\n    attributes:\n      label: macOS Version\n      options:\n        - macOS 26 Tahoe\n        - macOS 15 Sequoia\n        - macOS 14 Sonoma\n        - macOS 13 Ventura\n        - macOS 12 Monterey\n        - macOS 11 Big Sur\n        - macOS 10.15 Catalina\n        - macOS 10.14 Mojave\n        - Other/Legacy (specify below)\n    validations:\n      required: true\n\n  - type: textarea\n    attributes:\n      label: System Info\n      description: Host OS and hardware specs info\n      placeholder: |\n        Host OS: e.g. Proxmox, QEMU/KVM, UTM, TrueNAS, Unraid\n        Mainboard: Z490\n        CPU: i7-10700K\n        RAM: 32GB\n        dGPU: None\n      render: shell\n    validations:\n      required: true\n\n  - type: textarea\n    attributes:\n      label: VM Config or QEMU cmdline\n      description: Proxmox VM config (`qm config VMID`) or QEMU command line used to start the VM\n      placeholder: |\n        # qm config VMID\n        bios: ovmf\n        machine: q35\n        cpu: Skylake-Client-v4\n        \n        # QEMU cmdline\n        /usr/bin/qemu-system-x86_64 -accel kvm -machine q35 -m 4096 \\\n          -cpu Skylake-Client-noTSX-IBRS,vendor=GenuineIntel \\\n          -usb -device usb-tablet -device usb-kbd \\\n      render: shell\n    validations:\n      required: true\n\n  - type: textarea\n    attributes:\n      label: Problem Description\n      description: What's the issue?\n    validations:\n      required: true\n\n  - type: textarea\n    attributes:\n      label: What You've Tried\n      description: Steps taken to resolve\n    validations:\n      required: false\n\n  - type: textarea\n    attributes:\n      label: Additional Context\n      description: Screenshots or other details (relevant errors or logs)\n    validations:\n      required: false"
  },
  {
    "path": ".github/workflows/build-iso.yml",
    "content": "name: Build ISO\n\non:\n  workflow_dispatch:\n    inputs:\n      release_tag:\n        description: 'Optional: Tag the build to upload it to Releases'\n        required: false\n        type: string\n\njobs:\n  build-opencore-iso:\n    runs-on: macos-latest\n\n    steps:\n      - name: Checkout repository\n        uses: actions/checkout@v6\n        \n      - name: Install xorriso\n        run: |\n          echo \"Installing xorriso ...\"\n          brew install xorriso\n\n      - name: Download ProperTree and GenSMBIOS\n        run: |\n          git clone --depth 1 https://github.com/corpnewt/GenSMBIOS\n          curl -OL https://github.com/LongQT-sea/OpenCore-ISO/releases/download/v0.2/ProperTree.zip\n          unzip -qq ProperTree.zip && rm ProperTree.zip && rm -rf GenSMBIOS/.git\n\n      - name: Make OpenCore-ISO\n        run: |\n          echo \"Making ISO ...\"\n          bash Make_ISO.command\n\n      - name: Upload artifact\n        uses: actions/upload-artifact@v7\n        with:\n          name: OpenCore-ISO\n          path: ~/Desktop/LongQT-OpenCore*.iso\n\n      - name: Create Release\n        if: github.event.inputs.release_tag != ''\n        env:\n          GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}\n        run: |\n          tag=${{ github.event.inputs.release_tag }}\n          title=\"$tag\"\n          \n          cat > release_notes.md << 'EOF'\n          > [!Tip]\n          > For macOS Installer ISO and Recovery ISO:\n          > https://github.com/LongQT-sea/macos-iso-builder\n          \n          > [!CAUTION]\n          > These iso are **true CD/DVD ISO image**. Do **NOT** modify VM config to change **`media=cdrom`** to **`media=disk`**.\n          EOF\n          \n          gh release create \"$tag\" \\\n            --title \"$title\" \\\n            --notes-file release_notes.md \\\n            ~/Desktop/LongQT-OpenCore*.iso\n"
  },
  {
    "path": ".github/workflows/stale.yml",
    "content": "name: Close stale issues\n\non:\n  schedule:\n    - cron: '0 0 * * *' # runs daily at midnight\n\njobs:\n  stale:\n    runs-on: ubuntu-latest\n    steps:\n      - uses: actions/stale@v9\n        with:\n          days-before-stale: 30\n          days-before-close: 7\n          close-issue-reason: 'completed'\n          stale-issue-message: 'This issue has been automatically marked as stale due to inactivity.'\n          close-issue-message: 'Closing this issue due to prolonged inactivity.'\n          exempt-issue-labels: 'keep-open'\n"
  },
  {
    "path": ".gitignore",
    "content": ".DS_Store\n*.pkg\n*.dmg\nProperTree*\nGenSMBIOS*\n"
  },
  {
    "path": "Create_Recovery_ISO.command",
    "content": "#!/bin/bash\n# Copyright (c) 2024-2025, LongQT-sea\n# macOS Recovery ISO Creator\n# Downloads macOS recovery images from Apple and converts them to bootable DVD ISO files\n\nset -e\n\n# Color codes for output\nRED='\\033[0;31m'\nGREEN='\\033[0;32m'\nYELLOW='\\033[1;33m'\nNC='\\033[0m' # No Color\n\n# Check if running as root, if not, re-execute with sudo\nif [ \"$EUID\" -ne 0 ]; then\n    echo \"\"\n    echo -e \"${YELLOW}[INFO]${NC} Administrator privileges required...\"\n    exec sudo \"$0\" \"$@\"\n    exit\nfi\n\n# Function to get version info by key\nget_version_info() {\n    local key=$1\n    case $key in\n        high_sierra) echo \"Mac-7BA5B2D9E42DDD94:00000000000J80300:High_Sierra:\" ;;\n        mojave) echo \"Mac-7BA5B2DFE22DDD8C:00000000000KXPG00:Mojave:\" ;;\n        catalina) echo \"Mac-CFF7D910A743CAAF:00000000000PHCD00:Catalina:\" ;;\n        big_sur) echo \"Mac-2BD1B31983FE1663:00000000000000000:Big_Sur:\" ;;\n        monterey) echo \"Mac-E43C1C25D4880AD6:00000000000000000:Monterey:\" ;;\n        ventura) echo \"Mac-B4831CEBD52A0C4C:00000000000000000:Ventura:\" ;;\n        sonoma) echo \"Mac-827FAC58A8FDFA22:00000000000000000:Sonoma:\" ;;\n        sequoia) echo \"Mac-7BA5B2D9E42DDD94:00000000000000000:Sequoia:\" ;;\n        tahoe) echo \"Mac-CFF7D910A743CAAF:00000000000000000:Tahoe:latest\" ;;\n        *) echo \"\" ;;\n    esac\n}\n\n# Function to print colored messages\nprint_info() {\n    echo -e \"${GREEN}[INFO]${NC} $1\"\n}\n\nprint_error() {\n    echo -e \"${RED}[ERROR]${NC} $1\"\n}\n\nprint_warning() {\n    echo -e \"${YELLOW}[WARNING]${NC} $1\"\n}\n\n# Function to check if Python 3 is available\ncheck_python() {\n    if ! command -v python3 &> /dev/null; then\n        print_error \"Python3 is not installed on your system.\"\n        echo \"Please install Python3:\"\n        echo \"Download it from: https://www.python.org/downloads/\"\n        echo \"Or use Install_Python3.command to do it automatically\"\n        exit 1\n    fi\n}\n\n# Function to download macrecovery.py\ndownload_macrecovery() {\n    local url=\"https://raw.githubusercontent.com/acidanthera/OpenCorePkg/master/Utilities/macrecovery/macrecovery.py\"\n    \n    if [ -f \"macrecovery.py\" ]; then\n        rm -f macrecovery.py\n    fi\n    \n    print_info \"Downloading macrecovery.py from acidanthera/OpenCorePkg...\"\n    if curl -sL \"$url\" -o macrecovery.py; then\n        chmod +x macrecovery.py\n    else\n        print_error \"Failed to download macrecovery.py\"\n        exit 1\n    fi\n}\n\n# Function to cleanup\ncleanup_recovery() {\n    if [ -d \"com.apple.recovery.boot\" ]; then\n        print_info \"Cleaning up...\"\n        rm -rf com.apple.recovery.boot\n        rm -rf macrecovery.py\n    fi\n}\n\n# Function to download macOS recovery\ndownload_recovery() {\n    local board_id=$1\n    local model=$2\n    local os_flag=$3\n    \n    print_info \"Downloading macOS recovery...\"\n    print_info \"Board ID: $board_id\"\n    \n    if [ -n \"$os_flag\" ]; then\n        python3 macrecovery.py -b \"$board_id\" -m \"$model\" -os \"$os_flag\" download\n    else\n        python3 macrecovery.py -b \"$board_id\" -m \"$model\" download\n    fi\n    \n    # Check if BaseSystem.dmg was downloaded (all versions 10.13+ use BaseSystem.dmg)\n    if [ ! -f \"com.apple.recovery.boot/BaseSystem.dmg\" ]; then\n        print_error \"Failed to download recovery image\"\n        exit 1\n    fi\n    \n    print_info \"Recovery image downloaded successfully\"\n}\n\n# Function to create ISO\ncreate_iso() {\n    local version_name=$1\n    local output_path=\"$HOME/Desktop/macOS_${version_name}_Recovery.iso\"\n    local recovery_path=\"com.apple.recovery.boot/BaseSystem.dmg\"\n    \n    # Check if the recovery file exists\n    if [ ! -f \"$recovery_path\" ]; then\n        print_error \"Recovery image not found at: $recovery_path\"\n        # List available files for debugging\n        print_info \"Available files in com.apple.recovery.boot/:\"\n        ls -la com.apple.recovery.boot/\n        exit 1\n    fi\n    \n    print_info \"Creating bootable ISO...\"\n\n    # All versions 10.13+ use -hfs -udf options\n    hdiutil makehybrid -ov -hfs -udf \\\n        -default-volume-name \"${version_name}_Recovery\" \\\n        -o \"$output_path\" \\\n        \"$recovery_path\"\n    \n    if [ -f \"$output_path\" ]; then\n        print_info \"ISO created successfully at: $output_path\"\n    else\n        print_error \"Failed to create ISO\"\n        exit 1\n    fi\n}\n\n# Function to display available versions\nshow_versions() {\n    echo \"\"\n    echo \"Available macOS versions:\"\n    echo \"=========================\"\n    echo \"  1. High Sierra (10.13)\"\n    echo \"  2. Mojave (10.14)\"\n    echo \"  3. Catalina (10.15)\"\n    echo \"  4. Big Sur (11)\"\n    echo \"  5. Monterey (12)\"\n    echo \"  6. Ventura (13)\"\n    echo \"  7. Sonoma (14)\"\n    echo \"  8. Sequoia (15)\"\n    echo \"  9. Tahoe (Latest)\"\n    echo \"\"\n}\n\n# Function to process version selection\nprocess_version() {\n    local version=$1\n    \n    case $version in\n        1|high_sierra)\n            key=\"high_sierra\"\n            ;;\n        2|mojave)\n            key=\"mojave\"\n            ;;\n        3|catalina)\n            key=\"catalina\"\n            ;;\n        4|big_sur)\n            key=\"big_sur\"\n            ;;\n        5|monterey)\n            key=\"monterey\"\n            ;;\n        6|ventura)\n            key=\"ventura\"\n            ;;\n        7|sonoma)\n            key=\"sonoma\"\n            ;;\n        8|sequoia)\n            key=\"sequoia\"\n            ;;\n        9|tahoe)\n            key=\"tahoe\"\n            ;;\n        *)\n            print_error \"Invalid version selection\"\n            exit 1\n            ;;\n    esac\n    \n    local version_info=\"$(get_version_info \"$key\")\"\n    \n    if [ -z \"$version_info\" ]; then\n        print_error \"Invalid version selection\"\n        exit 1\n    fi\n    IFS=':' read -r board_id model version_name os_flag <<< \"$version_info\"\n    \n    print_info \"Selected: $version_name\"\n    \n    cleanup_recovery\n    download_recovery \"$board_id\" \"$model\" \"$os_flag\"\n    create_iso \"$version_name\"\n    cleanup_recovery\n}\n\n# Function to show usage\nshow_usage() {\n    cat << EOF\nUsage: $0 [OPTIONS]\n\nOptions:\n  -v, --version <number|name>  macOS version to download (1-9 or name)\n  -h, --help                   Show this help message\n\nExamples:\n  $0                           # Interactive mode\n  $0 -v 3                      # Download Catalina\n  $0 -v catalina               # Download Catalina by name\n  $0 -v sonoma                 # Download Sonoma by name\n\nEOF\n    show_versions\n}\n\n# Main script\nmain() {\n    print_info \"macOS Recovery ISO Creator\"\n    print_info \"==========================\"\n    \n    # Check for macOS\n    if [[ \"$OSTYPE\" != \"darwin\"* ]]; then\n        print_error \"This script must be run on macOS\"\n        exit 1\n    fi\n    \n    # Check Python\n    check_python\n    \n    # Download macrecovery.py\n    download_macrecovery\n    \n    # Parse arguments\n    if [ $# -eq 0 ]; then\n        # Interactive mode\n        show_versions\n        read -p \"Select version (1-9): \" version_choice\n        echo \"\"\n        process_version \"$version_choice\"\n    else\n        # Non-interactive mode\n        while [[ $# -gt 0 ]]; do\n            case $1 in\n                -v|--version)\n                    process_version \"$2\"\n                    shift 2\n                    ;;\n                -h|--help)\n                    show_usage\n                    exit 0\n                    ;;\n                *)\n                    print_error \"Unknown option: $1\"\n                    show_usage\n                    exit 1\n                    ;;\n            esac\n        done\n    fi\n}\n\n# Run main function\nmain \"$@\"\n"
  },
  {
    "path": "Create_macOS_ISO.command",
    "content": "#!/usr/bin/env bash\n# Simple launcher for mkmaciso\nset -e\nMKMACISO_URL=\"https://raw.githubusercontent.com/LongQT-sea/mkmaciso/main/mkmaciso\"\nLOCAL_BIN=\"$HOME/.local/bin\"\nTARGET=\"$LOCAL_BIN/mkmaciso\"\nEXPORT_LINE='export PATH=\"$HOME/.local/bin:$PATH\"'\n\n# Check kernel version and set curl options accordingly\nKERNEL_VERSION=$(uname -r | cut -d. -f1)\nif [[ \"$KERNEL_VERSION\" -ge 15 ]]; then\n    CURL_OPTS=\"-fsSL\"\nelse\n    CURL_OPTS=\"-fsSL --insecure\"\nfi\n\n# Install mkmaciso if missing\nif [[ ! -f \"$TARGET\" ]]; then\n    mkdir -p \"$LOCAL_BIN\"\n    curl $CURL_OPTS \"$MKMACISO_URL\" -o \"$TARGET\"\n    chmod +x \"$TARGET\"\nfi\n# Ensure ~/.local/bin is in PATH\nif [[ \":$PATH:\" != *\":$LOCAL_BIN:\"* ]]; then\n    case \"$SHELL\" in\n      */zsh)  RC=\"$HOME/.zprofile\" ;;\n      */bash) RC=\"$HOME/.bash_profile\" ;;\n      *)      RC=\"$HOME/.profile\" ;;\n    esac\n    \n    touch \"$RC\"\n    grep -qxF \"$EXPORT_LINE\" \"$RC\" || printf '\\n%s\\n' \"$EXPORT_LINE\" >> \"$RC\"\nfi\nexec \"$TARGET\" \"$@\""
  },
  {
    "path": "Disable_GateKeeper.command",
    "content": "#!/bin/bash\n\n# Color codes\nRED='\\033[0;31m'\nGREEN='\\033[0;32m'\nYELLOW='\\033[1;33m'\nNC='\\033[0m'\n\nclear\necho -e \"${GREEN}=== Disable GateKeeper Script ===${NC}\"\necho \"\"\necho -e \"${YELLOW}Administrator privileges required.${NC}\"\n\nsudo spctl --master-disable\n\necho \"\"\necho \"────────────────────────────────────\"\necho \"Press Command-W to close this window\"\necho \"────────────────────────────────────\"\n"
  },
  {
    "path": "EFI_DEBUG/EFI/BOOT/.contentFlavour",
    "content": "OpenCore"
  },
  {
    "path": "EFI_DEBUG/EFI/BOOT/.contentVisibility",
    "content": "Disabled"
  },
  {
    "path": "EFI_DEBUG/EFI/OC/.contentFlavour",
    "content": "OpenCore"
  },
  {
    "path": "EFI_DEBUG/EFI/OC/.contentVisibility",
    "content": "Disabled"
  },
  {
    "path": "EFI_DEBUG/EFI/OC/Kexts/AppleMCEReporterDisabler.kext/Contents/Info.plist",
    "content": "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<!DOCTYPE plist PUBLIC \"-//Apple//DTD PLIST 1.0//EN\" \"http://www.apple.com/DTDs/PropertyList-1.0.dtd\">\n<plist version=\"1.0\">\n<dict>\n\t<key>CFBundleDevelopmentRegion</key>\n\t<string>English</string>\n\t<key>CFBundleGetInfoString</key>\n\t<string>AppleIntelMCEReporter Disabler 1.0, © 2019 by XLNC. All rights reserved.</string>\n\t<key>CFBundleIdentifier</key>\n\t<string>org.xlnc.disabler.MCEReporter</string>\n\t<key>CFBundleInfoDictionaryVersion</key>\n\t<string>6.0</string>\n\t<key>CFBundleName</key>\n\t<string>DisableAppleIntelMCEReporter</string>\n\t<key>CFBundlePackageType</key>\n\t<string>KEXT</string>\n\t<key>CFBundleVersion</key>\n\t<string>1.2</string>\n\t<key>IOKitPersonalities</key>\n\t<dict>\n\t\t<key>DisableMCEInterruptController</key>\n\t\t<dict>\n\t\t\t<key>CFBundleIdentifier</key>\n\t\t\t<string>com.apple.driver.AppleIntelMCEReporter</string>\n\t\t\t<key>IOClass</key>\n\t\t\t<string>IOService</string>\n\t\t\t<key>IOMatchCategory</key>\n\t\t\t<string>AppleIntelMCEInterruptController</string>\n\t\t\t<key>IOProbeScore</key>\n\t\t\t<integer>5000</integer>\n\t\t\t<key>IOPropertyMatch</key>\n\t\t\t<array>\n\t\t\t\t<dict>\n\t\t\t\t\t<key>board-id</key>\n\t\t\t\t\t<string>Mac-F60DEB81FF30ACF6</string>\n\t\t\t\t</dict>\n\t\t\t\t<dict>\n\t\t\t\t\t<key>board-id</key>\n\t\t\t\t\t<string>Mac-7BA5B2D9E42DDD94</string>\n\t\t\t\t</dict>\n\t\t\t\t<dict>\n\t\t\t\t\t<key>board-id</key>\n\t\t\t\t\t<string>Mac-27AD2F918AE68F61</string>\n\t\t\t\t</dict>\n\t\t\t</array>\n\t\t\t<key>IOProviderClass</key>\n\t\t\t<string>IOPlatformExpertDevice</string>\n\t\t</dict>\n\t\t<key>DisableMCEReporter</key>\n\t\t<dict>\n\t\t\t<key>CFBundleIdentifier</key>\n\t\t\t<string>com.apple.driver.AppleIntelMCEReporter</string>\n\t\t\t<key>IOClass</key>\n\t\t\t<string>IOService</string>\n\t\t\t<key>IOMatchCategory</key>\n\t\t\t<string>AppleIntelMCEReporter</string>\n\t\t\t<key>IOProbeScore</key>\n\t\t\t<integer>5000</integer>\n\t\t\t<key>IOProviderClass</key>\n\t\t\t<string>AppleIntelMCEInterruptNub</string>\n\t\t</dict>\n\t</dict>\n\t<key>OSBundleRequired</key>\n\t<string>Root</string>\n</dict>\n</plist>\n"
  },
  {
    "path": "EFI_DEBUG/EFI/OC/Kexts/Lilu.kext/Contents/Info.plist",
    "content": "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<!DOCTYPE plist PUBLIC \"-//Apple//DTD PLIST 1.0//EN\" \"http://www.apple.com/DTDs/PropertyList-1.0.dtd\">\n<plist version=\"1.0\">\n<dict>\n\t<key>BuildMachineOSBuild</key>\n\t<string>23H626</string>\n\t<key>CFBundleDevelopmentRegion</key>\n\t<string>en</string>\n\t<key>CFBundleExecutable</key>\n\t<string>Lilu</string>\n\t<key>CFBundleIdentifier</key>\n\t<string>as.vit9696.Lilu</string>\n\t<key>CFBundleInfoDictionaryVersion</key>\n\t<string>6.0</string>\n\t<key>CFBundleName</key>\n\t<string>Lilu</string>\n\t<key>CFBundlePackageType</key>\n\t<string>KEXT</string>\n\t<key>CFBundleShortVersionString</key>\n\t<string>1.7.1</string>\n\t<key>CFBundleSignature</key>\n\t<string>????</string>\n\t<key>CFBundleSupportedPlatforms</key>\n\t<array>\n\t\t<string>MacOSX</string>\n\t</array>\n\t<key>CFBundleVersion</key>\n\t<string>1.7.1</string>\n\t<key>DTCompiler</key>\n\t<string>com.apple.compilers.llvm.clang.1_0</string>\n\t<key>DTPlatformBuild</key>\n\t<string></string>\n\t<key>DTPlatformName</key>\n\t<string>macosx</string>\n\t<key>DTPlatformVersion</key>\n\t<string>14.2</string>\n\t<key>DTSDKBuild</key>\n\t<string>23C53</string>\n\t<key>DTSDKName</key>\n\t<string>macosx14.2</string>\n\t<key>DTXcode</key>\n\t<string>1520</string>\n\t<key>DTXcodeBuild</key>\n\t<string>15C500b</string>\n\t<key>IOKitPersonalities</key>\n\t<dict>\n\t\t<key>as.vit9696.Lilu</key>\n\t\t<dict>\n\t\t\t<key>CFBundleIdentifier</key>\n\t\t\t<string>as.vit9696.Lilu</string>\n\t\t\t<key>IOClass</key>\n\t\t\t<string>Lilu</string>\n\t\t\t<key>IOMatchCategory</key>\n\t\t\t<string>Lilu</string>\n\t\t\t<key>IOProviderClass</key>\n\t\t\t<string>IOResources</string>\n\t\t\t<key>IOResourceMatch</key>\n\t\t\t<string>IOBSD</string>\n\t\t</dict>\n\t</dict>\n\t<key>LSMinimumSystemVersion</key>\n\t<string>10.6</string>\n\t<key>NSHumanReadableCopyright</key>\n\t<string>Copyright © 2016-2020 vit9696. All rights reserved.</string>\n\t<key>OSBundleCompatibleVersion</key>\n\t<string>1.2.0</string>\n\t<key>OSBundleLibraries</key>\n\t<dict>\n\t\t<key>com.apple.kernel.6.0</key>\n\t\t<string>7.9.9</string>\n\t\t<key>com.apple.kpi.bsd</key>\n\t\t<string>8.0.0</string>\n\t\t<key>com.apple.kpi.iokit</key>\n\t\t<string>8.0.0</string>\n\t\t<key>com.apple.kpi.libkern</key>\n\t\t<string>8.0.0</string>\n\t\t<key>com.apple.kpi.mach</key>\n\t\t<string>8.0.0</string>\n\t\t<key>com.apple.kpi.unsupported</key>\n\t\t<string>8.0.0</string>\n\t</dict>\n\t<key>OSBundleLibraries_x86_64</key>\n\t<dict>\n\t\t<key>com.apple.kpi.bsd</key>\n\t\t<string>10.0.0</string>\n\t\t<key>com.apple.kpi.dsep</key>\n\t\t<string>10.0.0</string>\n\t\t<key>com.apple.kpi.iokit</key>\n\t\t<string>10.0.0</string>\n\t\t<key>com.apple.kpi.libkern</key>\n\t\t<string>10.0.0</string>\n\t\t<key>com.apple.kpi.mach</key>\n\t\t<string>10.0.0</string>\n\t\t<key>com.apple.kpi.unsupported</key>\n\t\t<string>10.0.0</string>\n\t</dict>\n\t<key>OSBundleRequired</key>\n\t<string>Root</string>\n</dict>\n</plist>\n"
  },
  {
    "path": "EFI_DEBUG/EFI/OC/Kexts/Lilu.kext/Contents/Resources/Headers/capstone/arm.h",
    "content": "#ifndef CAPSTONE_ARM_H\n#define CAPSTONE_ARM_H\n\n/* Capstone Disassembly Engine */\n/* By Nguyen Anh Quynh <aquynh@gmail.com>, 2013-2014 */\n\n#ifdef __cplusplus\nextern \"C\" {\n#endif\n\n#if !defined(_MSC_VER) || !defined(_KERNEL_MODE)\n#include <stdint.h>\n#endif\n\n#include \"platform.h\"\n\n#ifdef _MSC_VER\n#pragma warning(disable:4201)\n#endif\n\n//> ARM shift type\ntypedef enum arm_shifter {\n\tARM_SFT_INVALID = 0,\n\tARM_SFT_ASR,\t// shift with immediate const\n\tARM_SFT_LSL,\t// shift with immediate const\n\tARM_SFT_LSR,\t// shift with immediate const\n\tARM_SFT_ROR,\t// shift with immediate const\n\tARM_SFT_RRX,\t// shift with immediate const\n\tARM_SFT_ASR_REG,\t// shift with register\n\tARM_SFT_LSL_REG,\t// shift with register\n\tARM_SFT_LSR_REG,\t// shift with register\n\tARM_SFT_ROR_REG,\t// shift with register\n\tARM_SFT_RRX_REG,\t// shift with register\n} arm_shifter;\n\n//> ARM condition code\ntypedef enum arm_cc {\n\tARM_CC_INVALID = 0,\n\tARM_CC_EQ,            // Equal                      Equal\n\tARM_CC_NE,            // Not equal                  Not equal, or unordered\n\tARM_CC_HS,            // Carry set                  >, ==, or unordered\n\tARM_CC_LO,            // Carry clear                Less than\n\tARM_CC_MI,            // Minus, negative            Less than\n\tARM_CC_PL,            // Plus, positive or zero     >, ==, or unordered\n\tARM_CC_VS,            // Overflow                   Unordered\n\tARM_CC_VC,            // No overflow                Not unordered\n\tARM_CC_HI,            // Unsigned higher            Greater than, or unordered\n\tARM_CC_LS,            // Unsigned lower or same     Less than or equal\n\tARM_CC_GE,            // Greater than or equal      Greater than or equal\n\tARM_CC_LT,            // Less than                  Less than, or unordered\n\tARM_CC_GT,            // Greater than               Greater than\n\tARM_CC_LE,            // Less than or equal         <, ==, or unordered\n\tARM_CC_AL             // Always (unconditional)     Always (unconditional)\n} arm_cc;\n\ntypedef enum arm_sysreg {\n\t//> Special registers for MSR\n\tARM_SYSREG_INVALID = 0,\n\n\t// SPSR* registers can be OR combined\n\tARM_SYSREG_SPSR_C = 1,\n\tARM_SYSREG_SPSR_X = 2,\n\tARM_SYSREG_SPSR_S = 4,\n\tARM_SYSREG_SPSR_F = 8,\n\n\t// CPSR* registers can be OR combined\n\tARM_SYSREG_CPSR_C = 16,\n\tARM_SYSREG_CPSR_X = 32,\n\tARM_SYSREG_CPSR_S = 64,\n\tARM_SYSREG_CPSR_F = 128,\n\n\t// independent registers\n\tARM_SYSREG_APSR = 256,\n\tARM_SYSREG_APSR_G,\n\tARM_SYSREG_APSR_NZCVQ,\n\tARM_SYSREG_APSR_NZCVQG,\n\n\tARM_SYSREG_IAPSR,\n\tARM_SYSREG_IAPSR_G,\n\tARM_SYSREG_IAPSR_NZCVQG,\n\n\tARM_SYSREG_EAPSR,\n\tARM_SYSREG_EAPSR_G,\n\tARM_SYSREG_EAPSR_NZCVQG,\n\n\tARM_SYSREG_XPSR,\n\tARM_SYSREG_XPSR_G,\n\tARM_SYSREG_XPSR_NZCVQG,\n\n\tARM_SYSREG_IPSR,\n\tARM_SYSREG_EPSR,\n\tARM_SYSREG_IEPSR,\n\n\tARM_SYSREG_MSP,\n\tARM_SYSREG_PSP,\n\tARM_SYSREG_PRIMASK,\n\tARM_SYSREG_BASEPRI,\n\tARM_SYSREG_BASEPRI_MAX,\n\tARM_SYSREG_FAULTMASK,\n\tARM_SYSREG_CONTROL,\n} arm_sysreg;\n\n//> The memory barrier constants map directly to the 4-bit encoding of\n//> the option field for Memory Barrier operations.\ntypedef enum arm_mem_barrier {\n\tARM_MB_INVALID = 0,\n\tARM_MB_RESERVED_0,\n\tARM_MB_OSHLD,\n\tARM_MB_OSHST,\n\tARM_MB_OSH,\n\tARM_MB_RESERVED_4,\n\tARM_MB_NSHLD,\n\tARM_MB_NSHST,\n\tARM_MB_NSH,\n\tARM_MB_RESERVED_8,\n\tARM_MB_ISHLD,\n\tARM_MB_ISHST,\n\tARM_MB_ISH,\n\tARM_MB_RESERVED_12,\n\tARM_MB_LD,\n\tARM_MB_ST,\n\tARM_MB_SY,\n} arm_mem_barrier;\n\n//> Operand type for instruction's operands\ntypedef enum arm_op_type {\n\tARM_OP_INVALID = 0, // = CS_OP_INVALID (Uninitialized).\n\tARM_OP_REG, // = CS_OP_REG (Register operand).\n\tARM_OP_IMM, // = CS_OP_IMM (Immediate operand).\n\tARM_OP_MEM, // = CS_OP_MEM (Memory operand).\n\tARM_OP_FP,  // = CS_OP_FP (Floating-Point operand).\n\tARM_OP_CIMM = 64, // C-Immediate (coprocessor registers)\n\tARM_OP_PIMM, // P-Immediate (coprocessor registers)\n\tARM_OP_SETEND,\t// operand for SETEND instruction\n\tARM_OP_SYSREG,\t// MSR/MRS special register operand\n} arm_op_type;\n\n//> Operand type for SETEND instruction\ntypedef enum arm_setend_type {\n\tARM_SETEND_INVALID = 0,\t// Uninitialized.\n\tARM_SETEND_BE,\t// BE operand.\n\tARM_SETEND_LE, // LE operand\n} arm_setend_type;\n\ntypedef enum arm_cpsmode_type {\n\tARM_CPSMODE_INVALID = 0,\n\tARM_CPSMODE_IE = 2,\n\tARM_CPSMODE_ID = 3\n} arm_cpsmode_type;\n\n//> Operand type for SETEND instruction\ntypedef enum arm_cpsflag_type {\n\tARM_CPSFLAG_INVALID = 0,\n\tARM_CPSFLAG_F = 1,\n\tARM_CPSFLAG_I = 2,\n\tARM_CPSFLAG_A = 4,\n\tARM_CPSFLAG_NONE = 16,\t// no flag\n} arm_cpsflag_type;\n\n//> Data type for elements of vector instructions.\ntypedef enum arm_vectordata_type {\n\tARM_VECTORDATA_INVALID = 0,\n\n\t// Integer type\n\tARM_VECTORDATA_I8,\n\tARM_VECTORDATA_I16,\n\tARM_VECTORDATA_I32,\n\tARM_VECTORDATA_I64,\n\n\t// Signed integer type\n\tARM_VECTORDATA_S8,\n\tARM_VECTORDATA_S16,\n\tARM_VECTORDATA_S32,\n\tARM_VECTORDATA_S64,\n\n\t// Unsigned integer type\n\tARM_VECTORDATA_U8,\n\tARM_VECTORDATA_U16,\n\tARM_VECTORDATA_U32,\n\tARM_VECTORDATA_U64,\n\n\t// Data type for VMUL/VMULL\n\tARM_VECTORDATA_P8,\n\n\t// Floating type\n\tARM_VECTORDATA_F32,\n\tARM_VECTORDATA_F64,\n\n\t// Convert float <-> float\n\tARM_VECTORDATA_F16F64,\t// f16.f64\n\tARM_VECTORDATA_F64F16,\t// f64.f16\n\tARM_VECTORDATA_F32F16,\t// f32.f16\n\tARM_VECTORDATA_F16F32,\t// f32.f16\n\tARM_VECTORDATA_F64F32,\t// f64.f32\n\tARM_VECTORDATA_F32F64,\t// f32.f64\n\n\t// Convert integer <-> float\n\tARM_VECTORDATA_S32F32,\t// s32.f32\n\tARM_VECTORDATA_U32F32,\t// u32.f32\n\tARM_VECTORDATA_F32S32,\t// f32.s32\n\tARM_VECTORDATA_F32U32,\t// f32.u32\n\tARM_VECTORDATA_F64S16,\t// f64.s16\n\tARM_VECTORDATA_F32S16,\t// f32.s16\n\tARM_VECTORDATA_F64S32,\t// f64.s32\n\tARM_VECTORDATA_S16F64,\t// s16.f64\n\tARM_VECTORDATA_S16F32,\t// s16.f64\n\tARM_VECTORDATA_S32F64,\t// s32.f64\n\tARM_VECTORDATA_U16F64,\t// u16.f64\n\tARM_VECTORDATA_U16F32,\t// u16.f32\n\tARM_VECTORDATA_U32F64,\t// u32.f64\n\tARM_VECTORDATA_F64U16,\t// f64.u16\n\tARM_VECTORDATA_F32U16,\t// f32.u16\n\tARM_VECTORDATA_F64U32,\t// f64.u32\n} arm_vectordata_type;\n\n// Instruction's operand referring to memory\n// This is associated with ARM_OP_MEM operand type above\ntypedef struct arm_op_mem {\n\tunsigned int base;\t// base register\n\tunsigned int index;\t// index register\n\tint scale;\t// scale for index register (can be 1, or -1)\n\tint disp;\t// displacement/offset value\n} arm_op_mem;\n\n// Instruction operand\ntypedef struct cs_arm_op {\n\tint vector_index;\t// Vector Index for some vector operands (or -1 if irrelevant)\n\tstruct {\n\t\tarm_shifter type;\n\t\tunsigned int value;\n\t} shift;\n\tarm_op_type type;\t// operand type\n\tunion {\n\t\tunsigned int reg;\t// register value for REG/SYSREG operand\n\t\tint32_t imm;\t\t\t// immediate value for C-IMM, P-IMM or IMM operand\n\t\tdouble fp;\t\t\t// floating point value for FP operand\n\t\tarm_op_mem mem;\t\t// base/index/scale/disp value for MEM operand\n\t\tarm_setend_type setend; // SETEND instruction's operand type\n\t};\n\t// in some instructions, an operand can be subtracted or added to\n\t// the base register,\n\tbool subtracted; // if TRUE, this operand is subtracted. otherwise, it is added.\n} cs_arm_op;\n\n// Instruction structure\ntypedef struct cs_arm {\n\tbool usermode;\t// User-mode registers to be loaded (for LDM/STM instructions)\n\tint vector_size; \t// Scalar size for vector instructions\n\tarm_vectordata_type vector_data; // Data type for elements of vector instructions\n\tarm_cpsmode_type cps_mode;\t// CPS mode for CPS instruction\n\tarm_cpsflag_type cps_flag;\t// CPS mode for CPS instruction\n\tarm_cc cc;\t\t\t// conditional code for this insn\n\tbool update_flags;\t// does this insn update flags?\n\tbool writeback;\t\t// does this insn write-back?\n\tarm_mem_barrier mem_barrier;\t// Option for some memory barrier instructions\n\n\t// Number of operands of this instruction, \n\t// or 0 when instruction has no operand.\n\tuint8_t op_count;\n\n\tcs_arm_op operands[36];\t// operands for this instruction.\n} cs_arm;\n\n//> ARM registers\ntypedef enum arm_reg {\n\tARM_REG_INVALID = 0,\n\tARM_REG_APSR,\n\tARM_REG_APSR_NZCV,\n\tARM_REG_CPSR,\n\tARM_REG_FPEXC,\n\tARM_REG_FPINST,\n\tARM_REG_FPSCR,\n\tARM_REG_FPSCR_NZCV,\n\tARM_REG_FPSID,\n\tARM_REG_ITSTATE,\n\tARM_REG_LR,\n\tARM_REG_PC,\n\tARM_REG_SP,\n\tARM_REG_SPSR,\n\tARM_REG_D0,\n\tARM_REG_D1,\n\tARM_REG_D2,\n\tARM_REG_D3,\n\tARM_REG_D4,\n\tARM_REG_D5,\n\tARM_REG_D6,\n\tARM_REG_D7,\n\tARM_REG_D8,\n\tARM_REG_D9,\n\tARM_REG_D10,\n\tARM_REG_D11,\n\tARM_REG_D12,\n\tARM_REG_D13,\n\tARM_REG_D14,\n\tARM_REG_D15,\n\tARM_REG_D16,\n\tARM_REG_D17,\n\tARM_REG_D18,\n\tARM_REG_D19,\n\tARM_REG_D20,\n\tARM_REG_D21,\n\tARM_REG_D22,\n\tARM_REG_D23,\n\tARM_REG_D24,\n\tARM_REG_D25,\n\tARM_REG_D26,\n\tARM_REG_D27,\n\tARM_REG_D28,\n\tARM_REG_D29,\n\tARM_REG_D30,\n\tARM_REG_D31,\n\tARM_REG_FPINST2,\n\tARM_REG_MVFR0,\n\tARM_REG_MVFR1,\n\tARM_REG_MVFR2,\n\tARM_REG_Q0,\n\tARM_REG_Q1,\n\tARM_REG_Q2,\n\tARM_REG_Q3,\n\tARM_REG_Q4,\n\tARM_REG_Q5,\n\tARM_REG_Q6,\n\tARM_REG_Q7,\n\tARM_REG_Q8,\n\tARM_REG_Q9,\n\tARM_REG_Q10,\n\tARM_REG_Q11,\n\tARM_REG_Q12,\n\tARM_REG_Q13,\n\tARM_REG_Q14,\n\tARM_REG_Q15,\n\tARM_REG_R0,\n\tARM_REG_R1,\n\tARM_REG_R2,\n\tARM_REG_R3,\n\tARM_REG_R4,\n\tARM_REG_R5,\n\tARM_REG_R6,\n\tARM_REG_R7,\n\tARM_REG_R8,\n\tARM_REG_R9,\n\tARM_REG_R10,\n\tARM_REG_R11,\n\tARM_REG_R12,\n\tARM_REG_S0,\n\tARM_REG_S1,\n\tARM_REG_S2,\n\tARM_REG_S3,\n\tARM_REG_S4,\n\tARM_REG_S5,\n\tARM_REG_S6,\n\tARM_REG_S7,\n\tARM_REG_S8,\n\tARM_REG_S9,\n\tARM_REG_S10,\n\tARM_REG_S11,\n\tARM_REG_S12,\n\tARM_REG_S13,\n\tARM_REG_S14,\n\tARM_REG_S15,\n\tARM_REG_S16,\n\tARM_REG_S17,\n\tARM_REG_S18,\n\tARM_REG_S19,\n\tARM_REG_S20,\n\tARM_REG_S21,\n\tARM_REG_S22,\n\tARM_REG_S23,\n\tARM_REG_S24,\n\tARM_REG_S25,\n\tARM_REG_S26,\n\tARM_REG_S27,\n\tARM_REG_S28,\n\tARM_REG_S29,\n\tARM_REG_S30,\n\tARM_REG_S31,\n\n\tARM_REG_ENDING,\t\t// <-- mark the end of the list or registers\n\n\t//> alias registers\n\tARM_REG_R13 = ARM_REG_SP,\n\tARM_REG_R14 = ARM_REG_LR,\n\tARM_REG_R15 = ARM_REG_PC,\n\n\tARM_REG_SB = ARM_REG_R9,\n\tARM_REG_SL = ARM_REG_R10,\n\tARM_REG_FP = ARM_REG_R11,\n\tARM_REG_IP = ARM_REG_R12,\n} arm_reg;\n\n//> ARM instruction\ntypedef enum arm_insn {\n\tARM_INS_INVALID = 0,\n\n\tARM_INS_ADC,\n\tARM_INS_ADD,\n\tARM_INS_ADR,\n\tARM_INS_AESD,\n\tARM_INS_AESE,\n\tARM_INS_AESIMC,\n\tARM_INS_AESMC,\n\tARM_INS_AND,\n\tARM_INS_BFC,\n\tARM_INS_BFI,\n\tARM_INS_BIC,\n\tARM_INS_BKPT,\n\tARM_INS_BL,\n\tARM_INS_BLX,\n\tARM_INS_BX,\n\tARM_INS_BXJ,\n\tARM_INS_B,\n\tARM_INS_CDP,\n\tARM_INS_CDP2,\n\tARM_INS_CLREX,\n\tARM_INS_CLZ,\n\tARM_INS_CMN,\n\tARM_INS_CMP,\n\tARM_INS_CPS,\n\tARM_INS_CRC32B,\n\tARM_INS_CRC32CB,\n\tARM_INS_CRC32CH,\n\tARM_INS_CRC32CW,\n\tARM_INS_CRC32H,\n\tARM_INS_CRC32W,\n\tARM_INS_DBG,\n\tARM_INS_DMB,\n\tARM_INS_DSB,\n\tARM_INS_EOR,\n\tARM_INS_VMOV,\n\tARM_INS_FLDMDBX,\n\tARM_INS_FLDMIAX,\n\tARM_INS_VMRS,\n\tARM_INS_FSTMDBX,\n\tARM_INS_FSTMIAX,\n\tARM_INS_HINT,\n\tARM_INS_HLT,\n\tARM_INS_ISB,\n\tARM_INS_LDA,\n\tARM_INS_LDAB,\n\tARM_INS_LDAEX,\n\tARM_INS_LDAEXB,\n\tARM_INS_LDAEXD,\n\tARM_INS_LDAEXH,\n\tARM_INS_LDAH,\n\tARM_INS_LDC2L,\n\tARM_INS_LDC2,\n\tARM_INS_LDCL,\n\tARM_INS_LDC,\n\tARM_INS_LDMDA,\n\tARM_INS_LDMDB,\n\tARM_INS_LDM,\n\tARM_INS_LDMIB,\n\tARM_INS_LDRBT,\n\tARM_INS_LDRB,\n\tARM_INS_LDRD,\n\tARM_INS_LDREX,\n\tARM_INS_LDREXB,\n\tARM_INS_LDREXD,\n\tARM_INS_LDREXH,\n\tARM_INS_LDRH,\n\tARM_INS_LDRHT,\n\tARM_INS_LDRSB,\n\tARM_INS_LDRSBT,\n\tARM_INS_LDRSH,\n\tARM_INS_LDRSHT,\n\tARM_INS_LDRT,\n\tARM_INS_LDR,\n\tARM_INS_MCR,\n\tARM_INS_MCR2,\n\tARM_INS_MCRR,\n\tARM_INS_MCRR2,\n\tARM_INS_MLA,\n\tARM_INS_MLS,\n\tARM_INS_MOV,\n\tARM_INS_MOVT,\n\tARM_INS_MOVW,\n\tARM_INS_MRC,\n\tARM_INS_MRC2,\n\tARM_INS_MRRC,\n\tARM_INS_MRRC2,\n\tARM_INS_MRS,\n\tARM_INS_MSR,\n\tARM_INS_MUL,\n\tARM_INS_MVN,\n\tARM_INS_ORR,\n\tARM_INS_PKHBT,\n\tARM_INS_PKHTB,\n\tARM_INS_PLDW,\n\tARM_INS_PLD,\n\tARM_INS_PLI,\n\tARM_INS_QADD,\n\tARM_INS_QADD16,\n\tARM_INS_QADD8,\n\tARM_INS_QASX,\n\tARM_INS_QDADD,\n\tARM_INS_QDSUB,\n\tARM_INS_QSAX,\n\tARM_INS_QSUB,\n\tARM_INS_QSUB16,\n\tARM_INS_QSUB8,\n\tARM_INS_RBIT,\n\tARM_INS_REV,\n\tARM_INS_REV16,\n\tARM_INS_REVSH,\n\tARM_INS_RFEDA,\n\tARM_INS_RFEDB,\n\tARM_INS_RFEIA,\n\tARM_INS_RFEIB,\n\tARM_INS_RSB,\n\tARM_INS_RSC,\n\tARM_INS_SADD16,\n\tARM_INS_SADD8,\n\tARM_INS_SASX,\n\tARM_INS_SBC,\n\tARM_INS_SBFX,\n\tARM_INS_SDIV,\n\tARM_INS_SEL,\n\tARM_INS_SETEND,\n\tARM_INS_SHA1C,\n\tARM_INS_SHA1H,\n\tARM_INS_SHA1M,\n\tARM_INS_SHA1P,\n\tARM_INS_SHA1SU0,\n\tARM_INS_SHA1SU1,\n\tARM_INS_SHA256H,\n\tARM_INS_SHA256H2,\n\tARM_INS_SHA256SU0,\n\tARM_INS_SHA256SU1,\n\tARM_INS_SHADD16,\n\tARM_INS_SHADD8,\n\tARM_INS_SHASX,\n\tARM_INS_SHSAX,\n\tARM_INS_SHSUB16,\n\tARM_INS_SHSUB8,\n\tARM_INS_SMC,\n\tARM_INS_SMLABB,\n\tARM_INS_SMLABT,\n\tARM_INS_SMLAD,\n\tARM_INS_SMLADX,\n\tARM_INS_SMLAL,\n\tARM_INS_SMLALBB,\n\tARM_INS_SMLALBT,\n\tARM_INS_SMLALD,\n\tARM_INS_SMLALDX,\n\tARM_INS_SMLALTB,\n\tARM_INS_SMLALTT,\n\tARM_INS_SMLATB,\n\tARM_INS_SMLATT,\n\tARM_INS_SMLAWB,\n\tARM_INS_SMLAWT,\n\tARM_INS_SMLSD,\n\tARM_INS_SMLSDX,\n\tARM_INS_SMLSLD,\n\tARM_INS_SMLSLDX,\n\tARM_INS_SMMLA,\n\tARM_INS_SMMLAR,\n\tARM_INS_SMMLS,\n\tARM_INS_SMMLSR,\n\tARM_INS_SMMUL,\n\tARM_INS_SMMULR,\n\tARM_INS_SMUAD,\n\tARM_INS_SMUADX,\n\tARM_INS_SMULBB,\n\tARM_INS_SMULBT,\n\tARM_INS_SMULL,\n\tARM_INS_SMULTB,\n\tARM_INS_SMULTT,\n\tARM_INS_SMULWB,\n\tARM_INS_SMULWT,\n\tARM_INS_SMUSD,\n\tARM_INS_SMUSDX,\n\tARM_INS_SRSDA,\n\tARM_INS_SRSDB,\n\tARM_INS_SRSIA,\n\tARM_INS_SRSIB,\n\tARM_INS_SSAT,\n\tARM_INS_SSAT16,\n\tARM_INS_SSAX,\n\tARM_INS_SSUB16,\n\tARM_INS_SSUB8,\n\tARM_INS_STC2L,\n\tARM_INS_STC2,\n\tARM_INS_STCL,\n\tARM_INS_STC,\n\tARM_INS_STL,\n\tARM_INS_STLB,\n\tARM_INS_STLEX,\n\tARM_INS_STLEXB,\n\tARM_INS_STLEXD,\n\tARM_INS_STLEXH,\n\tARM_INS_STLH,\n\tARM_INS_STMDA,\n\tARM_INS_STMDB,\n\tARM_INS_STM,\n\tARM_INS_STMIB,\n\tARM_INS_STRBT,\n\tARM_INS_STRB,\n\tARM_INS_STRD,\n\tARM_INS_STREX,\n\tARM_INS_STREXB,\n\tARM_INS_STREXD,\n\tARM_INS_STREXH,\n\tARM_INS_STRH,\n\tARM_INS_STRHT,\n\tARM_INS_STRT,\n\tARM_INS_STR,\n\tARM_INS_SUB,\n\tARM_INS_SVC,\n\tARM_INS_SWP,\n\tARM_INS_SWPB,\n\tARM_INS_SXTAB,\n\tARM_INS_SXTAB16,\n\tARM_INS_SXTAH,\n\tARM_INS_SXTB,\n\tARM_INS_SXTB16,\n\tARM_INS_SXTH,\n\tARM_INS_TEQ,\n\tARM_INS_TRAP,\n\tARM_INS_TST,\n\tARM_INS_UADD16,\n\tARM_INS_UADD8,\n\tARM_INS_UASX,\n\tARM_INS_UBFX,\n\tARM_INS_UDF,\n\tARM_INS_UDIV,\n\tARM_INS_UHADD16,\n\tARM_INS_UHADD8,\n\tARM_INS_UHASX,\n\tARM_INS_UHSAX,\n\tARM_INS_UHSUB16,\n\tARM_INS_UHSUB8,\n\tARM_INS_UMAAL,\n\tARM_INS_UMLAL,\n\tARM_INS_UMULL,\n\tARM_INS_UQADD16,\n\tARM_INS_UQADD8,\n\tARM_INS_UQASX,\n\tARM_INS_UQSAX,\n\tARM_INS_UQSUB16,\n\tARM_INS_UQSUB8,\n\tARM_INS_USAD8,\n\tARM_INS_USADA8,\n\tARM_INS_USAT,\n\tARM_INS_USAT16,\n\tARM_INS_USAX,\n\tARM_INS_USUB16,\n\tARM_INS_USUB8,\n\tARM_INS_UXTAB,\n\tARM_INS_UXTAB16,\n\tARM_INS_UXTAH,\n\tARM_INS_UXTB,\n\tARM_INS_UXTB16,\n\tARM_INS_UXTH,\n\tARM_INS_VABAL,\n\tARM_INS_VABA,\n\tARM_INS_VABDL,\n\tARM_INS_VABD,\n\tARM_INS_VABS,\n\tARM_INS_VACGE,\n\tARM_INS_VACGT,\n\tARM_INS_VADD,\n\tARM_INS_VADDHN,\n\tARM_INS_VADDL,\n\tARM_INS_VADDW,\n\tARM_INS_VAND,\n\tARM_INS_VBIC,\n\tARM_INS_VBIF,\n\tARM_INS_VBIT,\n\tARM_INS_VBSL,\n\tARM_INS_VCEQ,\n\tARM_INS_VCGE,\n\tARM_INS_VCGT,\n\tARM_INS_VCLE,\n\tARM_INS_VCLS,\n\tARM_INS_VCLT,\n\tARM_INS_VCLZ,\n\tARM_INS_VCMP,\n\tARM_INS_VCMPE,\n\tARM_INS_VCNT,\n\tARM_INS_VCVTA,\n\tARM_INS_VCVTB,\n\tARM_INS_VCVT,\n\tARM_INS_VCVTM,\n\tARM_INS_VCVTN,\n\tARM_INS_VCVTP,\n\tARM_INS_VCVTT,\n\tARM_INS_VDIV,\n\tARM_INS_VDUP,\n\tARM_INS_VEOR,\n\tARM_INS_VEXT,\n\tARM_INS_VFMA,\n\tARM_INS_VFMS,\n\tARM_INS_VFNMA,\n\tARM_INS_VFNMS,\n\tARM_INS_VHADD,\n\tARM_INS_VHSUB,\n\tARM_INS_VLD1,\n\tARM_INS_VLD2,\n\tARM_INS_VLD3,\n\tARM_INS_VLD4,\n\tARM_INS_VLDMDB,\n\tARM_INS_VLDMIA,\n\tARM_INS_VLDR,\n\tARM_INS_VMAXNM,\n\tARM_INS_VMAX,\n\tARM_INS_VMINNM,\n\tARM_INS_VMIN,\n\tARM_INS_VMLA,\n\tARM_INS_VMLAL,\n\tARM_INS_VMLS,\n\tARM_INS_VMLSL,\n\tARM_INS_VMOVL,\n\tARM_INS_VMOVN,\n\tARM_INS_VMSR,\n\tARM_INS_VMUL,\n\tARM_INS_VMULL,\n\tARM_INS_VMVN,\n\tARM_INS_VNEG,\n\tARM_INS_VNMLA,\n\tARM_INS_VNMLS,\n\tARM_INS_VNMUL,\n\tARM_INS_VORN,\n\tARM_INS_VORR,\n\tARM_INS_VPADAL,\n\tARM_INS_VPADDL,\n\tARM_INS_VPADD,\n\tARM_INS_VPMAX,\n\tARM_INS_VPMIN,\n\tARM_INS_VQABS,\n\tARM_INS_VQADD,\n\tARM_INS_VQDMLAL,\n\tARM_INS_VQDMLSL,\n\tARM_INS_VQDMULH,\n\tARM_INS_VQDMULL,\n\tARM_INS_VQMOVUN,\n\tARM_INS_VQMOVN,\n\tARM_INS_VQNEG,\n\tARM_INS_VQRDMULH,\n\tARM_INS_VQRSHL,\n\tARM_INS_VQRSHRN,\n\tARM_INS_VQRSHRUN,\n\tARM_INS_VQSHL,\n\tARM_INS_VQSHLU,\n\tARM_INS_VQSHRN,\n\tARM_INS_VQSHRUN,\n\tARM_INS_VQSUB,\n\tARM_INS_VRADDHN,\n\tARM_INS_VRECPE,\n\tARM_INS_VRECPS,\n\tARM_INS_VREV16,\n\tARM_INS_VREV32,\n\tARM_INS_VREV64,\n\tARM_INS_VRHADD,\n\tARM_INS_VRINTA,\n\tARM_INS_VRINTM,\n\tARM_INS_VRINTN,\n\tARM_INS_VRINTP,\n\tARM_INS_VRINTR,\n\tARM_INS_VRINTX,\n\tARM_INS_VRINTZ,\n\tARM_INS_VRSHL,\n\tARM_INS_VRSHRN,\n\tARM_INS_VRSHR,\n\tARM_INS_VRSQRTE,\n\tARM_INS_VRSQRTS,\n\tARM_INS_VRSRA,\n\tARM_INS_VRSUBHN,\n\tARM_INS_VSELEQ,\n\tARM_INS_VSELGE,\n\tARM_INS_VSELGT,\n\tARM_INS_VSELVS,\n\tARM_INS_VSHLL,\n\tARM_INS_VSHL,\n\tARM_INS_VSHRN,\n\tARM_INS_VSHR,\n\tARM_INS_VSLI,\n\tARM_INS_VSQRT,\n\tARM_INS_VSRA,\n\tARM_INS_VSRI,\n\tARM_INS_VST1,\n\tARM_INS_VST2,\n\tARM_INS_VST3,\n\tARM_INS_VST4,\n\tARM_INS_VSTMDB,\n\tARM_INS_VSTMIA,\n\tARM_INS_VSTR,\n\tARM_INS_VSUB,\n\tARM_INS_VSUBHN,\n\tARM_INS_VSUBL,\n\tARM_INS_VSUBW,\n\tARM_INS_VSWP,\n\tARM_INS_VTBL,\n\tARM_INS_VTBX,\n\tARM_INS_VCVTR,\n\tARM_INS_VTRN,\n\tARM_INS_VTST,\n\tARM_INS_VUZP,\n\tARM_INS_VZIP,\n\tARM_INS_ADDW,\n\tARM_INS_ASR,\n\tARM_INS_DCPS1,\n\tARM_INS_DCPS2,\n\tARM_INS_DCPS3,\n\tARM_INS_IT,\n\tARM_INS_LSL,\n\tARM_INS_LSR,\n\tARM_INS_ASRS,\n\tARM_INS_LSRS,\n\tARM_INS_ORN,\n\tARM_INS_ROR,\n\tARM_INS_RRX,\n\tARM_INS_SUBS,\n\tARM_INS_SUBW,\n\tARM_INS_TBB,\n\tARM_INS_TBH,\n\tARM_INS_CBNZ,\n\tARM_INS_CBZ,\n\tARM_INS_MOVS,\n\tARM_INS_POP,\n\tARM_INS_PUSH,\n\n\t// special instructions\n\tARM_INS_NOP,\n\tARM_INS_YIELD,\n\tARM_INS_WFE,\n\tARM_INS_WFI,\n\tARM_INS_SEV,\n\tARM_INS_SEVL,\n\tARM_INS_VPUSH,\n\tARM_INS_VPOP,\n\n\tARM_INS_ENDING,\t// <-- mark the end of the list of instructions\n} arm_insn;\n\n//> Group of ARM instructions\ntypedef enum arm_insn_group {\n\tARM_GRP_INVALID = 0, // = CS_GRP_INVALID\n\n\t//> Generic groups\n\t// all jump instructions (conditional+direct+indirect jumps)\n\tARM_GRP_JUMP,\t// = CS_GRP_JUMP\n\n\t//> Architecture-specific groups\n\tARM_GRP_CRYPTO = 128,\n\tARM_GRP_DATABARRIER,\n\tARM_GRP_DIVIDE,\n\tARM_GRP_FPARMV8,\n\tARM_GRP_MULTPRO,\n\tARM_GRP_NEON,\n\tARM_GRP_T2EXTRACTPACK,\n\tARM_GRP_THUMB2DSP,\n\tARM_GRP_TRUSTZONE,\n\tARM_GRP_V4T,\n\tARM_GRP_V5T,\n\tARM_GRP_V5TE,\n\tARM_GRP_V6,\n\tARM_GRP_V6T2,\n\tARM_GRP_V7,\n\tARM_GRP_V8,\n\tARM_GRP_VFP2,\n\tARM_GRP_VFP3,\n\tARM_GRP_VFP4,\n\tARM_GRP_ARM,\n\tARM_GRP_MCLASS,\n\tARM_GRP_NOTMCLASS,\n\tARM_GRP_THUMB,\n\tARM_GRP_THUMB1ONLY,\n\tARM_GRP_THUMB2,\n\tARM_GRP_PREV8,\n\tARM_GRP_FPVMLX,\n\tARM_GRP_MULOPS,\n\tARM_GRP_CRC,\n\tARM_GRP_DPVFP,\n\tARM_GRP_V6M,\n\n\tARM_GRP_ENDING,\n} arm_insn_group;\n\n#ifdef __cplusplus\n}\n#endif\n\n#endif\n"
  },
  {
    "path": "EFI_DEBUG/EFI/OC/Kexts/Lilu.kext/Contents/Resources/Headers/capstone/arm64.h",
    "content": "#ifndef CAPSTONE_ARM64_H\n#define CAPSTONE_ARM64_H\n\n/* Capstone Disassembly Engine */\n/* By Nguyen Anh Quynh <aquynh@gmail.com>, 2013-2014 */\n\n#ifdef __cplusplus\nextern \"C\" {\n#endif\n\n#if !defined(_MSC_VER) || !defined(_KERNEL_MODE)\n#include <stdint.h>\n#endif\n\n#include \"platform.h\"\n\n#ifdef _MSC_VER\n#pragma warning(disable:4201)\n#endif\n\n//> ARM64 shift type\ntypedef enum arm64_shifter {\n\tARM64_SFT_INVALID = 0,\n\tARM64_SFT_LSL = 1,\n\tARM64_SFT_MSL = 2,\n\tARM64_SFT_LSR = 3,\n\tARM64_SFT_ASR = 4,\n\tARM64_SFT_ROR = 5,\n} arm64_shifter;\n\n//> ARM64 extender type\ntypedef enum arm64_extender {\n\tARM64_EXT_INVALID = 0,\n\tARM64_EXT_UXTB = 1,\n\tARM64_EXT_UXTH = 2,\n\tARM64_EXT_UXTW = 3,\n\tARM64_EXT_UXTX = 4,\n\tARM64_EXT_SXTB = 5,\n\tARM64_EXT_SXTH = 6,\n\tARM64_EXT_SXTW = 7,\n\tARM64_EXT_SXTX = 8,\n} arm64_extender;\n\n//> ARM64 condition code\ntypedef enum arm64_cc {\n\tARM64_CC_INVALID = 0,\n\tARM64_CC_EQ = 1,     // Equal\n\tARM64_CC_NE = 2,     // Not equal:                 Not equal, or unordered\n\tARM64_CC_HS = 3,     // Unsigned higher or same:   >, ==, or unordered\n\tARM64_CC_LO = 4,     // Unsigned lower or same:    Less than\n\tARM64_CC_MI = 5,     // Minus, negative:           Less than\n\tARM64_CC_PL = 6,     // Plus, positive or zero:    >, ==, or unordered\n\tARM64_CC_VS = 7,     // Overflow:                  Unordered\n\tARM64_CC_VC = 8,     // No overflow:               Ordered\n\tARM64_CC_HI = 9,     // Unsigned higher:           Greater than, or unordered\n\tARM64_CC_LS = 10,     // Unsigned lower or same:    Less than or equal\n\tARM64_CC_GE = 11,     // Greater than or equal:     Greater than or equal\n\tARM64_CC_LT = 12,     // Less than:                 Less than, or unordered\n\tARM64_CC_GT = 13,     // Signed greater than:       Greater than\n\tARM64_CC_LE = 14,     // Signed less than or equal: <, ==, or unordered\n\tARM64_CC_AL = 15,     // Always (unconditional):    Always (unconditional)\n\tARM64_CC_NV = 16,     // Always (unconditional):   Always (unconditional)\n\t// Note the NV exists purely to disassemble 0b1111. Execution\n\t// is \"always\".\n} arm64_cc;\n\n//> System registers\ntypedef enum arm64_sysreg {\n\t//> System registers for MRS\n\tARM64_SYSREG_INVALID           = 0,\n\tARM64_SYSREG_MDCCSR_EL0        = 0x9808, // 10  011  0000  0001  000\n\tARM64_SYSREG_DBGDTRRX_EL0      = 0x9828, // 10  011  0000  0101  000\n\tARM64_SYSREG_MDRAR_EL1         = 0x8080, // 10  000  0001  0000  000\n\tARM64_SYSREG_OSLSR_EL1         = 0x808c, // 10  000  0001  0001  100\n\tARM64_SYSREG_DBGAUTHSTATUS_EL1 = 0x83f6, // 10  000  0111  1110  110\n\tARM64_SYSREG_PMCEID0_EL0       = 0xdce6, // 11  011  1001  1100  110\n\tARM64_SYSREG_PMCEID1_EL0       = 0xdce7, // 11  011  1001  1100  111\n\tARM64_SYSREG_MIDR_EL1          = 0xc000, // 11  000  0000  0000  000\n\tARM64_SYSREG_CCSIDR_EL1        = 0xc800, // 11  001  0000  0000  000\n\tARM64_SYSREG_CLIDR_EL1         = 0xc801, // 11  001  0000  0000  001\n\tARM64_SYSREG_CTR_EL0           = 0xd801, // 11  011  0000  0000  001\n\tARM64_SYSREG_MPIDR_EL1         = 0xc005, // 11  000  0000  0000  101\n\tARM64_SYSREG_REVIDR_EL1        = 0xc006, // 11  000  0000  0000  110\n\tARM64_SYSREG_AIDR_EL1          = 0xc807, // 11  001  0000  0000  111\n\tARM64_SYSREG_DCZID_EL0         = 0xd807, // 11  011  0000  0000  111\n\tARM64_SYSREG_ID_PFR0_EL1       = 0xc008, // 11  000  0000  0001  000\n\tARM64_SYSREG_ID_PFR1_EL1       = 0xc009, // 11  000  0000  0001  001\n\tARM64_SYSREG_ID_DFR0_EL1       = 0xc00a, // 11  000  0000  0001  010\n\tARM64_SYSREG_ID_AFR0_EL1       = 0xc00b, // 11  000  0000  0001  011\n\tARM64_SYSREG_ID_MMFR0_EL1      = 0xc00c, // 11  000  0000  0001  100\n\tARM64_SYSREG_ID_MMFR1_EL1      = 0xc00d, // 11  000  0000  0001  101\n\tARM64_SYSREG_ID_MMFR2_EL1      = 0xc00e, // 11  000  0000  0001  110\n\tARM64_SYSREG_ID_MMFR3_EL1      = 0xc00f, // 11  000  0000  0001  111\n\tARM64_SYSREG_ID_ISAR0_EL1      = 0xc010, // 11  000  0000  0010  000\n\tARM64_SYSREG_ID_ISAR1_EL1      = 0xc011, // 11  000  0000  0010  001\n\tARM64_SYSREG_ID_ISAR2_EL1      = 0xc012, // 11  000  0000  0010  010\n\tARM64_SYSREG_ID_ISAR3_EL1      = 0xc013, // 11  000  0000  0010  011\n\tARM64_SYSREG_ID_ISAR4_EL1      = 0xc014, // 11  000  0000  0010  100\n\tARM64_SYSREG_ID_ISAR5_EL1      = 0xc015, // 11  000  0000  0010  101\n\tARM64_SYSREG_ID_A64PFR0_EL1   = 0xc020, // 11  000  0000  0100  000\n\tARM64_SYSREG_ID_A64PFR1_EL1   = 0xc021, // 11  000  0000  0100  001\n\tARM64_SYSREG_ID_A64DFR0_EL1   = 0xc028, // 11  000  0000  0101  000\n\tARM64_SYSREG_ID_A64DFR1_EL1   = 0xc029, // 11  000  0000  0101  001\n\tARM64_SYSREG_ID_A64AFR0_EL1   = 0xc02c, // 11  000  0000  0101  100\n\tARM64_SYSREG_ID_A64AFR1_EL1   = 0xc02d, // 11  000  0000  0101  101\n\tARM64_SYSREG_ID_A64ISAR0_EL1  = 0xc030, // 11  000  0000  0110  000\n\tARM64_SYSREG_ID_A64ISAR1_EL1  = 0xc031, // 11  000  0000  0110  001\n\tARM64_SYSREG_ID_A64MMFR0_EL1  = 0xc038, // 11  000  0000  0111  000\n\tARM64_SYSREG_ID_A64MMFR1_EL1  = 0xc039, // 11  000  0000  0111  001\n\tARM64_SYSREG_MVFR0_EL1         = 0xc018, // 11  000  0000  0011  000\n\tARM64_SYSREG_MVFR1_EL1         = 0xc019, // 11  000  0000  0011  001\n\tARM64_SYSREG_MVFR2_EL1         = 0xc01a, // 11  000  0000  0011  010\n\tARM64_SYSREG_RVBAR_EL1         = 0xc601, // 11  000  1100  0000  001\n\tARM64_SYSREG_RVBAR_EL2         = 0xe601, // 11  100  1100  0000  001\n\tARM64_SYSREG_RVBAR_EL3         = 0xf601, // 11  110  1100  0000  001\n\tARM64_SYSREG_ISR_EL1           = 0xc608, // 11  000  1100  0001  000\n\tARM64_SYSREG_CNTPCT_EL0        = 0xdf01, // 11  011  1110  0000  001\n\tARM64_SYSREG_CNTVCT_EL0        = 0xdf02,  // 11  011  1110  0000  010\n\n\t// Trace registers\n\tARM64_SYSREG_TRCSTATR          = 0x8818, // 10  001  0000  0011  000\n\tARM64_SYSREG_TRCIDR8           = 0x8806, // 10  001  0000  0000  110\n\tARM64_SYSREG_TRCIDR9           = 0x880e, // 10  001  0000  0001  110\n\tARM64_SYSREG_TRCIDR10          = 0x8816, // 10  001  0000  0010  110\n\tARM64_SYSREG_TRCIDR11          = 0x881e, // 10  001  0000  0011  110\n\tARM64_SYSREG_TRCIDR12          = 0x8826, // 10  001  0000  0100  110\n\tARM64_SYSREG_TRCIDR13          = 0x882e, // 10  001  0000  0101  110\n\tARM64_SYSREG_TRCIDR0           = 0x8847, // 10  001  0000  1000  111\n\tARM64_SYSREG_TRCIDR1           = 0x884f, // 10  001  0000  1001  111\n\tARM64_SYSREG_TRCIDR2           = 0x8857, // 10  001  0000  1010  111\n\tARM64_SYSREG_TRCIDR3           = 0x885f, // 10  001  0000  1011  111\n\tARM64_SYSREG_TRCIDR4           = 0x8867, // 10  001  0000  1100  111\n\tARM64_SYSREG_TRCIDR5           = 0x886f, // 10  001  0000  1101  111\n\tARM64_SYSREG_TRCIDR6           = 0x8877, // 10  001  0000  1110  111\n\tARM64_SYSREG_TRCIDR7           = 0x887f, // 10  001  0000  1111  111\n\tARM64_SYSREG_TRCOSLSR          = 0x888c, // 10  001  0001  0001  100\n\tARM64_SYSREG_TRCPDSR           = 0x88ac, // 10  001  0001  0101  100\n\tARM64_SYSREG_TRCDEVAFF0        = 0x8bd6, // 10  001  0111  1010  110\n\tARM64_SYSREG_TRCDEVAFF1        = 0x8bde, // 10  001  0111  1011  110\n\tARM64_SYSREG_TRCLSR            = 0x8bee, // 10  001  0111  1101  110\n\tARM64_SYSREG_TRCAUTHSTATUS     = 0x8bf6, // 10  001  0111  1110  110\n\tARM64_SYSREG_TRCDEVARCH        = 0x8bfe, // 10  001  0111  1111  110\n\tARM64_SYSREG_TRCDEVID          = 0x8b97, // 10  001  0111  0010  111\n\tARM64_SYSREG_TRCDEVTYPE        = 0x8b9f, // 10  001  0111  0011  111\n\tARM64_SYSREG_TRCPIDR4          = 0x8ba7, // 10  001  0111  0100  111\n\tARM64_SYSREG_TRCPIDR5          = 0x8baf, // 10  001  0111  0101  111\n\tARM64_SYSREG_TRCPIDR6          = 0x8bb7, // 10  001  0111  0110  111\n\tARM64_SYSREG_TRCPIDR7          = 0x8bbf, // 10  001  0111  0111  111\n\tARM64_SYSREG_TRCPIDR0          = 0x8bc7, // 10  001  0111  1000  111\n\tARM64_SYSREG_TRCPIDR1          = 0x8bcf, // 10  001  0111  1001  111\n\tARM64_SYSREG_TRCPIDR2          = 0x8bd7, // 10  001  0111  1010  111\n\tARM64_SYSREG_TRCPIDR3          = 0x8bdf, // 10  001  0111  1011  111\n\tARM64_SYSREG_TRCCIDR0          = 0x8be7, // 10  001  0111  1100  111\n\tARM64_SYSREG_TRCCIDR1          = 0x8bef, // 10  001  0111  1101  111\n\tARM64_SYSREG_TRCCIDR2          = 0x8bf7, // 10  001  0111  1110  111\n\tARM64_SYSREG_TRCCIDR3          = 0x8bff, // 10  001  0111  1111  111\n\n\t// GICv3 registers\n\tARM64_SYSREG_ICC_IAR1_EL1      = 0xc660, // 11  000  1100  1100  000\n\tARM64_SYSREG_ICC_IAR0_EL1      = 0xc640, // 11  000  1100  1000  000\n\tARM64_SYSREG_ICC_HPPIR1_EL1    = 0xc662, // 11  000  1100  1100  010\n\tARM64_SYSREG_ICC_HPPIR0_EL1    = 0xc642, // 11  000  1100  1000  010\n\tARM64_SYSREG_ICC_RPR_EL1       = 0xc65b, // 11  000  1100  1011  011\n\tARM64_SYSREG_ICH_VTR_EL2       = 0xe659, // 11  100  1100  1011  001\n\tARM64_SYSREG_ICH_EISR_EL2      = 0xe65b, // 11  100  1100  1011  011\n\tARM64_SYSREG_ICH_ELSR_EL2      = 0xe65d, // 11  100  1100  1011  101\n} arm64_sysreg;\n\ntypedef enum arm64_msr_reg {\n\t//> System registers for MSR\n\tARM64_SYSREG_DBGDTRTX_EL0      = 0x9828, // 10  011  0000  0101  000\n\tARM64_SYSREG_OSLAR_EL1         = 0x8084, // 10  000  0001  0000  100\n\tARM64_SYSREG_PMSWINC_EL0       = 0xdce4,  // 11  011  1001  1100  100\n\n\t// Trace Registers\n\tARM64_SYSREG_TRCOSLAR          = 0x8884, // 10  001  0001  0000  100\n\tARM64_SYSREG_TRCLAR            = 0x8be6, // 10  001  0111  1100  110\n\n\t// GICv3 registers\n\tARM64_SYSREG_ICC_EOIR1_EL1     = 0xc661, // 11  000  1100  1100  001\n\tARM64_SYSREG_ICC_EOIR0_EL1     = 0xc641, // 11  000  1100  1000  001\n\tARM64_SYSREG_ICC_DIR_EL1       = 0xc659, // 11  000  1100  1011  001\n\tARM64_SYSREG_ICC_SGI1R_EL1     = 0xc65d, // 11  000  1100  1011  101\n\tARM64_SYSREG_ICC_ASGI1R_EL1    = 0xc65e, // 11  000  1100  1011  110\n\tARM64_SYSREG_ICC_SGI0R_EL1     = 0xc65f, // 11  000  1100  1011  111\n} arm64_msr_reg;\n\n//> System PState Field (MSR instruction)\ntypedef enum arm64_pstate {\n\tARM64_PSTATE_INVALID = 0,\n\tARM64_PSTATE_SPSEL = 0x05,\n\tARM64_PSTATE_DAIFSET = 0x1e,\n\tARM64_PSTATE_DAIFCLR = 0x1f\n} arm64_pstate;\n\n//> Vector arrangement specifier (for FloatingPoint/Advanced SIMD insn)\ntypedef enum arm64_vas {\n\tARM64_VAS_INVALID = 0,\n\tARM64_VAS_8B,\n\tARM64_VAS_16B,\n\tARM64_VAS_4H,\n\tARM64_VAS_8H,\n\tARM64_VAS_2S,\n\tARM64_VAS_4S,\n\tARM64_VAS_1D,\n\tARM64_VAS_2D,\n\tARM64_VAS_1Q,\n} arm64_vas;\n\n//> Vector element size specifier\ntypedef enum arm64_vess {\n\tARM64_VESS_INVALID = 0,\n\tARM64_VESS_B,\n\tARM64_VESS_H,\n\tARM64_VESS_S,\n\tARM64_VESS_D,\n} arm64_vess;\n\n//> Memory barrier operands\ntypedef enum arm64_barrier_op {\n\tARM64_BARRIER_INVALID = 0,\n\tARM64_BARRIER_OSHLD = 0x1,\n\tARM64_BARRIER_OSHST = 0x2,\n\tARM64_BARRIER_OSH =   0x3,\n\tARM64_BARRIER_NSHLD = 0x5,\n\tARM64_BARRIER_NSHST = 0x6,\n\tARM64_BARRIER_NSH =   0x7,\n\tARM64_BARRIER_ISHLD = 0x9,\n\tARM64_BARRIER_ISHST = 0xa,\n\tARM64_BARRIER_ISH =   0xb,\n\tARM64_BARRIER_LD =    0xd,\n\tARM64_BARRIER_ST =    0xe,\n\tARM64_BARRIER_SY =    0xf\n} arm64_barrier_op;\n\n//> Operand type for instruction's operands\ntypedef enum arm64_op_type {\n\tARM64_OP_INVALID = 0, // = CS_OP_INVALID (Uninitialized).\n\tARM64_OP_REG, // = CS_OP_REG (Register operand).\n\tARM64_OP_IMM, // = CS_OP_IMM (Immediate operand).\n\tARM64_OP_MEM, // = CS_OP_MEM (Memory operand).\n\tARM64_OP_FP,  // = CS_OP_FP (Floating-Point operand).\n\tARM64_OP_CIMM = 64, // C-Immediate\n\tARM64_OP_REG_MRS, // MRS register operand.\n\tARM64_OP_REG_MSR, // MSR register operand.\n\tARM64_OP_PSTATE, // PState operand.\n\tARM64_OP_SYS, // SYS operand for IC/DC/AT/TLBI instructions.\n\tARM64_OP_PREFETCH, // Prefetch operand (PRFM).\n\tARM64_OP_BARRIER, // Memory barrier operand (ISB/DMB/DSB instructions).\n} arm64_op_type;\n\n//> TLBI operations\ntypedef enum arm64_tlbi_op {\n\tARM64_TLBI_INVALID = 0,\n\tARM64_TLBI_VMALLE1IS,\n\tARM64_TLBI_VAE1IS,\n\tARM64_TLBI_ASIDE1IS,\n\tARM64_TLBI_VAAE1IS,\n\tARM64_TLBI_VALE1IS,\n\tARM64_TLBI_VAALE1IS,\n\tARM64_TLBI_ALLE2IS,\n\tARM64_TLBI_VAE2IS,\n\tARM64_TLBI_ALLE1IS,\n\tARM64_TLBI_VALE2IS,\n\tARM64_TLBI_VMALLS12E1IS,\n\tARM64_TLBI_ALLE3IS,\n\tARM64_TLBI_VAE3IS,\n\tARM64_TLBI_VALE3IS,\n\tARM64_TLBI_IPAS2E1IS,\n\tARM64_TLBI_IPAS2LE1IS,\n\tARM64_TLBI_IPAS2E1,\n\tARM64_TLBI_IPAS2LE1,\n\tARM64_TLBI_VMALLE1,\n\tARM64_TLBI_VAE1,\n\tARM64_TLBI_ASIDE1,\n\tARM64_TLBI_VAAE1,\n\tARM64_TLBI_VALE1,\n\tARM64_TLBI_VAALE1,\n\tARM64_TLBI_ALLE2,\n\tARM64_TLBI_VAE2,\n\tARM64_TLBI_ALLE1,\n\tARM64_TLBI_VALE2,\n\tARM64_TLBI_VMALLS12E1,\n\tARM64_TLBI_ALLE3,\n\tARM64_TLBI_VAE3,\n\tARM64_TLBI_VALE3,\n} arm64_tlbi_op;\n\n//> AT operations\ntypedef enum arm64_at_op {\n\tARM64_AT_S1E1R,\n\tARM64_AT_S1E1W,\n\tARM64_AT_S1E0R,\n\tARM64_AT_S1E0W,\n\tARM64_AT_S1E2R,\n\tARM64_AT_S1E2W,\n\tARM64_AT_S12E1R,\n\tARM64_AT_S12E1W,\n\tARM64_AT_S12E0R,\n\tARM64_AT_S12E0W,\n\tARM64_AT_S1E3R,\n\tARM64_AT_S1E3W,\n} arm64_at_op;\n\n//> DC operations\ntypedef enum arm64_dc_op {\n\tARM64_DC_INVALID = 0,\n\tARM64_DC_ZVA,\n\tARM64_DC_IVAC,\n\tARM64_DC_ISW,\n\tARM64_DC_CVAC,\n\tARM64_DC_CSW,\n\tARM64_DC_CVAU,\n\tARM64_DC_CIVAC,\n\tARM64_DC_CISW,\n} arm64_dc_op;\n\n//> IC operations\ntypedef enum arm64_ic_op {\n\tARM64_IC_INVALID = 0,\n\tARM64_IC_IALLUIS,\n\tARM64_IC_IALLU,\n\tARM64_IC_IVAU,\n} arm64_ic_op;\n\n//> Prefetch operations (PRFM)\ntypedef enum arm64_prefetch_op {\n\tARM64_PRFM_INVALID = 0,\n\tARM64_PRFM_PLDL1KEEP = 0x00 + 1,\n\tARM64_PRFM_PLDL1STRM = 0x01 + 1,\n\tARM64_PRFM_PLDL2KEEP = 0x02 + 1,\n\tARM64_PRFM_PLDL2STRM = 0x03 + 1,\n\tARM64_PRFM_PLDL3KEEP = 0x04 + 1,\n\tARM64_PRFM_PLDL3STRM = 0x05 + 1,\n\tARM64_PRFM_PLIL1KEEP = 0x08 + 1,\n\tARM64_PRFM_PLIL1STRM = 0x09 + 1,\n\tARM64_PRFM_PLIL2KEEP = 0x0a + 1,\n\tARM64_PRFM_PLIL2STRM = 0x0b + 1,\n\tARM64_PRFM_PLIL3KEEP = 0x0c + 1,\n\tARM64_PRFM_PLIL3STRM = 0x0d + 1,\n\tARM64_PRFM_PSTL1KEEP = 0x10 + 1,\n\tARM64_PRFM_PSTL1STRM = 0x11 + 1,\n\tARM64_PRFM_PSTL2KEEP = 0x12 + 1,\n\tARM64_PRFM_PSTL2STRM = 0x13 + 1,\n\tARM64_PRFM_PSTL3KEEP = 0x14 + 1,\n\tARM64_PRFM_PSTL3STRM = 0x15 + 1,\n} arm64_prefetch_op;\n\n// Instruction's operand referring to memory\n// This is associated with ARM64_OP_MEM operand type above\ntypedef struct arm64_op_mem {\n\tunsigned int base;\t// base register\n\tunsigned int index;\t// index register\n\tint32_t disp;\t// displacement/offset value\n} arm64_op_mem;\n\n// Instruction operand\ntypedef struct cs_arm64_op {\n\tint vector_index;\t// Vector Index for some vector operands (or -1 if irrelevant)\n\tarm64_vas vas;\t\t// Vector Arrangement Specifier\n\tarm64_vess vess;\t// Vector Element Size Specifier\n\tstruct {\n\t\tarm64_shifter type;\t// shifter type of this operand\n\t\tunsigned int value;\t// shifter value of this operand\n\t} shift;\n\tarm64_extender ext;\t\t// extender type of this operand\n\tarm64_op_type type;\t// operand type\n\tunion {\n\t\tunsigned int reg;\t// register value for REG operand\n\t\tint64_t imm;\t\t// immediate value, or index for C-IMM or IMM operand\n\t\tdouble fp;\t\t\t// floating point value for FP operand\n\t\tarm64_op_mem mem;\t\t// base/index/scale/disp value for MEM operand\n\t\tarm64_pstate pstate;\t\t// PState field of MSR instruction.\n\t\tunsigned int sys;  // IC/DC/AT/TLBI operation (see arm64_ic_op, arm64_dc_op, arm64_at_op, arm64_tlbi_op)\n\t\tarm64_prefetch_op prefetch;  // PRFM operation.\n\t\tarm64_barrier_op barrier;  // Memory barrier operation (ISB/DMB/DSB instructions).\n\t};\n} cs_arm64_op;\n\n// Instruction structure\ntypedef struct cs_arm64 {\n\tarm64_cc cc;\t// conditional code for this insn\n\tbool update_flags;\t// does this insn update flags?\n\tbool writeback;\t// does this insn request writeback? 'True' means 'yes'\n\n\t// Number of operands of this instruction, \n\t// or 0 when instruction has no operand.\n\tuint8_t op_count;\n\n\tcs_arm64_op operands[8]; // operands for this instruction.\n} cs_arm64;\n\n//> ARM64 registers\ntypedef enum arm64_reg {\n\tARM64_REG_INVALID = 0,\n\n\tARM64_REG_X29,\n\tARM64_REG_X30,\n\tARM64_REG_NZCV,\n\tARM64_REG_SP,\n\tARM64_REG_WSP,\n\tARM64_REG_WZR,\n\tARM64_REG_XZR,\n\tARM64_REG_B0,\n\tARM64_REG_B1,\n\tARM64_REG_B2,\n\tARM64_REG_B3,\n\tARM64_REG_B4,\n\tARM64_REG_B5,\n\tARM64_REG_B6,\n\tARM64_REG_B7,\n\tARM64_REG_B8,\n\tARM64_REG_B9,\n\tARM64_REG_B10,\n\tARM64_REG_B11,\n\tARM64_REG_B12,\n\tARM64_REG_B13,\n\tARM64_REG_B14,\n\tARM64_REG_B15,\n\tARM64_REG_B16,\n\tARM64_REG_B17,\n\tARM64_REG_B18,\n\tARM64_REG_B19,\n\tARM64_REG_B20,\n\tARM64_REG_B21,\n\tARM64_REG_B22,\n\tARM64_REG_B23,\n\tARM64_REG_B24,\n\tARM64_REG_B25,\n\tARM64_REG_B26,\n\tARM64_REG_B27,\n\tARM64_REG_B28,\n\tARM64_REG_B29,\n\tARM64_REG_B30,\n\tARM64_REG_B31,\n\tARM64_REG_D0,\n\tARM64_REG_D1,\n\tARM64_REG_D2,\n\tARM64_REG_D3,\n\tARM64_REG_D4,\n\tARM64_REG_D5,\n\tARM64_REG_D6,\n\tARM64_REG_D7,\n\tARM64_REG_D8,\n\tARM64_REG_D9,\n\tARM64_REG_D10,\n\tARM64_REG_D11,\n\tARM64_REG_D12,\n\tARM64_REG_D13,\n\tARM64_REG_D14,\n\tARM64_REG_D15,\n\tARM64_REG_D16,\n\tARM64_REG_D17,\n\tARM64_REG_D18,\n\tARM64_REG_D19,\n\tARM64_REG_D20,\n\tARM64_REG_D21,\n\tARM64_REG_D22,\n\tARM64_REG_D23,\n\tARM64_REG_D24,\n\tARM64_REG_D25,\n\tARM64_REG_D26,\n\tARM64_REG_D27,\n\tARM64_REG_D28,\n\tARM64_REG_D29,\n\tARM64_REG_D30,\n\tARM64_REG_D31,\n\tARM64_REG_H0,\n\tARM64_REG_H1,\n\tARM64_REG_H2,\n\tARM64_REG_H3,\n\tARM64_REG_H4,\n\tARM64_REG_H5,\n\tARM64_REG_H6,\n\tARM64_REG_H7,\n\tARM64_REG_H8,\n\tARM64_REG_H9,\n\tARM64_REG_H10,\n\tARM64_REG_H11,\n\tARM64_REG_H12,\n\tARM64_REG_H13,\n\tARM64_REG_H14,\n\tARM64_REG_H15,\n\tARM64_REG_H16,\n\tARM64_REG_H17,\n\tARM64_REG_H18,\n\tARM64_REG_H19,\n\tARM64_REG_H20,\n\tARM64_REG_H21,\n\tARM64_REG_H22,\n\tARM64_REG_H23,\n\tARM64_REG_H24,\n\tARM64_REG_H25,\n\tARM64_REG_H26,\n\tARM64_REG_H27,\n\tARM64_REG_H28,\n\tARM64_REG_H29,\n\tARM64_REG_H30,\n\tARM64_REG_H31,\n\tARM64_REG_Q0,\n\tARM64_REG_Q1,\n\tARM64_REG_Q2,\n\tARM64_REG_Q3,\n\tARM64_REG_Q4,\n\tARM64_REG_Q5,\n\tARM64_REG_Q6,\n\tARM64_REG_Q7,\n\tARM64_REG_Q8,\n\tARM64_REG_Q9,\n\tARM64_REG_Q10,\n\tARM64_REG_Q11,\n\tARM64_REG_Q12,\n\tARM64_REG_Q13,\n\tARM64_REG_Q14,\n\tARM64_REG_Q15,\n\tARM64_REG_Q16,\n\tARM64_REG_Q17,\n\tARM64_REG_Q18,\n\tARM64_REG_Q19,\n\tARM64_REG_Q20,\n\tARM64_REG_Q21,\n\tARM64_REG_Q22,\n\tARM64_REG_Q23,\n\tARM64_REG_Q24,\n\tARM64_REG_Q25,\n\tARM64_REG_Q26,\n\tARM64_REG_Q27,\n\tARM64_REG_Q28,\n\tARM64_REG_Q29,\n\tARM64_REG_Q30,\n\tARM64_REG_Q31,\n\tARM64_REG_S0,\n\tARM64_REG_S1,\n\tARM64_REG_S2,\n\tARM64_REG_S3,\n\tARM64_REG_S4,\n\tARM64_REG_S5,\n\tARM64_REG_S6,\n\tARM64_REG_S7,\n\tARM64_REG_S8,\n\tARM64_REG_S9,\n\tARM64_REG_S10,\n\tARM64_REG_S11,\n\tARM64_REG_S12,\n\tARM64_REG_S13,\n\tARM64_REG_S14,\n\tARM64_REG_S15,\n\tARM64_REG_S16,\n\tARM64_REG_S17,\n\tARM64_REG_S18,\n\tARM64_REG_S19,\n\tARM64_REG_S20,\n\tARM64_REG_S21,\n\tARM64_REG_S22,\n\tARM64_REG_S23,\n\tARM64_REG_S24,\n\tARM64_REG_S25,\n\tARM64_REG_S26,\n\tARM64_REG_S27,\n\tARM64_REG_S28,\n\tARM64_REG_S29,\n\tARM64_REG_S30,\n\tARM64_REG_S31,\n\tARM64_REG_W0,\n\tARM64_REG_W1,\n\tARM64_REG_W2,\n\tARM64_REG_W3,\n\tARM64_REG_W4,\n\tARM64_REG_W5,\n\tARM64_REG_W6,\n\tARM64_REG_W7,\n\tARM64_REG_W8,\n\tARM64_REG_W9,\n\tARM64_REG_W10,\n\tARM64_REG_W11,\n\tARM64_REG_W12,\n\tARM64_REG_W13,\n\tARM64_REG_W14,\n\tARM64_REG_W15,\n\tARM64_REG_W16,\n\tARM64_REG_W17,\n\tARM64_REG_W18,\n\tARM64_REG_W19,\n\tARM64_REG_W20,\n\tARM64_REG_W21,\n\tARM64_REG_W22,\n\tARM64_REG_W23,\n\tARM64_REG_W24,\n\tARM64_REG_W25,\n\tARM64_REG_W26,\n\tARM64_REG_W27,\n\tARM64_REG_W28,\n\tARM64_REG_W29,\n\tARM64_REG_W30,\n\tARM64_REG_X0,\n\tARM64_REG_X1,\n\tARM64_REG_X2,\n\tARM64_REG_X3,\n\tARM64_REG_X4,\n\tARM64_REG_X5,\n\tARM64_REG_X6,\n\tARM64_REG_X7,\n\tARM64_REG_X8,\n\tARM64_REG_X9,\n\tARM64_REG_X10,\n\tARM64_REG_X11,\n\tARM64_REG_X12,\n\tARM64_REG_X13,\n\tARM64_REG_X14,\n\tARM64_REG_X15,\n\tARM64_REG_X16,\n\tARM64_REG_X17,\n\tARM64_REG_X18,\n\tARM64_REG_X19,\n\tARM64_REG_X20,\n\tARM64_REG_X21,\n\tARM64_REG_X22,\n\tARM64_REG_X23,\n\tARM64_REG_X24,\n\tARM64_REG_X25,\n\tARM64_REG_X26,\n\tARM64_REG_X27,\n\tARM64_REG_X28,\n\n\tARM64_REG_V0,\n\tARM64_REG_V1,\n\tARM64_REG_V2,\n\tARM64_REG_V3,\n\tARM64_REG_V4,\n\tARM64_REG_V5,\n\tARM64_REG_V6,\n\tARM64_REG_V7,\n\tARM64_REG_V8,\n\tARM64_REG_V9,\n\tARM64_REG_V10,\n\tARM64_REG_V11,\n\tARM64_REG_V12,\n\tARM64_REG_V13,\n\tARM64_REG_V14,\n\tARM64_REG_V15,\n\tARM64_REG_V16,\n\tARM64_REG_V17,\n\tARM64_REG_V18,\n\tARM64_REG_V19,\n\tARM64_REG_V20,\n\tARM64_REG_V21,\n\tARM64_REG_V22,\n\tARM64_REG_V23,\n\tARM64_REG_V24,\n\tARM64_REG_V25,\n\tARM64_REG_V26,\n\tARM64_REG_V27,\n\tARM64_REG_V28,\n\tARM64_REG_V29,\n\tARM64_REG_V30,\n\tARM64_REG_V31,\n\n\tARM64_REG_ENDING,\t\t// <-- mark the end of the list of registers\n\n\t//> alias registers\n\n\tARM64_REG_IP0 = ARM64_REG_X16,\n\tARM64_REG_IP1 = ARM64_REG_X17,\n\tARM64_REG_FP = ARM64_REG_X29,\n\tARM64_REG_LR = ARM64_REG_X30,\n} arm64_reg;\n\n//> ARM64 instruction\ntypedef enum arm64_insn {\n\tARM64_INS_INVALID = 0,\n\n\tARM64_INS_ABS,\n\tARM64_INS_ADC,\n\tARM64_INS_ADDHN,\n\tARM64_INS_ADDHN2,\n\tARM64_INS_ADDP,\n\tARM64_INS_ADD,\n\tARM64_INS_ADDV,\n\tARM64_INS_ADR,\n\tARM64_INS_ADRP,\n\tARM64_INS_AESD,\n\tARM64_INS_AESE,\n\tARM64_INS_AESIMC,\n\tARM64_INS_AESMC,\n\tARM64_INS_AND,\n\tARM64_INS_ASR,\n\tARM64_INS_B,\n\tARM64_INS_BFM,\n\tARM64_INS_BIC,\n\tARM64_INS_BIF,\n\tARM64_INS_BIT,\n\tARM64_INS_BL,\n\tARM64_INS_BLR,\n\tARM64_INS_BR,\n\tARM64_INS_BRK,\n\tARM64_INS_BSL,\n\tARM64_INS_CBNZ,\n\tARM64_INS_CBZ,\n\tARM64_INS_CCMN,\n\tARM64_INS_CCMP,\n\tARM64_INS_CLREX,\n\tARM64_INS_CLS,\n\tARM64_INS_CLZ,\n\tARM64_INS_CMEQ,\n\tARM64_INS_CMGE,\n\tARM64_INS_CMGT,\n\tARM64_INS_CMHI,\n\tARM64_INS_CMHS,\n\tARM64_INS_CMLE,\n\tARM64_INS_CMLT,\n\tARM64_INS_CMTST,\n\tARM64_INS_CNT,\n\tARM64_INS_MOV,\n\tARM64_INS_CRC32B,\n\tARM64_INS_CRC32CB,\n\tARM64_INS_CRC32CH,\n\tARM64_INS_CRC32CW,\n\tARM64_INS_CRC32CX,\n\tARM64_INS_CRC32H,\n\tARM64_INS_CRC32W,\n\tARM64_INS_CRC32X,\n\tARM64_INS_CSEL,\n\tARM64_INS_CSINC,\n\tARM64_INS_CSINV,\n\tARM64_INS_CSNEG,\n\tARM64_INS_DCPS1,\n\tARM64_INS_DCPS2,\n\tARM64_INS_DCPS3,\n\tARM64_INS_DMB,\n\tARM64_INS_DRPS,\n\tARM64_INS_DSB,\n\tARM64_INS_DUP,\n\tARM64_INS_EON,\n\tARM64_INS_EOR,\n\tARM64_INS_ERET,\n\tARM64_INS_EXTR,\n\tARM64_INS_EXT,\n\tARM64_INS_FABD,\n\tARM64_INS_FABS,\n\tARM64_INS_FACGE,\n\tARM64_INS_FACGT,\n\tARM64_INS_FADD,\n\tARM64_INS_FADDP,\n\tARM64_INS_FCCMP,\n\tARM64_INS_FCCMPE,\n\tARM64_INS_FCMEQ,\n\tARM64_INS_FCMGE,\n\tARM64_INS_FCMGT,\n\tARM64_INS_FCMLE,\n\tARM64_INS_FCMLT,\n\tARM64_INS_FCMP,\n\tARM64_INS_FCMPE,\n\tARM64_INS_FCSEL,\n\tARM64_INS_FCVTAS,\n\tARM64_INS_FCVTAU,\n\tARM64_INS_FCVT,\n\tARM64_INS_FCVTL,\n\tARM64_INS_FCVTL2,\n\tARM64_INS_FCVTMS,\n\tARM64_INS_FCVTMU,\n\tARM64_INS_FCVTNS,\n\tARM64_INS_FCVTNU,\n\tARM64_INS_FCVTN,\n\tARM64_INS_FCVTN2,\n\tARM64_INS_FCVTPS,\n\tARM64_INS_FCVTPU,\n\tARM64_INS_FCVTXN,\n\tARM64_INS_FCVTXN2,\n\tARM64_INS_FCVTZS,\n\tARM64_INS_FCVTZU,\n\tARM64_INS_FDIV,\n\tARM64_INS_FMADD,\n\tARM64_INS_FMAX,\n\tARM64_INS_FMAXNM,\n\tARM64_INS_FMAXNMP,\n\tARM64_INS_FMAXNMV,\n\tARM64_INS_FMAXP,\n\tARM64_INS_FMAXV,\n\tARM64_INS_FMIN,\n\tARM64_INS_FMINNM,\n\tARM64_INS_FMINNMP,\n\tARM64_INS_FMINNMV,\n\tARM64_INS_FMINP,\n\tARM64_INS_FMINV,\n\tARM64_INS_FMLA,\n\tARM64_INS_FMLS,\n\tARM64_INS_FMOV,\n\tARM64_INS_FMSUB,\n\tARM64_INS_FMUL,\n\tARM64_INS_FMULX,\n\tARM64_INS_FNEG,\n\tARM64_INS_FNMADD,\n\tARM64_INS_FNMSUB,\n\tARM64_INS_FNMUL,\n\tARM64_INS_FRECPE,\n\tARM64_INS_FRECPS,\n\tARM64_INS_FRECPX,\n\tARM64_INS_FRINTA,\n\tARM64_INS_FRINTI,\n\tARM64_INS_FRINTM,\n\tARM64_INS_FRINTN,\n\tARM64_INS_FRINTP,\n\tARM64_INS_FRINTX,\n\tARM64_INS_FRINTZ,\n\tARM64_INS_FRSQRTE,\n\tARM64_INS_FRSQRTS,\n\tARM64_INS_FSQRT,\n\tARM64_INS_FSUB,\n\tARM64_INS_HINT,\n\tARM64_INS_HLT,\n\tARM64_INS_HVC,\n\tARM64_INS_INS,\n\n\tARM64_INS_ISB,\n\tARM64_INS_LD1,\n\tARM64_INS_LD1R,\n\tARM64_INS_LD2R,\n\tARM64_INS_LD2,\n\tARM64_INS_LD3R,\n\tARM64_INS_LD3,\n\tARM64_INS_LD4,\n\tARM64_INS_LD4R,\n\n\tARM64_INS_LDARB,\n\tARM64_INS_LDARH,\n\tARM64_INS_LDAR,\n\tARM64_INS_LDAXP,\n\tARM64_INS_LDAXRB,\n\tARM64_INS_LDAXRH,\n\tARM64_INS_LDAXR,\n\tARM64_INS_LDNP,\n\tARM64_INS_LDP,\n\tARM64_INS_LDPSW,\n\tARM64_INS_LDRB,\n\tARM64_INS_LDR,\n\tARM64_INS_LDRH,\n\tARM64_INS_LDRSB,\n\tARM64_INS_LDRSH,\n\tARM64_INS_LDRSW,\n\tARM64_INS_LDTRB,\n\tARM64_INS_LDTRH,\n\tARM64_INS_LDTRSB,\n\n\tARM64_INS_LDTRSH,\n\tARM64_INS_LDTRSW,\n\tARM64_INS_LDTR,\n\tARM64_INS_LDURB,\n\tARM64_INS_LDUR,\n\tARM64_INS_LDURH,\n\tARM64_INS_LDURSB,\n\tARM64_INS_LDURSH,\n\tARM64_INS_LDURSW,\n\tARM64_INS_LDXP,\n\tARM64_INS_LDXRB,\n\tARM64_INS_LDXRH,\n\tARM64_INS_LDXR,\n\tARM64_INS_LSL,\n\tARM64_INS_LSR,\n\tARM64_INS_MADD,\n\tARM64_INS_MLA,\n\tARM64_INS_MLS,\n\tARM64_INS_MOVI,\n\tARM64_INS_MOVK,\n\tARM64_INS_MOVN,\n\tARM64_INS_MOVZ,\n\tARM64_INS_MRS,\n\tARM64_INS_MSR,\n\tARM64_INS_MSUB,\n\tARM64_INS_MUL,\n\tARM64_INS_MVNI,\n\tARM64_INS_NEG,\n\tARM64_INS_NOT,\n\tARM64_INS_ORN,\n\tARM64_INS_ORR,\n\tARM64_INS_PMULL2,\n\tARM64_INS_PMULL,\n\tARM64_INS_PMUL,\n\tARM64_INS_PRFM,\n\tARM64_INS_PRFUM,\n\tARM64_INS_RADDHN,\n\tARM64_INS_RADDHN2,\n\tARM64_INS_RBIT,\n\tARM64_INS_RET,\n\tARM64_INS_REV16,\n\tARM64_INS_REV32,\n\tARM64_INS_REV64,\n\tARM64_INS_REV,\n\tARM64_INS_ROR,\n\tARM64_INS_RSHRN2,\n\tARM64_INS_RSHRN,\n\tARM64_INS_RSUBHN,\n\tARM64_INS_RSUBHN2,\n\tARM64_INS_SABAL2,\n\tARM64_INS_SABAL,\n\n\tARM64_INS_SABA,\n\tARM64_INS_SABDL2,\n\tARM64_INS_SABDL,\n\tARM64_INS_SABD,\n\tARM64_INS_SADALP,\n\tARM64_INS_SADDLP,\n\tARM64_INS_SADDLV,\n\tARM64_INS_SADDL2,\n\tARM64_INS_SADDL,\n\tARM64_INS_SADDW2,\n\tARM64_INS_SADDW,\n\tARM64_INS_SBC,\n\tARM64_INS_SBFM,\n\tARM64_INS_SCVTF,\n\tARM64_INS_SDIV,\n\tARM64_INS_SHA1C,\n\tARM64_INS_SHA1H,\n\tARM64_INS_SHA1M,\n\tARM64_INS_SHA1P,\n\tARM64_INS_SHA1SU0,\n\tARM64_INS_SHA1SU1,\n\tARM64_INS_SHA256H2,\n\tARM64_INS_SHA256H,\n\tARM64_INS_SHA256SU0,\n\tARM64_INS_SHA256SU1,\n\tARM64_INS_SHADD,\n\tARM64_INS_SHLL2,\n\tARM64_INS_SHLL,\n\tARM64_INS_SHL,\n\tARM64_INS_SHRN2,\n\tARM64_INS_SHRN,\n\tARM64_INS_SHSUB,\n\tARM64_INS_SLI,\n\tARM64_INS_SMADDL,\n\tARM64_INS_SMAXP,\n\tARM64_INS_SMAXV,\n\tARM64_INS_SMAX,\n\tARM64_INS_SMC,\n\tARM64_INS_SMINP,\n\tARM64_INS_SMINV,\n\tARM64_INS_SMIN,\n\tARM64_INS_SMLAL2,\n\tARM64_INS_SMLAL,\n\tARM64_INS_SMLSL2,\n\tARM64_INS_SMLSL,\n\tARM64_INS_SMOV,\n\tARM64_INS_SMSUBL,\n\tARM64_INS_SMULH,\n\tARM64_INS_SMULL2,\n\tARM64_INS_SMULL,\n\tARM64_INS_SQABS,\n\tARM64_INS_SQADD,\n\tARM64_INS_SQDMLAL,\n\tARM64_INS_SQDMLAL2,\n\tARM64_INS_SQDMLSL,\n\tARM64_INS_SQDMLSL2,\n\tARM64_INS_SQDMULH,\n\tARM64_INS_SQDMULL,\n\tARM64_INS_SQDMULL2,\n\tARM64_INS_SQNEG,\n\tARM64_INS_SQRDMULH,\n\tARM64_INS_SQRSHL,\n\tARM64_INS_SQRSHRN,\n\tARM64_INS_SQRSHRN2,\n\tARM64_INS_SQRSHRUN,\n\tARM64_INS_SQRSHRUN2,\n\tARM64_INS_SQSHLU,\n\tARM64_INS_SQSHL,\n\tARM64_INS_SQSHRN,\n\tARM64_INS_SQSHRN2,\n\tARM64_INS_SQSHRUN,\n\tARM64_INS_SQSHRUN2,\n\tARM64_INS_SQSUB,\n\tARM64_INS_SQXTN2,\n\tARM64_INS_SQXTN,\n\tARM64_INS_SQXTUN2,\n\tARM64_INS_SQXTUN,\n\tARM64_INS_SRHADD,\n\tARM64_INS_SRI,\n\tARM64_INS_SRSHL,\n\tARM64_INS_SRSHR,\n\tARM64_INS_SRSRA,\n\tARM64_INS_SSHLL2,\n\tARM64_INS_SSHLL,\n\tARM64_INS_SSHL,\n\tARM64_INS_SSHR,\n\tARM64_INS_SSRA,\n\tARM64_INS_SSUBL2,\n\tARM64_INS_SSUBL,\n\tARM64_INS_SSUBW2,\n\tARM64_INS_SSUBW,\n\tARM64_INS_ST1,\n\tARM64_INS_ST2,\n\tARM64_INS_ST3,\n\tARM64_INS_ST4,\n\tARM64_INS_STLRB,\n\tARM64_INS_STLRH,\n\tARM64_INS_STLR,\n\tARM64_INS_STLXP,\n\tARM64_INS_STLXRB,\n\tARM64_INS_STLXRH,\n\tARM64_INS_STLXR,\n\tARM64_INS_STNP,\n\tARM64_INS_STP,\n\tARM64_INS_STRB,\n\tARM64_INS_STR,\n\tARM64_INS_STRH,\n\tARM64_INS_STTRB,\n\tARM64_INS_STTRH,\n\tARM64_INS_STTR,\n\tARM64_INS_STURB,\n\tARM64_INS_STUR,\n\tARM64_INS_STURH,\n\tARM64_INS_STXP,\n\tARM64_INS_STXRB,\n\tARM64_INS_STXRH,\n\tARM64_INS_STXR,\n\tARM64_INS_SUBHN,\n\tARM64_INS_SUBHN2,\n\tARM64_INS_SUB,\n\tARM64_INS_SUQADD,\n\tARM64_INS_SVC,\n\tARM64_INS_SYSL,\n\tARM64_INS_SYS,\n\tARM64_INS_TBL,\n\tARM64_INS_TBNZ,\n\tARM64_INS_TBX,\n\tARM64_INS_TBZ,\n\tARM64_INS_TRN1,\n\tARM64_INS_TRN2,\n\tARM64_INS_UABAL2,\n\tARM64_INS_UABAL,\n\tARM64_INS_UABA,\n\tARM64_INS_UABDL2,\n\tARM64_INS_UABDL,\n\tARM64_INS_UABD,\n\tARM64_INS_UADALP,\n\tARM64_INS_UADDLP,\n\tARM64_INS_UADDLV,\n\tARM64_INS_UADDL2,\n\tARM64_INS_UADDL,\n\tARM64_INS_UADDW2,\n\tARM64_INS_UADDW,\n\tARM64_INS_UBFM,\n\tARM64_INS_UCVTF,\n\tARM64_INS_UDIV,\n\tARM64_INS_UHADD,\n\tARM64_INS_UHSUB,\n\tARM64_INS_UMADDL,\n\tARM64_INS_UMAXP,\n\tARM64_INS_UMAXV,\n\tARM64_INS_UMAX,\n\tARM64_INS_UMINP,\n\tARM64_INS_UMINV,\n\tARM64_INS_UMIN,\n\tARM64_INS_UMLAL2,\n\tARM64_INS_UMLAL,\n\tARM64_INS_UMLSL2,\n\tARM64_INS_UMLSL,\n\tARM64_INS_UMOV,\n\tARM64_INS_UMSUBL,\n\tARM64_INS_UMULH,\n\tARM64_INS_UMULL2,\n\tARM64_INS_UMULL,\n\tARM64_INS_UQADD,\n\tARM64_INS_UQRSHL,\n\tARM64_INS_UQRSHRN,\n\tARM64_INS_UQRSHRN2,\n\tARM64_INS_UQSHL,\n\tARM64_INS_UQSHRN,\n\tARM64_INS_UQSHRN2,\n\tARM64_INS_UQSUB,\n\tARM64_INS_UQXTN2,\n\tARM64_INS_UQXTN,\n\tARM64_INS_URECPE,\n\tARM64_INS_URHADD,\n\tARM64_INS_URSHL,\n\tARM64_INS_URSHR,\n\tARM64_INS_URSQRTE,\n\tARM64_INS_URSRA,\n\tARM64_INS_USHLL2,\n\tARM64_INS_USHLL,\n\tARM64_INS_USHL,\n\tARM64_INS_USHR,\n\tARM64_INS_USQADD,\n\tARM64_INS_USRA,\n\tARM64_INS_USUBL2,\n\tARM64_INS_USUBL,\n\tARM64_INS_USUBW2,\n\tARM64_INS_USUBW,\n\tARM64_INS_UZP1,\n\tARM64_INS_UZP2,\n\tARM64_INS_XTN2,\n\tARM64_INS_XTN,\n\tARM64_INS_ZIP1,\n\tARM64_INS_ZIP2,\n\n\t// alias insn\n\tARM64_INS_MNEG,\n\tARM64_INS_UMNEGL,\n\tARM64_INS_SMNEGL,\n\tARM64_INS_NOP,\n\tARM64_INS_YIELD,\n\tARM64_INS_WFE,\n\tARM64_INS_WFI,\n\tARM64_INS_SEV,\n\tARM64_INS_SEVL,\n\tARM64_INS_NGC,\n\tARM64_INS_SBFIZ,\n\tARM64_INS_UBFIZ,\n\tARM64_INS_SBFX,\n\tARM64_INS_UBFX,\n\tARM64_INS_BFI,\n\tARM64_INS_BFXIL,\n\tARM64_INS_CMN,\n\tARM64_INS_MVN,\n\tARM64_INS_TST,\n\tARM64_INS_CSET,\n\tARM64_INS_CINC,\n\tARM64_INS_CSETM,\n\tARM64_INS_CINV,\n\tARM64_INS_CNEG,\n\tARM64_INS_SXTB,\n\tARM64_INS_SXTH,\n\tARM64_INS_SXTW,\n\tARM64_INS_CMP,\n\tARM64_INS_UXTB,\n\tARM64_INS_UXTH,\n\tARM64_INS_UXTW,\n\tARM64_INS_IC,\n\tARM64_INS_DC,\n\tARM64_INS_AT,\n\tARM64_INS_TLBI,\n\n\tARM64_INS_ENDING,  // <-- mark the end of the list of insn\n} arm64_insn;\n\n//> Group of ARM64 instructions\ntypedef enum arm64_insn_group {\n\tARM64_GRP_INVALID = 0, // = CS_GRP_INVALID\n\n\t//> Generic groups\n\t// all jump instructions (conditional+direct+indirect jumps)\n\tARM64_GRP_JUMP,\t// = CS_GRP_JUMP\n\n\t//> Architecture-specific groups\n\tARM64_GRP_CRYPTO = 128,\n\tARM64_GRP_FPARMV8,\n\tARM64_GRP_NEON,\n\tARM64_GRP_CRC,\n\n\tARM64_GRP_ENDING,  // <-- mark the end of the list of groups\n} arm64_insn_group;\n\n#ifdef __cplusplus\n}\n#endif\n\n#endif\n"
  },
  {
    "path": "EFI_DEBUG/EFI/OC/Kexts/Lilu.kext/Contents/Resources/Headers/capstone/capstone.h",
    "content": "#ifndef CAPSTONE_ENGINE_H\n#define CAPSTONE_ENGINE_H\n\n/* Capstone Disassembly Engine */\n/* By Nguyen Anh Quynh <aquynh@gmail.com>, 2013-2016 */\n\n#ifdef __cplusplus\nextern \"C\" {\n#endif\n\n#if !defined(_MSC_VER) || !defined(_KERNEL_MODE)\n#include <stdint.h>\n#endif\n\n#include <stdarg.h>\n\n#if defined(CAPSTONE_HAS_OSXKERNEL)\n#include <libkern/libkern.h>\n#else\n#include <stdlib.h>\n#include <stdio.h>\n#endif\n\n#include \"platform.h\"\n\n#ifdef _MSC_VER\n#pragma warning(disable:4201)\n#pragma warning(disable:4100)\n#define CAPSTONE_API __cdecl\n#ifdef CAPSTONE_SHARED\n#define CAPSTONE_EXPORT __declspec(dllexport)\n#else    // defined(CAPSTONE_STATIC)\n#define CAPSTONE_EXPORT\n#endif\n#else\n#define CAPSTONE_API\n#if defined(__GNUC__) && !defined(CAPSTONE_STATIC)\n#define CAPSTONE_EXPORT __attribute__((visibility(\"default\")))\n#else    // defined(CAPSTONE_STATIC)\n#define CAPSTONE_EXPORT\n#endif\n#endif\n\n#ifdef __GNUC__\n#define CAPSTONE_DEPRECATED __attribute__((deprecated))\n#elif defined(_MSC_VER)\n#define CAPSTONE_DEPRECATED __declspec(deprecated)\n#else\n#pragma message(\"WARNING: You need to implement CAPSTONE_DEPRECATED for this compiler\")\n#define CAPSTONE_DEPRECATED\n#endif\n\n// Capstone API version\n#define CS_API_MAJOR 3\n#define CS_API_MINOR 0\n\n// Capstone package version\n#define CS_VERSION_MAJOR CS_API_MAJOR\n#define CS_VERSION_MINOR CS_API_MINOR\n#define CS_VERSION_EXTRA 5\n\n// Macro to create combined version which can be compared to\n// result of cs_version() API.\n#define CS_MAKE_VERSION(major, minor) ((major << 8) + minor)\n\n// Handle using with all API\ntypedef size_t csh;\n\n// Architecture type\ntypedef enum cs_arch {\n\tCS_ARCH_ARM = 0,\t// ARM architecture (including Thumb, Thumb-2)\n\tCS_ARCH_ARM64,\t\t// ARM-64, also called AArch64\n\tCS_ARCH_MIPS,\t\t// Mips architecture\n\tCS_ARCH_X86,\t\t// X86 architecture (including x86 & x86-64)\n\tCS_ARCH_PPC,\t\t// PowerPC architecture\n\tCS_ARCH_SPARC,\t\t// Sparc architecture\n\tCS_ARCH_SYSZ,\t\t// SystemZ architecture\n\tCS_ARCH_XCORE,\t\t// XCore architecture\n\tCS_ARCH_MAX,\n\tCS_ARCH_ALL = 0xFFFF, // All architectures - for cs_support()\n} cs_arch;\n\n// Support value to verify diet mode of the engine.\n// If cs_support(CS_SUPPORT_DIET) return True, the engine was compiled\n// in diet mode.\n#define CS_SUPPORT_DIET (CS_ARCH_ALL + 1)\n\n// Support value to verify X86 reduce mode of the engine.\n// If cs_support(CS_SUPPORT_X86_REDUCE) return True, the engine was compiled\n// in X86 reduce mode.\n#define CS_SUPPORT_X86_REDUCE (CS_ARCH_ALL + 2)\n\n// Mode type\ntypedef enum cs_mode {\n\tCS_MODE_LITTLE_ENDIAN = 0,\t// little-endian mode (default mode)\n\tCS_MODE_ARM = 0,\t// 32-bit ARM\n\tCS_MODE_16 = 1 << 1,\t// 16-bit mode (X86)\n\tCS_MODE_32 = 1 << 2,\t// 32-bit mode (X86)\n\tCS_MODE_64 = 1 << 3,\t// 64-bit mode (X86, PPC)\n\tCS_MODE_THUMB = 1 << 4,\t// ARM's Thumb mode, including Thumb-2\n\tCS_MODE_MCLASS = 1 << 5,\t// ARM's Cortex-M series\n\tCS_MODE_V8 = 1 << 6,\t// ARMv8 A32 encodings for ARM\n\tCS_MODE_MICRO = 1 << 4, // MicroMips mode (MIPS)\n\tCS_MODE_MIPS3 = 1 << 5, // Mips III ISA\n\tCS_MODE_MIPS32R6 = 1 << 6, // Mips32r6 ISA\n\tCS_MODE_MIPSGP64 = 1 << 7, // General Purpose Registers are 64-bit wide (MIPS)\n\tCS_MODE_V9 = 1 << 4, // SparcV9 mode (Sparc)\n\tCS_MODE_BIG_ENDIAN = 1 << 31,\t// big-endian mode\n\tCS_MODE_MIPS32 = CS_MODE_32,\t// Mips32 ISA (Mips)\n\tCS_MODE_MIPS64 = CS_MODE_64,\t// Mips64 ISA (Mips)\n} cs_mode;\n\ntypedef void* (CAPSTONE_API *cs_malloc_t)(size_t size);\ntypedef void* (CAPSTONE_API *cs_calloc_t)(size_t nmemb, size_t size);\ntypedef void* (CAPSTONE_API *cs_realloc_t)(void *ptr, size_t size);\ntypedef void (CAPSTONE_API *cs_free_t)(void *ptr);\ntypedef int (CAPSTONE_API *cs_vsnprintf_t)(char *str, size_t size, const char *format, va_list ap);\n\n\n// User-defined dynamic memory related functions: malloc/calloc/realloc/free/vsnprintf()\n// By default, Capstone uses system's malloc(), calloc(), realloc(), free() & vsnprintf().\ntypedef struct cs_opt_mem {\n\tcs_malloc_t malloc;\n\tcs_calloc_t calloc;\n\tcs_realloc_t realloc;\n\tcs_free_t free;\n\tcs_vsnprintf_t vsnprintf;\n} cs_opt_mem;\n\n// Runtime option for the disassembled engine\ntypedef enum cs_opt_type {\n\tCS_OPT_INVALID = 0,\t// No option specified\n\tCS_OPT_SYNTAX,\t// Assembly output syntax\n\tCS_OPT_DETAIL,\t// Break down instruction structure into details\n\tCS_OPT_MODE,\t// Change engine's mode at run-time\n\tCS_OPT_MEM,\t// User-defined dynamic memory related functions\n\tCS_OPT_SKIPDATA, // Skip data when disassembling. Then engine is in SKIPDATA mode.\n\tCS_OPT_SKIPDATA_SETUP, // Setup user-defined function for SKIPDATA option\n} cs_opt_type;\n\n// Runtime option value (associated with option type above)\ntypedef enum cs_opt_value {\n\tCS_OPT_OFF = 0,  // Turn OFF an option - default option of CS_OPT_DETAIL, CS_OPT_SKIPDATA.\n\tCS_OPT_ON = 3, // Turn ON an option (CS_OPT_DETAIL, CS_OPT_SKIPDATA).\n\tCS_OPT_SYNTAX_DEFAULT = 0, // Default asm syntax (CS_OPT_SYNTAX).\n\tCS_OPT_SYNTAX_INTEL, // X86 Intel asm syntax - default on X86 (CS_OPT_SYNTAX).\n\tCS_OPT_SYNTAX_ATT,   // X86 ATT asm syntax (CS_OPT_SYNTAX).\n\tCS_OPT_SYNTAX_NOREGNAME, // Prints register name with only number (CS_OPT_SYNTAX)\n} cs_opt_value;\n\n//> Common instruction operand types - to be consistent across all architectures.\ntypedef enum cs_op_type {\n\tCS_OP_INVALID = 0,  // uninitialized/invalid operand.\n\tCS_OP_REG,          // Register operand.\n\tCS_OP_IMM,          // Immediate operand.\n\tCS_OP_MEM,          // Memory operand.\n\tCS_OP_FP,           // Floating-Point operand.\n} cs_op_type;\n\n//> Common instruction groups - to be consistent across all architectures.\ntypedef enum cs_group_type {\n\tCS_GRP_INVALID = 0,  // uninitialized/invalid group.\n\tCS_GRP_JUMP,    // all jump instructions (conditional+direct+indirect jumps)\n\tCS_GRP_CALL,    // all call instructions\n\tCS_GRP_RET,     // all return instructions\n\tCS_GRP_INT,     // all interrupt instructions (int+syscall)\n\tCS_GRP_IRET,    // all interrupt return instructions\n} cs_group_type;\n\n/*\n User-defined callback function for SKIPDATA option.\n See tests/test_skipdata.c for sample code demonstrating this API.\n\n @code: the input buffer containing code to be disassembled.\n        This is the same buffer passed to cs_disasm().\n @code_size: size (in bytes) of the above @code buffer.\n @offset: the position of the currently-examining byte in the input\n      buffer @code mentioned above.\n @user_data: user-data passed to cs_option() via @user_data field in\n      cs_opt_skipdata struct below.\n\n @return: return number of bytes to skip, or 0 to immediately stop disassembling.\n*/\ntypedef size_t (CAPSTONE_API *cs_skipdata_cb_t)(const uint8_t *code, size_t code_size, size_t offset, void *user_data);\n\n// User-customized setup for SKIPDATA option\ntypedef struct cs_opt_skipdata {\n\t// Capstone considers data to skip as special \"instructions\".\n\t// User can specify the string for this instruction's \"mnemonic\" here.\n\t// By default (if @mnemonic is NULL), Capstone use \".byte\".\n\tconst char *mnemonic;\n\n\t// User-defined callback function to be called when Capstone hits data.\n\t// If the returned value from this callback is positive (>0), Capstone\n\t// will skip exactly that number of bytes & continue. Otherwise, if\n\t// the callback returns 0, Capstone stops disassembling and returns\n\t// immediately from cs_disasm()\n\t// NOTE: if this callback pointer is NULL, Capstone would skip a number\n\t// of bytes depending on architectures, as following:\n\t// Arm:     2 bytes (Thumb mode) or 4 bytes.\n\t// Arm64:   4 bytes.\n\t// Mips:    4 bytes.\n\t// PowerPC: 4 bytes.\n\t// Sparc:   4 bytes.\n\t// SystemZ: 2 bytes.\n\t// X86:     1 bytes.\n\t// XCore:   2 bytes.\n\tcs_skipdata_cb_t callback; \t// default value is NULL\n\n\t// User-defined data to be passed to @callback function pointer.\n\tvoid *user_data;\n} cs_opt_skipdata;\n\n\n#include \"arm.h\"\n#include \"arm64.h\"\n#include \"mips.h\"\n#include \"ppc.h\"\n#include \"sparc.h\"\n#include \"systemz.h\"\n#include \"x86.h\"\n#include \"xcore.h\"\n\n// NOTE: All information in cs_detail is only available when CS_OPT_DETAIL = CS_OPT_ON\ntypedef struct cs_detail {\n\tuint8_t regs_read[12]; // list of implicit registers read by this insn\n\tuint8_t regs_read_count; // number of implicit registers read by this insn\n\n\tuint8_t regs_write[20]; // list of implicit registers modified by this insn\n\tuint8_t regs_write_count; // number of implicit registers modified by this insn\n\n\tuint8_t groups[8]; // list of group this instruction belong to\n\tuint8_t groups_count; // number of groups this insn belongs to\n\n\t// Architecture-specific instruction info\n\tunion {\n\t\tcs_x86 x86;\t// X86 architecture, including 16-bit, 32-bit & 64-bit mode\n\t\tcs_arm64 arm64;\t// ARM64 architecture (aka AArch64)\n\t\tcs_arm arm;\t\t// ARM architecture (including Thumb/Thumb2)\n\t\tcs_mips mips;\t// MIPS architecture\n\t\tcs_ppc ppc;\t// PowerPC architecture\n\t\tcs_sparc sparc;\t// Sparc architecture\n\t\tcs_sysz sysz;\t// SystemZ architecture\n\t\tcs_xcore xcore;\t// XCore architecture\n\t};\n} cs_detail;\n\n// Detail information of disassembled instruction\ntypedef struct cs_insn {\n\t// Instruction ID (basically a numeric ID for the instruction mnemonic)\n\t// Find the instruction id in the '[ARCH]_insn' enum in the header file \n\t// of corresponding architecture, such as 'arm_insn' in arm.h for ARM,\n\t// 'x86_insn' in x86.h for X86, etc...\n\t// This information is available even when CS_OPT_DETAIL = CS_OPT_OFF\n\t// NOTE: in Skipdata mode, \"data\" instruction has 0 for this id field.\n\tunsigned int id;\n\n\t// Address (EIP) of this instruction\n\t// This information is available even when CS_OPT_DETAIL = CS_OPT_OFF\n\tuint64_t address;\n\n\t// Size of this instruction\n\t// This information is available even when CS_OPT_DETAIL = CS_OPT_OFF\n\tuint16_t size;\n\t// Machine bytes of this instruction, with number of bytes indicated by @size above\n\t// This information is available even when CS_OPT_DETAIL = CS_OPT_OFF\n\tuint8_t bytes[16];\n\n\t// Ascii text of instruction mnemonic\n\t// This information is available even when CS_OPT_DETAIL = CS_OPT_OFF\n\tchar mnemonic[32];\n\n\t// Ascii text of instruction operands\n\t// This information is available even when CS_OPT_DETAIL = CS_OPT_OFF\n\tchar op_str[160];\n\n\t// Pointer to cs_detail.\n\t// NOTE: detail pointer is only valid when both requirements below are met:\n\t// (1) CS_OP_DETAIL = CS_OPT_ON\n\t// (2) Engine is not in Skipdata mode (CS_OP_SKIPDATA option set to CS_OPT_ON)\n\t//\n\t// NOTE 2: when in Skipdata mode, or when detail mode is OFF, even if this pointer\n\t//     is not NULL, its content is still irrelevant.\n\tcs_detail *detail;\n} cs_insn;\n\n\n// Calculate the offset of a disassembled instruction in its buffer, given its position\n// in its array of disassembled insn\n// NOTE: this macro works with position (>=1), not index\n#define CS_INSN_OFFSET(insns, post) (insns[post - 1].address - insns[0].address)\n\n\n// All type of errors encountered by Capstone API.\n// These are values returned by cs_errno()\ntypedef enum cs_err {\n\tCS_ERR_OK = 0,   // No error: everything was fine\n\tCS_ERR_MEM,      // Out-Of-Memory error: cs_open(), cs_disasm(), cs_disasm_iter()\n\tCS_ERR_ARCH,     // Unsupported architecture: cs_open()\n\tCS_ERR_HANDLE,   // Invalid handle: cs_op_count(), cs_op_index()\n\tCS_ERR_CSH,\t     // Invalid csh argument: cs_close(), cs_errno(), cs_option()\n\tCS_ERR_MODE,     // Invalid/unsupported mode: cs_open()\n\tCS_ERR_OPTION,   // Invalid/unsupported option: cs_option()\n\tCS_ERR_DETAIL,   // Information is unavailable because detail option is OFF\n\tCS_ERR_MEMSETUP, // Dynamic memory management uninitialized (see CS_OPT_MEM)\n\tCS_ERR_VERSION,  // Unsupported version (bindings)\n\tCS_ERR_DIET,     // Access irrelevant data in \"diet\" engine\n\tCS_ERR_SKIPDATA, // Access irrelevant data for \"data\" instruction in SKIPDATA mode\n\tCS_ERR_X86_ATT,  // X86 AT&T syntax is unsupported (opt-out at compile time)\n\tCS_ERR_X86_INTEL, // X86 Intel syntax is unsupported (opt-out at compile time)\n} cs_err;\n\n/*\n Return combined API version & major and minor version numbers.\n\n @major: major number of API version\n @minor: minor number of API version\n\n @return hexical number as (major << 8 | minor), which encodes both\n\t major & minor versions.\n\t NOTE: This returned value can be compared with version number made\n\t with macro CS_MAKE_VERSION\n\n For example, second API version would return 1 in @major, and 1 in @minor\n The return value would be 0x0101\n\n NOTE: if you only care about returned value, but not major and minor values,\n set both @major & @minor arguments to NULL.\n*/\nCAPSTONE_EXPORT\nunsigned int CAPSTONE_API cs_version(int *major, int *minor);\n\n\n/*\n This API can be used to either ask for archs supported by this library,\n or check to see if the library was compile with 'diet' option (or called\n in 'diet' mode).\n\n To check if a particular arch is supported by this library, set @query to\n arch mode (CS_ARCH_* value).\n To verify if this library supports all the archs, use CS_ARCH_ALL.\n\n To check if this library is in 'diet' mode, set @query to CS_SUPPORT_DIET.\n\n @return True if this library supports the given arch, or in 'diet' mode.\n*/\nCAPSTONE_EXPORT\nbool CAPSTONE_API cs_support(int query);\n\n/*\n Initialize CS handle: this must be done before any usage of CS.\n\n @arch: architecture type (CS_ARCH_*)\n @mode: hardware mode. This is combined of CS_MODE_*\n @handle: pointer to handle, which will be updated at return time\n\n @return CS_ERR_OK on success, or other value on failure (refer to cs_err enum\n for detailed error).\n*/\nCAPSTONE_EXPORT\ncs_err CAPSTONE_API cs_open(cs_arch arch, cs_mode mode, csh *handle);\n\n/*\n Close CS handle: MUST do to release the handle when it is not used anymore.\n NOTE: this must be only called when there is no longer usage of Capstone,\n not even access to cs_insn array. The reason is the this API releases some\n cached memory, thus access to any Capstone API after cs_close() might crash\n your application.\n\n In fact,this API invalidate @handle by ZERO out its value (i.e *handle = 0).\n\n @handle: pointer to a handle returned by cs_open()\n\n @return CS_ERR_OK on success, or other value on failure (refer to cs_err enum\n for detailed error).\n*/\nCAPSTONE_EXPORT\ncs_err CAPSTONE_API cs_close(csh *handle);\n\n/*\n Set option for disassembling engine at runtime\n\n @handle: handle returned by cs_open()\n @type: type of option to be set\n @value: option value corresponding with @type\n\n @return: CS_ERR_OK on success, or other value on failure.\n Refer to cs_err enum for detailed error.\n\n NOTE: in the case of CS_OPT_MEM, handle's value can be anything,\n so that cs_option(handle, CS_OPT_MEM, value) can (i.e must) be called\n even before cs_open()\n*/\nCAPSTONE_EXPORT\ncs_err CAPSTONE_API cs_option(csh handle, cs_opt_type type, size_t value);\n\n/*\n Report the last error number when some API function fail.\n Like glibc's errno, cs_errno might not retain its old value once accessed.\n\n @handle: handle returned by cs_open()\n\n @return: error code of cs_err enum type (CS_ERR_*, see above)\n*/\nCAPSTONE_EXPORT\ncs_err CAPSTONE_API cs_errno(csh handle);\n\n\n/*\n Return a string describing given error code.\n\n @code: error code (see CS_ERR_* above)\n\n @return: returns a pointer to a string that describes the error code\n\tpassed in the argument @code\n*/\nCAPSTONE_EXPORT\nconst char * CAPSTONE_API cs_strerror(cs_err code);\n\n/*\n Disassemble binary code, given the code buffer, size, address and number\n of instructions to be decoded.\n This API dynamically allocate memory to contain disassembled instruction.\n Resulted instructions will be put into @*insn\n\n NOTE 1: this API will automatically determine memory needed to contain\n output disassembled instructions in @insn.\n\n NOTE 2: caller must free the allocated memory itself to avoid memory leaking.\n\n NOTE 3: for system with scarce memory to be dynamically allocated such as\n OS kernel or firmware, the API cs_disasm_iter() might be a better choice than\n cs_disasm(). The reason is that with cs_disasm(), based on limited available\n memory, we have to calculate in advance how many instructions to be disassembled,\n which complicates things. This is especially troublesome for the case @count=0,\n when cs_disasm() runs uncontrollably (until either end of input buffer, or\n when it encounters an invalid instruction).\n \n @handle: handle returned by cs_open()\n @code: buffer containing raw binary code to be disassembled.\n @code_size: size of the above code buffer.\n @address: address of the first instruction in given raw code buffer.\n @insn: array of instructions filled in by this API.\n\t   NOTE: @insn will be allocated by this function, and should be freed\n\t   with cs_free() API.\n @count: number of instructions to be disassembled, or 0 to get all of them\n\n @return: the number of successfully disassembled instructions,\n or 0 if this function failed to disassemble the given code\n\n On failure, call cs_errno() for error code.\n*/\nCAPSTONE_EXPORT\nsize_t CAPSTONE_API cs_disasm(csh handle,\n\t\tconst uint8_t *code, size_t code_size,\n\t\tuint64_t address,\n\t\tsize_t count,\n\t\tcs_insn **insn);\n\n/*\n  Deprecated function - to be retired in the next version!\n  Use cs_disasm() instead of cs_disasm_ex()\n*/\nCAPSTONE_EXPORT\nCAPSTONE_DEPRECATED\nsize_t CAPSTONE_API cs_disasm_ex(csh handle,\n\t\tconst uint8_t *code, size_t code_size,\n\t\tuint64_t address,\n\t\tsize_t count,\n\t\tcs_insn **insn);\n\n/*\n Free memory allocated by cs_malloc() or cs_disasm() (argument @insn)\n\n @insn: pointer returned by @insn argument in cs_disasm() or cs_malloc()\n @count: number of cs_insn structures returned by cs_disasm(), or 1\n     to free memory allocated by cs_malloc().\n*/\nCAPSTONE_EXPORT\nvoid CAPSTONE_API cs_free(cs_insn *insn, size_t count);\n\n\n/*\n Allocate memory for 1 instruction to be used by cs_disasm_iter().\n\n @handle: handle returned by cs_open()\n\n NOTE: when no longer in use, you can reclaim the memory allocated for\n this instruction with cs_free(insn, 1)\n*/\nCAPSTONE_EXPORT\ncs_insn * CAPSTONE_API cs_malloc(csh handle);\n\n/*\n Fast API to disassemble binary code, given the code buffer, size, address\n and number of instructions to be decoded.\n This API put the resulted instruction into a given cache in @insn.\n See tests/test_iter.c for sample code demonstrating this API.\n\n NOTE 1: this API will update @code, @size & @address to point to the next\n instruction in the input buffer. Therefore, it is convenient to use\n cs_disasm_iter() inside a loop to quickly iterate all the instructions.\n While decoding one instruction at a time can also be achieved with\n cs_disasm(count=1), some benchmarks shown that cs_disasm_iter() can be 30%\n faster on random input.\n\n NOTE 2: the cache in @insn can be created with cs_malloc() API.\n\n NOTE 3: for system with scarce memory to be dynamically allocated such as\n OS kernel or firmware, this API is recommended over cs_disasm(), which\n allocates memory based on the number of instructions to be disassembled.\n The reason is that with cs_disasm(), based on limited available memory,\n we have to calculate in advance how many instructions to be disassembled,\n which complicates things. This is especially troublesome for the case\n @count=0, when cs_disasm() runs uncontrollably (until either end of input\n buffer, or when it encounters an invalid instruction).\n \n @handle: handle returned by cs_open()\n @code: buffer containing raw binary code to be disassembled\n @size: size of above code\n @address: address of the first insn in given raw code buffer\n @insn: pointer to instruction to be filled in by this API.\n\n @return: true if this API successfully decode 1 instruction,\n or false otherwise.\n\n On failure, call cs_errno() for error code.\n*/\nCAPSTONE_EXPORT\nbool CAPSTONE_API cs_disasm_iter(csh handle,\n\tconst uint8_t **code, size_t *size,\n\tuint64_t *address, cs_insn *insn);\n\n/*\n Return friendly name of register in a string.\n Find the instruction id from header file of corresponding architecture (arm.h for ARM,\n x86.h for X86, ...)\n\n WARN: when in 'diet' mode, this API is irrelevant because engine does not\n store register name.\n\n @handle: handle returned by cs_open()\n @reg_id: register id\n\n @return: string name of the register, or NULL if @reg_id is invalid.\n*/\nCAPSTONE_EXPORT\nconst char * CAPSTONE_API cs_reg_name(csh handle, unsigned int reg_id);\n\n/*\n Return friendly name of an instruction in a string.\n Find the instruction id from header file of corresponding architecture (arm.h for ARM, x86.h for X86, ...)\n\n WARN: when in 'diet' mode, this API is irrelevant because the engine does not\n store instruction name.\n\n @handle: handle returned by cs_open()\n @insn_id: instruction id\n\n @return: string name of the instruction, or NULL if @insn_id is invalid.\n*/\nCAPSTONE_EXPORT\nconst char * CAPSTONE_API cs_insn_name(csh handle, unsigned int insn_id);\n\n/*\n Return friendly name of a group id (that an instruction can belong to)\n Find the group id from header file of corresponding architecture (arm.h for ARM, x86.h for X86, ...)\n\n WARN: when in 'diet' mode, this API is irrelevant because the engine does not\n store group name.\n\n @handle: handle returned by cs_open()\n @group_id: group id\n\n @return: string name of the group, or NULL if @group_id is invalid.\n*/\nCAPSTONE_EXPORT\nconst char * CAPSTONE_API cs_group_name(csh handle, unsigned int group_id);\n\n/*\n Check if a disassembled instruction belong to a particular group.\n Find the group id from header file of corresponding architecture (arm.h for ARM, x86.h for X86, ...)\n Internally, this simply verifies if @group_id matches any member of insn->groups array.\n\n NOTE: this API is only valid when detail option is ON (which is OFF by default).\n\n WARN: when in 'diet' mode, this API is irrelevant because the engine does not\n update @groups array.\n\n @handle: handle returned by cs_open()\n @insn: disassembled instruction structure received from cs_disasm() or cs_disasm_iter()\n @group_id: group that you want to check if this instruction belong to.\n\n @return: true if this instruction indeed belongs to aboved group, or false otherwise.\n*/\nCAPSTONE_EXPORT\nbool CAPSTONE_API cs_insn_group(csh handle, const cs_insn *insn, unsigned int group_id);\n\n/*\n Check if a disassembled instruction IMPLICITLY used a particular register.\n Find the register id from header file of corresponding architecture (arm.h for ARM, x86.h for X86, ...)\n Internally, this simply verifies if @reg_id matches any member of insn->regs_read array.\n\n NOTE: this API is only valid when detail option is ON (which is OFF by default)\n\n WARN: when in 'diet' mode, this API is irrelevant because the engine does not\n update @regs_read array.\n\n @insn: disassembled instruction structure received from cs_disasm() or cs_disasm_iter()\n @reg_id: register that you want to check if this instruction used it.\n\n @return: true if this instruction indeed implicitly used aboved register, or false otherwise.\n*/\nCAPSTONE_EXPORT\nbool CAPSTONE_API cs_reg_read(csh handle, const cs_insn *insn, unsigned int reg_id);\n\n/*\n Check if a disassembled instruction IMPLICITLY modified a particular register.\n Find the register id from header file of corresponding architecture (arm.h for ARM, x86.h for X86, ...)\n Internally, this simply verifies if @reg_id matches any member of insn->regs_write array.\n\n NOTE: this API is only valid when detail option is ON (which is OFF by default)\n\n WARN: when in 'diet' mode, this API is irrelevant because the engine does not\n update @regs_write array.\n\n @insn: disassembled instruction structure received from cs_disasm() or cs_disasm_iter()\n @reg_id: register that you want to check if this instruction modified it.\n\n @return: true if this instruction indeed implicitly modified aboved register, or false otherwise.\n*/\nCAPSTONE_EXPORT\nbool CAPSTONE_API cs_reg_write(csh handle, const cs_insn *insn, unsigned int reg_id);\n\n/*\n Count the number of operands of a given type.\n Find the operand type in header file of corresponding architecture (arm.h for ARM, x86.h for X86, ...)\n\n NOTE: this API is only valid when detail option is ON (which is OFF by default)\n\n @handle: handle returned by cs_open()\n @insn: disassembled instruction structure received from cs_disasm() or cs_disasm_iter()\n @op_type: Operand type to be found.\n\n @return: number of operands of given type @op_type in instruction @insn,\n or -1 on failure.\n*/\nCAPSTONE_EXPORT\nint CAPSTONE_API cs_op_count(csh handle, const cs_insn *insn, unsigned int op_type);\n\n/*\n Retrieve the position of operand of given type in <arch>.operands[] array.\n Later, the operand can be accessed using the returned position.\n Find the operand type in header file of corresponding architecture (arm.h for ARM, x86.h for X86, ...)\n\n NOTE: this API is only valid when detail option is ON (which is OFF by default)\n\n @handle: handle returned by cs_open()\n @insn: disassembled instruction structure received from cs_disasm() or cs_disasm_iter()\n @op_type: Operand type to be found.\n @position: position of the operand to be found. This must be in the range\n\t\t\t[1, cs_op_count(handle, insn, op_type)]\n\n @return: index of operand of given type @op_type in <arch>.operands[] array\n in instruction @insn, or -1 on failure.\n*/\nCAPSTONE_EXPORT\nint CAPSTONE_API cs_op_index(csh handle, const cs_insn *insn, unsigned int op_type,\n\t\tunsigned int position);\n\n#ifdef __cplusplus\n}\n#endif\n\n#endif\n"
  },
  {
    "path": "EFI_DEBUG/EFI/OC/Kexts/Lilu.kext/Contents/Resources/Headers/capstone/mips.h",
    "content": "#ifndef CAPSTONE_MIPS_H\n#define CAPSTONE_MIPS_H\n\n/* Capstone Disassembly Engine */\n/* By Nguyen Anh Quynh <aquynh@gmail.com>, 2013-2014 */\n\n#ifdef __cplusplus\nextern \"C\" {\n#endif\n\n#if !defined(_MSC_VER) || !defined(_KERNEL_MODE)\n#include <stdint.h>\n#endif\n\n#include \"platform.h\"\n\n// GCC MIPS toolchain has a default macro called \"mips\" which breaks\n// compilation\n#undef mips\n\n#ifdef _MSC_VER\n#pragma warning(disable:4201)\n#endif\n\n//> Operand type for instruction's operands\ntypedef enum mips_op_type {\n\tMIPS_OP_INVALID = 0, // = CS_OP_INVALID (Uninitialized).\n\tMIPS_OP_REG, // = CS_OP_REG (Register operand).\n\tMIPS_OP_IMM, // = CS_OP_IMM (Immediate operand).\n\tMIPS_OP_MEM, // = CS_OP_MEM (Memory operand).\n} mips_op_type;\n\n// Instruction's operand referring to memory\n// This is associated with MIPS_OP_MEM operand type above\ntypedef struct mips_op_mem {\n\tunsigned int base;\t// base register\n\tint64_t disp;\t// displacement/offset value\n} mips_op_mem;\n\n// Instruction operand\ntypedef struct cs_mips_op {\n\tmips_op_type type;\t// operand type\n\tunion {\n\t\tunsigned int reg;\t// register value for REG operand\n\t\tint64_t imm;\t\t// immediate value for IMM operand\n\t\tmips_op_mem mem;\t// base/index/scale/disp value for MEM operand\n\t};\n} cs_mips_op;\n\n// Instruction structure\ntypedef struct cs_mips {\n\t// Number of operands of this instruction, \n\t// or 0 when instruction has no operand.\n\tuint8_t op_count;\n\tcs_mips_op operands[8]; // operands for this instruction.\n} cs_mips;\n\n//> MIPS registers\ntypedef enum mips_reg {\n\tMIPS_REG_INVALID = 0,\n\t//> General purpose registers\n\tMIPS_REG_0,\n\tMIPS_REG_1,\n\tMIPS_REG_2,\n\tMIPS_REG_3,\n\tMIPS_REG_4,\n\tMIPS_REG_5,\n\tMIPS_REG_6,\n\tMIPS_REG_7,\n\tMIPS_REG_8,\n\tMIPS_REG_9,\n\tMIPS_REG_10,\n\tMIPS_REG_11,\n\tMIPS_REG_12,\n\tMIPS_REG_13,\n\tMIPS_REG_14,\n\tMIPS_REG_15,\n\tMIPS_REG_16,\n\tMIPS_REG_17,\n\tMIPS_REG_18,\n\tMIPS_REG_19,\n\tMIPS_REG_20,\n\tMIPS_REG_21,\n\tMIPS_REG_22,\n\tMIPS_REG_23,\n\tMIPS_REG_24,\n\tMIPS_REG_25,\n\tMIPS_REG_26,\n\tMIPS_REG_27,\n\tMIPS_REG_28,\n\tMIPS_REG_29,\n\tMIPS_REG_30,\n\tMIPS_REG_31,\n\n\t//> DSP registers\n\tMIPS_REG_DSPCCOND,\n\tMIPS_REG_DSPCARRY,\n\tMIPS_REG_DSPEFI,\n\tMIPS_REG_DSPOUTFLAG,\n\tMIPS_REG_DSPOUTFLAG16_19,\n\tMIPS_REG_DSPOUTFLAG20,\n\tMIPS_REG_DSPOUTFLAG21,\n\tMIPS_REG_DSPOUTFLAG22,\n\tMIPS_REG_DSPOUTFLAG23,\n\tMIPS_REG_DSPPOS,\n\tMIPS_REG_DSPSCOUNT,\n\n\t//> ACC registers\n\tMIPS_REG_AC0,\n\tMIPS_REG_AC1,\n\tMIPS_REG_AC2,\n\tMIPS_REG_AC3,\n\n\t//> COP registers\n\tMIPS_REG_CC0,\n\tMIPS_REG_CC1,\n\tMIPS_REG_CC2,\n\tMIPS_REG_CC3,\n\tMIPS_REG_CC4,\n\tMIPS_REG_CC5,\n\tMIPS_REG_CC6,\n\tMIPS_REG_CC7,\n\n\t//> FPU registers\n\tMIPS_REG_F0,\n\tMIPS_REG_F1,\n\tMIPS_REG_F2,\n\tMIPS_REG_F3,\n\tMIPS_REG_F4,\n\tMIPS_REG_F5,\n\tMIPS_REG_F6,\n\tMIPS_REG_F7,\n\tMIPS_REG_F8,\n\tMIPS_REG_F9,\n\tMIPS_REG_F10,\n\tMIPS_REG_F11,\n\tMIPS_REG_F12,\n\tMIPS_REG_F13,\n\tMIPS_REG_F14,\n\tMIPS_REG_F15,\n\tMIPS_REG_F16,\n\tMIPS_REG_F17,\n\tMIPS_REG_F18,\n\tMIPS_REG_F19,\n\tMIPS_REG_F20,\n\tMIPS_REG_F21,\n\tMIPS_REG_F22,\n\tMIPS_REG_F23,\n\tMIPS_REG_F24,\n\tMIPS_REG_F25,\n\tMIPS_REG_F26,\n\tMIPS_REG_F27,\n\tMIPS_REG_F28,\n\tMIPS_REG_F29,\n\tMIPS_REG_F30,\n\tMIPS_REG_F31,\n\n\tMIPS_REG_FCC0,\n\tMIPS_REG_FCC1,\n\tMIPS_REG_FCC2,\n\tMIPS_REG_FCC3,\n\tMIPS_REG_FCC4,\n\tMIPS_REG_FCC5,\n\tMIPS_REG_FCC6,\n\tMIPS_REG_FCC7,\n\n\t//> AFPR128\n\tMIPS_REG_W0,\n\tMIPS_REG_W1,\n\tMIPS_REG_W2,\n\tMIPS_REG_W3,\n\tMIPS_REG_W4,\n\tMIPS_REG_W5,\n\tMIPS_REG_W6,\n\tMIPS_REG_W7,\n\tMIPS_REG_W8,\n\tMIPS_REG_W9,\n\tMIPS_REG_W10,\n\tMIPS_REG_W11,\n\tMIPS_REG_W12,\n\tMIPS_REG_W13,\n\tMIPS_REG_W14,\n\tMIPS_REG_W15,\n\tMIPS_REG_W16,\n\tMIPS_REG_W17,\n\tMIPS_REG_W18,\n\tMIPS_REG_W19,\n\tMIPS_REG_W20,\n\tMIPS_REG_W21,\n\tMIPS_REG_W22,\n\tMIPS_REG_W23,\n\tMIPS_REG_W24,\n\tMIPS_REG_W25,\n\tMIPS_REG_W26,\n\tMIPS_REG_W27,\n\tMIPS_REG_W28,\n\tMIPS_REG_W29,\n\tMIPS_REG_W30,\n\tMIPS_REG_W31,\n\n\tMIPS_REG_HI,\n\tMIPS_REG_LO,\n\n\tMIPS_REG_P0,\n\tMIPS_REG_P1,\n\tMIPS_REG_P2,\n\n\tMIPS_REG_MPL0,\n\tMIPS_REG_MPL1,\n\tMIPS_REG_MPL2,\n\n\tMIPS_REG_ENDING,\t// <-- mark the end of the list or registers\n\n\t// alias registers\n\tMIPS_REG_ZERO = MIPS_REG_0,\n\tMIPS_REG_AT = MIPS_REG_1,\n\tMIPS_REG_V0 = MIPS_REG_2,\n\tMIPS_REG_V1 = MIPS_REG_3,\n\tMIPS_REG_A0 = MIPS_REG_4,\n\tMIPS_REG_A1 = MIPS_REG_5,\n\tMIPS_REG_A2 = MIPS_REG_6,\n\tMIPS_REG_A3 = MIPS_REG_7,\n\tMIPS_REG_T0 = MIPS_REG_8,\n\tMIPS_REG_T1 = MIPS_REG_9,\n\tMIPS_REG_T2 = MIPS_REG_10,\n\tMIPS_REG_T3 = MIPS_REG_11,\n\tMIPS_REG_T4 = MIPS_REG_12,\n\tMIPS_REG_T5 = MIPS_REG_13,\n\tMIPS_REG_T6 = MIPS_REG_14,\n\tMIPS_REG_T7 = MIPS_REG_15,\n\tMIPS_REG_S0 = MIPS_REG_16,\n\tMIPS_REG_S1 = MIPS_REG_17,\n\tMIPS_REG_S2 = MIPS_REG_18,\n\tMIPS_REG_S3 = MIPS_REG_19,\n\tMIPS_REG_S4 = MIPS_REG_20,\n\tMIPS_REG_S5 = MIPS_REG_21,\n\tMIPS_REG_S6 = MIPS_REG_22,\n\tMIPS_REG_S7 = MIPS_REG_23,\n\tMIPS_REG_T8 = MIPS_REG_24,\n\tMIPS_REG_T9 = MIPS_REG_25,\n\tMIPS_REG_K0 = MIPS_REG_26,\n\tMIPS_REG_K1 = MIPS_REG_27,\n\tMIPS_REG_GP = MIPS_REG_28,\n\tMIPS_REG_SP = MIPS_REG_29,\n\tMIPS_REG_FP = MIPS_REG_30, MIPS_REG_S8 = MIPS_REG_30,\n\tMIPS_REG_RA = MIPS_REG_31,\n\n\tMIPS_REG_HI0 = MIPS_REG_AC0,\n\tMIPS_REG_HI1 = MIPS_REG_AC1,\n\tMIPS_REG_HI2 = MIPS_REG_AC2,\n\tMIPS_REG_HI3 = MIPS_REG_AC3,\n\n\tMIPS_REG_LO0 = MIPS_REG_HI0,\n\tMIPS_REG_LO1 = MIPS_REG_HI1,\n\tMIPS_REG_LO2 = MIPS_REG_HI2,\n\tMIPS_REG_LO3 = MIPS_REG_HI3,\n} mips_reg;\n\n//> MIPS instruction\ntypedef enum mips_insn {\n\tMIPS_INS_INVALID = 0,\n\n\tMIPS_INS_ABSQ_S,\n\tMIPS_INS_ADD,\n\tMIPS_INS_ADDIUPC,\n\tMIPS_INS_ADDQH,\n\tMIPS_INS_ADDQH_R,\n\tMIPS_INS_ADDQ,\n\tMIPS_INS_ADDQ_S,\n\tMIPS_INS_ADDSC,\n\tMIPS_INS_ADDS_A,\n\tMIPS_INS_ADDS_S,\n\tMIPS_INS_ADDS_U,\n\tMIPS_INS_ADDUH,\n\tMIPS_INS_ADDUH_R,\n\tMIPS_INS_ADDU,\n\tMIPS_INS_ADDU_S,\n\tMIPS_INS_ADDVI,\n\tMIPS_INS_ADDV,\n\tMIPS_INS_ADDWC,\n\tMIPS_INS_ADD_A,\n\tMIPS_INS_ADDI,\n\tMIPS_INS_ADDIU,\n\tMIPS_INS_ALIGN,\n\tMIPS_INS_ALUIPC,\n\tMIPS_INS_AND,\n\tMIPS_INS_ANDI,\n\tMIPS_INS_APPEND,\n\tMIPS_INS_ASUB_S,\n\tMIPS_INS_ASUB_U,\n\tMIPS_INS_AUI,\n\tMIPS_INS_AUIPC,\n\tMIPS_INS_AVER_S,\n\tMIPS_INS_AVER_U,\n\tMIPS_INS_AVE_S,\n\tMIPS_INS_AVE_U,\n\tMIPS_INS_BADDU,\n\tMIPS_INS_BAL,\n\tMIPS_INS_BALC,\n\tMIPS_INS_BALIGN,\n\tMIPS_INS_BC,\n\tMIPS_INS_BC0F,\n\tMIPS_INS_BC0FL,\n\tMIPS_INS_BC0T,\n\tMIPS_INS_BC0TL,\n\tMIPS_INS_BC1EQZ,\n\tMIPS_INS_BC1F,\n\tMIPS_INS_BC1FL,\n\tMIPS_INS_BC1NEZ,\n\tMIPS_INS_BC1T,\n\tMIPS_INS_BC1TL,\n\tMIPS_INS_BC2EQZ,\n\tMIPS_INS_BC2F,\n\tMIPS_INS_BC2FL,\n\tMIPS_INS_BC2NEZ,\n\tMIPS_INS_BC2T,\n\tMIPS_INS_BC2TL,\n\tMIPS_INS_BC3F,\n\tMIPS_INS_BC3FL,\n\tMIPS_INS_BC3T,\n\tMIPS_INS_BC3TL,\n\tMIPS_INS_BCLRI,\n\tMIPS_INS_BCLR,\n\tMIPS_INS_BEQ,\n\tMIPS_INS_BEQC,\n\tMIPS_INS_BEQL,\n\tMIPS_INS_BEQZALC,\n\tMIPS_INS_BEQZC,\n\tMIPS_INS_BGEC,\n\tMIPS_INS_BGEUC,\n\tMIPS_INS_BGEZ,\n\tMIPS_INS_BGEZAL,\n\tMIPS_INS_BGEZALC,\n\tMIPS_INS_BGEZALL,\n\tMIPS_INS_BGEZALS,\n\tMIPS_INS_BGEZC,\n\tMIPS_INS_BGEZL,\n\tMIPS_INS_BGTZ,\n\tMIPS_INS_BGTZALC,\n\tMIPS_INS_BGTZC,\n\tMIPS_INS_BGTZL,\n\tMIPS_INS_BINSLI,\n\tMIPS_INS_BINSL,\n\tMIPS_INS_BINSRI,\n\tMIPS_INS_BINSR,\n\tMIPS_INS_BITREV,\n\tMIPS_INS_BITSWAP,\n\tMIPS_INS_BLEZ,\n\tMIPS_INS_BLEZALC,\n\tMIPS_INS_BLEZC,\n\tMIPS_INS_BLEZL,\n\tMIPS_INS_BLTC,\n\tMIPS_INS_BLTUC,\n\tMIPS_INS_BLTZ,\n\tMIPS_INS_BLTZAL,\n\tMIPS_INS_BLTZALC,\n\tMIPS_INS_BLTZALL,\n\tMIPS_INS_BLTZALS,\n\tMIPS_INS_BLTZC,\n\tMIPS_INS_BLTZL,\n\tMIPS_INS_BMNZI,\n\tMIPS_INS_BMNZ,\n\tMIPS_INS_BMZI,\n\tMIPS_INS_BMZ,\n\tMIPS_INS_BNE,\n\tMIPS_INS_BNEC,\n\tMIPS_INS_BNEGI,\n\tMIPS_INS_BNEG,\n\tMIPS_INS_BNEL,\n\tMIPS_INS_BNEZALC,\n\tMIPS_INS_BNEZC,\n\tMIPS_INS_BNVC,\n\tMIPS_INS_BNZ,\n\tMIPS_INS_BOVC,\n\tMIPS_INS_BPOSGE32,\n\tMIPS_INS_BREAK,\n\tMIPS_INS_BSELI,\n\tMIPS_INS_BSEL,\n\tMIPS_INS_BSETI,\n\tMIPS_INS_BSET,\n\tMIPS_INS_BZ,\n\tMIPS_INS_BEQZ,\n\tMIPS_INS_B,\n\tMIPS_INS_BNEZ,\n\tMIPS_INS_BTEQZ,\n\tMIPS_INS_BTNEZ,\n\tMIPS_INS_CACHE,\n\tMIPS_INS_CEIL,\n\tMIPS_INS_CEQI,\n\tMIPS_INS_CEQ,\n\tMIPS_INS_CFC1,\n\tMIPS_INS_CFCMSA,\n\tMIPS_INS_CINS,\n\tMIPS_INS_CINS32,\n\tMIPS_INS_CLASS,\n\tMIPS_INS_CLEI_S,\n\tMIPS_INS_CLEI_U,\n\tMIPS_INS_CLE_S,\n\tMIPS_INS_CLE_U,\n\tMIPS_INS_CLO,\n\tMIPS_INS_CLTI_S,\n\tMIPS_INS_CLTI_U,\n\tMIPS_INS_CLT_S,\n\tMIPS_INS_CLT_U,\n\tMIPS_INS_CLZ,\n\tMIPS_INS_CMPGDU,\n\tMIPS_INS_CMPGU,\n\tMIPS_INS_CMPU,\n\tMIPS_INS_CMP,\n\tMIPS_INS_COPY_S,\n\tMIPS_INS_COPY_U,\n\tMIPS_INS_CTC1,\n\tMIPS_INS_CTCMSA,\n\tMIPS_INS_CVT,\n\tMIPS_INS_C,\n\tMIPS_INS_CMPI,\n\tMIPS_INS_DADD,\n\tMIPS_INS_DADDI,\n\tMIPS_INS_DADDIU,\n\tMIPS_INS_DADDU,\n\tMIPS_INS_DAHI,\n\tMIPS_INS_DALIGN,\n\tMIPS_INS_DATI,\n\tMIPS_INS_DAUI,\n\tMIPS_INS_DBITSWAP,\n\tMIPS_INS_DCLO,\n\tMIPS_INS_DCLZ,\n\tMIPS_INS_DDIV,\n\tMIPS_INS_DDIVU,\n\tMIPS_INS_DERET,\n\tMIPS_INS_DEXT,\n\tMIPS_INS_DEXTM,\n\tMIPS_INS_DEXTU,\n\tMIPS_INS_DI,\n\tMIPS_INS_DINS,\n\tMIPS_INS_DINSM,\n\tMIPS_INS_DINSU,\n\tMIPS_INS_DIV,\n\tMIPS_INS_DIVU,\n\tMIPS_INS_DIV_S,\n\tMIPS_INS_DIV_U,\n\tMIPS_INS_DLSA,\n\tMIPS_INS_DMFC0,\n\tMIPS_INS_DMFC1,\n\tMIPS_INS_DMFC2,\n\tMIPS_INS_DMOD,\n\tMIPS_INS_DMODU,\n\tMIPS_INS_DMTC0,\n\tMIPS_INS_DMTC1,\n\tMIPS_INS_DMTC2,\n\tMIPS_INS_DMUH,\n\tMIPS_INS_DMUHU,\n\tMIPS_INS_DMUL,\n\tMIPS_INS_DMULT,\n\tMIPS_INS_DMULTU,\n\tMIPS_INS_DMULU,\n\tMIPS_INS_DOTP_S,\n\tMIPS_INS_DOTP_U,\n\tMIPS_INS_DPADD_S,\n\tMIPS_INS_DPADD_U,\n\tMIPS_INS_DPAQX_SA,\n\tMIPS_INS_DPAQX_S,\n\tMIPS_INS_DPAQ_SA,\n\tMIPS_INS_DPAQ_S,\n\tMIPS_INS_DPAU,\n\tMIPS_INS_DPAX,\n\tMIPS_INS_DPA,\n\tMIPS_INS_DPOP,\n\tMIPS_INS_DPSQX_SA,\n\tMIPS_INS_DPSQX_S,\n\tMIPS_INS_DPSQ_SA,\n\tMIPS_INS_DPSQ_S,\n\tMIPS_INS_DPSUB_S,\n\tMIPS_INS_DPSUB_U,\n\tMIPS_INS_DPSU,\n\tMIPS_INS_DPSX,\n\tMIPS_INS_DPS,\n\tMIPS_INS_DROTR,\n\tMIPS_INS_DROTR32,\n\tMIPS_INS_DROTRV,\n\tMIPS_INS_DSBH,\n\tMIPS_INS_DSHD,\n\tMIPS_INS_DSLL,\n\tMIPS_INS_DSLL32,\n\tMIPS_INS_DSLLV,\n\tMIPS_INS_DSRA,\n\tMIPS_INS_DSRA32,\n\tMIPS_INS_DSRAV,\n\tMIPS_INS_DSRL,\n\tMIPS_INS_DSRL32,\n\tMIPS_INS_DSRLV,\n\tMIPS_INS_DSUB,\n\tMIPS_INS_DSUBU,\n\tMIPS_INS_EHB,\n\tMIPS_INS_EI,\n\tMIPS_INS_ERET,\n\tMIPS_INS_EXT,\n\tMIPS_INS_EXTP,\n\tMIPS_INS_EXTPDP,\n\tMIPS_INS_EXTPDPV,\n\tMIPS_INS_EXTPV,\n\tMIPS_INS_EXTRV_RS,\n\tMIPS_INS_EXTRV_R,\n\tMIPS_INS_EXTRV_S,\n\tMIPS_INS_EXTRV,\n\tMIPS_INS_EXTR_RS,\n\tMIPS_INS_EXTR_R,\n\tMIPS_INS_EXTR_S,\n\tMIPS_INS_EXTR,\n\tMIPS_INS_EXTS,\n\tMIPS_INS_EXTS32,\n\tMIPS_INS_ABS,\n\tMIPS_INS_FADD,\n\tMIPS_INS_FCAF,\n\tMIPS_INS_FCEQ,\n\tMIPS_INS_FCLASS,\n\tMIPS_INS_FCLE,\n\tMIPS_INS_FCLT,\n\tMIPS_INS_FCNE,\n\tMIPS_INS_FCOR,\n\tMIPS_INS_FCUEQ,\n\tMIPS_INS_FCULE,\n\tMIPS_INS_FCULT,\n\tMIPS_INS_FCUNE,\n\tMIPS_INS_FCUN,\n\tMIPS_INS_FDIV,\n\tMIPS_INS_FEXDO,\n\tMIPS_INS_FEXP2,\n\tMIPS_INS_FEXUPL,\n\tMIPS_INS_FEXUPR,\n\tMIPS_INS_FFINT_S,\n\tMIPS_INS_FFINT_U,\n\tMIPS_INS_FFQL,\n\tMIPS_INS_FFQR,\n\tMIPS_INS_FILL,\n\tMIPS_INS_FLOG2,\n\tMIPS_INS_FLOOR,\n\tMIPS_INS_FMADD,\n\tMIPS_INS_FMAX_A,\n\tMIPS_INS_FMAX,\n\tMIPS_INS_FMIN_A,\n\tMIPS_INS_FMIN,\n\tMIPS_INS_MOV,\n\tMIPS_INS_FMSUB,\n\tMIPS_INS_FMUL,\n\tMIPS_INS_MUL,\n\tMIPS_INS_NEG,\n\tMIPS_INS_FRCP,\n\tMIPS_INS_FRINT,\n\tMIPS_INS_FRSQRT,\n\tMIPS_INS_FSAF,\n\tMIPS_INS_FSEQ,\n\tMIPS_INS_FSLE,\n\tMIPS_INS_FSLT,\n\tMIPS_INS_FSNE,\n\tMIPS_INS_FSOR,\n\tMIPS_INS_FSQRT,\n\tMIPS_INS_SQRT,\n\tMIPS_INS_FSUB,\n\tMIPS_INS_SUB,\n\tMIPS_INS_FSUEQ,\n\tMIPS_INS_FSULE,\n\tMIPS_INS_FSULT,\n\tMIPS_INS_FSUNE,\n\tMIPS_INS_FSUN,\n\tMIPS_INS_FTINT_S,\n\tMIPS_INS_FTINT_U,\n\tMIPS_INS_FTQ,\n\tMIPS_INS_FTRUNC_S,\n\tMIPS_INS_FTRUNC_U,\n\tMIPS_INS_HADD_S,\n\tMIPS_INS_HADD_U,\n\tMIPS_INS_HSUB_S,\n\tMIPS_INS_HSUB_U,\n\tMIPS_INS_ILVEV,\n\tMIPS_INS_ILVL,\n\tMIPS_INS_ILVOD,\n\tMIPS_INS_ILVR,\n\tMIPS_INS_INS,\n\tMIPS_INS_INSERT,\n\tMIPS_INS_INSV,\n\tMIPS_INS_INSVE,\n\tMIPS_INS_J,\n\tMIPS_INS_JAL,\n\tMIPS_INS_JALR,\n\tMIPS_INS_JALRS,\n\tMIPS_INS_JALS,\n\tMIPS_INS_JALX,\n\tMIPS_INS_JIALC,\n\tMIPS_INS_JIC,\n\tMIPS_INS_JR,\n\tMIPS_INS_JRADDIUSP,\n\tMIPS_INS_JRC,\n\tMIPS_INS_JALRC,\n\tMIPS_INS_LB,\n\tMIPS_INS_LBUX,\n\tMIPS_INS_LBU,\n\tMIPS_INS_LD,\n\tMIPS_INS_LDC1,\n\tMIPS_INS_LDC2,\n\tMIPS_INS_LDC3,\n\tMIPS_INS_LDI,\n\tMIPS_INS_LDL,\n\tMIPS_INS_LDPC,\n\tMIPS_INS_LDR,\n\tMIPS_INS_LDXC1,\n\tMIPS_INS_LH,\n\tMIPS_INS_LHX,\n\tMIPS_INS_LHU,\n\tMIPS_INS_LL,\n\tMIPS_INS_LLD,\n\tMIPS_INS_LSA,\n\tMIPS_INS_LUXC1,\n\tMIPS_INS_LUI,\n\tMIPS_INS_LW,\n\tMIPS_INS_LWC1,\n\tMIPS_INS_LWC2,\n\tMIPS_INS_LWC3,\n\tMIPS_INS_LWL,\n\tMIPS_INS_LWPC,\n\tMIPS_INS_LWR,\n\tMIPS_INS_LWUPC,\n\tMIPS_INS_LWU,\n\tMIPS_INS_LWX,\n\tMIPS_INS_LWXC1,\n\tMIPS_INS_LI,\n\tMIPS_INS_MADD,\n\tMIPS_INS_MADDF,\n\tMIPS_INS_MADDR_Q,\n\tMIPS_INS_MADDU,\n\tMIPS_INS_MADDV,\n\tMIPS_INS_MADD_Q,\n\tMIPS_INS_MAQ_SA,\n\tMIPS_INS_MAQ_S,\n\tMIPS_INS_MAXA,\n\tMIPS_INS_MAXI_S,\n\tMIPS_INS_MAXI_U,\n\tMIPS_INS_MAX_A,\n\tMIPS_INS_MAX,\n\tMIPS_INS_MAX_S,\n\tMIPS_INS_MAX_U,\n\tMIPS_INS_MFC0,\n\tMIPS_INS_MFC1,\n\tMIPS_INS_MFC2,\n\tMIPS_INS_MFHC1,\n\tMIPS_INS_MFHI,\n\tMIPS_INS_MFLO,\n\tMIPS_INS_MINA,\n\tMIPS_INS_MINI_S,\n\tMIPS_INS_MINI_U,\n\tMIPS_INS_MIN_A,\n\tMIPS_INS_MIN,\n\tMIPS_INS_MIN_S,\n\tMIPS_INS_MIN_U,\n\tMIPS_INS_MOD,\n\tMIPS_INS_MODSUB,\n\tMIPS_INS_MODU,\n\tMIPS_INS_MOD_S,\n\tMIPS_INS_MOD_U,\n\tMIPS_INS_MOVE,\n\tMIPS_INS_MOVF,\n\tMIPS_INS_MOVN,\n\tMIPS_INS_MOVT,\n\tMIPS_INS_MOVZ,\n\tMIPS_INS_MSUB,\n\tMIPS_INS_MSUBF,\n\tMIPS_INS_MSUBR_Q,\n\tMIPS_INS_MSUBU,\n\tMIPS_INS_MSUBV,\n\tMIPS_INS_MSUB_Q,\n\tMIPS_INS_MTC0,\n\tMIPS_INS_MTC1,\n\tMIPS_INS_MTC2,\n\tMIPS_INS_MTHC1,\n\tMIPS_INS_MTHI,\n\tMIPS_INS_MTHLIP,\n\tMIPS_INS_MTLO,\n\tMIPS_INS_MTM0,\n\tMIPS_INS_MTM1,\n\tMIPS_INS_MTM2,\n\tMIPS_INS_MTP0,\n\tMIPS_INS_MTP1,\n\tMIPS_INS_MTP2,\n\tMIPS_INS_MUH,\n\tMIPS_INS_MUHU,\n\tMIPS_INS_MULEQ_S,\n\tMIPS_INS_MULEU_S,\n\tMIPS_INS_MULQ_RS,\n\tMIPS_INS_MULQ_S,\n\tMIPS_INS_MULR_Q,\n\tMIPS_INS_MULSAQ_S,\n\tMIPS_INS_MULSA,\n\tMIPS_INS_MULT,\n\tMIPS_INS_MULTU,\n\tMIPS_INS_MULU,\n\tMIPS_INS_MULV,\n\tMIPS_INS_MUL_Q,\n\tMIPS_INS_MUL_S,\n\tMIPS_INS_NLOC,\n\tMIPS_INS_NLZC,\n\tMIPS_INS_NMADD,\n\tMIPS_INS_NMSUB,\n\tMIPS_INS_NOR,\n\tMIPS_INS_NORI,\n\tMIPS_INS_NOT,\n\tMIPS_INS_OR,\n\tMIPS_INS_ORI,\n\tMIPS_INS_PACKRL,\n\tMIPS_INS_PAUSE,\n\tMIPS_INS_PCKEV,\n\tMIPS_INS_PCKOD,\n\tMIPS_INS_PCNT,\n\tMIPS_INS_PICK,\n\tMIPS_INS_POP,\n\tMIPS_INS_PRECEQU,\n\tMIPS_INS_PRECEQ,\n\tMIPS_INS_PRECEU,\n\tMIPS_INS_PRECRQU_S,\n\tMIPS_INS_PRECRQ,\n\tMIPS_INS_PRECRQ_RS,\n\tMIPS_INS_PRECR,\n\tMIPS_INS_PRECR_SRA,\n\tMIPS_INS_PRECR_SRA_R,\n\tMIPS_INS_PREF,\n\tMIPS_INS_PREPEND,\n\tMIPS_INS_RADDU,\n\tMIPS_INS_RDDSP,\n\tMIPS_INS_RDHWR,\n\tMIPS_INS_REPLV,\n\tMIPS_INS_REPL,\n\tMIPS_INS_RINT,\n\tMIPS_INS_ROTR,\n\tMIPS_INS_ROTRV,\n\tMIPS_INS_ROUND,\n\tMIPS_INS_SAT_S,\n\tMIPS_INS_SAT_U,\n\tMIPS_INS_SB,\n\tMIPS_INS_SC,\n\tMIPS_INS_SCD,\n\tMIPS_INS_SD,\n\tMIPS_INS_SDBBP,\n\tMIPS_INS_SDC1,\n\tMIPS_INS_SDC2,\n\tMIPS_INS_SDC3,\n\tMIPS_INS_SDL,\n\tMIPS_INS_SDR,\n\tMIPS_INS_SDXC1,\n\tMIPS_INS_SEB,\n\tMIPS_INS_SEH,\n\tMIPS_INS_SELEQZ,\n\tMIPS_INS_SELNEZ,\n\tMIPS_INS_SEL,\n\tMIPS_INS_SEQ,\n\tMIPS_INS_SEQI,\n\tMIPS_INS_SH,\n\tMIPS_INS_SHF,\n\tMIPS_INS_SHILO,\n\tMIPS_INS_SHILOV,\n\tMIPS_INS_SHLLV,\n\tMIPS_INS_SHLLV_S,\n\tMIPS_INS_SHLL,\n\tMIPS_INS_SHLL_S,\n\tMIPS_INS_SHRAV,\n\tMIPS_INS_SHRAV_R,\n\tMIPS_INS_SHRA,\n\tMIPS_INS_SHRA_R,\n\tMIPS_INS_SHRLV,\n\tMIPS_INS_SHRL,\n\tMIPS_INS_SLDI,\n\tMIPS_INS_SLD,\n\tMIPS_INS_SLL,\n\tMIPS_INS_SLLI,\n\tMIPS_INS_SLLV,\n\tMIPS_INS_SLT,\n\tMIPS_INS_SLTI,\n\tMIPS_INS_SLTIU,\n\tMIPS_INS_SLTU,\n\tMIPS_INS_SNE,\n\tMIPS_INS_SNEI,\n\tMIPS_INS_SPLATI,\n\tMIPS_INS_SPLAT,\n\tMIPS_INS_SRA,\n\tMIPS_INS_SRAI,\n\tMIPS_INS_SRARI,\n\tMIPS_INS_SRAR,\n\tMIPS_INS_SRAV,\n\tMIPS_INS_SRL,\n\tMIPS_INS_SRLI,\n\tMIPS_INS_SRLRI,\n\tMIPS_INS_SRLR,\n\tMIPS_INS_SRLV,\n\tMIPS_INS_SSNOP,\n\tMIPS_INS_ST,\n\tMIPS_INS_SUBQH,\n\tMIPS_INS_SUBQH_R,\n\tMIPS_INS_SUBQ,\n\tMIPS_INS_SUBQ_S,\n\tMIPS_INS_SUBSUS_U,\n\tMIPS_INS_SUBSUU_S,\n\tMIPS_INS_SUBS_S,\n\tMIPS_INS_SUBS_U,\n\tMIPS_INS_SUBUH,\n\tMIPS_INS_SUBUH_R,\n\tMIPS_INS_SUBU,\n\tMIPS_INS_SUBU_S,\n\tMIPS_INS_SUBVI,\n\tMIPS_INS_SUBV,\n\tMIPS_INS_SUXC1,\n\tMIPS_INS_SW,\n\tMIPS_INS_SWC1,\n\tMIPS_INS_SWC2,\n\tMIPS_INS_SWC3,\n\tMIPS_INS_SWL,\n\tMIPS_INS_SWR,\n\tMIPS_INS_SWXC1,\n\tMIPS_INS_SYNC,\n\tMIPS_INS_SYSCALL,\n\tMIPS_INS_TEQ,\n\tMIPS_INS_TEQI,\n\tMIPS_INS_TGE,\n\tMIPS_INS_TGEI,\n\tMIPS_INS_TGEIU,\n\tMIPS_INS_TGEU,\n\tMIPS_INS_TLBP,\n\tMIPS_INS_TLBR,\n\tMIPS_INS_TLBWI,\n\tMIPS_INS_TLBWR,\n\tMIPS_INS_TLT,\n\tMIPS_INS_TLTI,\n\tMIPS_INS_TLTIU,\n\tMIPS_INS_TLTU,\n\tMIPS_INS_TNE,\n\tMIPS_INS_TNEI,\n\tMIPS_INS_TRUNC,\n\tMIPS_INS_V3MULU,\n\tMIPS_INS_VMM0,\n\tMIPS_INS_VMULU,\n\tMIPS_INS_VSHF,\n\tMIPS_INS_WAIT,\n\tMIPS_INS_WRDSP,\n\tMIPS_INS_WSBH,\n\tMIPS_INS_XOR,\n\tMIPS_INS_XORI,\n\n\t//> some alias instructions\n\tMIPS_INS_NOP,\n\tMIPS_INS_NEGU,\n\n\t//> special instructions\n\tMIPS_INS_JALR_HB,\t// jump and link with Hazard Barrier\n\tMIPS_INS_JR_HB,\t\t// jump register with Hazard Barrier\n\n\tMIPS_INS_ENDING,\n} mips_insn;\n\n//> Group of MIPS instructions\ntypedef enum mips_insn_group {\n\tMIPS_GRP_INVALID = 0, // = CS_GRP_INVALID\n\n\t//> Generic groups\n\t// all jump instructions (conditional+direct+indirect jumps)\n\tMIPS_GRP_JUMP,\t// = CS_GRP_JUMP\n\n\t//> Architecture-specific groups\n\tMIPS_GRP_BITCOUNT = 128,\n\tMIPS_GRP_DSP,\n\tMIPS_GRP_DSPR2,\n\tMIPS_GRP_FPIDX,\n\tMIPS_GRP_MSA,\n\tMIPS_GRP_MIPS32R2,\n\tMIPS_GRP_MIPS64,\n\tMIPS_GRP_MIPS64R2,\n\tMIPS_GRP_SEINREG,\n\tMIPS_GRP_STDENC,\n\tMIPS_GRP_SWAP,\n\tMIPS_GRP_MICROMIPS,\n\tMIPS_GRP_MIPS16MODE,\n\tMIPS_GRP_FP64BIT,\n\tMIPS_GRP_NONANSFPMATH,\n\tMIPS_GRP_NOTFP64BIT,\n\tMIPS_GRP_NOTINMICROMIPS,\n\tMIPS_GRP_NOTNACL,\n\tMIPS_GRP_NOTMIPS32R6,\n\tMIPS_GRP_NOTMIPS64R6,\n\tMIPS_GRP_CNMIPS,\n\tMIPS_GRP_MIPS32,\n\tMIPS_GRP_MIPS32R6,\n\tMIPS_GRP_MIPS64R6,\n\tMIPS_GRP_MIPS2,\n\tMIPS_GRP_MIPS3,\n\tMIPS_GRP_MIPS3_32,\n\tMIPS_GRP_MIPS3_32R2,\n\tMIPS_GRP_MIPS4_32,\n\tMIPS_GRP_MIPS4_32R2,\n\tMIPS_GRP_MIPS5_32R2,\n\tMIPS_GRP_GP32BIT,\n\tMIPS_GRP_GP64BIT,\n\n\tMIPS_GRP_ENDING,\n} mips_insn_group;\n\n#ifdef __cplusplus\n}\n#endif\n\n#endif\n"
  },
  {
    "path": "EFI_DEBUG/EFI/OC/Kexts/Lilu.kext/Contents/Resources/Headers/capstone/platform.h",
    "content": "/* Capstone Disassembly Engine */\n/* By Axel Souchet & Nguyen Anh Quynh, 2014 */\n\n#ifndef CAPSTONE_PLATFORM_H\n#define CAPSTONE_PLATFORM_H\n\n// handle C99 issue (for pre-2013 VisualStudio)\n#if !defined(__CYGWIN__) && !defined(__MINGW32__) && !defined(__MINGW64__) && (defined (WIN32) || defined (WIN64) || defined (_WIN32) || defined (_WIN64))\n// MSVC\n\n// stdbool.h\n#if (_MSC_VER < 1800) || defined(_KERNEL_MODE)\n// this system does not have stdbool.h\n#ifndef __cplusplus\ntypedef unsigned char bool;\n#define false 0\n#define true 1\n#endif\n\n#else\n// VisualStudio 2013+ -> C99 is supported\n#include <stdbool.h>\n#endif\n\n#else\n// not MSVC -> C99 is supported\n#include <stdbool.h>\n#endif\n\n\n// handle C99 issue (for pre-2013 VisualStudio)\n#if defined(CAPSTONE_HAS_OSXKERNEL) || (defined(_MSC_VER) && (_MSC_VER <= 1700 || defined(_KERNEL_MODE)))\n// this system does not have inttypes.h\n\n#if defined(_MSC_VER) && (_MSC_VER < 1600 || defined(_KERNEL_MODE))\n// this system does not have stdint.h\ntypedef signed char  int8_t;\ntypedef signed short int16_t;\ntypedef signed int   int32_t;\ntypedef unsigned char  uint8_t;\ntypedef unsigned short uint16_t;\ntypedef unsigned int   uint32_t;\ntypedef signed long long   int64_t;\ntypedef unsigned long long uint64_t;\n\n#define INT8_MIN         (-127i8 - 1)\n#define INT16_MIN        (-32767i16 - 1)\n#define INT32_MIN        (-2147483647i32 - 1)\n#define INT64_MIN        (-9223372036854775807i64 - 1)\n#define INT8_MAX         127i8\n#define INT16_MAX        32767i16\n#define INT32_MAX        2147483647i32\n#define INT64_MAX        9223372036854775807i64\n#define UINT8_MAX        0xffui8\n#define UINT16_MAX       0xffffui16\n#define UINT32_MAX       0xffffffffui32\n#define UINT64_MAX       0xffffffffffffffffui64\n#endif\n\n#define __PRI_8_LENGTH_MODIFIER__ \"hh\"\n#define __PRI_64_LENGTH_MODIFIER__ \"ll\"\n\n#define PRId8         __PRI_8_LENGTH_MODIFIER__ \"d\"\n#define PRIi8         __PRI_8_LENGTH_MODIFIER__ \"i\"\n#define PRIo8         __PRI_8_LENGTH_MODIFIER__ \"o\"\n#define PRIu8         __PRI_8_LENGTH_MODIFIER__ \"u\"\n#define PRIx8         __PRI_8_LENGTH_MODIFIER__ \"x\"\n#define PRIX8         __PRI_8_LENGTH_MODIFIER__ \"X\"\n\n#define PRId16        \"hd\"\n#define PRIi16        \"hi\"\n#define PRIo16        \"ho\"\n#define PRIu16        \"hu\"\n#define PRIx16        \"hx\"\n#define PRIX16        \"hX\"\n\n#if defined(_MSC_VER) && _MSC_VER <= 1700\n#define PRId32        \"ld\"\n#define PRIi32        \"li\"\n#define PRIo32        \"lo\"\n#define PRIu32        \"lu\"\n#define PRIx32        \"lx\"\n#define PRIX32        \"lX\"\n#else\t// OSX\n#define PRId32        \"d\"\n#define PRIi32        \"i\"\n#define PRIo32        \"o\"\n#define PRIu32        \"u\"\n#define PRIx32        \"x\"\n#define PRIX32        \"X\"\n#endif\n\n#if defined(_MSC_VER) && _MSC_VER <= 1700\n// redefine functions from inttypes.h used in cstool\n#define strtoull _strtoui64\n#endif\n\n#define PRId64        __PRI_64_LENGTH_MODIFIER__ \"d\"\n#define PRIi64        __PRI_64_LENGTH_MODIFIER__ \"i\"\n#define PRIo64        __PRI_64_LENGTH_MODIFIER__ \"o\"\n#define PRIu64        __PRI_64_LENGTH_MODIFIER__ \"u\"\n#define PRIx64        __PRI_64_LENGTH_MODIFIER__ \"x\"\n#define PRIX64        __PRI_64_LENGTH_MODIFIER__ \"X\"\n\n#else\n// this system has inttypes.h by default\n#include <inttypes.h>\n#endif\n\n#endif\n"
  },
  {
    "path": "EFI_DEBUG/EFI/OC/Kexts/Lilu.kext/Contents/Resources/Headers/capstone/ppc.h",
    "content": "#ifndef CAPSTONE_PPC_H\n#define CAPSTONE_PPC_H\n\n/* Capstone Disassembly Engine */\n/* By Nguyen Anh Quynh <aquynh@gmail.com>, 2013-2014 */\n\n#ifdef __cplusplus\nextern \"C\" {\n#endif\n\n#if !defined(_MSC_VER) || !defined(_KERNEL_MODE)\n#include <stdint.h>\n#endif\n\n#include \"platform.h\"\n\n#ifdef _MSC_VER\n#pragma warning(disable:4201)\n#endif\n\n//> PPC branch codes for some branch instructions\ntypedef enum ppc_bc {\n\tPPC_BC_INVALID  = 0,\n\tPPC_BC_LT       = (0 << 5) | 12,\n\tPPC_BC_LE       = (1 << 5) |  4,\n\tPPC_BC_EQ       = (2 << 5) | 12,\n\tPPC_BC_GE       = (0 << 5) |  4,\n\tPPC_BC_GT       = (1 << 5) | 12,\n\tPPC_BC_NE       = (2 << 5) |  4,\n\tPPC_BC_UN       = (3 << 5) | 12,\n\tPPC_BC_NU       = (3 << 5) |  4,\n\n\t// extra conditions\n\tPPC_BC_SO = (4 << 5) | 12,\t// summary overflow\n\tPPC_BC_NS = (4 << 5) | 4,\t// not summary overflow\n} ppc_bc;\n\n//> PPC branch hint for some branch instructions\ntypedef enum ppc_bh {\n\tPPC_BH_INVALID = 0,\t// no hint\n\tPPC_BH_PLUS,\t// PLUS hint\n\tPPC_BH_MINUS,\t// MINUS hint\n} ppc_bh;\n\n//> PPC registers\ntypedef enum ppc_reg {\n\tPPC_REG_INVALID = 0,\n\n\tPPC_REG_CARRY,\n\tPPC_REG_CC,\n\tPPC_REG_CR0,\n\tPPC_REG_CR1,\n\tPPC_REG_CR2,\n\tPPC_REG_CR3,\n\tPPC_REG_CR4,\n\tPPC_REG_CR5,\n\tPPC_REG_CR6,\n\tPPC_REG_CR7,\n\tPPC_REG_CTR,\n\tPPC_REG_F0,\n\tPPC_REG_F1,\n\tPPC_REG_F2,\n\tPPC_REG_F3,\n\tPPC_REG_F4,\n\tPPC_REG_F5,\n\tPPC_REG_F6,\n\tPPC_REG_F7,\n\tPPC_REG_F8,\n\tPPC_REG_F9,\n\tPPC_REG_F10,\n\tPPC_REG_F11,\n\tPPC_REG_F12,\n\tPPC_REG_F13,\n\tPPC_REG_F14,\n\tPPC_REG_F15,\n\tPPC_REG_F16,\n\tPPC_REG_F17,\n\tPPC_REG_F18,\n\tPPC_REG_F19,\n\tPPC_REG_F20,\n\tPPC_REG_F21,\n\tPPC_REG_F22,\n\tPPC_REG_F23,\n\tPPC_REG_F24,\n\tPPC_REG_F25,\n\tPPC_REG_F26,\n\tPPC_REG_F27,\n\tPPC_REG_F28,\n\tPPC_REG_F29,\n\tPPC_REG_F30,\n\tPPC_REG_F31,\n\tPPC_REG_LR,\n\tPPC_REG_R0,\n\tPPC_REG_R1,\n\tPPC_REG_R2,\n\tPPC_REG_R3,\n\tPPC_REG_R4,\n\tPPC_REG_R5,\n\tPPC_REG_R6,\n\tPPC_REG_R7,\n\tPPC_REG_R8,\n\tPPC_REG_R9,\n\tPPC_REG_R10,\n\tPPC_REG_R11,\n\tPPC_REG_R12,\n\tPPC_REG_R13,\n\tPPC_REG_R14,\n\tPPC_REG_R15,\n\tPPC_REG_R16,\n\tPPC_REG_R17,\n\tPPC_REG_R18,\n\tPPC_REG_R19,\n\tPPC_REG_R20,\n\tPPC_REG_R21,\n\tPPC_REG_R22,\n\tPPC_REG_R23,\n\tPPC_REG_R24,\n\tPPC_REG_R25,\n\tPPC_REG_R26,\n\tPPC_REG_R27,\n\tPPC_REG_R28,\n\tPPC_REG_R29,\n\tPPC_REG_R30,\n\tPPC_REG_R31,\n\tPPC_REG_V0,\n\tPPC_REG_V1,\n\tPPC_REG_V2,\n\tPPC_REG_V3,\n\tPPC_REG_V4,\n\tPPC_REG_V5,\n\tPPC_REG_V6,\n\tPPC_REG_V7,\n\tPPC_REG_V8,\n\tPPC_REG_V9,\n\tPPC_REG_V10,\n\tPPC_REG_V11,\n\tPPC_REG_V12,\n\tPPC_REG_V13,\n\tPPC_REG_V14,\n\tPPC_REG_V15,\n\tPPC_REG_V16,\n\tPPC_REG_V17,\n\tPPC_REG_V18,\n\tPPC_REG_V19,\n\tPPC_REG_V20,\n\tPPC_REG_V21,\n\tPPC_REG_V22,\n\tPPC_REG_V23,\n\tPPC_REG_V24,\n\tPPC_REG_V25,\n\tPPC_REG_V26,\n\tPPC_REG_V27,\n\tPPC_REG_V28,\n\tPPC_REG_V29,\n\tPPC_REG_V30,\n\tPPC_REG_V31,\n\tPPC_REG_VRSAVE,\n\tPPC_REG_VS0,\n\tPPC_REG_VS1,\n\tPPC_REG_VS2,\n\tPPC_REG_VS3,\n\tPPC_REG_VS4,\n\tPPC_REG_VS5,\n\tPPC_REG_VS6,\n\tPPC_REG_VS7,\n\tPPC_REG_VS8,\n\tPPC_REG_VS9,\n\tPPC_REG_VS10,\n\tPPC_REG_VS11,\n\tPPC_REG_VS12,\n\tPPC_REG_VS13,\n\tPPC_REG_VS14,\n\tPPC_REG_VS15,\n\tPPC_REG_VS16,\n\tPPC_REG_VS17,\n\tPPC_REG_VS18,\n\tPPC_REG_VS19,\n\tPPC_REG_VS20,\n\tPPC_REG_VS21,\n\tPPC_REG_VS22,\n\tPPC_REG_VS23,\n\tPPC_REG_VS24,\n\tPPC_REG_VS25,\n\tPPC_REG_VS26,\n\tPPC_REG_VS27,\n\tPPC_REG_VS28,\n\tPPC_REG_VS29,\n\tPPC_REG_VS30,\n\tPPC_REG_VS31,\n\tPPC_REG_VS32,\n\tPPC_REG_VS33,\n\tPPC_REG_VS34,\n\tPPC_REG_VS35,\n\tPPC_REG_VS36,\n\tPPC_REG_VS37,\n\tPPC_REG_VS38,\n\tPPC_REG_VS39,\n\tPPC_REG_VS40,\n\tPPC_REG_VS41,\n\tPPC_REG_VS42,\n\tPPC_REG_VS43,\n\tPPC_REG_VS44,\n\tPPC_REG_VS45,\n\tPPC_REG_VS46,\n\tPPC_REG_VS47,\n\tPPC_REG_VS48,\n\tPPC_REG_VS49,\n\tPPC_REG_VS50,\n\tPPC_REG_VS51,\n\tPPC_REG_VS52,\n\tPPC_REG_VS53,\n\tPPC_REG_VS54,\n\tPPC_REG_VS55,\n\tPPC_REG_VS56,\n\tPPC_REG_VS57,\n\tPPC_REG_VS58,\n\tPPC_REG_VS59,\n\tPPC_REG_VS60,\n\tPPC_REG_VS61,\n\tPPC_REG_VS62,\n\tPPC_REG_VS63,\n\n\t// extra registers for PPCMapping.c\n\tPPC_REG_RM,\n\tPPC_REG_CTR8,\n\tPPC_REG_LR8,\n\tPPC_REG_CR1EQ,\n\n\tPPC_REG_ENDING,   // <-- mark the end of the list of registers\n} ppc_reg;\n\n//> Operand type for instruction's operands\ntypedef enum ppc_op_type {\n\tPPC_OP_INVALID = 0, // = CS_OP_INVALID (Uninitialized).\n\tPPC_OP_REG, // = CS_OP_REG (Register operand).\n\tPPC_OP_IMM, // = CS_OP_IMM (Immediate operand).\n\tPPC_OP_MEM, // = CS_OP_MEM (Memory operand).\n\tPPC_OP_CRX = 64,\t// Condition Register field\n} ppc_op_type;\n\n// Instruction's operand referring to memory\n// This is associated with PPC_OP_MEM operand type above\ntypedef struct ppc_op_mem {\n\tppc_reg base;\t// base register\n\tint32_t disp;\t// displacement/offset value\n} ppc_op_mem;\n\ntypedef struct ppc_op_crx {\n\tunsigned int scale;\n\tppc_reg reg;\n\tppc_bc cond;\n} ppc_op_crx;\n\n// Instruction operand\ntypedef struct cs_ppc_op {\n\tppc_op_type type;\t// operand type\n\tunion {\n\t\tppc_reg reg;\t// register value for REG operand\n\t\tint32_t imm;\t\t// immediate value for IMM operand\n\t\tppc_op_mem mem;\t\t// base/disp value for MEM operand\n\t\tppc_op_crx crx;\t\t// operand with condition register\n\t};\n} cs_ppc_op;\n\n// Instruction structure\ntypedef struct cs_ppc {\n\t// branch code for branch instructions\n\tppc_bc bc;\n\n\t// branch hint for branch instructions\n\tppc_bh bh;\n\n\t// if update_cr0 = True, then this 'dot' insn updates CR0\n\tbool update_cr0;\n\n\t// Number of operands of this instruction, \n\t// or 0 when instruction has no operand.\n\tuint8_t op_count;\n\tcs_ppc_op operands[8]; // operands for this instruction.\n} cs_ppc;\n\n\n//> PPC instruction\ntypedef enum ppc_insn {\n\tPPC_INS_INVALID = 0,\n\n\tPPC_INS_ADD,\n\tPPC_INS_ADDC,\n\tPPC_INS_ADDE,\n\tPPC_INS_ADDI,\n\tPPC_INS_ADDIC,\n\tPPC_INS_ADDIS,\n\tPPC_INS_ADDME,\n\tPPC_INS_ADDZE,\n\tPPC_INS_AND,\n\tPPC_INS_ANDC,\n\tPPC_INS_ANDIS,\n\tPPC_INS_ANDI,\n\tPPC_INS_B,\n\tPPC_INS_BA,\n\tPPC_INS_BC,\n\tPPC_INS_BCCTR,\n\tPPC_INS_BCCTRL,\n\tPPC_INS_BCL,\n\tPPC_INS_BCLR,\n\tPPC_INS_BCLRL,\n\tPPC_INS_BCTR,\n\tPPC_INS_BCTRL,\n\tPPC_INS_BDNZ,\n\tPPC_INS_BDNZA,\n\tPPC_INS_BDNZL,\n\tPPC_INS_BDNZLA,\n\tPPC_INS_BDNZLR,\n\tPPC_INS_BDNZLRL,\n\tPPC_INS_BDZ,\n\tPPC_INS_BDZA,\n\tPPC_INS_BDZL,\n\tPPC_INS_BDZLA,\n\tPPC_INS_BDZLR,\n\tPPC_INS_BDZLRL,\n\tPPC_INS_BL,\n\tPPC_INS_BLA,\n\tPPC_INS_BLR,\n\tPPC_INS_BLRL,\n\tPPC_INS_BRINC,\n\tPPC_INS_CMPD,\n\tPPC_INS_CMPDI,\n\tPPC_INS_CMPLD,\n\tPPC_INS_CMPLDI,\n\tPPC_INS_CMPLW,\n\tPPC_INS_CMPLWI,\n\tPPC_INS_CMPW,\n\tPPC_INS_CMPWI,\n\tPPC_INS_CNTLZD,\n\tPPC_INS_CNTLZW,\n\tPPC_INS_CREQV,\n\tPPC_INS_CRXOR,\n\tPPC_INS_CRAND,\n\tPPC_INS_CRANDC,\n\tPPC_INS_CRNAND,\n\tPPC_INS_CRNOR,\n\tPPC_INS_CROR,\n\tPPC_INS_CRORC,\n\tPPC_INS_DCBA,\n\tPPC_INS_DCBF,\n\tPPC_INS_DCBI,\n\tPPC_INS_DCBST,\n\tPPC_INS_DCBT,\n\tPPC_INS_DCBTST,\n\tPPC_INS_DCBZ,\n\tPPC_INS_DCBZL,\n\tPPC_INS_DCCCI,\n\tPPC_INS_DIVD,\n\tPPC_INS_DIVDU,\n\tPPC_INS_DIVW,\n\tPPC_INS_DIVWU,\n\tPPC_INS_DSS,\n\tPPC_INS_DSSALL,\n\tPPC_INS_DST,\n\tPPC_INS_DSTST,\n\tPPC_INS_DSTSTT,\n\tPPC_INS_DSTT,\n\tPPC_INS_EIEIO,\n\tPPC_INS_EQV,\n\tPPC_INS_EVABS,\n\tPPC_INS_EVADDIW,\n\tPPC_INS_EVADDSMIAAW,\n\tPPC_INS_EVADDSSIAAW,\n\tPPC_INS_EVADDUMIAAW,\n\tPPC_INS_EVADDUSIAAW,\n\tPPC_INS_EVADDW,\n\tPPC_INS_EVAND,\n\tPPC_INS_EVANDC,\n\tPPC_INS_EVCMPEQ,\n\tPPC_INS_EVCMPGTS,\n\tPPC_INS_EVCMPGTU,\n\tPPC_INS_EVCMPLTS,\n\tPPC_INS_EVCMPLTU,\n\tPPC_INS_EVCNTLSW,\n\tPPC_INS_EVCNTLZW,\n\tPPC_INS_EVDIVWS,\n\tPPC_INS_EVDIVWU,\n\tPPC_INS_EVEQV,\n\tPPC_INS_EVEXTSB,\n\tPPC_INS_EVEXTSH,\n\tPPC_INS_EVLDD,\n\tPPC_INS_EVLDDX,\n\tPPC_INS_EVLDH,\n\tPPC_INS_EVLDHX,\n\tPPC_INS_EVLDW,\n\tPPC_INS_EVLDWX,\n\tPPC_INS_EVLHHESPLAT,\n\tPPC_INS_EVLHHESPLATX,\n\tPPC_INS_EVLHHOSSPLAT,\n\tPPC_INS_EVLHHOSSPLATX,\n\tPPC_INS_EVLHHOUSPLAT,\n\tPPC_INS_EVLHHOUSPLATX,\n\tPPC_INS_EVLWHE,\n\tPPC_INS_EVLWHEX,\n\tPPC_INS_EVLWHOS,\n\tPPC_INS_EVLWHOSX,\n\tPPC_INS_EVLWHOU,\n\tPPC_INS_EVLWHOUX,\n\tPPC_INS_EVLWHSPLAT,\n\tPPC_INS_EVLWHSPLATX,\n\tPPC_INS_EVLWWSPLAT,\n\tPPC_INS_EVLWWSPLATX,\n\tPPC_INS_EVMERGEHI,\n\tPPC_INS_EVMERGEHILO,\n\tPPC_INS_EVMERGELO,\n\tPPC_INS_EVMERGELOHI,\n\tPPC_INS_EVMHEGSMFAA,\n\tPPC_INS_EVMHEGSMFAN,\n\tPPC_INS_EVMHEGSMIAA,\n\tPPC_INS_EVMHEGSMIAN,\n\tPPC_INS_EVMHEGUMIAA,\n\tPPC_INS_EVMHEGUMIAN,\n\tPPC_INS_EVMHESMF,\n\tPPC_INS_EVMHESMFA,\n\tPPC_INS_EVMHESMFAAW,\n\tPPC_INS_EVMHESMFANW,\n\tPPC_INS_EVMHESMI,\n\tPPC_INS_EVMHESMIA,\n\tPPC_INS_EVMHESMIAAW,\n\tPPC_INS_EVMHESMIANW,\n\tPPC_INS_EVMHESSF,\n\tPPC_INS_EVMHESSFA,\n\tPPC_INS_EVMHESSFAAW,\n\tPPC_INS_EVMHESSFANW,\n\tPPC_INS_EVMHESSIAAW,\n\tPPC_INS_EVMHESSIANW,\n\tPPC_INS_EVMHEUMI,\n\tPPC_INS_EVMHEUMIA,\n\tPPC_INS_EVMHEUMIAAW,\n\tPPC_INS_EVMHEUMIANW,\n\tPPC_INS_EVMHEUSIAAW,\n\tPPC_INS_EVMHEUSIANW,\n\tPPC_INS_EVMHOGSMFAA,\n\tPPC_INS_EVMHOGSMFAN,\n\tPPC_INS_EVMHOGSMIAA,\n\tPPC_INS_EVMHOGSMIAN,\n\tPPC_INS_EVMHOGUMIAA,\n\tPPC_INS_EVMHOGUMIAN,\n\tPPC_INS_EVMHOSMF,\n\tPPC_INS_EVMHOSMFA,\n\tPPC_INS_EVMHOSMFAAW,\n\tPPC_INS_EVMHOSMFANW,\n\tPPC_INS_EVMHOSMI,\n\tPPC_INS_EVMHOSMIA,\n\tPPC_INS_EVMHOSMIAAW,\n\tPPC_INS_EVMHOSMIANW,\n\tPPC_INS_EVMHOSSF,\n\tPPC_INS_EVMHOSSFA,\n\tPPC_INS_EVMHOSSFAAW,\n\tPPC_INS_EVMHOSSFANW,\n\tPPC_INS_EVMHOSSIAAW,\n\tPPC_INS_EVMHOSSIANW,\n\tPPC_INS_EVMHOUMI,\n\tPPC_INS_EVMHOUMIA,\n\tPPC_INS_EVMHOUMIAAW,\n\tPPC_INS_EVMHOUMIANW,\n\tPPC_INS_EVMHOUSIAAW,\n\tPPC_INS_EVMHOUSIANW,\n\tPPC_INS_EVMRA,\n\tPPC_INS_EVMWHSMF,\n\tPPC_INS_EVMWHSMFA,\n\tPPC_INS_EVMWHSMI,\n\tPPC_INS_EVMWHSMIA,\n\tPPC_INS_EVMWHSSF,\n\tPPC_INS_EVMWHSSFA,\n\tPPC_INS_EVMWHUMI,\n\tPPC_INS_EVMWHUMIA,\n\tPPC_INS_EVMWLSMIAAW,\n\tPPC_INS_EVMWLSMIANW,\n\tPPC_INS_EVMWLSSIAAW,\n\tPPC_INS_EVMWLSSIANW,\n\tPPC_INS_EVMWLUMI,\n\tPPC_INS_EVMWLUMIA,\n\tPPC_INS_EVMWLUMIAAW,\n\tPPC_INS_EVMWLUMIANW,\n\tPPC_INS_EVMWLUSIAAW,\n\tPPC_INS_EVMWLUSIANW,\n\tPPC_INS_EVMWSMF,\n\tPPC_INS_EVMWSMFA,\n\tPPC_INS_EVMWSMFAA,\n\tPPC_INS_EVMWSMFAN,\n\tPPC_INS_EVMWSMI,\n\tPPC_INS_EVMWSMIA,\n\tPPC_INS_EVMWSMIAA,\n\tPPC_INS_EVMWSMIAN,\n\tPPC_INS_EVMWSSF,\n\tPPC_INS_EVMWSSFA,\n\tPPC_INS_EVMWSSFAA,\n\tPPC_INS_EVMWSSFAN,\n\tPPC_INS_EVMWUMI,\n\tPPC_INS_EVMWUMIA,\n\tPPC_INS_EVMWUMIAA,\n\tPPC_INS_EVMWUMIAN,\n\tPPC_INS_EVNAND,\n\tPPC_INS_EVNEG,\n\tPPC_INS_EVNOR,\n\tPPC_INS_EVOR,\n\tPPC_INS_EVORC,\n\tPPC_INS_EVRLW,\n\tPPC_INS_EVRLWI,\n\tPPC_INS_EVRNDW,\n\tPPC_INS_EVSLW,\n\tPPC_INS_EVSLWI,\n\tPPC_INS_EVSPLATFI,\n\tPPC_INS_EVSPLATI,\n\tPPC_INS_EVSRWIS,\n\tPPC_INS_EVSRWIU,\n\tPPC_INS_EVSRWS,\n\tPPC_INS_EVSRWU,\n\tPPC_INS_EVSTDD,\n\tPPC_INS_EVSTDDX,\n\tPPC_INS_EVSTDH,\n\tPPC_INS_EVSTDHX,\n\tPPC_INS_EVSTDW,\n\tPPC_INS_EVSTDWX,\n\tPPC_INS_EVSTWHE,\n\tPPC_INS_EVSTWHEX,\n\tPPC_INS_EVSTWHO,\n\tPPC_INS_EVSTWHOX,\n\tPPC_INS_EVSTWWE,\n\tPPC_INS_EVSTWWEX,\n\tPPC_INS_EVSTWWO,\n\tPPC_INS_EVSTWWOX,\n\tPPC_INS_EVSUBFSMIAAW,\n\tPPC_INS_EVSUBFSSIAAW,\n\tPPC_INS_EVSUBFUMIAAW,\n\tPPC_INS_EVSUBFUSIAAW,\n\tPPC_INS_EVSUBFW,\n\tPPC_INS_EVSUBIFW,\n\tPPC_INS_EVXOR,\n\tPPC_INS_EXTSB,\n\tPPC_INS_EXTSH,\n\tPPC_INS_EXTSW,\n\tPPC_INS_FABS,\n\tPPC_INS_FADD,\n\tPPC_INS_FADDS,\n\tPPC_INS_FCFID,\n\tPPC_INS_FCFIDS,\n\tPPC_INS_FCFIDU,\n\tPPC_INS_FCFIDUS,\n\tPPC_INS_FCMPU,\n\tPPC_INS_FCPSGN,\n\tPPC_INS_FCTID,\n\tPPC_INS_FCTIDUZ,\n\tPPC_INS_FCTIDZ,\n\tPPC_INS_FCTIW,\n\tPPC_INS_FCTIWUZ,\n\tPPC_INS_FCTIWZ,\n\tPPC_INS_FDIV,\n\tPPC_INS_FDIVS,\n\tPPC_INS_FMADD,\n\tPPC_INS_FMADDS,\n\tPPC_INS_FMR,\n\tPPC_INS_FMSUB,\n\tPPC_INS_FMSUBS,\n\tPPC_INS_FMUL,\n\tPPC_INS_FMULS,\n\tPPC_INS_FNABS,\n\tPPC_INS_FNEG,\n\tPPC_INS_FNMADD,\n\tPPC_INS_FNMADDS,\n\tPPC_INS_FNMSUB,\n\tPPC_INS_FNMSUBS,\n\tPPC_INS_FRE,\n\tPPC_INS_FRES,\n\tPPC_INS_FRIM,\n\tPPC_INS_FRIN,\n\tPPC_INS_FRIP,\n\tPPC_INS_FRIZ,\n\tPPC_INS_FRSP,\n\tPPC_INS_FRSQRTE,\n\tPPC_INS_FRSQRTES,\n\tPPC_INS_FSEL,\n\tPPC_INS_FSQRT,\n\tPPC_INS_FSQRTS,\n\tPPC_INS_FSUB,\n\tPPC_INS_FSUBS,\n\tPPC_INS_ICBI,\n\tPPC_INS_ICCCI,\n\tPPC_INS_ISEL,\n\tPPC_INS_ISYNC,\n\tPPC_INS_LA,\n\tPPC_INS_LBZ,\n\tPPC_INS_LBZU,\n\tPPC_INS_LBZUX,\n\tPPC_INS_LBZX,\n\tPPC_INS_LD,\n\tPPC_INS_LDARX,\n\tPPC_INS_LDBRX,\n\tPPC_INS_LDU,\n\tPPC_INS_LDUX,\n\tPPC_INS_LDX,\n\tPPC_INS_LFD,\n\tPPC_INS_LFDU,\n\tPPC_INS_LFDUX,\n\tPPC_INS_LFDX,\n\tPPC_INS_LFIWAX,\n\tPPC_INS_LFIWZX,\n\tPPC_INS_LFS,\n\tPPC_INS_LFSU,\n\tPPC_INS_LFSUX,\n\tPPC_INS_LFSX,\n\tPPC_INS_LHA,\n\tPPC_INS_LHAU,\n\tPPC_INS_LHAUX,\n\tPPC_INS_LHAX,\n\tPPC_INS_LHBRX,\n\tPPC_INS_LHZ,\n\tPPC_INS_LHZU,\n\tPPC_INS_LHZUX,\n\tPPC_INS_LHZX,\n\tPPC_INS_LI,\n\tPPC_INS_LIS,\n\tPPC_INS_LMW,\n\tPPC_INS_LSWI,\n\tPPC_INS_LVEBX,\n\tPPC_INS_LVEHX,\n\tPPC_INS_LVEWX,\n\tPPC_INS_LVSL,\n\tPPC_INS_LVSR,\n\tPPC_INS_LVX,\n\tPPC_INS_LVXL,\n\tPPC_INS_LWA,\n\tPPC_INS_LWARX,\n\tPPC_INS_LWAUX,\n\tPPC_INS_LWAX,\n\tPPC_INS_LWBRX,\n\tPPC_INS_LWZ,\n\tPPC_INS_LWZU,\n\tPPC_INS_LWZUX,\n\tPPC_INS_LWZX,\n\tPPC_INS_LXSDX,\n\tPPC_INS_LXVD2X,\n\tPPC_INS_LXVDSX,\n\tPPC_INS_LXVW4X,\n\tPPC_INS_MBAR,\n\tPPC_INS_MCRF,\n\tPPC_INS_MFCR,\n\tPPC_INS_MFCTR,\n\tPPC_INS_MFDCR,\n\tPPC_INS_MFFS,\n\tPPC_INS_MFLR,\n\tPPC_INS_MFMSR,\n\tPPC_INS_MFOCRF,\n\tPPC_INS_MFSPR,\n\tPPC_INS_MFSR,\n\tPPC_INS_MFSRIN,\n\tPPC_INS_MFTB,\n\tPPC_INS_MFVSCR,\n\tPPC_INS_MSYNC,\n\tPPC_INS_MTCRF,\n\tPPC_INS_MTCTR,\n\tPPC_INS_MTDCR,\n\tPPC_INS_MTFSB0,\n\tPPC_INS_MTFSB1,\n\tPPC_INS_MTFSF,\n\tPPC_INS_MTLR,\n\tPPC_INS_MTMSR,\n\tPPC_INS_MTMSRD,\n\tPPC_INS_MTOCRF,\n\tPPC_INS_MTSPR,\n\tPPC_INS_MTSR,\n\tPPC_INS_MTSRIN,\n\tPPC_INS_MTVSCR,\n\tPPC_INS_MULHD,\n\tPPC_INS_MULHDU,\n\tPPC_INS_MULHW,\n\tPPC_INS_MULHWU,\n\tPPC_INS_MULLD,\n\tPPC_INS_MULLI,\n\tPPC_INS_MULLW,\n\tPPC_INS_NAND,\n\tPPC_INS_NEG,\n\tPPC_INS_NOP,\n\tPPC_INS_ORI,\n\tPPC_INS_NOR,\n\tPPC_INS_OR,\n\tPPC_INS_ORC,\n\tPPC_INS_ORIS,\n\tPPC_INS_POPCNTD,\n\tPPC_INS_POPCNTW,\n\tPPC_INS_RFCI,\n\tPPC_INS_RFDI,\n\tPPC_INS_RFI,\n\tPPC_INS_RFID,\n\tPPC_INS_RFMCI,\n\tPPC_INS_RLDCL,\n\tPPC_INS_RLDCR,\n\tPPC_INS_RLDIC,\n\tPPC_INS_RLDICL,\n\tPPC_INS_RLDICR,\n\tPPC_INS_RLDIMI,\n\tPPC_INS_RLWIMI,\n\tPPC_INS_RLWINM,\n\tPPC_INS_RLWNM,\n\tPPC_INS_SC,\n\tPPC_INS_SLBIA,\n\tPPC_INS_SLBIE,\n\tPPC_INS_SLBMFEE,\n\tPPC_INS_SLBMTE,\n\tPPC_INS_SLD,\n\tPPC_INS_SLW,\n\tPPC_INS_SRAD,\n\tPPC_INS_SRADI,\n\tPPC_INS_SRAW,\n\tPPC_INS_SRAWI,\n\tPPC_INS_SRD,\n\tPPC_INS_SRW,\n\tPPC_INS_STB,\n\tPPC_INS_STBU,\n\tPPC_INS_STBUX,\n\tPPC_INS_STBX,\n\tPPC_INS_STD,\n\tPPC_INS_STDBRX,\n\tPPC_INS_STDCX,\n\tPPC_INS_STDU,\n\tPPC_INS_STDUX,\n\tPPC_INS_STDX,\n\tPPC_INS_STFD,\n\tPPC_INS_STFDU,\n\tPPC_INS_STFDUX,\n\tPPC_INS_STFDX,\n\tPPC_INS_STFIWX,\n\tPPC_INS_STFS,\n\tPPC_INS_STFSU,\n\tPPC_INS_STFSUX,\n\tPPC_INS_STFSX,\n\tPPC_INS_STH,\n\tPPC_INS_STHBRX,\n\tPPC_INS_STHU,\n\tPPC_INS_STHUX,\n\tPPC_INS_STHX,\n\tPPC_INS_STMW,\n\tPPC_INS_STSWI,\n\tPPC_INS_STVEBX,\n\tPPC_INS_STVEHX,\n\tPPC_INS_STVEWX,\n\tPPC_INS_STVX,\n\tPPC_INS_STVXL,\n\tPPC_INS_STW,\n\tPPC_INS_STWBRX,\n\tPPC_INS_STWCX,\n\tPPC_INS_STWU,\n\tPPC_INS_STWUX,\n\tPPC_INS_STWX,\n\tPPC_INS_STXSDX,\n\tPPC_INS_STXVD2X,\n\tPPC_INS_STXVW4X,\n\tPPC_INS_SUBF,\n\tPPC_INS_SUBFC,\n\tPPC_INS_SUBFE,\n\tPPC_INS_SUBFIC,\n\tPPC_INS_SUBFME,\n\tPPC_INS_SUBFZE,\n\tPPC_INS_SYNC,\n\tPPC_INS_TD,\n\tPPC_INS_TDI,\n\tPPC_INS_TLBIA,\n\tPPC_INS_TLBIE,\n\tPPC_INS_TLBIEL,\n\tPPC_INS_TLBIVAX,\n\tPPC_INS_TLBLD,\n\tPPC_INS_TLBLI,\n\tPPC_INS_TLBRE,\n\tPPC_INS_TLBSX,\n\tPPC_INS_TLBSYNC,\n\tPPC_INS_TLBWE,\n\tPPC_INS_TRAP,\n\tPPC_INS_TW,\n\tPPC_INS_TWI,\n\tPPC_INS_VADDCUW,\n\tPPC_INS_VADDFP,\n\tPPC_INS_VADDSBS,\n\tPPC_INS_VADDSHS,\n\tPPC_INS_VADDSWS,\n\tPPC_INS_VADDUBM,\n\tPPC_INS_VADDUBS,\n\tPPC_INS_VADDUHM,\n\tPPC_INS_VADDUHS,\n\tPPC_INS_VADDUWM,\n\tPPC_INS_VADDUWS,\n\tPPC_INS_VAND,\n\tPPC_INS_VANDC,\n\tPPC_INS_VAVGSB,\n\tPPC_INS_VAVGSH,\n\tPPC_INS_VAVGSW,\n\tPPC_INS_VAVGUB,\n\tPPC_INS_VAVGUH,\n\tPPC_INS_VAVGUW,\n\tPPC_INS_VCFSX,\n\tPPC_INS_VCFUX,\n\tPPC_INS_VCMPBFP,\n\tPPC_INS_VCMPEQFP,\n\tPPC_INS_VCMPEQUB,\n\tPPC_INS_VCMPEQUH,\n\tPPC_INS_VCMPEQUW,\n\tPPC_INS_VCMPGEFP,\n\tPPC_INS_VCMPGTFP,\n\tPPC_INS_VCMPGTSB,\n\tPPC_INS_VCMPGTSH,\n\tPPC_INS_VCMPGTSW,\n\tPPC_INS_VCMPGTUB,\n\tPPC_INS_VCMPGTUH,\n\tPPC_INS_VCMPGTUW,\n\tPPC_INS_VCTSXS,\n\tPPC_INS_VCTUXS,\n\tPPC_INS_VEXPTEFP,\n\tPPC_INS_VLOGEFP,\n\tPPC_INS_VMADDFP,\n\tPPC_INS_VMAXFP,\n\tPPC_INS_VMAXSB,\n\tPPC_INS_VMAXSH,\n\tPPC_INS_VMAXSW,\n\tPPC_INS_VMAXUB,\n\tPPC_INS_VMAXUH,\n\tPPC_INS_VMAXUW,\n\tPPC_INS_VMHADDSHS,\n\tPPC_INS_VMHRADDSHS,\n\tPPC_INS_VMINFP,\n\tPPC_INS_VMINSB,\n\tPPC_INS_VMINSH,\n\tPPC_INS_VMINSW,\n\tPPC_INS_VMINUB,\n\tPPC_INS_VMINUH,\n\tPPC_INS_VMINUW,\n\tPPC_INS_VMLADDUHM,\n\tPPC_INS_VMRGHB,\n\tPPC_INS_VMRGHH,\n\tPPC_INS_VMRGHW,\n\tPPC_INS_VMRGLB,\n\tPPC_INS_VMRGLH,\n\tPPC_INS_VMRGLW,\n\tPPC_INS_VMSUMMBM,\n\tPPC_INS_VMSUMSHM,\n\tPPC_INS_VMSUMSHS,\n\tPPC_INS_VMSUMUBM,\n\tPPC_INS_VMSUMUHM,\n\tPPC_INS_VMSUMUHS,\n\tPPC_INS_VMULESB,\n\tPPC_INS_VMULESH,\n\tPPC_INS_VMULEUB,\n\tPPC_INS_VMULEUH,\n\tPPC_INS_VMULOSB,\n\tPPC_INS_VMULOSH,\n\tPPC_INS_VMULOUB,\n\tPPC_INS_VMULOUH,\n\tPPC_INS_VNMSUBFP,\n\tPPC_INS_VNOR,\n\tPPC_INS_VOR,\n\tPPC_INS_VPERM,\n\tPPC_INS_VPKPX,\n\tPPC_INS_VPKSHSS,\n\tPPC_INS_VPKSHUS,\n\tPPC_INS_VPKSWSS,\n\tPPC_INS_VPKSWUS,\n\tPPC_INS_VPKUHUM,\n\tPPC_INS_VPKUHUS,\n\tPPC_INS_VPKUWUM,\n\tPPC_INS_VPKUWUS,\n\tPPC_INS_VREFP,\n\tPPC_INS_VRFIM,\n\tPPC_INS_VRFIN,\n\tPPC_INS_VRFIP,\n\tPPC_INS_VRFIZ,\n\tPPC_INS_VRLB,\n\tPPC_INS_VRLH,\n\tPPC_INS_VRLW,\n\tPPC_INS_VRSQRTEFP,\n\tPPC_INS_VSEL,\n\tPPC_INS_VSL,\n\tPPC_INS_VSLB,\n\tPPC_INS_VSLDOI,\n\tPPC_INS_VSLH,\n\tPPC_INS_VSLO,\n\tPPC_INS_VSLW,\n\tPPC_INS_VSPLTB,\n\tPPC_INS_VSPLTH,\n\tPPC_INS_VSPLTISB,\n\tPPC_INS_VSPLTISH,\n\tPPC_INS_VSPLTISW,\n\tPPC_INS_VSPLTW,\n\tPPC_INS_VSR,\n\tPPC_INS_VSRAB,\n\tPPC_INS_VSRAH,\n\tPPC_INS_VSRAW,\n\tPPC_INS_VSRB,\n\tPPC_INS_VSRH,\n\tPPC_INS_VSRO,\n\tPPC_INS_VSRW,\n\tPPC_INS_VSUBCUW,\n\tPPC_INS_VSUBFP,\n\tPPC_INS_VSUBSBS,\n\tPPC_INS_VSUBSHS,\n\tPPC_INS_VSUBSWS,\n\tPPC_INS_VSUBUBM,\n\tPPC_INS_VSUBUBS,\n\tPPC_INS_VSUBUHM,\n\tPPC_INS_VSUBUHS,\n\tPPC_INS_VSUBUWM,\n\tPPC_INS_VSUBUWS,\n\tPPC_INS_VSUM2SWS,\n\tPPC_INS_VSUM4SBS,\n\tPPC_INS_VSUM4SHS,\n\tPPC_INS_VSUM4UBS,\n\tPPC_INS_VSUMSWS,\n\tPPC_INS_VUPKHPX,\n\tPPC_INS_VUPKHSB,\n\tPPC_INS_VUPKHSH,\n\tPPC_INS_VUPKLPX,\n\tPPC_INS_VUPKLSB,\n\tPPC_INS_VUPKLSH,\n\tPPC_INS_VXOR,\n\tPPC_INS_WAIT,\n\tPPC_INS_WRTEE,\n\tPPC_INS_WRTEEI,\n\tPPC_INS_XOR,\n\tPPC_INS_XORI,\n\tPPC_INS_XORIS,\n\tPPC_INS_XSABSDP,\n\tPPC_INS_XSADDDP,\n\tPPC_INS_XSCMPODP,\n\tPPC_INS_XSCMPUDP,\n\tPPC_INS_XSCPSGNDP,\n\tPPC_INS_XSCVDPSP,\n\tPPC_INS_XSCVDPSXDS,\n\tPPC_INS_XSCVDPSXWS,\n\tPPC_INS_XSCVDPUXDS,\n\tPPC_INS_XSCVDPUXWS,\n\tPPC_INS_XSCVSPDP,\n\tPPC_INS_XSCVSXDDP,\n\tPPC_INS_XSCVUXDDP,\n\tPPC_INS_XSDIVDP,\n\tPPC_INS_XSMADDADP,\n\tPPC_INS_XSMADDMDP,\n\tPPC_INS_XSMAXDP,\n\tPPC_INS_XSMINDP,\n\tPPC_INS_XSMSUBADP,\n\tPPC_INS_XSMSUBMDP,\n\tPPC_INS_XSMULDP,\n\tPPC_INS_XSNABSDP,\n\tPPC_INS_XSNEGDP,\n\tPPC_INS_XSNMADDADP,\n\tPPC_INS_XSNMADDMDP,\n\tPPC_INS_XSNMSUBADP,\n\tPPC_INS_XSNMSUBMDP,\n\tPPC_INS_XSRDPI,\n\tPPC_INS_XSRDPIC,\n\tPPC_INS_XSRDPIM,\n\tPPC_INS_XSRDPIP,\n\tPPC_INS_XSRDPIZ,\n\tPPC_INS_XSREDP,\n\tPPC_INS_XSRSQRTEDP,\n\tPPC_INS_XSSQRTDP,\n\tPPC_INS_XSSUBDP,\n\tPPC_INS_XSTDIVDP,\n\tPPC_INS_XSTSQRTDP,\n\tPPC_INS_XVABSDP,\n\tPPC_INS_XVABSSP,\n\tPPC_INS_XVADDDP,\n\tPPC_INS_XVADDSP,\n\tPPC_INS_XVCMPEQDP,\n\tPPC_INS_XVCMPEQSP,\n\tPPC_INS_XVCMPGEDP,\n\tPPC_INS_XVCMPGESP,\n\tPPC_INS_XVCMPGTDP,\n\tPPC_INS_XVCMPGTSP,\n\tPPC_INS_XVCPSGNDP,\n\tPPC_INS_XVCPSGNSP,\n\tPPC_INS_XVCVDPSP,\n\tPPC_INS_XVCVDPSXDS,\n\tPPC_INS_XVCVDPSXWS,\n\tPPC_INS_XVCVDPUXDS,\n\tPPC_INS_XVCVDPUXWS,\n\tPPC_INS_XVCVSPDP,\n\tPPC_INS_XVCVSPSXDS,\n\tPPC_INS_XVCVSPSXWS,\n\tPPC_INS_XVCVSPUXDS,\n\tPPC_INS_XVCVSPUXWS,\n\tPPC_INS_XVCVSXDDP,\n\tPPC_INS_XVCVSXDSP,\n\tPPC_INS_XVCVSXWDP,\n\tPPC_INS_XVCVSXWSP,\n\tPPC_INS_XVCVUXDDP,\n\tPPC_INS_XVCVUXDSP,\n\tPPC_INS_XVCVUXWDP,\n\tPPC_INS_XVCVUXWSP,\n\tPPC_INS_XVDIVDP,\n\tPPC_INS_XVDIVSP,\n\tPPC_INS_XVMADDADP,\n\tPPC_INS_XVMADDASP,\n\tPPC_INS_XVMADDMDP,\n\tPPC_INS_XVMADDMSP,\n\tPPC_INS_XVMAXDP,\n\tPPC_INS_XVMAXSP,\n\tPPC_INS_XVMINDP,\n\tPPC_INS_XVMINSP,\n\tPPC_INS_XVMSUBADP,\n\tPPC_INS_XVMSUBASP,\n\tPPC_INS_XVMSUBMDP,\n\tPPC_INS_XVMSUBMSP,\n\tPPC_INS_XVMULDP,\n\tPPC_INS_XVMULSP,\n\tPPC_INS_XVNABSDP,\n\tPPC_INS_XVNABSSP,\n\tPPC_INS_XVNEGDP,\n\tPPC_INS_XVNEGSP,\n\tPPC_INS_XVNMADDADP,\n\tPPC_INS_XVNMADDASP,\n\tPPC_INS_XVNMADDMDP,\n\tPPC_INS_XVNMADDMSP,\n\tPPC_INS_XVNMSUBADP,\n\tPPC_INS_XVNMSUBASP,\n\tPPC_INS_XVNMSUBMDP,\n\tPPC_INS_XVNMSUBMSP,\n\tPPC_INS_XVRDPI,\n\tPPC_INS_XVRDPIC,\n\tPPC_INS_XVRDPIM,\n\tPPC_INS_XVRDPIP,\n\tPPC_INS_XVRDPIZ,\n\tPPC_INS_XVREDP,\n\tPPC_INS_XVRESP,\n\tPPC_INS_XVRSPI,\n\tPPC_INS_XVRSPIC,\n\tPPC_INS_XVRSPIM,\n\tPPC_INS_XVRSPIP,\n\tPPC_INS_XVRSPIZ,\n\tPPC_INS_XVRSQRTEDP,\n\tPPC_INS_XVRSQRTESP,\n\tPPC_INS_XVSQRTDP,\n\tPPC_INS_XVSQRTSP,\n\tPPC_INS_XVSUBDP,\n\tPPC_INS_XVSUBSP,\n\tPPC_INS_XVTDIVDP,\n\tPPC_INS_XVTDIVSP,\n\tPPC_INS_XVTSQRTDP,\n\tPPC_INS_XVTSQRTSP,\n\tPPC_INS_XXLAND,\n\tPPC_INS_XXLANDC,\n\tPPC_INS_XXLNOR,\n\tPPC_INS_XXLOR,\n\tPPC_INS_XXLXOR,\n\tPPC_INS_XXMRGHW,\n\tPPC_INS_XXMRGLW,\n\tPPC_INS_XXPERMDI,\n\tPPC_INS_XXSEL,\n\tPPC_INS_XXSLDWI,\n\tPPC_INS_XXSPLTW,\n\tPPC_INS_BCA,\n\tPPC_INS_BCLA,\n\n\t// extra & alias instructions\n\tPPC_INS_SLWI,\n\tPPC_INS_SRWI,\n\tPPC_INS_SLDI,\n\n\tPPC_INS_BTA,\n\tPPC_INS_CRSET,\n\tPPC_INS_CRNOT,\n\tPPC_INS_CRMOVE,\n\tPPC_INS_CRCLR,\n\tPPC_INS_MFBR0,\n\tPPC_INS_MFBR1,\n\tPPC_INS_MFBR2,\n\tPPC_INS_MFBR3,\n\tPPC_INS_MFBR4,\n\tPPC_INS_MFBR5,\n\tPPC_INS_MFBR6,\n\tPPC_INS_MFBR7,\n\tPPC_INS_MFXER,\n\tPPC_INS_MFRTCU,\n\tPPC_INS_MFRTCL,\n\tPPC_INS_MFDSCR,\n\tPPC_INS_MFDSISR,\n\tPPC_INS_MFDAR,\n\tPPC_INS_MFSRR2,\n\tPPC_INS_MFSRR3,\n\tPPC_INS_MFCFAR,\n\tPPC_INS_MFAMR,\n\tPPC_INS_MFPID,\n\tPPC_INS_MFTBLO,\n\tPPC_INS_MFTBHI,\n\tPPC_INS_MFDBATU,\n\tPPC_INS_MFDBATL,\n\tPPC_INS_MFIBATU,\n\tPPC_INS_MFIBATL,\n\tPPC_INS_MFDCCR,\n\tPPC_INS_MFICCR,\n\tPPC_INS_MFDEAR,\n\tPPC_INS_MFESR,\n\tPPC_INS_MFSPEFSCR,\n\tPPC_INS_MFTCR,\n\tPPC_INS_MFASR,\n\tPPC_INS_MFPVR,\n\tPPC_INS_MFTBU,\n\tPPC_INS_MTCR,\n\tPPC_INS_MTBR0,\n\tPPC_INS_MTBR1,\n\tPPC_INS_MTBR2,\n\tPPC_INS_MTBR3,\n\tPPC_INS_MTBR4,\n\tPPC_INS_MTBR5,\n\tPPC_INS_MTBR6,\n\tPPC_INS_MTBR7,\n\tPPC_INS_MTXER,\n\tPPC_INS_MTDSCR,\n\tPPC_INS_MTDSISR,\n\tPPC_INS_MTDAR,\n\tPPC_INS_MTSRR2,\n\tPPC_INS_MTSRR3,\n\tPPC_INS_MTCFAR,\n\tPPC_INS_MTAMR,\n\tPPC_INS_MTPID,\n\tPPC_INS_MTTBL,\n\tPPC_INS_MTTBU,\n\tPPC_INS_MTTBLO,\n\tPPC_INS_MTTBHI,\n\tPPC_INS_MTDBATU,\n\tPPC_INS_MTDBATL,\n\tPPC_INS_MTIBATU,\n\tPPC_INS_MTIBATL,\n\tPPC_INS_MTDCCR,\n\tPPC_INS_MTICCR,\n\tPPC_INS_MTDEAR,\n\tPPC_INS_MTESR,\n\tPPC_INS_MTSPEFSCR,\n\tPPC_INS_MTTCR,\n\tPPC_INS_NOT,\n\tPPC_INS_MR,\n\tPPC_INS_ROTLD,\n\tPPC_INS_ROTLDI,\n\tPPC_INS_CLRLDI,\n\tPPC_INS_ROTLWI,\n\tPPC_INS_CLRLWI,\n\tPPC_INS_ROTLW,\n\tPPC_INS_SUB,\n\tPPC_INS_SUBC,\n\tPPC_INS_LWSYNC,\n\tPPC_INS_PTESYNC,\n\tPPC_INS_TDLT,\n\tPPC_INS_TDEQ,\n\tPPC_INS_TDGT,\n\tPPC_INS_TDNE,\n\tPPC_INS_TDLLT,\n\tPPC_INS_TDLGT,\n\tPPC_INS_TDU,\n\tPPC_INS_TDLTI,\n\tPPC_INS_TDEQI,\n\tPPC_INS_TDGTI,\n\tPPC_INS_TDNEI,\n\tPPC_INS_TDLLTI,\n\tPPC_INS_TDLGTI,\n\tPPC_INS_TDUI,\n\tPPC_INS_TLBREHI,\n\tPPC_INS_TLBRELO,\n\tPPC_INS_TLBWEHI,\n\tPPC_INS_TLBWELO,\n\tPPC_INS_TWLT,\n\tPPC_INS_TWEQ,\n\tPPC_INS_TWGT,\n\tPPC_INS_TWNE,\n\tPPC_INS_TWLLT,\n\tPPC_INS_TWLGT,\n\tPPC_INS_TWU,\n\tPPC_INS_TWLTI,\n\tPPC_INS_TWEQI,\n\tPPC_INS_TWGTI,\n\tPPC_INS_TWNEI,\n\tPPC_INS_TWLLTI,\n\tPPC_INS_TWLGTI,\n\tPPC_INS_TWUI,\n\tPPC_INS_WAITRSV,\n\tPPC_INS_WAITIMPL,\n\tPPC_INS_XNOP,\n\tPPC_INS_XVMOVDP,\n\tPPC_INS_XVMOVSP,\n\tPPC_INS_XXSPLTD,\n\tPPC_INS_XXMRGHD,\n\tPPC_INS_XXMRGLD,\n\tPPC_INS_XXSWAPD,\n\tPPC_INS_BT,\n\tPPC_INS_BF,\n\tPPC_INS_BDNZT,\n\tPPC_INS_BDNZF,\n\tPPC_INS_BDZF,\n\tPPC_INS_BDZT,\n\tPPC_INS_BFA,\n\tPPC_INS_BDNZTA,\n\tPPC_INS_BDNZFA,\n\tPPC_INS_BDZTA,\n\tPPC_INS_BDZFA,\n\tPPC_INS_BTCTR,\n\tPPC_INS_BFCTR,\n\tPPC_INS_BTCTRL,\n\tPPC_INS_BFCTRL,\n\tPPC_INS_BTL,\n\tPPC_INS_BFL,\n\tPPC_INS_BDNZTL,\n\tPPC_INS_BDNZFL,\n\tPPC_INS_BDZTL,\n\tPPC_INS_BDZFL,\n\tPPC_INS_BTLA,\n\tPPC_INS_BFLA,\n\tPPC_INS_BDNZTLA,\n\tPPC_INS_BDNZFLA,\n\tPPC_INS_BDZTLA,\n\tPPC_INS_BDZFLA,\n\tPPC_INS_BTLR,\n\tPPC_INS_BFLR,\n\tPPC_INS_BDNZTLR,\n\tPPC_INS_BDZTLR,\n\tPPC_INS_BDZFLR,\n\tPPC_INS_BTLRL,\n\tPPC_INS_BFLRL,\n\tPPC_INS_BDNZTLRL,\n\tPPC_INS_BDNZFLRL,\n\tPPC_INS_BDZTLRL,\n\tPPC_INS_BDZFLRL,\n\n\tPPC_INS_ENDING,   // <-- mark the end of the list of instructions\n} ppc_insn;\n\n//> Group of PPC instructions\ntypedef enum ppc_insn_group {\n\tPPC_GRP_INVALID = 0, // = CS_GRP_INVALID\n\n\t//> Generic groups\n\t// all jump instructions (conditional+direct+indirect jumps)\n\tPPC_GRP_JUMP,\t// = CS_GRP_JUMP\n\n\t//> Architecture-specific groups\n\tPPC_GRP_ALTIVEC = 128,\n\tPPC_GRP_MODE32,\n\tPPC_GRP_MODE64,\n\tPPC_GRP_BOOKE,\n\tPPC_GRP_NOTBOOKE,\n\tPPC_GRP_SPE,\n\tPPC_GRP_VSX,\n\tPPC_GRP_E500,\n\tPPC_GRP_PPC4XX,\n\tPPC_GRP_PPC6XX,\n\n\tPPC_GRP_ENDING,   // <-- mark the end of the list of groups\n} ppc_insn_group;\n\n#ifdef __cplusplus\n}\n#endif\n\n#endif\n"
  },
  {
    "path": "EFI_DEBUG/EFI/OC/Kexts/Lilu.kext/Contents/Resources/Headers/capstone/sparc.h",
    "content": "#ifndef CAPSTONE_SPARC_H\n#define CAPSTONE_SPARC_H\n\n/* Capstone Disassembly Engine */\n/* By Nguyen Anh Quynh <aquynh@gmail.com>, 2014 */\n\n#ifdef __cplusplus\nextern \"C\" {\n#endif\n\n#if !defined(_MSC_VER) || !defined(_KERNEL_MODE)\n#include <stdint.h>\n#endif\n\n#include \"platform.h\"\n\n// GCC SPARC toolchain has a default macro called \"sparc\" which breaks\n// compilation\n#undef sparc\n\n#ifdef _MSC_VER\n#pragma warning(disable:4201)\n#endif\n\n//> Enums corresponding to Sparc condition codes, both icc's and fcc's.\ntypedef enum sparc_cc {\n\tSPARC_CC_INVALID = 0,\t// invalid CC (default)\n\t//> Integer condition codes\n\tSPARC_CC_ICC_A   =  8+256,  // Always\n\tSPARC_CC_ICC_N   =  0+256,  // Never\n\tSPARC_CC_ICC_NE  =  9+256,  // Not Equal\n\tSPARC_CC_ICC_E   =  1+256,  // Equal\n\tSPARC_CC_ICC_G   = 10+256,  // Greater\n\tSPARC_CC_ICC_LE  =  2+256,  // Less or Equal\n\tSPARC_CC_ICC_GE  = 11+256,  // Greater or Equal\n\tSPARC_CC_ICC_L   =  3+256,  // Less\n\tSPARC_CC_ICC_GU  = 12+256,  // Greater Unsigned\n\tSPARC_CC_ICC_LEU =  4+256,  // Less or Equal Unsigned\n\tSPARC_CC_ICC_CC  = 13+256,  // Carry Clear/Great or Equal Unsigned\n\tSPARC_CC_ICC_CS  =  5+256,  // Carry Set/Less Unsigned\n\tSPARC_CC_ICC_POS = 14+256,  // Positive\n\tSPARC_CC_ICC_NEG =  6+256,  // Negative\n\tSPARC_CC_ICC_VC  = 15+256,  // Overflow Clear\n\tSPARC_CC_ICC_VS  =  7+256,  // Overflow Set\n\n\t//> Floating condition codes\n\tSPARC_CC_FCC_A   =  8+16+256,  // Always\n\tSPARC_CC_FCC_N   =  0+16+256,  // Never\n\tSPARC_CC_FCC_U   =  7+16+256,  // Unordered\n\tSPARC_CC_FCC_G   =  6+16+256,  // Greater\n\tSPARC_CC_FCC_UG  =  5+16+256,  // Unordered or Greater\n\tSPARC_CC_FCC_L   =  4+16+256,  // Less\n\tSPARC_CC_FCC_UL  =  3+16+256,  // Unordered or Less\n\tSPARC_CC_FCC_LG  =  2+16+256,  // Less or Greater\n\tSPARC_CC_FCC_NE  =  1+16+256,  // Not Equal\n\tSPARC_CC_FCC_E   =  9+16+256,  // Equal\n\tSPARC_CC_FCC_UE  = 10+16+256,  // Unordered or Equal\n\tSPARC_CC_FCC_GE  = 11+16+256,  // Greater or Equal\n\tSPARC_CC_FCC_UGE = 12+16+256,  // Unordered or Greater or Equal\n\tSPARC_CC_FCC_LE  = 13+16+256,  // Less or Equal\n\tSPARC_CC_FCC_ULE = 14+16+256,  // Unordered or Less or Equal\n\tSPARC_CC_FCC_O   = 15+16+256,  // Ordered\n} sparc_cc;\n\n//> Branch hint\ntypedef enum sparc_hint {\n\tSPARC_HINT_INVALID = 0,\t// no hint\n\tSPARC_HINT_A\t= 1 << 0,\t// annul delay slot instruction\n\tSPARC_HINT_PT\t= 1 << 1,\t// branch taken\n\tSPARC_HINT_PN\t= 1 << 2,\t// branch NOT taken\n} sparc_hint;\n\n//> Operand type for instruction's operands\ntypedef enum sparc_op_type {\n\tSPARC_OP_INVALID = 0, // = CS_OP_INVALID (Uninitialized).\n\tSPARC_OP_REG, // = CS_OP_REG (Register operand).\n\tSPARC_OP_IMM, // = CS_OP_IMM (Immediate operand).\n\tSPARC_OP_MEM, // = CS_OP_MEM (Memory operand).\n} sparc_op_type;\n\n// Instruction's operand referring to memory\n// This is associated with SPARC_OP_MEM operand type above\ntypedef struct sparc_op_mem {\n\tuint8_t base;\t// base register\n\tuint8_t index;\t// index register\n\tint32_t disp;\t// displacement/offset value\n} sparc_op_mem;\n\n// Instruction operand\ntypedef struct cs_sparc_op {\n\tsparc_op_type type;\t// operand type\n\tunion {\n\t\tunsigned int reg;\t// register value for REG operand\n\t\tint32_t imm;\t\t// immediate value for IMM operand\n\t\tsparc_op_mem mem;\t\t// base/disp value for MEM operand\n\t};\n} cs_sparc_op;\n\n// Instruction structure\ntypedef struct cs_sparc {\n\tsparc_cc cc;\t// code condition for this insn\n\tsparc_hint hint;\t// branch hint: encoding as bitwise OR of sparc_hint.\n\t// Number of operands of this instruction, \n\t// or 0 when instruction has no operand.\n\tuint8_t op_count;\n\tcs_sparc_op operands[4]; // operands for this instruction.\n} cs_sparc;\n\n//> SPARC registers\ntypedef enum sparc_reg {\n\tSPARC_REG_INVALID = 0,\n\n\tSPARC_REG_F0,\n\tSPARC_REG_F1,\n\tSPARC_REG_F2,\n\tSPARC_REG_F3,\n\tSPARC_REG_F4,\n\tSPARC_REG_F5,\n\tSPARC_REG_F6,\n\tSPARC_REG_F7,\n\tSPARC_REG_F8,\n\tSPARC_REG_F9,\n\tSPARC_REG_F10,\n\tSPARC_REG_F11,\n\tSPARC_REG_F12,\n\tSPARC_REG_F13,\n\tSPARC_REG_F14,\n\tSPARC_REG_F15,\n\tSPARC_REG_F16,\n\tSPARC_REG_F17,\n\tSPARC_REG_F18,\n\tSPARC_REG_F19,\n\tSPARC_REG_F20,\n\tSPARC_REG_F21,\n\tSPARC_REG_F22,\n\tSPARC_REG_F23,\n\tSPARC_REG_F24,\n\tSPARC_REG_F25,\n\tSPARC_REG_F26,\n\tSPARC_REG_F27,\n\tSPARC_REG_F28,\n\tSPARC_REG_F29,\n\tSPARC_REG_F30,\n\tSPARC_REG_F31,\n\tSPARC_REG_F32,\n\tSPARC_REG_F34,\n\tSPARC_REG_F36,\n\tSPARC_REG_F38,\n\tSPARC_REG_F40,\n\tSPARC_REG_F42,\n\tSPARC_REG_F44,\n\tSPARC_REG_F46,\n\tSPARC_REG_F48,\n\tSPARC_REG_F50,\n\tSPARC_REG_F52,\n\tSPARC_REG_F54,\n\tSPARC_REG_F56,\n\tSPARC_REG_F58,\n\tSPARC_REG_F60,\n\tSPARC_REG_F62,\n\tSPARC_REG_FCC0,\t// Floating condition codes\n\tSPARC_REG_FCC1,\n\tSPARC_REG_FCC2,\n\tSPARC_REG_FCC3,\n\tSPARC_REG_FP,\n\tSPARC_REG_G0,\n\tSPARC_REG_G1,\n\tSPARC_REG_G2,\n\tSPARC_REG_G3,\n\tSPARC_REG_G4,\n\tSPARC_REG_G5,\n\tSPARC_REG_G6,\n\tSPARC_REG_G7,\n\tSPARC_REG_I0,\n\tSPARC_REG_I1,\n\tSPARC_REG_I2,\n\tSPARC_REG_I3,\n\tSPARC_REG_I4,\n\tSPARC_REG_I5,\n\tSPARC_REG_I7,\n\tSPARC_REG_ICC,\t// Integer condition codes\n\tSPARC_REG_L0,\n\tSPARC_REG_L1,\n\tSPARC_REG_L2,\n\tSPARC_REG_L3,\n\tSPARC_REG_L4,\n\tSPARC_REG_L5,\n\tSPARC_REG_L6,\n\tSPARC_REG_L7,\n\tSPARC_REG_O0,\n\tSPARC_REG_O1,\n\tSPARC_REG_O2,\n\tSPARC_REG_O3,\n\tSPARC_REG_O4,\n\tSPARC_REG_O5,\n\tSPARC_REG_O7,\n\tSPARC_REG_SP,\n\tSPARC_REG_Y,\n\n\t// special register\n\tSPARC_REG_XCC,\n\n\tSPARC_REG_ENDING,   // <-- mark the end of the list of registers\n\n\t// extras\n\tSPARC_REG_O6 = SPARC_REG_SP,\n\tSPARC_REG_I6 = SPARC_REG_FP,\n} sparc_reg;\n\n//> SPARC instruction\ntypedef enum sparc_insn {\n\tSPARC_INS_INVALID = 0,\n\n\tSPARC_INS_ADDCC,\n\tSPARC_INS_ADDX,\n\tSPARC_INS_ADDXCC,\n\tSPARC_INS_ADDXC,\n\tSPARC_INS_ADDXCCC,\n\tSPARC_INS_ADD,\n\tSPARC_INS_ALIGNADDR,\n\tSPARC_INS_ALIGNADDRL,\n\tSPARC_INS_ANDCC,\n\tSPARC_INS_ANDNCC,\n\tSPARC_INS_ANDN,\n\tSPARC_INS_AND,\n\tSPARC_INS_ARRAY16,\n\tSPARC_INS_ARRAY32,\n\tSPARC_INS_ARRAY8,\n\tSPARC_INS_B,\n\tSPARC_INS_JMP,\n\tSPARC_INS_BMASK,\n\tSPARC_INS_FB,\n\tSPARC_INS_BRGEZ,\n\tSPARC_INS_BRGZ,\n\tSPARC_INS_BRLEZ,\n\tSPARC_INS_BRLZ,\n\tSPARC_INS_BRNZ,\n\tSPARC_INS_BRZ,\n\tSPARC_INS_BSHUFFLE,\n\tSPARC_INS_CALL,\n\tSPARC_INS_CASX,\n\tSPARC_INS_CAS,\n\tSPARC_INS_CMASK16,\n\tSPARC_INS_CMASK32,\n\tSPARC_INS_CMASK8,\n\tSPARC_INS_CMP,\n\tSPARC_INS_EDGE16,\n\tSPARC_INS_EDGE16L,\n\tSPARC_INS_EDGE16LN,\n\tSPARC_INS_EDGE16N,\n\tSPARC_INS_EDGE32,\n\tSPARC_INS_EDGE32L,\n\tSPARC_INS_EDGE32LN,\n\tSPARC_INS_EDGE32N,\n\tSPARC_INS_EDGE8,\n\tSPARC_INS_EDGE8L,\n\tSPARC_INS_EDGE8LN,\n\tSPARC_INS_EDGE8N,\n\tSPARC_INS_FABSD,\n\tSPARC_INS_FABSQ,\n\tSPARC_INS_FABSS,\n\tSPARC_INS_FADDD,\n\tSPARC_INS_FADDQ,\n\tSPARC_INS_FADDS,\n\tSPARC_INS_FALIGNDATA,\n\tSPARC_INS_FAND,\n\tSPARC_INS_FANDNOT1,\n\tSPARC_INS_FANDNOT1S,\n\tSPARC_INS_FANDNOT2,\n\tSPARC_INS_FANDNOT2S,\n\tSPARC_INS_FANDS,\n\tSPARC_INS_FCHKSM16,\n\tSPARC_INS_FCMPD,\n\tSPARC_INS_FCMPEQ16,\n\tSPARC_INS_FCMPEQ32,\n\tSPARC_INS_FCMPGT16,\n\tSPARC_INS_FCMPGT32,\n\tSPARC_INS_FCMPLE16,\n\tSPARC_INS_FCMPLE32,\n\tSPARC_INS_FCMPNE16,\n\tSPARC_INS_FCMPNE32,\n\tSPARC_INS_FCMPQ,\n\tSPARC_INS_FCMPS,\n\tSPARC_INS_FDIVD,\n\tSPARC_INS_FDIVQ,\n\tSPARC_INS_FDIVS,\n\tSPARC_INS_FDMULQ,\n\tSPARC_INS_FDTOI,\n\tSPARC_INS_FDTOQ,\n\tSPARC_INS_FDTOS,\n\tSPARC_INS_FDTOX,\n\tSPARC_INS_FEXPAND,\n\tSPARC_INS_FHADDD,\n\tSPARC_INS_FHADDS,\n\tSPARC_INS_FHSUBD,\n\tSPARC_INS_FHSUBS,\n\tSPARC_INS_FITOD,\n\tSPARC_INS_FITOQ,\n\tSPARC_INS_FITOS,\n\tSPARC_INS_FLCMPD,\n\tSPARC_INS_FLCMPS,\n\tSPARC_INS_FLUSHW,\n\tSPARC_INS_FMEAN16,\n\tSPARC_INS_FMOVD,\n\tSPARC_INS_FMOVQ,\n\tSPARC_INS_FMOVRDGEZ,\n\tSPARC_INS_FMOVRQGEZ,\n\tSPARC_INS_FMOVRSGEZ,\n\tSPARC_INS_FMOVRDGZ,\n\tSPARC_INS_FMOVRQGZ,\n\tSPARC_INS_FMOVRSGZ,\n\tSPARC_INS_FMOVRDLEZ,\n\tSPARC_INS_FMOVRQLEZ,\n\tSPARC_INS_FMOVRSLEZ,\n\tSPARC_INS_FMOVRDLZ,\n\tSPARC_INS_FMOVRQLZ,\n\tSPARC_INS_FMOVRSLZ,\n\tSPARC_INS_FMOVRDNZ,\n\tSPARC_INS_FMOVRQNZ,\n\tSPARC_INS_FMOVRSNZ,\n\tSPARC_INS_FMOVRDZ,\n\tSPARC_INS_FMOVRQZ,\n\tSPARC_INS_FMOVRSZ,\n\tSPARC_INS_FMOVS,\n\tSPARC_INS_FMUL8SUX16,\n\tSPARC_INS_FMUL8ULX16,\n\tSPARC_INS_FMUL8X16,\n\tSPARC_INS_FMUL8X16AL,\n\tSPARC_INS_FMUL8X16AU,\n\tSPARC_INS_FMULD,\n\tSPARC_INS_FMULD8SUX16,\n\tSPARC_INS_FMULD8ULX16,\n\tSPARC_INS_FMULQ,\n\tSPARC_INS_FMULS,\n\tSPARC_INS_FNADDD,\n\tSPARC_INS_FNADDS,\n\tSPARC_INS_FNAND,\n\tSPARC_INS_FNANDS,\n\tSPARC_INS_FNEGD,\n\tSPARC_INS_FNEGQ,\n\tSPARC_INS_FNEGS,\n\tSPARC_INS_FNHADDD,\n\tSPARC_INS_FNHADDS,\n\tSPARC_INS_FNOR,\n\tSPARC_INS_FNORS,\n\tSPARC_INS_FNOT1,\n\tSPARC_INS_FNOT1S,\n\tSPARC_INS_FNOT2,\n\tSPARC_INS_FNOT2S,\n\tSPARC_INS_FONE,\n\tSPARC_INS_FONES,\n\tSPARC_INS_FOR,\n\tSPARC_INS_FORNOT1,\n\tSPARC_INS_FORNOT1S,\n\tSPARC_INS_FORNOT2,\n\tSPARC_INS_FORNOT2S,\n\tSPARC_INS_FORS,\n\tSPARC_INS_FPACK16,\n\tSPARC_INS_FPACK32,\n\tSPARC_INS_FPACKFIX,\n\tSPARC_INS_FPADD16,\n\tSPARC_INS_FPADD16S,\n\tSPARC_INS_FPADD32,\n\tSPARC_INS_FPADD32S,\n\tSPARC_INS_FPADD64,\n\tSPARC_INS_FPMERGE,\n\tSPARC_INS_FPSUB16,\n\tSPARC_INS_FPSUB16S,\n\tSPARC_INS_FPSUB32,\n\tSPARC_INS_FPSUB32S,\n\tSPARC_INS_FQTOD,\n\tSPARC_INS_FQTOI,\n\tSPARC_INS_FQTOS,\n\tSPARC_INS_FQTOX,\n\tSPARC_INS_FSLAS16,\n\tSPARC_INS_FSLAS32,\n\tSPARC_INS_FSLL16,\n\tSPARC_INS_FSLL32,\n\tSPARC_INS_FSMULD,\n\tSPARC_INS_FSQRTD,\n\tSPARC_INS_FSQRTQ,\n\tSPARC_INS_FSQRTS,\n\tSPARC_INS_FSRA16,\n\tSPARC_INS_FSRA32,\n\tSPARC_INS_FSRC1,\n\tSPARC_INS_FSRC1S,\n\tSPARC_INS_FSRC2,\n\tSPARC_INS_FSRC2S,\n\tSPARC_INS_FSRL16,\n\tSPARC_INS_FSRL32,\n\tSPARC_INS_FSTOD,\n\tSPARC_INS_FSTOI,\n\tSPARC_INS_FSTOQ,\n\tSPARC_INS_FSTOX,\n\tSPARC_INS_FSUBD,\n\tSPARC_INS_FSUBQ,\n\tSPARC_INS_FSUBS,\n\tSPARC_INS_FXNOR,\n\tSPARC_INS_FXNORS,\n\tSPARC_INS_FXOR,\n\tSPARC_INS_FXORS,\n\tSPARC_INS_FXTOD,\n\tSPARC_INS_FXTOQ,\n\tSPARC_INS_FXTOS,\n\tSPARC_INS_FZERO,\n\tSPARC_INS_FZEROS,\n\tSPARC_INS_JMPL,\n\tSPARC_INS_LDD,\n\tSPARC_INS_LD,\n\tSPARC_INS_LDQ,\n\tSPARC_INS_LDSB,\n\tSPARC_INS_LDSH,\n\tSPARC_INS_LDSW,\n\tSPARC_INS_LDUB,\n\tSPARC_INS_LDUH,\n\tSPARC_INS_LDX,\n\tSPARC_INS_LZCNT,\n\tSPARC_INS_MEMBAR,\n\tSPARC_INS_MOVDTOX,\n\tSPARC_INS_MOV,\n\tSPARC_INS_MOVRGEZ,\n\tSPARC_INS_MOVRGZ,\n\tSPARC_INS_MOVRLEZ,\n\tSPARC_INS_MOVRLZ,\n\tSPARC_INS_MOVRNZ,\n\tSPARC_INS_MOVRZ,\n\tSPARC_INS_MOVSTOSW,\n\tSPARC_INS_MOVSTOUW,\n\tSPARC_INS_MULX,\n\tSPARC_INS_NOP,\n\tSPARC_INS_ORCC,\n\tSPARC_INS_ORNCC,\n\tSPARC_INS_ORN,\n\tSPARC_INS_OR,\n\tSPARC_INS_PDIST,\n\tSPARC_INS_PDISTN,\n\tSPARC_INS_POPC,\n\tSPARC_INS_RD,\n\tSPARC_INS_RESTORE,\n\tSPARC_INS_RETT,\n\tSPARC_INS_SAVE,\n\tSPARC_INS_SDIVCC,\n\tSPARC_INS_SDIVX,\n\tSPARC_INS_SDIV,\n\tSPARC_INS_SETHI,\n\tSPARC_INS_SHUTDOWN,\n\tSPARC_INS_SIAM,\n\tSPARC_INS_SLLX,\n\tSPARC_INS_SLL,\n\tSPARC_INS_SMULCC,\n\tSPARC_INS_SMUL,\n\tSPARC_INS_SRAX,\n\tSPARC_INS_SRA,\n\tSPARC_INS_SRLX,\n\tSPARC_INS_SRL,\n\tSPARC_INS_STBAR,\n\tSPARC_INS_STB,\n\tSPARC_INS_STD,\n\tSPARC_INS_ST,\n\tSPARC_INS_STH,\n\tSPARC_INS_STQ,\n\tSPARC_INS_STX,\n\tSPARC_INS_SUBCC,\n\tSPARC_INS_SUBX,\n\tSPARC_INS_SUBXCC,\n\tSPARC_INS_SUB,\n\tSPARC_INS_SWAP,\n\tSPARC_INS_TADDCCTV,\n\tSPARC_INS_TADDCC,\n\tSPARC_INS_T,\n\tSPARC_INS_TSUBCCTV,\n\tSPARC_INS_TSUBCC,\n\tSPARC_INS_UDIVCC,\n\tSPARC_INS_UDIVX,\n\tSPARC_INS_UDIV,\n\tSPARC_INS_UMULCC,\n\tSPARC_INS_UMULXHI,\n\tSPARC_INS_UMUL,\n\tSPARC_INS_UNIMP,\n\tSPARC_INS_FCMPED,\n\tSPARC_INS_FCMPEQ,\n\tSPARC_INS_FCMPES,\n\tSPARC_INS_WR,\n\tSPARC_INS_XMULX,\n\tSPARC_INS_XMULXHI,\n\tSPARC_INS_XNORCC,\n\tSPARC_INS_XNOR,\n\tSPARC_INS_XORCC,\n\tSPARC_INS_XOR,\n\n\t// alias instructions\n\tSPARC_INS_RET,\n\tSPARC_INS_RETL,\n\n\tSPARC_INS_ENDING,   // <-- mark the end of the list of instructions\n} sparc_insn;\n\n//> Group of SPARC instructions\ntypedef enum sparc_insn_group {\n\tSPARC_GRP_INVALID = 0, // = CS_GRP_INVALID\n\n\t//> Generic groups\n\t// all jump instructions (conditional+direct+indirect jumps)\n\tSPARC_GRP_JUMP,\t// = CS_GRP_JUMP\n\n\t//> Architecture-specific groups\n\tSPARC_GRP_HARDQUAD = 128,\n\tSPARC_GRP_V9,\n\tSPARC_GRP_VIS,\n\tSPARC_GRP_VIS2,\n\tSPARC_GRP_VIS3, \n\tSPARC_GRP_32BIT,\n\tSPARC_GRP_64BIT,\n\n\tSPARC_GRP_ENDING,   // <-- mark the end of the list of groups\n} sparc_insn_group;\n\n#ifdef __cplusplus\n}\n#endif\n\n#endif\n"
  },
  {
    "path": "EFI_DEBUG/EFI/OC/Kexts/Lilu.kext/Contents/Resources/Headers/capstone/systemz.h",
    "content": "#ifndef CAPSTONE_SYSTEMZ_H\n#define CAPSTONE_SYSTEMZ_H\n\n/* Capstone Disassembly Engine */\n/* By Nguyen Anh Quynh <aquynh@gmail.com>, 2014 */\n\n#ifdef __cplusplus\nextern \"C\" {\n#endif\n\n#if !defined(_MSC_VER) || !defined(_KERNEL_MODE)\n#include <stdint.h>\n#endif\n\n#include \"platform.h\"\n\n#ifdef _MSC_VER\n#pragma warning(disable:4201)\n#endif\n\n//> Enums corresponding to SystemZ condition codes\ntypedef enum sysz_cc {\n\tSYSZ_CC_INVALID = 0,\t// invalid CC (default)\n\n\tSYSZ_CC_O,\n\tSYSZ_CC_H,\n\tSYSZ_CC_NLE,\n\tSYSZ_CC_L,\n\tSYSZ_CC_NHE,\n\tSYSZ_CC_LH,\n\tSYSZ_CC_NE,\n\tSYSZ_CC_E,\n\tSYSZ_CC_NLH,\n\tSYSZ_CC_HE,\n\tSYSZ_CC_NL,\n\tSYSZ_CC_LE,\n\tSYSZ_CC_NH,\n\tSYSZ_CC_NO,\n} sysz_cc;\n\n//> Operand type for instruction's operands\ntypedef enum sysz_op_type {\n\tSYSZ_OP_INVALID = 0, // = CS_OP_INVALID (Uninitialized).\n\tSYSZ_OP_REG, // = CS_OP_REG (Register operand).\n\tSYSZ_OP_IMM, // = CS_OP_IMM (Immediate operand).\n\tSYSZ_OP_MEM, // = CS_OP_MEM (Memory operand).\n\tSYSZ_OP_ACREG = 64,\t// Access register operand.\n} sysz_op_type;\n\n// Instruction's operand referring to memory\n// This is associated with SYSZ_OP_MEM operand type above\ntypedef struct sysz_op_mem {\n\tuint8_t base;\t// base register\n\tuint8_t index;\t// index register\n\tuint64_t length;\t// BDLAddr operand\n\tint64_t disp;\t// displacement/offset value\n} sysz_op_mem;\n\n// Instruction operand\ntypedef struct cs_sysz_op {\n\tsysz_op_type type;\t// operand type\n\tunion {\n\t\tunsigned int reg;\t// register value for REG operand\n\t\tint64_t imm;\t\t// immediate value for IMM operand\n\t\tsysz_op_mem mem;\t\t// base/disp value for MEM operand\n\t};\n} cs_sysz_op;\n\n// Instruction structure\ntypedef struct cs_sysz {\n\tsysz_cc cc;\t\t// Code condition\n\t// Number of operands of this instruction, \n\t// or 0 when instruction has no operand.\n\tuint8_t op_count;\n\tcs_sysz_op operands[6]; // operands for this instruction.\n} cs_sysz;\n\n//> SystemZ registers\ntypedef enum sysz_reg {\n\tSYSZ_REG_INVALID = 0,\n\n\tSYSZ_REG_0, \n\tSYSZ_REG_1, \n\tSYSZ_REG_2, \n\tSYSZ_REG_3, \n\tSYSZ_REG_4, \n\tSYSZ_REG_5, \n\tSYSZ_REG_6, \n\tSYSZ_REG_7, \n\tSYSZ_REG_8, \n\tSYSZ_REG_9, \n\tSYSZ_REG_10,\n\tSYSZ_REG_11,\n\tSYSZ_REG_12,\n\tSYSZ_REG_13,\n\tSYSZ_REG_14,\n\tSYSZ_REG_15,\n\tSYSZ_REG_CC,\n\tSYSZ_REG_F0,\n\tSYSZ_REG_F1,\n\tSYSZ_REG_F2,\n\tSYSZ_REG_F3,\n\tSYSZ_REG_F4,\n\tSYSZ_REG_F5,\n\tSYSZ_REG_F6,\n\tSYSZ_REG_F7,\n\tSYSZ_REG_F8,\n\tSYSZ_REG_F9,\n\tSYSZ_REG_F10,\n\tSYSZ_REG_F11,\n\tSYSZ_REG_F12,\n\tSYSZ_REG_F13,\n\tSYSZ_REG_F14,\n\tSYSZ_REG_F15,\n\n\tSYSZ_REG_R0L,\n\n\tSYSZ_REG_ENDING,\n} sysz_reg;\n\n//> SystemZ instruction\ntypedef enum sysz_insn {\n\tSYSZ_INS_INVALID = 0,\n\n\tSYSZ_INS_A,\n\tSYSZ_INS_ADB,\n\tSYSZ_INS_ADBR,\n\tSYSZ_INS_AEB,\n\tSYSZ_INS_AEBR,\n\tSYSZ_INS_AFI,\n\tSYSZ_INS_AG,\n\tSYSZ_INS_AGF,\n\tSYSZ_INS_AGFI,\n\tSYSZ_INS_AGFR,\n\tSYSZ_INS_AGHI,\n\tSYSZ_INS_AGHIK,\n\tSYSZ_INS_AGR,\n\tSYSZ_INS_AGRK,\n\tSYSZ_INS_AGSI,\n\tSYSZ_INS_AH,\n\tSYSZ_INS_AHI,\n\tSYSZ_INS_AHIK,\n\tSYSZ_INS_AHY,\n\tSYSZ_INS_AIH,\n\tSYSZ_INS_AL,\n\tSYSZ_INS_ALC,\n\tSYSZ_INS_ALCG,\n\tSYSZ_INS_ALCGR,\n\tSYSZ_INS_ALCR,\n\tSYSZ_INS_ALFI,\n\tSYSZ_INS_ALG,\n\tSYSZ_INS_ALGF,\n\tSYSZ_INS_ALGFI,\n\tSYSZ_INS_ALGFR,\n\tSYSZ_INS_ALGHSIK,\n\tSYSZ_INS_ALGR,\n\tSYSZ_INS_ALGRK,\n\tSYSZ_INS_ALHSIK,\n\tSYSZ_INS_ALR,\n\tSYSZ_INS_ALRK,\n\tSYSZ_INS_ALY,\n\tSYSZ_INS_AR,\n\tSYSZ_INS_ARK,\n\tSYSZ_INS_ASI,\n\tSYSZ_INS_AXBR,\n\tSYSZ_INS_AY,\n\tSYSZ_INS_BCR,\n\tSYSZ_INS_BRC,\n\tSYSZ_INS_BRCL,\n\tSYSZ_INS_CGIJ,\n\tSYSZ_INS_CGRJ,\n\tSYSZ_INS_CIJ,\n\tSYSZ_INS_CLGIJ,\n\tSYSZ_INS_CLGRJ,\n\tSYSZ_INS_CLIJ,\n\tSYSZ_INS_CLRJ,\n\tSYSZ_INS_CRJ,\n\tSYSZ_INS_BER,\n\tSYSZ_INS_JE,\n\tSYSZ_INS_JGE,\n\tSYSZ_INS_LOCE,\n\tSYSZ_INS_LOCGE,\n\tSYSZ_INS_LOCGRE,\n\tSYSZ_INS_LOCRE,\n\tSYSZ_INS_STOCE,\n\tSYSZ_INS_STOCGE,\n\tSYSZ_INS_BHR,\n\tSYSZ_INS_BHER,\n\tSYSZ_INS_JHE,\n\tSYSZ_INS_JGHE,\n\tSYSZ_INS_LOCHE,\n\tSYSZ_INS_LOCGHE,\n\tSYSZ_INS_LOCGRHE,\n\tSYSZ_INS_LOCRHE,\n\tSYSZ_INS_STOCHE,\n\tSYSZ_INS_STOCGHE,\n\tSYSZ_INS_JH,\n\tSYSZ_INS_JGH,\n\tSYSZ_INS_LOCH,\n\tSYSZ_INS_LOCGH,\n\tSYSZ_INS_LOCGRH,\n\tSYSZ_INS_LOCRH,\n\tSYSZ_INS_STOCH,\n\tSYSZ_INS_STOCGH,\n\tSYSZ_INS_CGIJNLH,\n\tSYSZ_INS_CGRJNLH,\n\tSYSZ_INS_CIJNLH,\n\tSYSZ_INS_CLGIJNLH,\n\tSYSZ_INS_CLGRJNLH,\n\tSYSZ_INS_CLIJNLH,\n\tSYSZ_INS_CLRJNLH,\n\tSYSZ_INS_CRJNLH,\n\tSYSZ_INS_CGIJE,\n\tSYSZ_INS_CGRJE,\n\tSYSZ_INS_CIJE,\n\tSYSZ_INS_CLGIJE,\n\tSYSZ_INS_CLGRJE,\n\tSYSZ_INS_CLIJE,\n\tSYSZ_INS_CLRJE,\n\tSYSZ_INS_CRJE,\n\tSYSZ_INS_CGIJNLE,\n\tSYSZ_INS_CGRJNLE,\n\tSYSZ_INS_CIJNLE,\n\tSYSZ_INS_CLGIJNLE,\n\tSYSZ_INS_CLGRJNLE,\n\tSYSZ_INS_CLIJNLE,\n\tSYSZ_INS_CLRJNLE,\n\tSYSZ_INS_CRJNLE,\n\tSYSZ_INS_CGIJH,\n\tSYSZ_INS_CGRJH,\n\tSYSZ_INS_CIJH,\n\tSYSZ_INS_CLGIJH,\n\tSYSZ_INS_CLGRJH,\n\tSYSZ_INS_CLIJH,\n\tSYSZ_INS_CLRJH,\n\tSYSZ_INS_CRJH,\n\tSYSZ_INS_CGIJNL,\n\tSYSZ_INS_CGRJNL,\n\tSYSZ_INS_CIJNL,\n\tSYSZ_INS_CLGIJNL,\n\tSYSZ_INS_CLGRJNL,\n\tSYSZ_INS_CLIJNL,\n\tSYSZ_INS_CLRJNL,\n\tSYSZ_INS_CRJNL,\n\tSYSZ_INS_CGIJHE,\n\tSYSZ_INS_CGRJHE,\n\tSYSZ_INS_CIJHE,\n\tSYSZ_INS_CLGIJHE,\n\tSYSZ_INS_CLGRJHE,\n\tSYSZ_INS_CLIJHE,\n\tSYSZ_INS_CLRJHE,\n\tSYSZ_INS_CRJHE,\n\tSYSZ_INS_CGIJNHE,\n\tSYSZ_INS_CGRJNHE,\n\tSYSZ_INS_CIJNHE,\n\tSYSZ_INS_CLGIJNHE,\n\tSYSZ_INS_CLGRJNHE,\n\tSYSZ_INS_CLIJNHE,\n\tSYSZ_INS_CLRJNHE,\n\tSYSZ_INS_CRJNHE,\n\tSYSZ_INS_CGIJL,\n\tSYSZ_INS_CGRJL,\n\tSYSZ_INS_CIJL,\n\tSYSZ_INS_CLGIJL,\n\tSYSZ_INS_CLGRJL,\n\tSYSZ_INS_CLIJL,\n\tSYSZ_INS_CLRJL,\n\tSYSZ_INS_CRJL,\n\tSYSZ_INS_CGIJNH,\n\tSYSZ_INS_CGRJNH,\n\tSYSZ_INS_CIJNH,\n\tSYSZ_INS_CLGIJNH,\n\tSYSZ_INS_CLGRJNH,\n\tSYSZ_INS_CLIJNH,\n\tSYSZ_INS_CLRJNH,\n\tSYSZ_INS_CRJNH,\n\tSYSZ_INS_CGIJLE,\n\tSYSZ_INS_CGRJLE,\n\tSYSZ_INS_CIJLE,\n\tSYSZ_INS_CLGIJLE,\n\tSYSZ_INS_CLGRJLE,\n\tSYSZ_INS_CLIJLE,\n\tSYSZ_INS_CLRJLE,\n\tSYSZ_INS_CRJLE,\n\tSYSZ_INS_CGIJNE,\n\tSYSZ_INS_CGRJNE,\n\tSYSZ_INS_CIJNE,\n\tSYSZ_INS_CLGIJNE,\n\tSYSZ_INS_CLGRJNE,\n\tSYSZ_INS_CLIJNE,\n\tSYSZ_INS_CLRJNE,\n\tSYSZ_INS_CRJNE,\n\tSYSZ_INS_CGIJLH,\n\tSYSZ_INS_CGRJLH,\n\tSYSZ_INS_CIJLH,\n\tSYSZ_INS_CLGIJLH,\n\tSYSZ_INS_CLGRJLH,\n\tSYSZ_INS_CLIJLH,\n\tSYSZ_INS_CLRJLH,\n\tSYSZ_INS_CRJLH,\n\tSYSZ_INS_BLR,\n\tSYSZ_INS_BLER,\n\tSYSZ_INS_JLE,\n\tSYSZ_INS_JGLE,\n\tSYSZ_INS_LOCLE,\n\tSYSZ_INS_LOCGLE,\n\tSYSZ_INS_LOCGRLE,\n\tSYSZ_INS_LOCRLE,\n\tSYSZ_INS_STOCLE,\n\tSYSZ_INS_STOCGLE,\n\tSYSZ_INS_BLHR,\n\tSYSZ_INS_JLH,\n\tSYSZ_INS_JGLH,\n\tSYSZ_INS_LOCLH,\n\tSYSZ_INS_LOCGLH,\n\tSYSZ_INS_LOCGRLH,\n\tSYSZ_INS_LOCRLH,\n\tSYSZ_INS_STOCLH,\n\tSYSZ_INS_STOCGLH,\n\tSYSZ_INS_JL,\n\tSYSZ_INS_JGL,\n\tSYSZ_INS_LOCL,\n\tSYSZ_INS_LOCGL,\n\tSYSZ_INS_LOCGRL,\n\tSYSZ_INS_LOCRL,\n\tSYSZ_INS_LOC,\n\tSYSZ_INS_LOCG,\n\tSYSZ_INS_LOCGR,\n\tSYSZ_INS_LOCR,\n\tSYSZ_INS_STOCL,\n\tSYSZ_INS_STOCGL,\n\tSYSZ_INS_BNER,\n\tSYSZ_INS_JNE,\n\tSYSZ_INS_JGNE,\n\tSYSZ_INS_LOCNE,\n\tSYSZ_INS_LOCGNE,\n\tSYSZ_INS_LOCGRNE,\n\tSYSZ_INS_LOCRNE,\n\tSYSZ_INS_STOCNE,\n\tSYSZ_INS_STOCGNE,\n\tSYSZ_INS_BNHR,\n\tSYSZ_INS_BNHER,\n\tSYSZ_INS_JNHE,\n\tSYSZ_INS_JGNHE,\n\tSYSZ_INS_LOCNHE,\n\tSYSZ_INS_LOCGNHE,\n\tSYSZ_INS_LOCGRNHE,\n\tSYSZ_INS_LOCRNHE,\n\tSYSZ_INS_STOCNHE,\n\tSYSZ_INS_STOCGNHE,\n\tSYSZ_INS_JNH,\n\tSYSZ_INS_JGNH,\n\tSYSZ_INS_LOCNH,\n\tSYSZ_INS_LOCGNH,\n\tSYSZ_INS_LOCGRNH,\n\tSYSZ_INS_LOCRNH,\n\tSYSZ_INS_STOCNH,\n\tSYSZ_INS_STOCGNH,\n\tSYSZ_INS_BNLR,\n\tSYSZ_INS_BNLER,\n\tSYSZ_INS_JNLE,\n\tSYSZ_INS_JGNLE,\n\tSYSZ_INS_LOCNLE,\n\tSYSZ_INS_LOCGNLE,\n\tSYSZ_INS_LOCGRNLE,\n\tSYSZ_INS_LOCRNLE,\n\tSYSZ_INS_STOCNLE,\n\tSYSZ_INS_STOCGNLE,\n\tSYSZ_INS_BNLHR,\n\tSYSZ_INS_JNLH,\n\tSYSZ_INS_JGNLH,\n\tSYSZ_INS_LOCNLH,\n\tSYSZ_INS_LOCGNLH,\n\tSYSZ_INS_LOCGRNLH,\n\tSYSZ_INS_LOCRNLH,\n\tSYSZ_INS_STOCNLH,\n\tSYSZ_INS_STOCGNLH,\n\tSYSZ_INS_JNL,\n\tSYSZ_INS_JGNL,\n\tSYSZ_INS_LOCNL,\n\tSYSZ_INS_LOCGNL,\n\tSYSZ_INS_LOCGRNL,\n\tSYSZ_INS_LOCRNL,\n\tSYSZ_INS_STOCNL,\n\tSYSZ_INS_STOCGNL,\n\tSYSZ_INS_BNOR,\n\tSYSZ_INS_JNO,\n\tSYSZ_INS_JGNO,\n\tSYSZ_INS_LOCNO,\n\tSYSZ_INS_LOCGNO,\n\tSYSZ_INS_LOCGRNO,\n\tSYSZ_INS_LOCRNO,\n\tSYSZ_INS_STOCNO,\n\tSYSZ_INS_STOCGNO,\n\tSYSZ_INS_BOR,\n\tSYSZ_INS_JO,\n\tSYSZ_INS_JGO,\n\tSYSZ_INS_LOCO,\n\tSYSZ_INS_LOCGO,\n\tSYSZ_INS_LOCGRO,\n\tSYSZ_INS_LOCRO,\n\tSYSZ_INS_STOCO,\n\tSYSZ_INS_STOCGO,\n\tSYSZ_INS_STOC,\n\tSYSZ_INS_STOCG,\n\tSYSZ_INS_BASR,\n\tSYSZ_INS_BR,\n\tSYSZ_INS_BRAS,\n\tSYSZ_INS_BRASL,\n\tSYSZ_INS_J,\n\tSYSZ_INS_JG,\n\tSYSZ_INS_BRCT,\n\tSYSZ_INS_BRCTG,\n\tSYSZ_INS_C,\n\tSYSZ_INS_CDB,\n\tSYSZ_INS_CDBR,\n\tSYSZ_INS_CDFBR,\n\tSYSZ_INS_CDGBR,\n\tSYSZ_INS_CDLFBR,\n\tSYSZ_INS_CDLGBR,\n\tSYSZ_INS_CEB,\n\tSYSZ_INS_CEBR,\n\tSYSZ_INS_CEFBR,\n\tSYSZ_INS_CEGBR,\n\tSYSZ_INS_CELFBR,\n\tSYSZ_INS_CELGBR,\n\tSYSZ_INS_CFDBR,\n\tSYSZ_INS_CFEBR,\n\tSYSZ_INS_CFI,\n\tSYSZ_INS_CFXBR,\n\tSYSZ_INS_CG,\n\tSYSZ_INS_CGDBR,\n\tSYSZ_INS_CGEBR,\n\tSYSZ_INS_CGF,\n\tSYSZ_INS_CGFI,\n\tSYSZ_INS_CGFR,\n\tSYSZ_INS_CGFRL,\n\tSYSZ_INS_CGH,\n\tSYSZ_INS_CGHI,\n\tSYSZ_INS_CGHRL,\n\tSYSZ_INS_CGHSI,\n\tSYSZ_INS_CGR,\n\tSYSZ_INS_CGRL,\n\tSYSZ_INS_CGXBR,\n\tSYSZ_INS_CH,\n\tSYSZ_INS_CHF,\n\tSYSZ_INS_CHHSI,\n\tSYSZ_INS_CHI,\n\tSYSZ_INS_CHRL,\n\tSYSZ_INS_CHSI,\n\tSYSZ_INS_CHY,\n\tSYSZ_INS_CIH,\n\tSYSZ_INS_CL,\n\tSYSZ_INS_CLC,\n\tSYSZ_INS_CLFDBR,\n\tSYSZ_INS_CLFEBR,\n\tSYSZ_INS_CLFHSI,\n\tSYSZ_INS_CLFI,\n\tSYSZ_INS_CLFXBR,\n\tSYSZ_INS_CLG,\n\tSYSZ_INS_CLGDBR,\n\tSYSZ_INS_CLGEBR,\n\tSYSZ_INS_CLGF,\n\tSYSZ_INS_CLGFI,\n\tSYSZ_INS_CLGFR,\n\tSYSZ_INS_CLGFRL,\n\tSYSZ_INS_CLGHRL,\n\tSYSZ_INS_CLGHSI,\n\tSYSZ_INS_CLGR,\n\tSYSZ_INS_CLGRL,\n\tSYSZ_INS_CLGXBR,\n\tSYSZ_INS_CLHF,\n\tSYSZ_INS_CLHHSI,\n\tSYSZ_INS_CLHRL,\n\tSYSZ_INS_CLI,\n\tSYSZ_INS_CLIH,\n\tSYSZ_INS_CLIY,\n\tSYSZ_INS_CLR,\n\tSYSZ_INS_CLRL,\n\tSYSZ_INS_CLST,\n\tSYSZ_INS_CLY,\n\tSYSZ_INS_CPSDR,\n\tSYSZ_INS_CR,\n\tSYSZ_INS_CRL,\n\tSYSZ_INS_CS,\n\tSYSZ_INS_CSG,\n\tSYSZ_INS_CSY,\n\tSYSZ_INS_CXBR,\n\tSYSZ_INS_CXFBR,\n\tSYSZ_INS_CXGBR,\n\tSYSZ_INS_CXLFBR,\n\tSYSZ_INS_CXLGBR,\n\tSYSZ_INS_CY,\n\tSYSZ_INS_DDB,\n\tSYSZ_INS_DDBR,\n\tSYSZ_INS_DEB,\n\tSYSZ_INS_DEBR,\n\tSYSZ_INS_DL,\n\tSYSZ_INS_DLG,\n\tSYSZ_INS_DLGR,\n\tSYSZ_INS_DLR,\n\tSYSZ_INS_DSG,\n\tSYSZ_INS_DSGF,\n\tSYSZ_INS_DSGFR,\n\tSYSZ_INS_DSGR,\n\tSYSZ_INS_DXBR,\n\tSYSZ_INS_EAR,\n\tSYSZ_INS_FIDBR,\n\tSYSZ_INS_FIDBRA,\n\tSYSZ_INS_FIEBR,\n\tSYSZ_INS_FIEBRA,\n\tSYSZ_INS_FIXBR,\n\tSYSZ_INS_FIXBRA,\n\tSYSZ_INS_FLOGR,\n\tSYSZ_INS_IC,\n\tSYSZ_INS_ICY,\n\tSYSZ_INS_IIHF,\n\tSYSZ_INS_IIHH,\n\tSYSZ_INS_IIHL,\n\tSYSZ_INS_IILF,\n\tSYSZ_INS_IILH,\n\tSYSZ_INS_IILL,\n\tSYSZ_INS_IPM,\n\tSYSZ_INS_L,\n\tSYSZ_INS_LA,\n\tSYSZ_INS_LAA,\n\tSYSZ_INS_LAAG,\n\tSYSZ_INS_LAAL,\n\tSYSZ_INS_LAALG,\n\tSYSZ_INS_LAN,\n\tSYSZ_INS_LANG,\n\tSYSZ_INS_LAO,\n\tSYSZ_INS_LAOG,\n\tSYSZ_INS_LARL,\n\tSYSZ_INS_LAX,\n\tSYSZ_INS_LAXG,\n\tSYSZ_INS_LAY,\n\tSYSZ_INS_LB,\n\tSYSZ_INS_LBH,\n\tSYSZ_INS_LBR,\n\tSYSZ_INS_LCDBR,\n\tSYSZ_INS_LCEBR,\n\tSYSZ_INS_LCGFR,\n\tSYSZ_INS_LCGR,\n\tSYSZ_INS_LCR,\n\tSYSZ_INS_LCXBR,\n\tSYSZ_INS_LD,\n\tSYSZ_INS_LDEB,\n\tSYSZ_INS_LDEBR,\n\tSYSZ_INS_LDGR,\n\tSYSZ_INS_LDR,\n\tSYSZ_INS_LDXBR,\n\tSYSZ_INS_LDXBRA,\n\tSYSZ_INS_LDY,\n\tSYSZ_INS_LE,\n\tSYSZ_INS_LEDBR,\n\tSYSZ_INS_LEDBRA,\n\tSYSZ_INS_LER,\n\tSYSZ_INS_LEXBR,\n\tSYSZ_INS_LEXBRA,\n\tSYSZ_INS_LEY,\n\tSYSZ_INS_LFH,\n\tSYSZ_INS_LG,\n\tSYSZ_INS_LGB,\n\tSYSZ_INS_LGBR,\n\tSYSZ_INS_LGDR,\n\tSYSZ_INS_LGF,\n\tSYSZ_INS_LGFI,\n\tSYSZ_INS_LGFR,\n\tSYSZ_INS_LGFRL,\n\tSYSZ_INS_LGH,\n\tSYSZ_INS_LGHI,\n\tSYSZ_INS_LGHR,\n\tSYSZ_INS_LGHRL,\n\tSYSZ_INS_LGR,\n\tSYSZ_INS_LGRL,\n\tSYSZ_INS_LH,\n\tSYSZ_INS_LHH,\n\tSYSZ_INS_LHI,\n\tSYSZ_INS_LHR,\n\tSYSZ_INS_LHRL,\n\tSYSZ_INS_LHY,\n\tSYSZ_INS_LLC,\n\tSYSZ_INS_LLCH,\n\tSYSZ_INS_LLCR,\n\tSYSZ_INS_LLGC,\n\tSYSZ_INS_LLGCR,\n\tSYSZ_INS_LLGF,\n\tSYSZ_INS_LLGFR,\n\tSYSZ_INS_LLGFRL,\n\tSYSZ_INS_LLGH,\n\tSYSZ_INS_LLGHR,\n\tSYSZ_INS_LLGHRL,\n\tSYSZ_INS_LLH,\n\tSYSZ_INS_LLHH,\n\tSYSZ_INS_LLHR,\n\tSYSZ_INS_LLHRL,\n\tSYSZ_INS_LLIHF,\n\tSYSZ_INS_LLIHH,\n\tSYSZ_INS_LLIHL,\n\tSYSZ_INS_LLILF,\n\tSYSZ_INS_LLILH,\n\tSYSZ_INS_LLILL,\n\tSYSZ_INS_LMG,\n\tSYSZ_INS_LNDBR,\n\tSYSZ_INS_LNEBR,\n\tSYSZ_INS_LNGFR,\n\tSYSZ_INS_LNGR,\n\tSYSZ_INS_LNR,\n\tSYSZ_INS_LNXBR,\n\tSYSZ_INS_LPDBR,\n\tSYSZ_INS_LPEBR,\n\tSYSZ_INS_LPGFR,\n\tSYSZ_INS_LPGR,\n\tSYSZ_INS_LPR,\n\tSYSZ_INS_LPXBR,\n\tSYSZ_INS_LR,\n\tSYSZ_INS_LRL,\n\tSYSZ_INS_LRV,\n\tSYSZ_INS_LRVG,\n\tSYSZ_INS_LRVGR,\n\tSYSZ_INS_LRVR,\n\tSYSZ_INS_LT,\n\tSYSZ_INS_LTDBR,\n\tSYSZ_INS_LTEBR,\n\tSYSZ_INS_LTG,\n\tSYSZ_INS_LTGF,\n\tSYSZ_INS_LTGFR,\n\tSYSZ_INS_LTGR,\n\tSYSZ_INS_LTR,\n\tSYSZ_INS_LTXBR,\n\tSYSZ_INS_LXDB,\n\tSYSZ_INS_LXDBR,\n\tSYSZ_INS_LXEB,\n\tSYSZ_INS_LXEBR,\n\tSYSZ_INS_LXR,\n\tSYSZ_INS_LY,\n\tSYSZ_INS_LZDR,\n\tSYSZ_INS_LZER,\n\tSYSZ_INS_LZXR,\n\tSYSZ_INS_MADB,\n\tSYSZ_INS_MADBR,\n\tSYSZ_INS_MAEB,\n\tSYSZ_INS_MAEBR,\n\tSYSZ_INS_MDB,\n\tSYSZ_INS_MDBR,\n\tSYSZ_INS_MDEB,\n\tSYSZ_INS_MDEBR,\n\tSYSZ_INS_MEEB,\n\tSYSZ_INS_MEEBR,\n\tSYSZ_INS_MGHI,\n\tSYSZ_INS_MH,\n\tSYSZ_INS_MHI,\n\tSYSZ_INS_MHY,\n\tSYSZ_INS_MLG,\n\tSYSZ_INS_MLGR,\n\tSYSZ_INS_MS,\n\tSYSZ_INS_MSDB,\n\tSYSZ_INS_MSDBR,\n\tSYSZ_INS_MSEB,\n\tSYSZ_INS_MSEBR,\n\tSYSZ_INS_MSFI,\n\tSYSZ_INS_MSG,\n\tSYSZ_INS_MSGF,\n\tSYSZ_INS_MSGFI,\n\tSYSZ_INS_MSGFR,\n\tSYSZ_INS_MSGR,\n\tSYSZ_INS_MSR,\n\tSYSZ_INS_MSY,\n\tSYSZ_INS_MVC,\n\tSYSZ_INS_MVGHI,\n\tSYSZ_INS_MVHHI,\n\tSYSZ_INS_MVHI,\n\tSYSZ_INS_MVI,\n\tSYSZ_INS_MVIY,\n\tSYSZ_INS_MVST,\n\tSYSZ_INS_MXBR,\n\tSYSZ_INS_MXDB,\n\tSYSZ_INS_MXDBR,\n\tSYSZ_INS_N,\n\tSYSZ_INS_NC,\n\tSYSZ_INS_NG,\n\tSYSZ_INS_NGR,\n\tSYSZ_INS_NGRK,\n\tSYSZ_INS_NI,\n\tSYSZ_INS_NIHF,\n\tSYSZ_INS_NIHH,\n\tSYSZ_INS_NIHL,\n\tSYSZ_INS_NILF,\n\tSYSZ_INS_NILH,\n\tSYSZ_INS_NILL,\n\tSYSZ_INS_NIY,\n\tSYSZ_INS_NR,\n\tSYSZ_INS_NRK,\n\tSYSZ_INS_NY,\n\tSYSZ_INS_O,\n\tSYSZ_INS_OC,\n\tSYSZ_INS_OG,\n\tSYSZ_INS_OGR,\n\tSYSZ_INS_OGRK,\n\tSYSZ_INS_OI,\n\tSYSZ_INS_OIHF,\n\tSYSZ_INS_OIHH,\n\tSYSZ_INS_OIHL,\n\tSYSZ_INS_OILF,\n\tSYSZ_INS_OILH,\n\tSYSZ_INS_OILL,\n\tSYSZ_INS_OIY,\n\tSYSZ_INS_OR,\n\tSYSZ_INS_ORK,\n\tSYSZ_INS_OY,\n\tSYSZ_INS_PFD,\n\tSYSZ_INS_PFDRL,\n\tSYSZ_INS_RISBG,\n\tSYSZ_INS_RISBHG,\n\tSYSZ_INS_RISBLG,\n\tSYSZ_INS_RLL,\n\tSYSZ_INS_RLLG,\n\tSYSZ_INS_RNSBG,\n\tSYSZ_INS_ROSBG,\n\tSYSZ_INS_RXSBG,\n\tSYSZ_INS_S,\n\tSYSZ_INS_SDB,\n\tSYSZ_INS_SDBR,\n\tSYSZ_INS_SEB,\n\tSYSZ_INS_SEBR,\n\tSYSZ_INS_SG,\n\tSYSZ_INS_SGF,\n\tSYSZ_INS_SGFR,\n\tSYSZ_INS_SGR,\n\tSYSZ_INS_SGRK,\n\tSYSZ_INS_SH,\n\tSYSZ_INS_SHY,\n\tSYSZ_INS_SL,\n\tSYSZ_INS_SLB,\n\tSYSZ_INS_SLBG,\n\tSYSZ_INS_SLBR,\n\tSYSZ_INS_SLFI,\n\tSYSZ_INS_SLG,\n\tSYSZ_INS_SLBGR,\n\tSYSZ_INS_SLGF,\n\tSYSZ_INS_SLGFI,\n\tSYSZ_INS_SLGFR,\n\tSYSZ_INS_SLGR,\n\tSYSZ_INS_SLGRK,\n\tSYSZ_INS_SLL,\n\tSYSZ_INS_SLLG,\n\tSYSZ_INS_SLLK,\n\tSYSZ_INS_SLR,\n\tSYSZ_INS_SLRK,\n\tSYSZ_INS_SLY,\n\tSYSZ_INS_SQDB,\n\tSYSZ_INS_SQDBR,\n\tSYSZ_INS_SQEB,\n\tSYSZ_INS_SQEBR,\n\tSYSZ_INS_SQXBR,\n\tSYSZ_INS_SR,\n\tSYSZ_INS_SRA,\n\tSYSZ_INS_SRAG,\n\tSYSZ_INS_SRAK,\n\tSYSZ_INS_SRK,\n\tSYSZ_INS_SRL,\n\tSYSZ_INS_SRLG,\n\tSYSZ_INS_SRLK,\n\tSYSZ_INS_SRST,\n\tSYSZ_INS_ST,\n\tSYSZ_INS_STC,\n\tSYSZ_INS_STCH,\n\tSYSZ_INS_STCY,\n\tSYSZ_INS_STD,\n\tSYSZ_INS_STDY,\n\tSYSZ_INS_STE,\n\tSYSZ_INS_STEY,\n\tSYSZ_INS_STFH,\n\tSYSZ_INS_STG,\n\tSYSZ_INS_STGRL,\n\tSYSZ_INS_STH,\n\tSYSZ_INS_STHH,\n\tSYSZ_INS_STHRL,\n\tSYSZ_INS_STHY,\n\tSYSZ_INS_STMG,\n\tSYSZ_INS_STRL,\n\tSYSZ_INS_STRV,\n\tSYSZ_INS_STRVG,\n\tSYSZ_INS_STY,\n\tSYSZ_INS_SXBR,\n\tSYSZ_INS_SY,\n\tSYSZ_INS_TM,\n\tSYSZ_INS_TMHH,\n\tSYSZ_INS_TMHL,\n\tSYSZ_INS_TMLH,\n\tSYSZ_INS_TMLL,\n\tSYSZ_INS_TMY,\n\tSYSZ_INS_X,\n\tSYSZ_INS_XC,\n\tSYSZ_INS_XG,\n\tSYSZ_INS_XGR,\n\tSYSZ_INS_XGRK,\n\tSYSZ_INS_XI,\n\tSYSZ_INS_XIHF,\n\tSYSZ_INS_XILF,\n\tSYSZ_INS_XIY,\n\tSYSZ_INS_XR,\n\tSYSZ_INS_XRK,\n\tSYSZ_INS_XY,\n\n\tSYSZ_INS_ENDING,   // <-- mark the end of the list of instructions\n} sysz_insn;\n\n//> Group of SystemZ instructions\ntypedef enum sysz_insn_group {\n\tSYSZ_GRP_INVALID = 0, // = CS_GRP_INVALID\n\n\t//> Generic groups\n\t// all jump instructions (conditional+direct+indirect jumps)\n\tSYSZ_GRP_JUMP,\t// = CS_GRP_JUMP\n\n\t//> Architecture-specific groups\n\tSYSZ_GRP_DISTINCTOPS = 128,\n\tSYSZ_GRP_FPEXTENSION,\n\tSYSZ_GRP_HIGHWORD,\n\tSYSZ_GRP_INTERLOCKEDACCESS1,\n\tSYSZ_GRP_LOADSTOREONCOND,\n\n\tSYSZ_GRP_ENDING,   // <-- mark the end of the list of groups\n} sysz_insn_group;\n\n#ifdef __cplusplus\n}\n#endif\n\n#endif\n"
  },
  {
    "path": "EFI_DEBUG/EFI/OC/Kexts/Lilu.kext/Contents/Resources/Headers/capstone/x86.h",
    "content": "#ifndef CAPSTONE_X86_H\n#define CAPSTONE_X86_H\n\n/* Capstone Disassembly Engine */\n/* By Nguyen Anh Quynh <aquynh@gmail.com>, 2013-2014 */\n\n#ifdef __cplusplus\nextern \"C\" {\n#endif\n\n#if !defined(_MSC_VER) || !defined(_KERNEL_MODE)\n#include <stdint.h>\n#endif\n\n// Calculate relative address for X86-64, given cs_insn structure\n#define X86_REL_ADDR(insn) (((insn).detail->x86.operands[0].type == X86_OP_IMM) \\\n\t? (uint64_t)((insn).detail->x86.operands[0].imm) \\\n\t: (((insn).address + (insn).size) + (uint64_t)(insn).detail->x86.disp))\n\n//> X86 registers\ntypedef enum x86_reg {\n\tX86_REG_INVALID = 0,\n\tX86_REG_AH, X86_REG_AL, X86_REG_AX, X86_REG_BH, X86_REG_BL,\n\tX86_REG_BP, X86_REG_BPL, X86_REG_BX, X86_REG_CH, X86_REG_CL,\n\tX86_REG_CS, X86_REG_CX, X86_REG_DH, X86_REG_DI, X86_REG_DIL,\n\tX86_REG_DL, X86_REG_DS, X86_REG_DX, X86_REG_EAX, X86_REG_EBP,\n\tX86_REG_EBX, X86_REG_ECX, X86_REG_EDI, X86_REG_EDX, X86_REG_EFLAGS,\n\tX86_REG_EIP, X86_REG_EIZ, X86_REG_ES, X86_REG_ESI, X86_REG_ESP,\n\tX86_REG_FPSW, X86_REG_FS, X86_REG_GS, X86_REG_IP, X86_REG_RAX,\n\tX86_REG_RBP, X86_REG_RBX, X86_REG_RCX, X86_REG_RDI, X86_REG_RDX,\n\tX86_REG_RIP, X86_REG_RIZ, X86_REG_RSI, X86_REG_RSP, X86_REG_SI,\n\tX86_REG_SIL, X86_REG_SP, X86_REG_SPL, X86_REG_SS, X86_REG_CR0,\n\tX86_REG_CR1, X86_REG_CR2, X86_REG_CR3, X86_REG_CR4, X86_REG_CR5,\n\tX86_REG_CR6, X86_REG_CR7, X86_REG_CR8, X86_REG_CR9, X86_REG_CR10,\n\tX86_REG_CR11, X86_REG_CR12, X86_REG_CR13, X86_REG_CR14, X86_REG_CR15,\n\tX86_REG_DR0, X86_REG_DR1, X86_REG_DR2, X86_REG_DR3, X86_REG_DR4,\n\tX86_REG_DR5, X86_REG_DR6, X86_REG_DR7, X86_REG_FP0, X86_REG_FP1,\n\tX86_REG_FP2, X86_REG_FP3, X86_REG_FP4, X86_REG_FP5, X86_REG_FP6, X86_REG_FP7,\n\tX86_REG_K0, X86_REG_K1, X86_REG_K2, X86_REG_K3, X86_REG_K4,\n\tX86_REG_K5, X86_REG_K6, X86_REG_K7, X86_REG_MM0, X86_REG_MM1,\n\tX86_REG_MM2, X86_REG_MM3, X86_REG_MM4, X86_REG_MM5, X86_REG_MM6,\n\tX86_REG_MM7, X86_REG_R8, X86_REG_R9, X86_REG_R10, X86_REG_R11,\n\tX86_REG_R12, X86_REG_R13, X86_REG_R14, X86_REG_R15,\n\tX86_REG_ST0, X86_REG_ST1, X86_REG_ST2, X86_REG_ST3,\n\tX86_REG_ST4, X86_REG_ST5, X86_REG_ST6, X86_REG_ST7,\n\tX86_REG_XMM0, X86_REG_XMM1, X86_REG_XMM2, X86_REG_XMM3, X86_REG_XMM4,\n\tX86_REG_XMM5, X86_REG_XMM6, X86_REG_XMM7, X86_REG_XMM8, X86_REG_XMM9,\n\tX86_REG_XMM10, X86_REG_XMM11, X86_REG_XMM12, X86_REG_XMM13, X86_REG_XMM14,\n\tX86_REG_XMM15, X86_REG_XMM16, X86_REG_XMM17, X86_REG_XMM18, X86_REG_XMM19,\n\tX86_REG_XMM20, X86_REG_XMM21, X86_REG_XMM22, X86_REG_XMM23, X86_REG_XMM24,\n\tX86_REG_XMM25, X86_REG_XMM26, X86_REG_XMM27, X86_REG_XMM28, X86_REG_XMM29,\n\tX86_REG_XMM30, X86_REG_XMM31, X86_REG_YMM0, X86_REG_YMM1, X86_REG_YMM2,\n\tX86_REG_YMM3, X86_REG_YMM4, X86_REG_YMM5, X86_REG_YMM6, X86_REG_YMM7,\n\tX86_REG_YMM8, X86_REG_YMM9, X86_REG_YMM10, X86_REG_YMM11, X86_REG_YMM12,\n\tX86_REG_YMM13, X86_REG_YMM14, X86_REG_YMM15, X86_REG_YMM16, X86_REG_YMM17,\n\tX86_REG_YMM18, X86_REG_YMM19, X86_REG_YMM20, X86_REG_YMM21, X86_REG_YMM22,\n\tX86_REG_YMM23, X86_REG_YMM24, X86_REG_YMM25, X86_REG_YMM26, X86_REG_YMM27,\n\tX86_REG_YMM28, X86_REG_YMM29, X86_REG_YMM30, X86_REG_YMM31, X86_REG_ZMM0,\n\tX86_REG_ZMM1, X86_REG_ZMM2, X86_REG_ZMM3, X86_REG_ZMM4, X86_REG_ZMM5,\n\tX86_REG_ZMM6, X86_REG_ZMM7, X86_REG_ZMM8, X86_REG_ZMM9, X86_REG_ZMM10,\n\tX86_REG_ZMM11, X86_REG_ZMM12, X86_REG_ZMM13, X86_REG_ZMM14, X86_REG_ZMM15,\n\tX86_REG_ZMM16, X86_REG_ZMM17, X86_REG_ZMM18, X86_REG_ZMM19, X86_REG_ZMM20,\n\tX86_REG_ZMM21, X86_REG_ZMM22, X86_REG_ZMM23, X86_REG_ZMM24, X86_REG_ZMM25,\n\tX86_REG_ZMM26, X86_REG_ZMM27, X86_REG_ZMM28, X86_REG_ZMM29, X86_REG_ZMM30,\n\tX86_REG_ZMM31, X86_REG_R8B, X86_REG_R9B, X86_REG_R10B, X86_REG_R11B,\n\tX86_REG_R12B, X86_REG_R13B, X86_REG_R14B, X86_REG_R15B, X86_REG_R8D,\n\tX86_REG_R9D, X86_REG_R10D, X86_REG_R11D, X86_REG_R12D, X86_REG_R13D,\n\tX86_REG_R14D, X86_REG_R15D, X86_REG_R8W, X86_REG_R9W, X86_REG_R10W,\n\tX86_REG_R11W, X86_REG_R12W, X86_REG_R13W, X86_REG_R14W, X86_REG_R15W,\n\n\tX86_REG_ENDING\t\t// <-- mark the end of the list of registers\n} x86_reg;\n\n//> Operand type for instruction's operands\ntypedef enum x86_op_type {\n\tX86_OP_INVALID = 0, // = CS_OP_INVALID (Uninitialized).\n\tX86_OP_REG, // = CS_OP_REG (Register operand).\n\tX86_OP_IMM, // = CS_OP_IMM (Immediate operand).\n\tX86_OP_MEM, // = CS_OP_MEM (Memory operand).\n\tX86_OP_FP,  //  = CS_OP_FP  (Floating-Point operand).\n} x86_op_type;\n\n//> AVX broadcast type\ntypedef enum x86_avx_bcast {\n\tX86_AVX_BCAST_INVALID = 0,\t// Uninitialized.\n\tX86_AVX_BCAST_2,\t// AVX512 broadcast type {1to2}\n\tX86_AVX_BCAST_4,\t// AVX512 broadcast type {1to4}\n\tX86_AVX_BCAST_8,\t// AVX512 broadcast type {1to8}\n\tX86_AVX_BCAST_16,\t// AVX512 broadcast type {1to16}\n} x86_avx_bcast;\n\n//> SSE Code Condition type\ntypedef enum x86_sse_cc {\n\tX86_SSE_CC_INVALID = 0,\t// Uninitialized.\n\tX86_SSE_CC_EQ,\n\tX86_SSE_CC_LT,\n\tX86_SSE_CC_LE,\n\tX86_SSE_CC_UNORD,\n\tX86_SSE_CC_NEQ,\n\tX86_SSE_CC_NLT,\n\tX86_SSE_CC_NLE,\n\tX86_SSE_CC_ORD,\n\tX86_SSE_CC_EQ_UQ,\n\tX86_SSE_CC_NGE,\n\tX86_SSE_CC_NGT,\n\tX86_SSE_CC_FALSE,\n\tX86_SSE_CC_NEQ_OQ,\n\tX86_SSE_CC_GE,\n\tX86_SSE_CC_GT,\n\tX86_SSE_CC_TRUE,\n} x86_sse_cc;\n\n//> AVX Code Condition type\ntypedef enum x86_avx_cc {\n\tX86_AVX_CC_INVALID = 0,\t// Uninitialized.\n\tX86_AVX_CC_EQ,\n\tX86_AVX_CC_LT,\n\tX86_AVX_CC_LE,\n\tX86_AVX_CC_UNORD,\n\tX86_AVX_CC_NEQ,\n\tX86_AVX_CC_NLT,\n\tX86_AVX_CC_NLE,\n\tX86_AVX_CC_ORD,\n\tX86_AVX_CC_EQ_UQ,\n\tX86_AVX_CC_NGE,\n\tX86_AVX_CC_NGT,\n\tX86_AVX_CC_FALSE,\n\tX86_AVX_CC_NEQ_OQ,\n\tX86_AVX_CC_GE,\n\tX86_AVX_CC_GT,\n\tX86_AVX_CC_TRUE,\n\tX86_AVX_CC_EQ_OS,\n\tX86_AVX_CC_LT_OQ,\n\tX86_AVX_CC_LE_OQ,\n\tX86_AVX_CC_UNORD_S,\n\tX86_AVX_CC_NEQ_US,\n\tX86_AVX_CC_NLT_UQ,\n\tX86_AVX_CC_NLE_UQ,\n\tX86_AVX_CC_ORD_S,\n\tX86_AVX_CC_EQ_US,\n\tX86_AVX_CC_NGE_UQ,\n\tX86_AVX_CC_NGT_UQ,\n\tX86_AVX_CC_FALSE_OS,\n\tX86_AVX_CC_NEQ_OS,\n\tX86_AVX_CC_GE_OQ,\n\tX86_AVX_CC_GT_OQ,\n\tX86_AVX_CC_TRUE_US,\n} x86_avx_cc;\n\n//> AVX static rounding mode type\ntypedef enum x86_avx_rm {\n\tX86_AVX_RM_INVALID = 0,\t// Uninitialized.\n\tX86_AVX_RM_RN,\t// Round to nearest\n\tX86_AVX_RM_RD,\t// Round down\n\tX86_AVX_RM_RU,\t// Round up\n\tX86_AVX_RM_RZ,\t// Round toward zero\n} x86_avx_rm;\n\n//> Instruction prefixes - to be used in cs_x86.prefix[]\ntypedef enum x86_prefix {\n\tX86_PREFIX_LOCK\t\t= \t0xf0,\t// lock (cs_x86.prefix[0]\n\tX86_PREFIX_REP\t\t= \t0xf3,\t// rep (cs_x86.prefix[0]\n\tX86_PREFIX_REPNE\t= \t0xf2,\t// repne (cs_x86.prefix[0]\n\n\tX86_PREFIX_CS\t\t= \t0x2e,\t// segment override CS (cs_x86.prefix[1]\n\tX86_PREFIX_SS\t\t= \t0x36,\t// segment override SS (cs_x86.prefix[1]\n\tX86_PREFIX_DS\t\t= \t0x3e,\t// segment override DS (cs_x86.prefix[1]\n\tX86_PREFIX_ES\t\t= \t0x26,\t// segment override ES (cs_x86.prefix[1]\n\tX86_PREFIX_FS\t\t= \t0x64,\t// segment override FS (cs_x86.prefix[1]\n\tX86_PREFIX_GS\t\t= \t0x65,\t// segment override GS (cs_x86.prefix[1]\n\n\tX86_PREFIX_OPSIZE\t=\t0x66,\t// operand-size override (cs_x86.prefix[2]\n\tX86_PREFIX_ADDRSIZE\t=\t0x67,\t// address-size override (cs_x86.prefix[3]\n} x86_prefix;\n\n// Instruction's operand referring to memory\n// This is associated with X86_OP_MEM operand type above\ntypedef struct x86_op_mem {\n\tunsigned int segment; // segment register (or X86_REG_INVALID if irrelevant)\n\tunsigned int base;\t// base register (or X86_REG_INVALID if irrelevant)\n\tunsigned int index;\t// index register (or X86_REG_INVALID if irrelevant)\n\tint scale;\t// scale for index register\n\tint64_t disp;\t// displacement value\n} x86_op_mem;\n\n// Instruction operand\ntypedef struct cs_x86_op {\n\t\tx86_op_type type;\t// operand type\n\t\tunion {\n\t\t\tx86_reg reg;\t// register value for REG operand\n\t\t\tint64_t imm;\t\t// immediate value for IMM operand\n\t\t\tdouble fp;\t\t// floating point value for FP operand\n\t\t\tx86_op_mem mem;\t\t// base/index/scale/disp value for MEM operand\n\t\t};\n\n\t\t// size of this operand (in bytes).\n\t\tuint8_t size;\n\n\t\t// AVX broadcast type, or 0 if irrelevant\n\t\tx86_avx_bcast avx_bcast;\n\n\t\t// AVX zero opmask {z}\n\t\tbool avx_zero_opmask;\n} cs_x86_op;\n\n// Instruction structure\ntypedef struct cs_x86 {\n\t// Instruction prefix, which can be up to 4 bytes.\n\t// A prefix byte gets value 0 when irrelevant.\n\t// prefix[0] indicates REP/REPNE/LOCK prefix (See X86_PREFIX_REP/REPNE/LOCK above)\n\t// prefix[1] indicates segment override (irrelevant for x86_64):\n\t// See X86_PREFIX_CS/SS/DS/ES/FS/GS above.\n\t// prefix[2] indicates operand-size override (X86_PREFIX_OPSIZE)\n\t// prefix[3] indicates address-size override (X86_PREFIX_ADDRSIZE)\n\tuint8_t prefix[4];\n\n\t// Instruction opcode, which can be from 1 to 4 bytes in size.\n\t// This contains VEX opcode as well.\n\t// An trailing opcode byte gets value 0 when irrelevant.\n\tuint8_t opcode[4];\n\n\t// REX prefix: only a non-zero value is relevant for x86_64\n\tuint8_t rex;\n\n\t// Address size, which can be overridden with above prefix[5].\n\tuint8_t addr_size;\n\n\t// ModR/M byte\n\tuint8_t modrm;\n\n\t// SIB value, or 0 when irrelevant.\n\tuint8_t sib;\n\n\t// Displacement value, or 0 when irrelevant.\n\tint32_t disp;\n\n\t/* SIB state */\n\t// SIB index register, or X86_REG_INVALID when irrelevant.\n\tx86_reg sib_index;\n\t// SIB scale. only applicable if sib_index is relevant.\n\tint8_t sib_scale;\n\t// SIB base register, or X86_REG_INVALID when irrelevant.\n\tx86_reg sib_base;\n\n\t// SSE Code Condition\n\tx86_sse_cc sse_cc;\n\n\t// AVX Code Condition\n\tx86_avx_cc avx_cc;\n\n\t// AVX Suppress all Exception\n\tbool avx_sae;\n\n\t// AVX static rounding mode\n\tx86_avx_rm avx_rm;\n\n\t// Number of operands of this instruction,\n\t// or 0 when instruction has no operand.\n\tuint8_t op_count;\n\n\tcs_x86_op operands[8];\t// operands for this instruction.\n} cs_x86;\n\n//> X86 instructions\ntypedef enum x86_insn {\n\tX86_INS_INVALID = 0,\n\n\tX86_INS_AAA,\n\tX86_INS_AAD,\n\tX86_INS_AAM,\n\tX86_INS_AAS,\n\tX86_INS_FABS,\n\tX86_INS_ADC,\n\tX86_INS_ADCX,\n\tX86_INS_ADD,\n\tX86_INS_ADDPD,\n\tX86_INS_ADDPS,\n\tX86_INS_ADDSD,\n\tX86_INS_ADDSS,\n\tX86_INS_ADDSUBPD,\n\tX86_INS_ADDSUBPS,\n\tX86_INS_FADD,\n\tX86_INS_FIADD,\n\tX86_INS_FADDP,\n\tX86_INS_ADOX,\n\tX86_INS_AESDECLAST,\n\tX86_INS_AESDEC,\n\tX86_INS_AESENCLAST,\n\tX86_INS_AESENC,\n\tX86_INS_AESIMC,\n\tX86_INS_AESKEYGENASSIST,\n\tX86_INS_AND,\n\tX86_INS_ANDN,\n\tX86_INS_ANDNPD,\n\tX86_INS_ANDNPS,\n\tX86_INS_ANDPD,\n\tX86_INS_ANDPS,\n\tX86_INS_ARPL,\n\tX86_INS_BEXTR,\n\tX86_INS_BLCFILL,\n\tX86_INS_BLCI,\n\tX86_INS_BLCIC,\n\tX86_INS_BLCMSK,\n\tX86_INS_BLCS,\n\tX86_INS_BLENDPD,\n\tX86_INS_BLENDPS,\n\tX86_INS_BLENDVPD,\n\tX86_INS_BLENDVPS,\n\tX86_INS_BLSFILL,\n\tX86_INS_BLSI,\n\tX86_INS_BLSIC,\n\tX86_INS_BLSMSK,\n\tX86_INS_BLSR,\n\tX86_INS_BOUND,\n\tX86_INS_BSF,\n\tX86_INS_BSR,\n\tX86_INS_BSWAP,\n\tX86_INS_BT,\n\tX86_INS_BTC,\n\tX86_INS_BTR,\n\tX86_INS_BTS,\n\tX86_INS_BZHI,\n\tX86_INS_CALL,\n\tX86_INS_CBW,\n\tX86_INS_CDQ,\n\tX86_INS_CDQE,\n\tX86_INS_FCHS,\n\tX86_INS_CLAC,\n\tX86_INS_CLC,\n\tX86_INS_CLD,\n\tX86_INS_CLFLUSH,\n\tX86_INS_CLGI,\n\tX86_INS_CLI,\n\tX86_INS_CLTS,\n\tX86_INS_CMC,\n\tX86_INS_CMOVA,\n\tX86_INS_CMOVAE,\n\tX86_INS_CMOVB,\n\tX86_INS_CMOVBE,\n\tX86_INS_FCMOVBE,\n\tX86_INS_FCMOVB,\n\tX86_INS_CMOVE,\n\tX86_INS_FCMOVE,\n\tX86_INS_CMOVG,\n\tX86_INS_CMOVGE,\n\tX86_INS_CMOVL,\n\tX86_INS_CMOVLE,\n\tX86_INS_FCMOVNBE,\n\tX86_INS_FCMOVNB,\n\tX86_INS_CMOVNE,\n\tX86_INS_FCMOVNE,\n\tX86_INS_CMOVNO,\n\tX86_INS_CMOVNP,\n\tX86_INS_FCMOVNU,\n\tX86_INS_CMOVNS,\n\tX86_INS_CMOVO,\n\tX86_INS_CMOVP,\n\tX86_INS_FCMOVU,\n\tX86_INS_CMOVS,\n\tX86_INS_CMP,\n\tX86_INS_CMPPD,\n\tX86_INS_CMPPS,\n\tX86_INS_CMPSB,\n\tX86_INS_CMPSD,\n\tX86_INS_CMPSQ,\n\tX86_INS_CMPSS,\n\tX86_INS_CMPSW,\n\tX86_INS_CMPXCHG16B,\n\tX86_INS_CMPXCHG,\n\tX86_INS_CMPXCHG8B,\n\tX86_INS_COMISD,\n\tX86_INS_COMISS,\n\tX86_INS_FCOMP,\n\tX86_INS_FCOMPI,\n\tX86_INS_FCOMI,\n\tX86_INS_FCOM,\n\tX86_INS_FCOS,\n\tX86_INS_CPUID,\n\tX86_INS_CQO,\n\tX86_INS_CRC32,\n\tX86_INS_CVTDQ2PD,\n\tX86_INS_CVTDQ2PS,\n\tX86_INS_CVTPD2DQ,\n\tX86_INS_CVTPD2PS,\n\tX86_INS_CVTPS2DQ,\n\tX86_INS_CVTPS2PD,\n\tX86_INS_CVTSD2SI,\n\tX86_INS_CVTSD2SS,\n\tX86_INS_CVTSI2SD,\n\tX86_INS_CVTSI2SS,\n\tX86_INS_CVTSS2SD,\n\tX86_INS_CVTSS2SI,\n\tX86_INS_CVTTPD2DQ,\n\tX86_INS_CVTTPS2DQ,\n\tX86_INS_CVTTSD2SI,\n\tX86_INS_CVTTSS2SI,\n\tX86_INS_CWD,\n\tX86_INS_CWDE,\n\tX86_INS_DAA,\n\tX86_INS_DAS,\n\tX86_INS_DATA16,\n\tX86_INS_DEC,\n\tX86_INS_DIV,\n\tX86_INS_DIVPD,\n\tX86_INS_DIVPS,\n\tX86_INS_FDIVR,\n\tX86_INS_FIDIVR,\n\tX86_INS_FDIVRP,\n\tX86_INS_DIVSD,\n\tX86_INS_DIVSS,\n\tX86_INS_FDIV,\n\tX86_INS_FIDIV,\n\tX86_INS_FDIVP,\n\tX86_INS_DPPD,\n\tX86_INS_DPPS,\n\tX86_INS_RET,\n\tX86_INS_ENCLS,\n\tX86_INS_ENCLU,\n\tX86_INS_ENTER,\n\tX86_INS_EXTRACTPS,\n\tX86_INS_EXTRQ,\n\tX86_INS_F2XM1,\n\tX86_INS_LCALL,\n\tX86_INS_LJMP,\n\tX86_INS_FBLD,\n\tX86_INS_FBSTP,\n\tX86_INS_FCOMPP,\n\tX86_INS_FDECSTP,\n\tX86_INS_FEMMS,\n\tX86_INS_FFREE,\n\tX86_INS_FICOM,\n\tX86_INS_FICOMP,\n\tX86_INS_FINCSTP,\n\tX86_INS_FLDCW,\n\tX86_INS_FLDENV,\n\tX86_INS_FLDL2E,\n\tX86_INS_FLDL2T,\n\tX86_INS_FLDLG2,\n\tX86_INS_FLDLN2,\n\tX86_INS_FLDPI,\n\tX86_INS_FNCLEX,\n\tX86_INS_FNINIT,\n\tX86_INS_FNOP,\n\tX86_INS_FNSTCW,\n\tX86_INS_FNSTSW,\n\tX86_INS_FPATAN,\n\tX86_INS_FPREM,\n\tX86_INS_FPREM1,\n\tX86_INS_FPTAN,\n\tX86_INS_FRNDINT,\n\tX86_INS_FRSTOR,\n\tX86_INS_FNSAVE,\n\tX86_INS_FSCALE,\n\tX86_INS_FSETPM,\n\tX86_INS_FSINCOS,\n\tX86_INS_FNSTENV,\n\tX86_INS_FXAM,\n\tX86_INS_FXRSTOR,\n\tX86_INS_FXRSTOR64,\n\tX86_INS_FXSAVE,\n\tX86_INS_FXSAVE64,\n\tX86_INS_FXTRACT,\n\tX86_INS_FYL2X,\n\tX86_INS_FYL2XP1,\n\tX86_INS_MOVAPD,\n\tX86_INS_MOVAPS,\n\tX86_INS_ORPD,\n\tX86_INS_ORPS,\n\tX86_INS_VMOVAPD,\n\tX86_INS_VMOVAPS,\n\tX86_INS_XORPD,\n\tX86_INS_XORPS,\n\tX86_INS_GETSEC,\n\tX86_INS_HADDPD,\n\tX86_INS_HADDPS,\n\tX86_INS_HLT,\n\tX86_INS_HSUBPD,\n\tX86_INS_HSUBPS,\n\tX86_INS_IDIV,\n\tX86_INS_FILD,\n\tX86_INS_IMUL,\n\tX86_INS_IN,\n\tX86_INS_INC,\n\tX86_INS_INSB,\n\tX86_INS_INSERTPS,\n\tX86_INS_INSERTQ,\n\tX86_INS_INSD,\n\tX86_INS_INSW,\n\tX86_INS_INT,\n\tX86_INS_INT1,\n\tX86_INS_INT3,\n\tX86_INS_INTO,\n\tX86_INS_INVD,\n\tX86_INS_INVEPT,\n\tX86_INS_INVLPG,\n\tX86_INS_INVLPGA,\n\tX86_INS_INVPCID,\n\tX86_INS_INVVPID,\n\tX86_INS_IRET,\n\tX86_INS_IRETD,\n\tX86_INS_IRETQ,\n\tX86_INS_FISTTP,\n\tX86_INS_FIST,\n\tX86_INS_FISTP,\n\tX86_INS_UCOMISD,\n\tX86_INS_UCOMISS,\n\tX86_INS_VCMP,\n\tX86_INS_VCOMISD,\n\tX86_INS_VCOMISS,\n\tX86_INS_VCVTSD2SS,\n\tX86_INS_VCVTSI2SD,\n\tX86_INS_VCVTSI2SS,\n\tX86_INS_VCVTSS2SD,\n\tX86_INS_VCVTTSD2SI,\n\tX86_INS_VCVTTSD2USI,\n\tX86_INS_VCVTTSS2SI,\n\tX86_INS_VCVTTSS2USI,\n\tX86_INS_VCVTUSI2SD,\n\tX86_INS_VCVTUSI2SS,\n\tX86_INS_VUCOMISD,\n\tX86_INS_VUCOMISS,\n\tX86_INS_JAE,\n\tX86_INS_JA,\n\tX86_INS_JBE,\n\tX86_INS_JB,\n\tX86_INS_JCXZ,\n\tX86_INS_JECXZ,\n\tX86_INS_JE,\n\tX86_INS_JGE,\n\tX86_INS_JG,\n\tX86_INS_JLE,\n\tX86_INS_JL,\n\tX86_INS_JMP,\n\tX86_INS_JNE,\n\tX86_INS_JNO,\n\tX86_INS_JNP,\n\tX86_INS_JNS,\n\tX86_INS_JO,\n\tX86_INS_JP,\n\tX86_INS_JRCXZ,\n\tX86_INS_JS,\n\tX86_INS_KANDB,\n\tX86_INS_KANDD,\n\tX86_INS_KANDNB,\n\tX86_INS_KANDND,\n\tX86_INS_KANDNQ,\n\tX86_INS_KANDNW,\n\tX86_INS_KANDQ,\n\tX86_INS_KANDW,\n\tX86_INS_KMOVB,\n\tX86_INS_KMOVD,\n\tX86_INS_KMOVQ,\n\tX86_INS_KMOVW,\n\tX86_INS_KNOTB,\n\tX86_INS_KNOTD,\n\tX86_INS_KNOTQ,\n\tX86_INS_KNOTW,\n\tX86_INS_KORB,\n\tX86_INS_KORD,\n\tX86_INS_KORQ,\n\tX86_INS_KORTESTW,\n\tX86_INS_KORW,\n\tX86_INS_KSHIFTLW,\n\tX86_INS_KSHIFTRW,\n\tX86_INS_KUNPCKBW,\n\tX86_INS_KXNORB,\n\tX86_INS_KXNORD,\n\tX86_INS_KXNORQ,\n\tX86_INS_KXNORW,\n\tX86_INS_KXORB,\n\tX86_INS_KXORD,\n\tX86_INS_KXORQ,\n\tX86_INS_KXORW,\n\tX86_INS_LAHF,\n\tX86_INS_LAR,\n\tX86_INS_LDDQU,\n\tX86_INS_LDMXCSR,\n\tX86_INS_LDS,\n\tX86_INS_FLDZ,\n\tX86_INS_FLD1,\n\tX86_INS_FLD,\n\tX86_INS_LEA,\n\tX86_INS_LEAVE,\n\tX86_INS_LES,\n\tX86_INS_LFENCE,\n\tX86_INS_LFS,\n\tX86_INS_LGDT,\n\tX86_INS_LGS,\n\tX86_INS_LIDT,\n\tX86_INS_LLDT,\n\tX86_INS_LMSW,\n\tX86_INS_OR,\n\tX86_INS_SUB,\n\tX86_INS_XOR,\n\tX86_INS_LODSB,\n\tX86_INS_LODSD,\n\tX86_INS_LODSQ,\n\tX86_INS_LODSW,\n\tX86_INS_LOOP,\n\tX86_INS_LOOPE,\n\tX86_INS_LOOPNE,\n\tX86_INS_RETF,\n\tX86_INS_RETFQ,\n\tX86_INS_LSL,\n\tX86_INS_LSS,\n\tX86_INS_LTR,\n\tX86_INS_XADD,\n\tX86_INS_LZCNT,\n\tX86_INS_MASKMOVDQU,\n\tX86_INS_MAXPD,\n\tX86_INS_MAXPS,\n\tX86_INS_MAXSD,\n\tX86_INS_MAXSS,\n\tX86_INS_MFENCE,\n\tX86_INS_MINPD,\n\tX86_INS_MINPS,\n\tX86_INS_MINSD,\n\tX86_INS_MINSS,\n\tX86_INS_CVTPD2PI,\n\tX86_INS_CVTPI2PD,\n\tX86_INS_CVTPI2PS,\n\tX86_INS_CVTPS2PI,\n\tX86_INS_CVTTPD2PI,\n\tX86_INS_CVTTPS2PI,\n\tX86_INS_EMMS,\n\tX86_INS_MASKMOVQ,\n\tX86_INS_MOVD,\n\tX86_INS_MOVDQ2Q,\n\tX86_INS_MOVNTQ,\n\tX86_INS_MOVQ2DQ,\n\tX86_INS_MOVQ,\n\tX86_INS_PABSB,\n\tX86_INS_PABSD,\n\tX86_INS_PABSW,\n\tX86_INS_PACKSSDW,\n\tX86_INS_PACKSSWB,\n\tX86_INS_PACKUSWB,\n\tX86_INS_PADDB,\n\tX86_INS_PADDD,\n\tX86_INS_PADDQ,\n\tX86_INS_PADDSB,\n\tX86_INS_PADDSW,\n\tX86_INS_PADDUSB,\n\tX86_INS_PADDUSW,\n\tX86_INS_PADDW,\n\tX86_INS_PALIGNR,\n\tX86_INS_PANDN,\n\tX86_INS_PAND,\n\tX86_INS_PAVGB,\n\tX86_INS_PAVGW,\n\tX86_INS_PCMPEQB,\n\tX86_INS_PCMPEQD,\n\tX86_INS_PCMPEQW,\n\tX86_INS_PCMPGTB,\n\tX86_INS_PCMPGTD,\n\tX86_INS_PCMPGTW,\n\tX86_INS_PEXTRW,\n\tX86_INS_PHADDSW,\n\tX86_INS_PHADDW,\n\tX86_INS_PHADDD,\n\tX86_INS_PHSUBD,\n\tX86_INS_PHSUBSW,\n\tX86_INS_PHSUBW,\n\tX86_INS_PINSRW,\n\tX86_INS_PMADDUBSW,\n\tX86_INS_PMADDWD,\n\tX86_INS_PMAXSW,\n\tX86_INS_PMAXUB,\n\tX86_INS_PMINSW,\n\tX86_INS_PMINUB,\n\tX86_INS_PMOVMSKB,\n\tX86_INS_PMULHRSW,\n\tX86_INS_PMULHUW,\n\tX86_INS_PMULHW,\n\tX86_INS_PMULLW,\n\tX86_INS_PMULUDQ,\n\tX86_INS_POR,\n\tX86_INS_PSADBW,\n\tX86_INS_PSHUFB,\n\tX86_INS_PSHUFW,\n\tX86_INS_PSIGNB,\n\tX86_INS_PSIGND,\n\tX86_INS_PSIGNW,\n\tX86_INS_PSLLD,\n\tX86_INS_PSLLQ,\n\tX86_INS_PSLLW,\n\tX86_INS_PSRAD,\n\tX86_INS_PSRAW,\n\tX86_INS_PSRLD,\n\tX86_INS_PSRLQ,\n\tX86_INS_PSRLW,\n\tX86_INS_PSUBB,\n\tX86_INS_PSUBD,\n\tX86_INS_PSUBQ,\n\tX86_INS_PSUBSB,\n\tX86_INS_PSUBSW,\n\tX86_INS_PSUBUSB,\n\tX86_INS_PSUBUSW,\n\tX86_INS_PSUBW,\n\tX86_INS_PUNPCKHBW,\n\tX86_INS_PUNPCKHDQ,\n\tX86_INS_PUNPCKHWD,\n\tX86_INS_PUNPCKLBW,\n\tX86_INS_PUNPCKLDQ,\n\tX86_INS_PUNPCKLWD,\n\tX86_INS_PXOR,\n\tX86_INS_MONITOR,\n\tX86_INS_MONTMUL,\n\tX86_INS_MOV,\n\tX86_INS_MOVABS,\n\tX86_INS_MOVBE,\n\tX86_INS_MOVDDUP,\n\tX86_INS_MOVDQA,\n\tX86_INS_MOVDQU,\n\tX86_INS_MOVHLPS,\n\tX86_INS_MOVHPD,\n\tX86_INS_MOVHPS,\n\tX86_INS_MOVLHPS,\n\tX86_INS_MOVLPD,\n\tX86_INS_MOVLPS,\n\tX86_INS_MOVMSKPD,\n\tX86_INS_MOVMSKPS,\n\tX86_INS_MOVNTDQA,\n\tX86_INS_MOVNTDQ,\n\tX86_INS_MOVNTI,\n\tX86_INS_MOVNTPD,\n\tX86_INS_MOVNTPS,\n\tX86_INS_MOVNTSD,\n\tX86_INS_MOVNTSS,\n\tX86_INS_MOVSB,\n\tX86_INS_MOVSD,\n\tX86_INS_MOVSHDUP,\n\tX86_INS_MOVSLDUP,\n\tX86_INS_MOVSQ,\n\tX86_INS_MOVSS,\n\tX86_INS_MOVSW,\n\tX86_INS_MOVSX,\n\tX86_INS_MOVSXD,\n\tX86_INS_MOVUPD,\n\tX86_INS_MOVUPS,\n\tX86_INS_MOVZX,\n\tX86_INS_MPSADBW,\n\tX86_INS_MUL,\n\tX86_INS_MULPD,\n\tX86_INS_MULPS,\n\tX86_INS_MULSD,\n\tX86_INS_MULSS,\n\tX86_INS_MULX,\n\tX86_INS_FMUL,\n\tX86_INS_FIMUL,\n\tX86_INS_FMULP,\n\tX86_INS_MWAIT,\n\tX86_INS_NEG,\n\tX86_INS_NOP,\n\tX86_INS_NOT,\n\tX86_INS_OUT,\n\tX86_INS_OUTSB,\n\tX86_INS_OUTSD,\n\tX86_INS_OUTSW,\n\tX86_INS_PACKUSDW,\n\tX86_INS_PAUSE,\n\tX86_INS_PAVGUSB,\n\tX86_INS_PBLENDVB,\n\tX86_INS_PBLENDW,\n\tX86_INS_PCLMULQDQ,\n\tX86_INS_PCMPEQQ,\n\tX86_INS_PCMPESTRI,\n\tX86_INS_PCMPESTRM,\n\tX86_INS_PCMPGTQ,\n\tX86_INS_PCMPISTRI,\n\tX86_INS_PCMPISTRM,\n\tX86_INS_PDEP,\n\tX86_INS_PEXT,\n\tX86_INS_PEXTRB,\n\tX86_INS_PEXTRD,\n\tX86_INS_PEXTRQ,\n\tX86_INS_PF2ID,\n\tX86_INS_PF2IW,\n\tX86_INS_PFACC,\n\tX86_INS_PFADD,\n\tX86_INS_PFCMPEQ,\n\tX86_INS_PFCMPGE,\n\tX86_INS_PFCMPGT,\n\tX86_INS_PFMAX,\n\tX86_INS_PFMIN,\n\tX86_INS_PFMUL,\n\tX86_INS_PFNACC,\n\tX86_INS_PFPNACC,\n\tX86_INS_PFRCPIT1,\n\tX86_INS_PFRCPIT2,\n\tX86_INS_PFRCP,\n\tX86_INS_PFRSQIT1,\n\tX86_INS_PFRSQRT,\n\tX86_INS_PFSUBR,\n\tX86_INS_PFSUB,\n\tX86_INS_PHMINPOSUW,\n\tX86_INS_PI2FD,\n\tX86_INS_PI2FW,\n\tX86_INS_PINSRB,\n\tX86_INS_PINSRD,\n\tX86_INS_PINSRQ,\n\tX86_INS_PMAXSB,\n\tX86_INS_PMAXSD,\n\tX86_INS_PMAXUD,\n\tX86_INS_PMAXUW,\n\tX86_INS_PMINSB,\n\tX86_INS_PMINSD,\n\tX86_INS_PMINUD,\n\tX86_INS_PMINUW,\n\tX86_INS_PMOVSXBD,\n\tX86_INS_PMOVSXBQ,\n\tX86_INS_PMOVSXBW,\n\tX86_INS_PMOVSXDQ,\n\tX86_INS_PMOVSXWD,\n\tX86_INS_PMOVSXWQ,\n\tX86_INS_PMOVZXBD,\n\tX86_INS_PMOVZXBQ,\n\tX86_INS_PMOVZXBW,\n\tX86_INS_PMOVZXDQ,\n\tX86_INS_PMOVZXWD,\n\tX86_INS_PMOVZXWQ,\n\tX86_INS_PMULDQ,\n\tX86_INS_PMULHRW,\n\tX86_INS_PMULLD,\n\tX86_INS_POP,\n\tX86_INS_POPAW,\n\tX86_INS_POPAL,\n\tX86_INS_POPCNT,\n\tX86_INS_POPF,\n\tX86_INS_POPFD,\n\tX86_INS_POPFQ,\n\tX86_INS_PREFETCH,\n\tX86_INS_PREFETCHNTA,\n\tX86_INS_PREFETCHT0,\n\tX86_INS_PREFETCHT1,\n\tX86_INS_PREFETCHT2,\n\tX86_INS_PREFETCHW,\n\tX86_INS_PSHUFD,\n\tX86_INS_PSHUFHW,\n\tX86_INS_PSHUFLW,\n\tX86_INS_PSLLDQ,\n\tX86_INS_PSRLDQ,\n\tX86_INS_PSWAPD,\n\tX86_INS_PTEST,\n\tX86_INS_PUNPCKHQDQ,\n\tX86_INS_PUNPCKLQDQ,\n\tX86_INS_PUSH,\n\tX86_INS_PUSHAW,\n\tX86_INS_PUSHAL,\n\tX86_INS_PUSHF,\n\tX86_INS_PUSHFD,\n\tX86_INS_PUSHFQ,\n\tX86_INS_RCL,\n\tX86_INS_RCPPS,\n\tX86_INS_RCPSS,\n\tX86_INS_RCR,\n\tX86_INS_RDFSBASE,\n\tX86_INS_RDGSBASE,\n\tX86_INS_RDMSR,\n\tX86_INS_RDPMC,\n\tX86_INS_RDRAND,\n\tX86_INS_RDSEED,\n\tX86_INS_RDTSC,\n\tX86_INS_RDTSCP,\n\tX86_INS_ROL,\n\tX86_INS_ROR,\n\tX86_INS_RORX,\n\tX86_INS_ROUNDPD,\n\tX86_INS_ROUNDPS,\n\tX86_INS_ROUNDSD,\n\tX86_INS_ROUNDSS,\n\tX86_INS_RSM,\n\tX86_INS_RSQRTPS,\n\tX86_INS_RSQRTSS,\n\tX86_INS_SAHF,\n\tX86_INS_SAL,\n\tX86_INS_SALC,\n\tX86_INS_SAR,\n\tX86_INS_SARX,\n\tX86_INS_SBB,\n\tX86_INS_SCASB,\n\tX86_INS_SCASD,\n\tX86_INS_SCASQ,\n\tX86_INS_SCASW,\n\tX86_INS_SETAE,\n\tX86_INS_SETA,\n\tX86_INS_SETBE,\n\tX86_INS_SETB,\n\tX86_INS_SETE,\n\tX86_INS_SETGE,\n\tX86_INS_SETG,\n\tX86_INS_SETLE,\n\tX86_INS_SETL,\n\tX86_INS_SETNE,\n\tX86_INS_SETNO,\n\tX86_INS_SETNP,\n\tX86_INS_SETNS,\n\tX86_INS_SETO,\n\tX86_INS_SETP,\n\tX86_INS_SETS,\n\tX86_INS_SFENCE,\n\tX86_INS_SGDT,\n\tX86_INS_SHA1MSG1,\n\tX86_INS_SHA1MSG2,\n\tX86_INS_SHA1NEXTE,\n\tX86_INS_SHA1RNDS4,\n\tX86_INS_SHA256MSG1,\n\tX86_INS_SHA256MSG2,\n\tX86_INS_SHA256RNDS2,\n\tX86_INS_SHL,\n\tX86_INS_SHLD,\n\tX86_INS_SHLX,\n\tX86_INS_SHR,\n\tX86_INS_SHRD,\n\tX86_INS_SHRX,\n\tX86_INS_SHUFPD,\n\tX86_INS_SHUFPS,\n\tX86_INS_SIDT,\n\tX86_INS_FSIN,\n\tX86_INS_SKINIT,\n\tX86_INS_SLDT,\n\tX86_INS_SMSW,\n\tX86_INS_SQRTPD,\n\tX86_INS_SQRTPS,\n\tX86_INS_SQRTSD,\n\tX86_INS_SQRTSS,\n\tX86_INS_FSQRT,\n\tX86_INS_STAC,\n\tX86_INS_STC,\n\tX86_INS_STD,\n\tX86_INS_STGI,\n\tX86_INS_STI,\n\tX86_INS_STMXCSR,\n\tX86_INS_STOSB,\n\tX86_INS_STOSD,\n\tX86_INS_STOSQ,\n\tX86_INS_STOSW,\n\tX86_INS_STR,\n\tX86_INS_FST,\n\tX86_INS_FSTP,\n\tX86_INS_FSTPNCE,\n\tX86_INS_SUBPD,\n\tX86_INS_SUBPS,\n\tX86_INS_FSUBR,\n\tX86_INS_FISUBR,\n\tX86_INS_FSUBRP,\n\tX86_INS_SUBSD,\n\tX86_INS_SUBSS,\n\tX86_INS_FSUB,\n\tX86_INS_FISUB,\n\tX86_INS_FSUBP,\n\tX86_INS_SWAPGS,\n\tX86_INS_SYSCALL,\n\tX86_INS_SYSENTER,\n\tX86_INS_SYSEXIT,\n\tX86_INS_SYSRET,\n\tX86_INS_T1MSKC,\n\tX86_INS_TEST,\n\tX86_INS_UD2,\n\tX86_INS_FTST,\n\tX86_INS_TZCNT,\n\tX86_INS_TZMSK,\n\tX86_INS_FUCOMPI,\n\tX86_INS_FUCOMI,\n\tX86_INS_FUCOMPP,\n\tX86_INS_FUCOMP,\n\tX86_INS_FUCOM,\n\tX86_INS_UD2B,\n\tX86_INS_UNPCKHPD,\n\tX86_INS_UNPCKHPS,\n\tX86_INS_UNPCKLPD,\n\tX86_INS_UNPCKLPS,\n\tX86_INS_VADDPD,\n\tX86_INS_VADDPS,\n\tX86_INS_VADDSD,\n\tX86_INS_VADDSS,\n\tX86_INS_VADDSUBPD,\n\tX86_INS_VADDSUBPS,\n\tX86_INS_VAESDECLAST,\n\tX86_INS_VAESDEC,\n\tX86_INS_VAESENCLAST,\n\tX86_INS_VAESENC,\n\tX86_INS_VAESIMC,\n\tX86_INS_VAESKEYGENASSIST,\n\tX86_INS_VALIGND,\n\tX86_INS_VALIGNQ,\n\tX86_INS_VANDNPD,\n\tX86_INS_VANDNPS,\n\tX86_INS_VANDPD,\n\tX86_INS_VANDPS,\n\tX86_INS_VBLENDMPD,\n\tX86_INS_VBLENDMPS,\n\tX86_INS_VBLENDPD,\n\tX86_INS_VBLENDPS,\n\tX86_INS_VBLENDVPD,\n\tX86_INS_VBLENDVPS,\n\tX86_INS_VBROADCASTF128,\n\tX86_INS_VBROADCASTI128,\n\tX86_INS_VBROADCASTI32X4,\n\tX86_INS_VBROADCASTI64X4,\n\tX86_INS_VBROADCASTSD,\n\tX86_INS_VBROADCASTSS,\n\tX86_INS_VCMPPD,\n\tX86_INS_VCMPPS,\n\tX86_INS_VCMPSD,\n\tX86_INS_VCMPSS,\n\tX86_INS_VCVTDQ2PD,\n\tX86_INS_VCVTDQ2PS,\n\tX86_INS_VCVTPD2DQX,\n\tX86_INS_VCVTPD2DQ,\n\tX86_INS_VCVTPD2PSX,\n\tX86_INS_VCVTPD2PS,\n\tX86_INS_VCVTPD2UDQ,\n\tX86_INS_VCVTPH2PS,\n\tX86_INS_VCVTPS2DQ,\n\tX86_INS_VCVTPS2PD,\n\tX86_INS_VCVTPS2PH,\n\tX86_INS_VCVTPS2UDQ,\n\tX86_INS_VCVTSD2SI,\n\tX86_INS_VCVTSD2USI,\n\tX86_INS_VCVTSS2SI,\n\tX86_INS_VCVTSS2USI,\n\tX86_INS_VCVTTPD2DQX,\n\tX86_INS_VCVTTPD2DQ,\n\tX86_INS_VCVTTPD2UDQ,\n\tX86_INS_VCVTTPS2DQ,\n\tX86_INS_VCVTTPS2UDQ,\n\tX86_INS_VCVTUDQ2PD,\n\tX86_INS_VCVTUDQ2PS,\n\tX86_INS_VDIVPD,\n\tX86_INS_VDIVPS,\n\tX86_INS_VDIVSD,\n\tX86_INS_VDIVSS,\n\tX86_INS_VDPPD,\n\tX86_INS_VDPPS,\n\tX86_INS_VERR,\n\tX86_INS_VERW,\n\tX86_INS_VEXTRACTF128,\n\tX86_INS_VEXTRACTF32X4,\n\tX86_INS_VEXTRACTF64X4,\n\tX86_INS_VEXTRACTI128,\n\tX86_INS_VEXTRACTI32X4,\n\tX86_INS_VEXTRACTI64X4,\n\tX86_INS_VEXTRACTPS,\n\tX86_INS_VFMADD132PD,\n\tX86_INS_VFMADD132PS,\n\tX86_INS_VFMADD213PD,\n\tX86_INS_VFMADD213PS,\n\tX86_INS_VFMADDPD,\n\tX86_INS_VFMADD231PD,\n\tX86_INS_VFMADDPS,\n\tX86_INS_VFMADD231PS,\n\tX86_INS_VFMADDSD,\n\tX86_INS_VFMADD213SD,\n\tX86_INS_VFMADD132SD,\n\tX86_INS_VFMADD231SD,\n\tX86_INS_VFMADDSS,\n\tX86_INS_VFMADD213SS,\n\tX86_INS_VFMADD132SS,\n\tX86_INS_VFMADD231SS,\n\tX86_INS_VFMADDSUB132PD,\n\tX86_INS_VFMADDSUB132PS,\n\tX86_INS_VFMADDSUB213PD,\n\tX86_INS_VFMADDSUB213PS,\n\tX86_INS_VFMADDSUBPD,\n\tX86_INS_VFMADDSUB231PD,\n\tX86_INS_VFMADDSUBPS,\n\tX86_INS_VFMADDSUB231PS,\n\tX86_INS_VFMSUB132PD,\n\tX86_INS_VFMSUB132PS,\n\tX86_INS_VFMSUB213PD,\n\tX86_INS_VFMSUB213PS,\n\tX86_INS_VFMSUBADD132PD,\n\tX86_INS_VFMSUBADD132PS,\n\tX86_INS_VFMSUBADD213PD,\n\tX86_INS_VFMSUBADD213PS,\n\tX86_INS_VFMSUBADDPD,\n\tX86_INS_VFMSUBADD231PD,\n\tX86_INS_VFMSUBADDPS,\n\tX86_INS_VFMSUBADD231PS,\n\tX86_INS_VFMSUBPD,\n\tX86_INS_VFMSUB231PD,\n\tX86_INS_VFMSUBPS,\n\tX86_INS_VFMSUB231PS,\n\tX86_INS_VFMSUBSD,\n\tX86_INS_VFMSUB213SD,\n\tX86_INS_VFMSUB132SD,\n\tX86_INS_VFMSUB231SD,\n\tX86_INS_VFMSUBSS,\n\tX86_INS_VFMSUB213SS,\n\tX86_INS_VFMSUB132SS,\n\tX86_INS_VFMSUB231SS,\n\tX86_INS_VFNMADD132PD,\n\tX86_INS_VFNMADD132PS,\n\tX86_INS_VFNMADD213PD,\n\tX86_INS_VFNMADD213PS,\n\tX86_INS_VFNMADDPD,\n\tX86_INS_VFNMADD231PD,\n\tX86_INS_VFNMADDPS,\n\tX86_INS_VFNMADD231PS,\n\tX86_INS_VFNMADDSD,\n\tX86_INS_VFNMADD213SD,\n\tX86_INS_VFNMADD132SD,\n\tX86_INS_VFNMADD231SD,\n\tX86_INS_VFNMADDSS,\n\tX86_INS_VFNMADD213SS,\n\tX86_INS_VFNMADD132SS,\n\tX86_INS_VFNMADD231SS,\n\tX86_INS_VFNMSUB132PD,\n\tX86_INS_VFNMSUB132PS,\n\tX86_INS_VFNMSUB213PD,\n\tX86_INS_VFNMSUB213PS,\n\tX86_INS_VFNMSUBPD,\n\tX86_INS_VFNMSUB231PD,\n\tX86_INS_VFNMSUBPS,\n\tX86_INS_VFNMSUB231PS,\n\tX86_INS_VFNMSUBSD,\n\tX86_INS_VFNMSUB213SD,\n\tX86_INS_VFNMSUB132SD,\n\tX86_INS_VFNMSUB231SD,\n\tX86_INS_VFNMSUBSS,\n\tX86_INS_VFNMSUB213SS,\n\tX86_INS_VFNMSUB132SS,\n\tX86_INS_VFNMSUB231SS,\n\tX86_INS_VFRCZPD,\n\tX86_INS_VFRCZPS,\n\tX86_INS_VFRCZSD,\n\tX86_INS_VFRCZSS,\n\tX86_INS_VORPD,\n\tX86_INS_VORPS,\n\tX86_INS_VXORPD,\n\tX86_INS_VXORPS,\n\tX86_INS_VGATHERDPD,\n\tX86_INS_VGATHERDPS,\n\tX86_INS_VGATHERPF0DPD,\n\tX86_INS_VGATHERPF0DPS,\n\tX86_INS_VGATHERPF0QPD,\n\tX86_INS_VGATHERPF0QPS,\n\tX86_INS_VGATHERPF1DPD,\n\tX86_INS_VGATHERPF1DPS,\n\tX86_INS_VGATHERPF1QPD,\n\tX86_INS_VGATHERPF1QPS,\n\tX86_INS_VGATHERQPD,\n\tX86_INS_VGATHERQPS,\n\tX86_INS_VHADDPD,\n\tX86_INS_VHADDPS,\n\tX86_INS_VHSUBPD,\n\tX86_INS_VHSUBPS,\n\tX86_INS_VINSERTF128,\n\tX86_INS_VINSERTF32X4,\n\tX86_INS_VINSERTF64X4,\n\tX86_INS_VINSERTI128,\n\tX86_INS_VINSERTI32X4,\n\tX86_INS_VINSERTI64X4,\n\tX86_INS_VINSERTPS,\n\tX86_INS_VLDDQU,\n\tX86_INS_VLDMXCSR,\n\tX86_INS_VMASKMOVDQU,\n\tX86_INS_VMASKMOVPD,\n\tX86_INS_VMASKMOVPS,\n\tX86_INS_VMAXPD,\n\tX86_INS_VMAXPS,\n\tX86_INS_VMAXSD,\n\tX86_INS_VMAXSS,\n\tX86_INS_VMCALL,\n\tX86_INS_VMCLEAR,\n\tX86_INS_VMFUNC,\n\tX86_INS_VMINPD,\n\tX86_INS_VMINPS,\n\tX86_INS_VMINSD,\n\tX86_INS_VMINSS,\n\tX86_INS_VMLAUNCH,\n\tX86_INS_VMLOAD,\n\tX86_INS_VMMCALL,\n\tX86_INS_VMOVQ,\n\tX86_INS_VMOVDDUP,\n\tX86_INS_VMOVD,\n\tX86_INS_VMOVDQA32,\n\tX86_INS_VMOVDQA64,\n\tX86_INS_VMOVDQA,\n\tX86_INS_VMOVDQU16,\n\tX86_INS_VMOVDQU32,\n\tX86_INS_VMOVDQU64,\n\tX86_INS_VMOVDQU8,\n\tX86_INS_VMOVDQU,\n\tX86_INS_VMOVHLPS,\n\tX86_INS_VMOVHPD,\n\tX86_INS_VMOVHPS,\n\tX86_INS_VMOVLHPS,\n\tX86_INS_VMOVLPD,\n\tX86_INS_VMOVLPS,\n\tX86_INS_VMOVMSKPD,\n\tX86_INS_VMOVMSKPS,\n\tX86_INS_VMOVNTDQA,\n\tX86_INS_VMOVNTDQ,\n\tX86_INS_VMOVNTPD,\n\tX86_INS_VMOVNTPS,\n\tX86_INS_VMOVSD,\n\tX86_INS_VMOVSHDUP,\n\tX86_INS_VMOVSLDUP,\n\tX86_INS_VMOVSS,\n\tX86_INS_VMOVUPD,\n\tX86_INS_VMOVUPS,\n\tX86_INS_VMPSADBW,\n\tX86_INS_VMPTRLD,\n\tX86_INS_VMPTRST,\n\tX86_INS_VMREAD,\n\tX86_INS_VMRESUME,\n\tX86_INS_VMRUN,\n\tX86_INS_VMSAVE,\n\tX86_INS_VMULPD,\n\tX86_INS_VMULPS,\n\tX86_INS_VMULSD,\n\tX86_INS_VMULSS,\n\tX86_INS_VMWRITE,\n\tX86_INS_VMXOFF,\n\tX86_INS_VMXON,\n\tX86_INS_VPABSB,\n\tX86_INS_VPABSD,\n\tX86_INS_VPABSQ,\n\tX86_INS_VPABSW,\n\tX86_INS_VPACKSSDW,\n\tX86_INS_VPACKSSWB,\n\tX86_INS_VPACKUSDW,\n\tX86_INS_VPACKUSWB,\n\tX86_INS_VPADDB,\n\tX86_INS_VPADDD,\n\tX86_INS_VPADDQ,\n\tX86_INS_VPADDSB,\n\tX86_INS_VPADDSW,\n\tX86_INS_VPADDUSB,\n\tX86_INS_VPADDUSW,\n\tX86_INS_VPADDW,\n\tX86_INS_VPALIGNR,\n\tX86_INS_VPANDD,\n\tX86_INS_VPANDND,\n\tX86_INS_VPANDNQ,\n\tX86_INS_VPANDN,\n\tX86_INS_VPANDQ,\n\tX86_INS_VPAND,\n\tX86_INS_VPAVGB,\n\tX86_INS_VPAVGW,\n\tX86_INS_VPBLENDD,\n\tX86_INS_VPBLENDMD,\n\tX86_INS_VPBLENDMQ,\n\tX86_INS_VPBLENDVB,\n\tX86_INS_VPBLENDW,\n\tX86_INS_VPBROADCASTB,\n\tX86_INS_VPBROADCASTD,\n\tX86_INS_VPBROADCASTMB2Q,\n\tX86_INS_VPBROADCASTMW2D,\n\tX86_INS_VPBROADCASTQ,\n\tX86_INS_VPBROADCASTW,\n\tX86_INS_VPCLMULQDQ,\n\tX86_INS_VPCMOV,\n\tX86_INS_VPCMP,\n\tX86_INS_VPCMPD,\n\tX86_INS_VPCMPEQB,\n\tX86_INS_VPCMPEQD,\n\tX86_INS_VPCMPEQQ,\n\tX86_INS_VPCMPEQW,\n\tX86_INS_VPCMPESTRI,\n\tX86_INS_VPCMPESTRM,\n\tX86_INS_VPCMPGTB,\n\tX86_INS_VPCMPGTD,\n\tX86_INS_VPCMPGTQ,\n\tX86_INS_VPCMPGTW,\n\tX86_INS_VPCMPISTRI,\n\tX86_INS_VPCMPISTRM,\n\tX86_INS_VPCMPQ,\n\tX86_INS_VPCMPUD,\n\tX86_INS_VPCMPUQ,\n\tX86_INS_VPCOMB,\n\tX86_INS_VPCOMD,\n\tX86_INS_VPCOMQ,\n\tX86_INS_VPCOMUB,\n\tX86_INS_VPCOMUD,\n\tX86_INS_VPCOMUQ,\n\tX86_INS_VPCOMUW,\n\tX86_INS_VPCOMW,\n\tX86_INS_VPCONFLICTD,\n\tX86_INS_VPCONFLICTQ,\n\tX86_INS_VPERM2F128,\n\tX86_INS_VPERM2I128,\n\tX86_INS_VPERMD,\n\tX86_INS_VPERMI2D,\n\tX86_INS_VPERMI2PD,\n\tX86_INS_VPERMI2PS,\n\tX86_INS_VPERMI2Q,\n\tX86_INS_VPERMIL2PD,\n\tX86_INS_VPERMIL2PS,\n\tX86_INS_VPERMILPD,\n\tX86_INS_VPERMILPS,\n\tX86_INS_VPERMPD,\n\tX86_INS_VPERMPS,\n\tX86_INS_VPERMQ,\n\tX86_INS_VPERMT2D,\n\tX86_INS_VPERMT2PD,\n\tX86_INS_VPERMT2PS,\n\tX86_INS_VPERMT2Q,\n\tX86_INS_VPEXTRB,\n\tX86_INS_VPEXTRD,\n\tX86_INS_VPEXTRQ,\n\tX86_INS_VPEXTRW,\n\tX86_INS_VPGATHERDD,\n\tX86_INS_VPGATHERDQ,\n\tX86_INS_VPGATHERQD,\n\tX86_INS_VPGATHERQQ,\n\tX86_INS_VPHADDBD,\n\tX86_INS_VPHADDBQ,\n\tX86_INS_VPHADDBW,\n\tX86_INS_VPHADDDQ,\n\tX86_INS_VPHADDD,\n\tX86_INS_VPHADDSW,\n\tX86_INS_VPHADDUBD,\n\tX86_INS_VPHADDUBQ,\n\tX86_INS_VPHADDUBW,\n\tX86_INS_VPHADDUDQ,\n\tX86_INS_VPHADDUWD,\n\tX86_INS_VPHADDUWQ,\n\tX86_INS_VPHADDWD,\n\tX86_INS_VPHADDWQ,\n\tX86_INS_VPHADDW,\n\tX86_INS_VPHMINPOSUW,\n\tX86_INS_VPHSUBBW,\n\tX86_INS_VPHSUBDQ,\n\tX86_INS_VPHSUBD,\n\tX86_INS_VPHSUBSW,\n\tX86_INS_VPHSUBWD,\n\tX86_INS_VPHSUBW,\n\tX86_INS_VPINSRB,\n\tX86_INS_VPINSRD,\n\tX86_INS_VPINSRQ,\n\tX86_INS_VPINSRW,\n\tX86_INS_VPLZCNTD,\n\tX86_INS_VPLZCNTQ,\n\tX86_INS_VPMACSDD,\n\tX86_INS_VPMACSDQH,\n\tX86_INS_VPMACSDQL,\n\tX86_INS_VPMACSSDD,\n\tX86_INS_VPMACSSDQH,\n\tX86_INS_VPMACSSDQL,\n\tX86_INS_VPMACSSWD,\n\tX86_INS_VPMACSSWW,\n\tX86_INS_VPMACSWD,\n\tX86_INS_VPMACSWW,\n\tX86_INS_VPMADCSSWD,\n\tX86_INS_VPMADCSWD,\n\tX86_INS_VPMADDUBSW,\n\tX86_INS_VPMADDWD,\n\tX86_INS_VPMASKMOVD,\n\tX86_INS_VPMASKMOVQ,\n\tX86_INS_VPMAXSB,\n\tX86_INS_VPMAXSD,\n\tX86_INS_VPMAXSQ,\n\tX86_INS_VPMAXSW,\n\tX86_INS_VPMAXUB,\n\tX86_INS_VPMAXUD,\n\tX86_INS_VPMAXUQ,\n\tX86_INS_VPMAXUW,\n\tX86_INS_VPMINSB,\n\tX86_INS_VPMINSD,\n\tX86_INS_VPMINSQ,\n\tX86_INS_VPMINSW,\n\tX86_INS_VPMINUB,\n\tX86_INS_VPMINUD,\n\tX86_INS_VPMINUQ,\n\tX86_INS_VPMINUW,\n\tX86_INS_VPMOVDB,\n\tX86_INS_VPMOVDW,\n\tX86_INS_VPMOVMSKB,\n\tX86_INS_VPMOVQB,\n\tX86_INS_VPMOVQD,\n\tX86_INS_VPMOVQW,\n\tX86_INS_VPMOVSDB,\n\tX86_INS_VPMOVSDW,\n\tX86_INS_VPMOVSQB,\n\tX86_INS_VPMOVSQD,\n\tX86_INS_VPMOVSQW,\n\tX86_INS_VPMOVSXBD,\n\tX86_INS_VPMOVSXBQ,\n\tX86_INS_VPMOVSXBW,\n\tX86_INS_VPMOVSXDQ,\n\tX86_INS_VPMOVSXWD,\n\tX86_INS_VPMOVSXWQ,\n\tX86_INS_VPMOVUSDB,\n\tX86_INS_VPMOVUSDW,\n\tX86_INS_VPMOVUSQB,\n\tX86_INS_VPMOVUSQD,\n\tX86_INS_VPMOVUSQW,\n\tX86_INS_VPMOVZXBD,\n\tX86_INS_VPMOVZXBQ,\n\tX86_INS_VPMOVZXBW,\n\tX86_INS_VPMOVZXDQ,\n\tX86_INS_VPMOVZXWD,\n\tX86_INS_VPMOVZXWQ,\n\tX86_INS_VPMULDQ,\n\tX86_INS_VPMULHRSW,\n\tX86_INS_VPMULHUW,\n\tX86_INS_VPMULHW,\n\tX86_INS_VPMULLD,\n\tX86_INS_VPMULLW,\n\tX86_INS_VPMULUDQ,\n\tX86_INS_VPORD,\n\tX86_INS_VPORQ,\n\tX86_INS_VPOR,\n\tX86_INS_VPPERM,\n\tX86_INS_VPROTB,\n\tX86_INS_VPROTD,\n\tX86_INS_VPROTQ,\n\tX86_INS_VPROTW,\n\tX86_INS_VPSADBW,\n\tX86_INS_VPSCATTERDD,\n\tX86_INS_VPSCATTERDQ,\n\tX86_INS_VPSCATTERQD,\n\tX86_INS_VPSCATTERQQ,\n\tX86_INS_VPSHAB,\n\tX86_INS_VPSHAD,\n\tX86_INS_VPSHAQ,\n\tX86_INS_VPSHAW,\n\tX86_INS_VPSHLB,\n\tX86_INS_VPSHLD,\n\tX86_INS_VPSHLQ,\n\tX86_INS_VPSHLW,\n\tX86_INS_VPSHUFB,\n\tX86_INS_VPSHUFD,\n\tX86_INS_VPSHUFHW,\n\tX86_INS_VPSHUFLW,\n\tX86_INS_VPSIGNB,\n\tX86_INS_VPSIGND,\n\tX86_INS_VPSIGNW,\n\tX86_INS_VPSLLDQ,\n\tX86_INS_VPSLLD,\n\tX86_INS_VPSLLQ,\n\tX86_INS_VPSLLVD,\n\tX86_INS_VPSLLVQ,\n\tX86_INS_VPSLLW,\n\tX86_INS_VPSRAD,\n\tX86_INS_VPSRAQ,\n\tX86_INS_VPSRAVD,\n\tX86_INS_VPSRAVQ,\n\tX86_INS_VPSRAW,\n\tX86_INS_VPSRLDQ,\n\tX86_INS_VPSRLD,\n\tX86_INS_VPSRLQ,\n\tX86_INS_VPSRLVD,\n\tX86_INS_VPSRLVQ,\n\tX86_INS_VPSRLW,\n\tX86_INS_VPSUBB,\n\tX86_INS_VPSUBD,\n\tX86_INS_VPSUBQ,\n\tX86_INS_VPSUBSB,\n\tX86_INS_VPSUBSW,\n\tX86_INS_VPSUBUSB,\n\tX86_INS_VPSUBUSW,\n\tX86_INS_VPSUBW,\n\tX86_INS_VPTESTMD,\n\tX86_INS_VPTESTMQ,\n\tX86_INS_VPTESTNMD,\n\tX86_INS_VPTESTNMQ,\n\tX86_INS_VPTEST,\n\tX86_INS_VPUNPCKHBW,\n\tX86_INS_VPUNPCKHDQ,\n\tX86_INS_VPUNPCKHQDQ,\n\tX86_INS_VPUNPCKHWD,\n\tX86_INS_VPUNPCKLBW,\n\tX86_INS_VPUNPCKLDQ,\n\tX86_INS_VPUNPCKLQDQ,\n\tX86_INS_VPUNPCKLWD,\n\tX86_INS_VPXORD,\n\tX86_INS_VPXORQ,\n\tX86_INS_VPXOR,\n\tX86_INS_VRCP14PD,\n\tX86_INS_VRCP14PS,\n\tX86_INS_VRCP14SD,\n\tX86_INS_VRCP14SS,\n\tX86_INS_VRCP28PD,\n\tX86_INS_VRCP28PS,\n\tX86_INS_VRCP28SD,\n\tX86_INS_VRCP28SS,\n\tX86_INS_VRCPPS,\n\tX86_INS_VRCPSS,\n\tX86_INS_VRNDSCALEPD,\n\tX86_INS_VRNDSCALEPS,\n\tX86_INS_VRNDSCALESD,\n\tX86_INS_VRNDSCALESS,\n\tX86_INS_VROUNDPD,\n\tX86_INS_VROUNDPS,\n\tX86_INS_VROUNDSD,\n\tX86_INS_VROUNDSS,\n\tX86_INS_VRSQRT14PD,\n\tX86_INS_VRSQRT14PS,\n\tX86_INS_VRSQRT14SD,\n\tX86_INS_VRSQRT14SS,\n\tX86_INS_VRSQRT28PD,\n\tX86_INS_VRSQRT28PS,\n\tX86_INS_VRSQRT28SD,\n\tX86_INS_VRSQRT28SS,\n\tX86_INS_VRSQRTPS,\n\tX86_INS_VRSQRTSS,\n\tX86_INS_VSCATTERDPD,\n\tX86_INS_VSCATTERDPS,\n\tX86_INS_VSCATTERPF0DPD,\n\tX86_INS_VSCATTERPF0DPS,\n\tX86_INS_VSCATTERPF0QPD,\n\tX86_INS_VSCATTERPF0QPS,\n\tX86_INS_VSCATTERPF1DPD,\n\tX86_INS_VSCATTERPF1DPS,\n\tX86_INS_VSCATTERPF1QPD,\n\tX86_INS_VSCATTERPF1QPS,\n\tX86_INS_VSCATTERQPD,\n\tX86_INS_VSCATTERQPS,\n\tX86_INS_VSHUFPD,\n\tX86_INS_VSHUFPS,\n\tX86_INS_VSQRTPD,\n\tX86_INS_VSQRTPS,\n\tX86_INS_VSQRTSD,\n\tX86_INS_VSQRTSS,\n\tX86_INS_VSTMXCSR,\n\tX86_INS_VSUBPD,\n\tX86_INS_VSUBPS,\n\tX86_INS_VSUBSD,\n\tX86_INS_VSUBSS,\n\tX86_INS_VTESTPD,\n\tX86_INS_VTESTPS,\n\tX86_INS_VUNPCKHPD,\n\tX86_INS_VUNPCKHPS,\n\tX86_INS_VUNPCKLPD,\n\tX86_INS_VUNPCKLPS,\n\tX86_INS_VZEROALL,\n\tX86_INS_VZEROUPPER,\n\tX86_INS_WAIT,\n\tX86_INS_WBINVD,\n\tX86_INS_WRFSBASE,\n\tX86_INS_WRGSBASE,\n\tX86_INS_WRMSR,\n\tX86_INS_XABORT,\n\tX86_INS_XACQUIRE,\n\tX86_INS_XBEGIN,\n\tX86_INS_XCHG,\n\tX86_INS_FXCH,\n\tX86_INS_XCRYPTCBC,\n\tX86_INS_XCRYPTCFB,\n\tX86_INS_XCRYPTCTR,\n\tX86_INS_XCRYPTECB,\n\tX86_INS_XCRYPTOFB,\n\tX86_INS_XEND,\n\tX86_INS_XGETBV,\n\tX86_INS_XLATB,\n\tX86_INS_XRELEASE,\n\tX86_INS_XRSTOR,\n\tX86_INS_XRSTOR64,\n\tX86_INS_XSAVE,\n\tX86_INS_XSAVE64,\n\tX86_INS_XSAVEOPT,\n\tX86_INS_XSAVEOPT64,\n\tX86_INS_XSETBV,\n\tX86_INS_XSHA1,\n\tX86_INS_XSHA256,\n\tX86_INS_XSTORE,\n\tX86_INS_XTEST,\n\n\tX86_INS_ENDING,\t// mark the end of the list of insn\n} x86_insn;\n\n//> Group of X86 instructions\ntypedef enum  x86_insn_group {\n\tX86_GRP_INVALID = 0, // = CS_GRP_INVALID\n\n\t//> Generic groups\n\t// all jump instructions (conditional+direct+indirect jumps)\n\tX86_GRP_JUMP,\t// = CS_GRP_JUMP\n\t// all call instructions\n\tX86_GRP_CALL,\t// = CS_GRP_CALL\n\t// all return instructions\n\tX86_GRP_RET,\t// = CS_GRP_RET\n\t// all interrupt instructions (int+syscall)\n\tX86_GRP_INT,\t// = CS_GRP_INT\n\t// all interrupt return instructions\n\tX86_GRP_IRET,\t// = CS_GRP_IRET\n\n\t//> Architecture-specific groups\n\tX86_GRP_VM = 128,\t// all virtualization instructions (VT-x + AMD-V)\n\tX86_GRP_3DNOW,\n\tX86_GRP_AES,\n\tX86_GRP_ADX,\n\tX86_GRP_AVX,\n\tX86_GRP_AVX2,\n\tX86_GRP_AVX512,\n\tX86_GRP_BMI,\n\tX86_GRP_BMI2,\n\tX86_GRP_CMOV,\n\tX86_GRP_F16C,\n\tX86_GRP_FMA,\n\tX86_GRP_FMA4,\n\tX86_GRP_FSGSBASE,\n\tX86_GRP_HLE,\n\tX86_GRP_MMX,\n\tX86_GRP_MODE32,\n\tX86_GRP_MODE64,\n\tX86_GRP_RTM,\n\tX86_GRP_SHA,\n\tX86_GRP_SSE1,\n\tX86_GRP_SSE2,\n\tX86_GRP_SSE3,\n\tX86_GRP_SSE41,\n\tX86_GRP_SSE42,\n\tX86_GRP_SSE4A,\n\tX86_GRP_SSSE3,\n\tX86_GRP_PCLMUL,\n\tX86_GRP_XOP,\n\tX86_GRP_CDI,\n\tX86_GRP_ERI,\n\tX86_GRP_TBM,\n\tX86_GRP_16BITMODE,\n\tX86_GRP_NOT64BITMODE,\n\tX86_GRP_SGX,\n\tX86_GRP_DQI,\n\tX86_GRP_BWI,\n\tX86_GRP_PFI,\n\tX86_GRP_VLX,\n\tX86_GRP_SMAP,\n\tX86_GRP_NOVLX,\n\n\tX86_GRP_ENDING\n} x86_insn_group;\n\n#ifdef __cplusplus\n}\n#endif\n\n#endif\n"
  },
  {
    "path": "EFI_DEBUG/EFI/OC/Kexts/Lilu.kext/Contents/Resources/Headers/capstone/xcore.h",
    "content": "#ifndef CAPSTONE_XCORE_H\n#define CAPSTONE_XCORE_H\n\n/* Capstone Disassembly Engine */\n/* By Nguyen Anh Quynh <aquynh@gmail.com>, 2014 */\n\n#ifdef __cplusplus\nextern \"C\" {\n#endif\n\n#if !defined(_MSC_VER) || !defined(_KERNEL_MODE)\n#include <stdint.h>\n#endif\n\n#include \"platform.h\"\n\n#ifdef _MSC_VER\n#pragma warning(disable:4201)\n#endif\n\n//> Operand type for instruction's operands\ntypedef enum xcore_op_type {\n\tXCORE_OP_INVALID = 0, // = CS_OP_INVALID (Uninitialized).\n\tXCORE_OP_REG, // = CS_OP_REG (Register operand).\n\tXCORE_OP_IMM, // = CS_OP_IMM (Immediate operand).\n\tXCORE_OP_MEM, // = CS_OP_MEM (Memory operand).\n} xcore_op_type;\n\n// Instruction's operand referring to memory\n// This is associated with XCORE_OP_MEM operand type above\ntypedef struct xcore_op_mem {\n\tuint8_t base;\t// base register\n\tuint8_t index;\t// index register\n\tint32_t disp;\t// displacement/offset value\n\tint     direct;\t// +1: forward, -1: backward\n} xcore_op_mem;\n\n// Instruction operand\ntypedef struct cs_xcore_op {\n\txcore_op_type type;\t// operand type\n\tunion {\n\t\tunsigned int reg;\t// register value for REG operand\n\t\tint32_t imm;\t\t// immediate value for IMM operand\n\t\txcore_op_mem mem;\t\t// base/disp value for MEM operand\n\t};\n} cs_xcore_op;\n\n// Instruction structure\ntypedef struct cs_xcore {\n\t// Number of operands of this instruction, \n\t// or 0 when instruction has no operand.\n\tuint8_t op_count;\n\tcs_xcore_op operands[8]; // operands for this instruction.\n} cs_xcore;\n\n//> XCore registers\ntypedef enum xcore_reg {\n\tXCORE_REG_INVALID = 0,\n\n\tXCORE_REG_CP,\n\tXCORE_REG_DP,\n\tXCORE_REG_LR,\n\tXCORE_REG_SP,\n\tXCORE_REG_R0,\n\tXCORE_REG_R1,\n\tXCORE_REG_R2,\n\tXCORE_REG_R3,\n\tXCORE_REG_R4,\n\tXCORE_REG_R5,\n\tXCORE_REG_R6,\n\tXCORE_REG_R7,\n\tXCORE_REG_R8,\n\tXCORE_REG_R9,\n\tXCORE_REG_R10,\n\tXCORE_REG_R11,\n\n\t//> pseudo registers\n\tXCORE_REG_PC,\t// pc\n\n\t// internal thread registers\n\t// see The-XMOS-XS1-Architecture(X7879A).pdf\n\tXCORE_REG_SCP,\t// save pc\n\tXCORE_REG_SSR,\t// save status\n\tXCORE_REG_ET,\t// exception type\n\tXCORE_REG_ED,\t// exception data\n\tXCORE_REG_SED,\t// save exception data\n\tXCORE_REG_KEP,\t// kernel entry pointer\n\tXCORE_REG_KSP,\t// kernel stack pointer\n\tXCORE_REG_ID,\t// thread ID\n\n\tXCORE_REG_ENDING,\t// <-- mark the end of the list of registers\n} xcore_reg;\n\n//> XCore instruction\ntypedef enum xcore_insn {\n\tXCORE_INS_INVALID = 0,\n\n\tXCORE_INS_ADD,\n\tXCORE_INS_ANDNOT,\n\tXCORE_INS_AND,\n\tXCORE_INS_ASHR,\n\tXCORE_INS_BAU,\n\tXCORE_INS_BITREV,\n\tXCORE_INS_BLA,\n\tXCORE_INS_BLAT,\n\tXCORE_INS_BL,\n\tXCORE_INS_BF,\n\tXCORE_INS_BT,\n\tXCORE_INS_BU,\n\tXCORE_INS_BRU,\n\tXCORE_INS_BYTEREV,\n\tXCORE_INS_CHKCT,\n\tXCORE_INS_CLRE,\n\tXCORE_INS_CLRPT,\n\tXCORE_INS_CLRSR,\n\tXCORE_INS_CLZ,\n\tXCORE_INS_CRC8,\n\tXCORE_INS_CRC32,\n\tXCORE_INS_DCALL,\n\tXCORE_INS_DENTSP,\n\tXCORE_INS_DGETREG,\n\tXCORE_INS_DIVS,\n\tXCORE_INS_DIVU,\n\tXCORE_INS_DRESTSP,\n\tXCORE_INS_DRET,\n\tXCORE_INS_ECALLF,\n\tXCORE_INS_ECALLT,\n\tXCORE_INS_EDU,\n\tXCORE_INS_EEF,\n\tXCORE_INS_EET,\n\tXCORE_INS_EEU,\n\tXCORE_INS_ENDIN,\n\tXCORE_INS_ENTSP,\n\tXCORE_INS_EQ,\n\tXCORE_INS_EXTDP,\n\tXCORE_INS_EXTSP,\n\tXCORE_INS_FREER,\n\tXCORE_INS_FREET,\n\tXCORE_INS_GETD,\n\tXCORE_INS_GET,\n\tXCORE_INS_GETN,\n\tXCORE_INS_GETR,\n\tXCORE_INS_GETSR,\n\tXCORE_INS_GETST,\n\tXCORE_INS_GETTS,\n\tXCORE_INS_INCT,\n\tXCORE_INS_INIT,\n\tXCORE_INS_INPW,\n\tXCORE_INS_INSHR,\n\tXCORE_INS_INT,\n\tXCORE_INS_IN,\n\tXCORE_INS_KCALL,\n\tXCORE_INS_KENTSP,\n\tXCORE_INS_KRESTSP,\n\tXCORE_INS_KRET,\n\tXCORE_INS_LADD,\n\tXCORE_INS_LD16S,\n\tXCORE_INS_LD8U,\n\tXCORE_INS_LDA16,\n\tXCORE_INS_LDAP,\n\tXCORE_INS_LDAW,\n\tXCORE_INS_LDC,\n\tXCORE_INS_LDW,\n\tXCORE_INS_LDIVU,\n\tXCORE_INS_LMUL,\n\tXCORE_INS_LSS,\n\tXCORE_INS_LSUB,\n\tXCORE_INS_LSU,\n\tXCORE_INS_MACCS,\n\tXCORE_INS_MACCU,\n\tXCORE_INS_MJOIN,\n\tXCORE_INS_MKMSK,\n\tXCORE_INS_MSYNC,\n\tXCORE_INS_MUL,\n\tXCORE_INS_NEG,\n\tXCORE_INS_NOT,\n\tXCORE_INS_OR,\n\tXCORE_INS_OUTCT,\n\tXCORE_INS_OUTPW,\n\tXCORE_INS_OUTSHR,\n\tXCORE_INS_OUTT,\n\tXCORE_INS_OUT,\n\tXCORE_INS_PEEK,\n\tXCORE_INS_REMS,\n\tXCORE_INS_REMU,\n\tXCORE_INS_RETSP,\n\tXCORE_INS_SETCLK,\n\tXCORE_INS_SET,\n\tXCORE_INS_SETC,\n\tXCORE_INS_SETD,\n\tXCORE_INS_SETEV,\n\tXCORE_INS_SETN,\n\tXCORE_INS_SETPSC,\n\tXCORE_INS_SETPT,\n\tXCORE_INS_SETRDY,\n\tXCORE_INS_SETSR,\n\tXCORE_INS_SETTW,\n\tXCORE_INS_SETV,\n\tXCORE_INS_SEXT,\n\tXCORE_INS_SHL,\n\tXCORE_INS_SHR,\n\tXCORE_INS_SSYNC,\n\tXCORE_INS_ST16,\n\tXCORE_INS_ST8,\n\tXCORE_INS_STW,\n\tXCORE_INS_SUB,\n\tXCORE_INS_SYNCR,\n\tXCORE_INS_TESTCT,\n\tXCORE_INS_TESTLCL,\n\tXCORE_INS_TESTWCT,\n\tXCORE_INS_TSETMR,\n\tXCORE_INS_START,\n\tXCORE_INS_WAITEF,\n\tXCORE_INS_WAITET,\n\tXCORE_INS_WAITEU,\n\tXCORE_INS_XOR,\n\tXCORE_INS_ZEXT,\n\n\tXCORE_INS_ENDING,   // <-- mark the end of the list of instructions\n} xcore_insn;\n\n//> Group of XCore instructions\ntypedef enum xcore_insn_group {\n\tXCORE_GRP_INVALID = 0, // = CS_GRP_INVALID\n\n\t//> Generic groups\n\t// all jump instructions (conditional+direct+indirect jumps)\n\tXCORE_GRP_JUMP,\t// = CS_GRP_JUMP\n\n\tXCORE_GRP_ENDING,   // <-- mark the end of the list of groups\n} xcore_insn_group;\n\n#ifdef __cplusplus\n}\n#endif\n\n#endif\n"
  },
  {
    "path": "EFI_DEBUG/EFI/OC/Kexts/Lilu.kext/Contents/Resources/Headers/hde32.h",
    "content": "/*\n * Hacker Disassembler Engine 32\n * Copyright (c) 2006-2009, Vyacheslav Patkov.\n * All rights reserved.\n *\n * hde32.h: C/C++ header file\n *\n */\n\n#ifndef _HDE32_H_\n#define _HDE32_H_\n\n#include <stdint.h>\n\n#define F_MODRM         0x00000001\n#define F_SIB           0x00000002\n#define F_IMM8          0x00000004\n#define F_IMM16         0x00000008\n#define F_IMM32         0x00000010\n#define F_DISP8         0x00000020\n#define F_DISP16        0x00000040\n#define F_DISP32        0x00000080\n#define F_RELATIVE      0x00000100\n#define F_2IMM16        0x00000800\n#define F_ERROR         0x00001000\n#define F_ERROR_OPCODE  0x00002000\n#define F_ERROR_LENGTH  0x00004000\n#define F_ERROR_LOCK    0x00008000\n#define F_ERROR_OPERAND 0x00010000\n#define F_PREFIX_REPNZ  0x01000000\n#define F_PREFIX_REPX   0x02000000\n#define F_PREFIX_REP    0x03000000\n#define F_PREFIX_66     0x04000000\n#define F_PREFIX_67     0x08000000\n#define F_PREFIX_LOCK   0x10000000\n#define F_PREFIX_SEG    0x20000000\n#define F_PREFIX_ANY    0x3f000000\n\n#define PREFIX_SEGMENT_CS   0x2e\n#define PREFIX_SEGMENT_SS   0x36\n#define PREFIX_SEGMENT_DS   0x3e\n#define PREFIX_SEGMENT_ES   0x26\n#define PREFIX_SEGMENT_FS   0x64\n#define PREFIX_SEGMENT_GS   0x65\n#define PREFIX_LOCK         0xf0\n#define PREFIX_REPNZ        0xf2\n#define PREFIX_REPX         0xf3\n#define PREFIX_OPERAND_SIZE 0x66\n#define PREFIX_ADDRESS_SIZE 0x67\n\n#pragma pack(push,1)\n\ntypedef struct {\n    uint8_t len;\n    uint8_t p_rep;\n    uint8_t p_lock;\n    uint8_t p_seg;\n    uint8_t p_66;\n    uint8_t p_67;\n    uint8_t opcode;\n    uint8_t opcode2;\n    uint8_t modrm;\n    uint8_t modrm_mod;\n    uint8_t modrm_reg;\n    uint8_t modrm_rm;\n    uint8_t sib;\n    uint8_t sib_scale;\n    uint8_t sib_index;\n    uint8_t sib_base;\n    union {\n        uint8_t imm8;\n        uint16_t imm16;\n        uint32_t imm32;\n    } imm;\n    union {\n        uint8_t disp8;\n        uint16_t disp16;\n        uint32_t disp32;\n    } disp;\n    uint32_t flags;\n} hde32s;\n\n#pragma pack(pop)\n\n#ifdef __cplusplus\nextern \"C\" {\n#endif\n\n/* __cdecl */\nunsigned int hde32_disasm(const void *code, hde32s *hs);\n\n#ifdef __cplusplus\n}\n#endif\n\n#endif /* _HDE32_H_ */\n"
  },
  {
    "path": "EFI_DEBUG/EFI/OC/Kexts/Lilu.kext/Contents/Resources/Headers/hde64.h",
    "content": "/*\n * Hacker Disassembler Engine 64\n * Copyright (c) 2008-2009, Vyacheslav Patkov.\n * All rights reserved.\n *\n * hde64.h: C/C++ header file\n *\n */\n\n#ifndef _HDE64_H_\n#define _HDE64_H_\n\n#include <stdint.h>\n\n#define F_MODRM         0x00000001\n#define F_SIB           0x00000002\n#define F_IMM8          0x00000004\n#define F_IMM16         0x00000008\n#define F_IMM32         0x00000010\n#define F_IMM64         0x00000020\n#define F_DISP8         0x00000040\n#define F_DISP16        0x00000080\n#define F_DISP32        0x00000100\n#define F_RELATIVE      0x00000200\n#define F_ERROR         0x00001000\n#define F_ERROR_OPCODE  0x00002000\n#define F_ERROR_LENGTH  0x00004000\n#define F_ERROR_LOCK    0x00008000\n#define F_ERROR_OPERAND 0x00010000\n#define F_PREFIX_REPNZ  0x01000000\n#define F_PREFIX_REPX   0x02000000\n#define F_PREFIX_REP    0x03000000\n#define F_PREFIX_66     0x04000000\n#define F_PREFIX_67     0x08000000\n#define F_PREFIX_LOCK   0x10000000\n#define F_PREFIX_SEG    0x20000000\n#define F_PREFIX_REX    0x40000000\n#define F_PREFIX_ANY    0x7f000000\n\n#define PREFIX_SEGMENT_CS   0x2e\n#define PREFIX_SEGMENT_SS   0x36\n#define PREFIX_SEGMENT_DS   0x3e\n#define PREFIX_SEGMENT_ES   0x26\n#define PREFIX_SEGMENT_FS   0x64\n#define PREFIX_SEGMENT_GS   0x65\n#define PREFIX_LOCK         0xf0\n#define PREFIX_REPNZ        0xf2\n#define PREFIX_REPX         0xf3\n#define PREFIX_OPERAND_SIZE 0x66\n#define PREFIX_ADDRESS_SIZE 0x67\n\n#pragma pack(push,1)\n\ntypedef struct {\n    uint8_t len;\n    uint8_t p_rep;\n    uint8_t p_lock;\n    uint8_t p_seg;\n    uint8_t p_66;\n    uint8_t p_67;\n    uint8_t rex;\n    uint8_t rex_w;\n    uint8_t rex_r;\n    uint8_t rex_x;\n    uint8_t rex_b;\n    uint8_t opcode;\n    uint8_t opcode2;\n    uint8_t modrm;\n    uint8_t modrm_mod;\n    uint8_t modrm_reg;\n    uint8_t modrm_rm;\n    uint8_t sib;\n    uint8_t sib_scale;\n    uint8_t sib_index;\n    uint8_t sib_base;\n    union {\n        uint8_t imm8;\n        uint16_t imm16;\n        uint32_t imm32;\n        uint64_t imm64;\n    } imm;\n    union {\n        uint8_t disp8;\n        uint16_t disp16;\n        uint32_t disp32;\n    } disp;\n    uint32_t flags;\n} hde64s;\n\n#pragma pack(pop)\n\n#ifdef __cplusplus\nextern \"C\" {\n#endif\n\n/* Note, code should point to at least 32 valid bytes. */\nunsigned int hde64_disasm(const void *code, hde64s *hs);\n\n#ifdef __cplusplus\n}\n#endif\n\n#endif /* _HDE64_H_ */\n"
  },
  {
    "path": "EFI_DEBUG/EFI/OC/Kexts/Lilu.kext/Contents/Resources/Headers/kern_api.hpp",
    "content": "//\n//  kern_api.hpp\n//  Lilu\n//\n//  Copyright © 2016-2017 vit9696. All rights reserved.\n//\n\n#ifndef kern_api_h\n#define kern_api_h\n\n#include <Headers/kern_config.hpp>\n#include <Headers/kern_patcher.hpp>\n#include <Headers/kern_user.hpp>\n#include <Headers/kern_util.hpp>\n\n#include <stdint.h>\n#include <sys/types.h>\n#include <libkern/OSAtomic.h>\n#include <Availability.h>\n\n#ifndef __ACIDANTHERA_MAC_SDK\n#error \"This kext SDK is unsupported. Download from https://github.com/acidanthera/MacKernelSDK\"\n#endif\n\nclass LiluAPI {\npublic:\n\t/**\n\t *  Initialise lilu api\n \t */\n\tvoid init();\n\n\t/**\n\t *  Deinitialise lilu api\n\t */\n\tvoid deinit();\n\n\t/**\n\t *  Errors returned by functions\n\t */\n\tenum class Error {\n\t\tNoError,\n\t\tLockError,\n\t\tMemoryError,\n\t\tUnsupportedFeature,\n\t\tIncompatibleOS,\n\t\tDisabled,\n\t\tTooLate,\n\t\tOffline\n\t};\n\n\t/**\n\t *  Minimal API version that guarantees forward ABI compatibility\n\t *  Present due to lack of OSBundleCompatibleVersion at kext injection\n\t */\n\tstatic constexpr size_t CompatibilityVersion {parseModuleVersion(\"1.2.0\")};\n\n\t/**\n\t *  Obtains api access by holding a lock, which is required when accessing out of the main context\n\t *\n\t *  @param version  api compatibility version\n\t *  @param check    do not wait on the lock but return Error::LockError on failure\n\t *\n\t *  @return Error::NoError on success\n\t */\n\tEXPORT Error requestAccess(size_t version=CompatibilityVersion, bool check=false);\n\n\t/**\n\t *  Releases api lock\n\t *\n\t *  @return Error::NoError on success\n\t */\n\tEXPORT Error releaseAccess();\n\n\t/**\n\t *  You are supposed declare that your plugins work in at least one of these modes\n\t *  It is assumed that single user mode is equal to normal, because it is generally\n\t *  used to continue the load of a complete OS, and by default Lilu itself ignores it.\n\t */\n\tenum RunningMode : uint32_t {\n\t\tRunningNormal            = 1,\n\t\tAllowNormal              = RunningNormal,\n\t\tRunningInstallerRecovery = 2,\n\t\tAllowInstallerRecovery   = RunningInstallerRecovery,\n\t\tRunningSafeMode          = 4,\n\t\tAllowSafeMode            = RunningSafeMode\n\t};\n\n\t/**\n\t *  Obtain current run mode similarly to requirements\n\t *\n\t *  @return run mode mask (RunningMode)\n\t */\n\tinline uint32_t getRunMode() {\n\t\treturn currentRunMode;\n\t}\n\n\t/**\n\t *  Decides whether you are eligible to continue\n\t *\n\t *  @param product       product name\n\t *  @param version       product version\n\t *  @param runmode       bitmask of allowed enviornments\n\t *  @param disableArg    pointer to disabling boot arguments array\n\t *  @param disableArgNum number of disabling boot arguments\n\t *  @param debugArg      pointer to debug boot arguments array\n\t *  @param debugArgNum   number of debug boot arguments\n\t *  @param betaArg       pointer to beta boot arguments array\n\t *  @param betaArgNum    number of beta boot arguments\n\t *  @param min           minimal required kernel version\n\t *  @param max           maximum supported kernel version\n\t *  @param printDebug    returns debug printing status (based on debugArg)\n\t *\n\t *  @return Error::NoError on success\n\t */\n\tEXPORT Error shouldLoad(const char *product, size_t version, uint32_t runmode, const char **disableArg, size_t disableArgNum, const char **debugArg, size_t debugArgNum, const char **betaArg, size_t betaArgNum, KernelVersion min, KernelVersion max, bool &printDebug);\n\n\t/**\n\t *  Kernel patcher loaded callback\n\t *\n\t *  @param user    user provided pointer at registering\n\t *  @param patcher kernel patcher instance\n\t */\n\tusing t_patcherLoaded = void (*)(void *user, KernelPatcher &patcher);\n\n\t/**\n\t *  Registers custom provided callbacks for later invocation on kernel patcher initialisation\n\t *\n\t *  @param callback your callback function\n\t *  @param user     your pointer that will be passed to the callback function\n\t *\n\t *  @return Error::NoError on success\n\t */\n\tEXPORT Error onPatcherLoad(t_patcherLoaded callback, void *user=nullptr);\n\n\t/**\n\t *  Registers custom provided callbacks for later invocation on kernel patcher initialisation\n\t *  Enforced version, which panics on registration failure (assuming your code cannot continue otherwise)\n\t *\n\t *  @param callback your callback function\n\t *  @param user     your pointer that will be passed to the callback function\n\t */\n\tinline void onPatcherLoadForce(t_patcherLoaded callback, void *user=nullptr) {\n\t\tauto err = onPatcherLoad(callback, user);\n\t\tif (err != Error::NoError)\n\t\t\tPANIC(\"api\", \"onPatcherLoad failed with code %d\", err);\n\t}\n\n\t/**\n\t *  Kext loaded callback\n\t *  Note that you will get notified of all the requested kexts for speed reasons\n\t *\n\t *  @param user    user provided pointer at registering\n\t *  @param patcher kernel patcher instance\n\t *  @param id      loaded kinfo id\n\t *  @param slide   loaded slide\n\t *  @param size    loaded memory size\n\t */\n\tusing t_kextLoaded = void (*)(void *user, KernelPatcher &patcher, size_t id, mach_vm_address_t slide, size_t size);\n\n\t/**\n\t *  Registers custom provided callbacks for later invocation on kext load\n\t *\n\t *  @param infos    your kext list (make sure to point to const memory)\n\t *  @param num      number of provided kext entries\n\t *  @param callback your callback function (optional)\n\t *  @param user     your pointer that will be passed to the callback function (optional)\n\t *\n\t *  @return Error::NoError on success\n\t */\n\tEXPORT Error onKextLoad(KernelPatcher::KextInfo *infos, size_t num=1, t_kextLoaded callback=nullptr, void *user=nullptr);\n\n\t/**\n\t *  Registers custom provided callbacks for later invocation on kext load\n\t *  Enforced version, which panics on registration failure (assuming your code cannot continue otherwise)\n\t *\n\t *  @param infos    your kext list (make sure to point to const memory)\n\t *  @param num      number of provided kext entries\n\t *  @param callback your callback function (optional)\n\t *  @param user     your pointer that will be passed to the callback function (optional)\n\t */\n\tinline void onKextLoadForce(KernelPatcher::KextInfo *infos, size_t num=1, t_kextLoaded callback=nullptr, void *user=nullptr) {\n\t\tauto err = onKextLoad(infos, num, callback, user);\n\t\tif (err != Error::NoError)\n\t\t\tPANIC(\"api\", \"onKextLoad failed with code %d\", err);\n\t}\n\n\t/**\n\t *  Registers custom provided callbacks for later invocation on binary load\n\t *\n\t *  @param infos    your binary list (make sure to point to const memory)\n\t *  @param num      number of provided binary entries\n\t *  @param callback your callback function (could be null)\n\t *  @param user     your pointer that will be passed to the callback function\n\t *  @param mods     optional mod list (make sure to point to const memory)\n\t *  @param modnum   number of provided mod entries\n\t *\n\t *  @return Error::NoError on success\n\t */\n\tEXPORT Error onProcLoad(UserPatcher::ProcInfo *infos, size_t num=1, UserPatcher::t_BinaryLoaded callback=nullptr, void *user=nullptr, UserPatcher::BinaryModInfo *mods=nullptr, size_t modnum=0);\n\n\t/**\n\t *  Registers custom provided callbacks for later invocation on binary load\n\t *  Enforced version, which panics on registration failure (assuming your code cannot continue otherwise)\n\t *\n\t *  @param infos    your binary list (make sure to point to const memory)\n\t *  @param num      number of provided binary entries\n\t *  @param callback your callback function (could be null)\n\t *  @param user     your pointer that will be passed to the callback function\n\t *  @param mods     optional mod list (make sure to point to const memory)\n\t *  @param modnum   number of provided mod entries\n\t */\n\tinline void onProcLoadForce(UserPatcher::ProcInfo *infos, size_t num=1, UserPatcher::t_BinaryLoaded callback=nullptr, void *user=nullptr, UserPatcher::BinaryModInfo *mods=nullptr, size_t modnum=0) {\n\t\tauto err = onProcLoad(infos, num, callback, user, mods, modnum);\n\t\tif (err != Error::NoError)\n\t\t\tPANIC(\"api\", \"onProcLoad failed with code %d\", err);\n\t}\n\n\t/**\n\t *  Kext loaded callback\n\t *  Note that you will get notified of all the requested kexts for speed reasons\n\t *\n\t *  @param user          user provided pointer at registering\n\t *  @param task          task\n\t *  @param entitlement   loaded kinfo id\n\t *  @param original      original entitlement value\n\t */\n\tusing t_entitlementRequested = void (*)(void *user, task_t task, const char *entitlement, OSObject *&original);\n\n\t/**\n\t *  Registers custom provided callbacks for later invocation on entitlement registration\n\t *\n\t *  @param callback your callback function\n\t *  @param user     your pointer that will be passed to the callback function\n\t *\n\t *  @return Error::NoError on success\n\t */\n\tEXPORT Error onEntitlementRequest(t_entitlementRequested callback, void *user=nullptr);\n\n\t/**\n\t *  Registers custom provided callbacks for later invocation on entitlement registration\n\t *  Enforced version, which panics on registration failure (assuming your code cannot continue otherwise)\n\t *\n\t *  @param callback your callback function\n\t *  @param user     your pointer that will be passed to the callback function\n\t */\n\tinline void onEntitlementRequestForce(t_entitlementRequested callback, void *user=nullptr) {\n\t\tauto err = onEntitlementRequest(callback, user);\n\t\tif (err != Error::NoError)\n\t\t\tPANIC(\"api\", \"onEntitlementRequest failed with code %d\", err);\n\t}\n\n\t/**\n\t *  Complete plugin registration and perform regulatory actions\n\t */\n\tvoid finaliseRequests();\n\n\t/**\n\t *  Processes all the registered patcher load callbacks\n\t *\n\t *  @param patcher kernel patcher instance\n\t */\n\tvoid processPatcherLoadCallbacks(KernelPatcher &patcher);\n\n\t/**\n\t *  Processes all the registered kext load callbacks\n\t *\n\t *  @param patcher    kernel patcher instance\n\t *  @param id         loaded kinfo id\n\t *  @param slide      loaded slide\n\t *  @param size       loaded memory size\n\t *  @param reloadable kinfo could be unloaded\n\t */\n\tvoid processKextLoadCallbacks(KernelPatcher &patcher, size_t id, mach_vm_address_t slide, size_t size, bool reloadable);\n\n\t/**\n\t *  Processes all the registered user patcher load callbacks\n\t *\n\t *  @param patcher user patcher instance\n\t */\n\tvoid processUserLoadCallbacks(UserPatcher &patcher);\n\n\t/**\n\t *  Processes all the registered binary load callbacks\n\t *\n\t *  @param patcher kernel patcher instance\n\t *  @param map     process image vm_map\n\t *  @param path    path to the binary absolute or relative\n\t *  @param len     path length excluding null terminator\n\t */\n\tvoid processBinaryLoadCallbacks(UserPatcher &patcher, vm_map_t map, const char *path, size_t len);\n\n\t/**\n\t *  Activates patchers\n\t *\n\t *  @param kpatcher  kernel patcher instance\n\t *  @param upatcher  user patcher instance\n\t */\n\tvoid activate(KernelPatcher &kpatcher, UserPatcher &upatcher);\n\nprivate:\n\n\t/**\n\t *  Api lock\n\t */\n\tIOLock *access {nullptr};\n\n\t/**\n\t *  Defines current running modes\n\t */\n\tuint32_t currentRunMode {};\n\n\t/**\n\t *  No longer accept any requests\n\t */\n\tbool apiRequestsOver {false};\n\n\t/**\n\t *  Stores call function and user pointer\n\t */\n\ttemplate <typename T, typename Y=void *>\n\tusing stored_pair = ppair<T, Y>;\n\n\t/**\n\t *  Stores multiple callbacks\n\t */\n\ttemplate <typename T, typename Y=void *>\n\tusing stored_vector = evector<stored_pair<T, Y> *, stored_pair<T, Y>::deleter>;\n\n\t/**\n\t *  List of patcher callbacks\n\t */\n\tstored_vector<t_patcherLoaded> patcherLoadedCallbacks;\n\n\t/**\n\t *  List of kext callbacks\n\t */\n\tstored_vector<t_kextLoaded> kextLoadedCallbacks;\n\n\t/**\n\t *  List of binary callbacks\n\t */\n\tstored_vector<UserPatcher::t_BinaryLoaded> binaryLoadedCallbacks;\n\n\t/**\n\t *  List of entitlement callbacks\n\t */\n\tstored_vector<t_entitlementRequested> entitlementRequestedCallbacks;\n\n\t/**\n\t *  List of processed kexts\n\t */\n\tstored_vector<KernelPatcher::KextInfo *, size_t> storedKexts;\n\n\t/**\n\t *  List of processed procs\n\t */\n\tevector<UserPatcher::ProcInfo *> storedProcs;\n\n\t/**\n\t *  List of processed binary mods\n\t */\n\tevector<UserPatcher::BinaryModInfo *> storedBinaryMods;\n\n\t/**\n\t *  Copy client entitlement type (see IOUserClient)\n\t */\n\tusing t_copyClientEntitlement = OSObject *(*)(task_t, const char *);\n\n\t/**\n\t *  Hooked entitlement copying method\n\t */\n\tstatic OSObject *copyClientEntitlement(task_t task, const char *entitlement);\n\n\t/**\n\t *  Trampoline for original entitlement copying method\n\t */\n\tt_copyClientEntitlement orgCopyClientEntitlement {nullptr};\n};\n\nEXPORT extern LiluAPI lilu;\n\n#endif /* kern_api_h */\n"
  },
  {
    "path": "EFI_DEBUG/EFI/OC/Kexts/Lilu.kext/Contents/Resources/Headers/kern_compat.hpp",
    "content": "//\n//  kern_compat.hpp\n//  Lilu\n//\n//  Copyright © 2016-2017 vit9696. All rights reserved.\n//\n\n#ifndef kern_compat_hpp\n#define kern_compat_hpp\n\n#include <Headers/kern_config.hpp>\n#include <stdint.h>\n\n// Legacy compatibility layer created to avoid 10.13 SDK macros\n// unsupported in older systems and improperly guarded due to\n// Availability.h header not being. Currently these macros\n// are left to avoid compilation errors.\n#define lilu_os_memcpy  memcpy\n#define lilu_os_memmove memmove\n#define lilu_os_strncpy strncpy\n#define lilu_os_strncat strncat\n#define lilu_os_strlcat strlcat\n#define lilu_os_strlcpy strlcpy\n#define lilu_os_strcat  strcat\n#define lilu_os_bcopy   bcopy\n\n// This may not be nice but will protect users from changes in KernInfo strcture.\n#ifndef LILU_DISABLE_BRACE_WARNINGS\n#pragma clang diagnostic error \"-Wmissing-braces\"\n#endif\n\n#if defined(__i386__)\n#define lilu_strtou\tstrtoul\n\n#elif defined(__x86_64__)\n#define lilu_strtou\tstrtouq\n\n#else\n#error Unsupported arch.\n#endif\n\n#endif /* kern_compat_hpp */\n"
  },
  {
    "path": "EFI_DEBUG/EFI/OC/Kexts/Lilu.kext/Contents/Resources/Headers/kern_compression.hpp",
    "content": "//\n//  kern_compression.hpp\n//  Lilu\n//\n//  Copyright © 2016-2017 vit9696. All rights reserved.\n//\n\n#ifndef kern_compression_hpp\n#define kern_compression_hpp\n\n#include <Headers/kern_config.hpp>\n\n#ifdef LILU_COMPRESSION_SUPPORT\n\n#include <Headers/kern_util.hpp>\n#include <stdint.h>\n\nnamespace Compression {\n\n\t/**\n\t *  Compression constants and modes\n\t */\n\tstatic constexpr uint32_t Magic {0x706D6F63}; //comp\n\tstatic constexpr uint32_t ModeLZVN {0x6E767A6C}; //lzvn\n\tstatic constexpr uint32_t ModeLZSS {0x73737A6C}; //lzss\n\tstatic constexpr uint32_t ModeZLIB {0x9C787A6C}; //zlib\n\n\t/**\n\t *  Compressed header structure\n\t */\n\tstruct Header {\n\t\tuint32_t magic;\n\t\tuint32_t compression;\n\t\tuint32_t hash; // adler32\n\t\tuint32_t decompressed;\n\t\tuint32_t compressed;\n\t\tuint32_t version;\n\t\tuint32_t padding[90];\n\t};\n\n\t/**\n\t *  Typed decompressing function (currently for lzvn, lzss, and zlib)\n\t *\n\t *  @param compression compression type\n\t *  @param dstlen      decompression buffer size\n\t *  @param src         compressed data\n\t *  @param srclen      compressed data size\n\t *  @param buffer      preallocated buffer to use\n\t *\n\t *  @return decompressed buffer (must be freeded by Buffer::deleter if not preallocated)\n\t */\n\tEXPORT uint8_t *decompress(uint32_t compression, uint32_t dstlen, const uint8_t *src, uint32_t srclen, uint8_t *buffer=nullptr);\n\n\t/**\n\t *  Typed decompressing function (currently for lzvn, lzss, and zlib)\n\t *\n\t *  @param compression compression type\n\t *  @param dstlen      decompression buffer size, actual decompressed size on success\n\t *  @param src         compressed data\n\t *  @param srclen      compressed data size\n\t *  @param buffer      preallocated buffer to use\n\t *\n\t *  @return decompressed buffer (must be freeded by Buffer::deleter if not preallocated)\n\t */\n\tEXPORT uint8_t *decompress(uint32_t compression, uint32_t *dstlen, const uint8_t *src, uint32_t srclen, uint8_t *buffer=nullptr);\n\n\t/**\n\t *  Typed compressing function (currently for lzss)\n\t *\n\t *  @param compression compression type\n\t *  @param dstlen      maximum compression buffer size\n\t *  @param src         uncompressed data\n\t *  @param srclen      uncompressed data size\n\t *  @param buffer      preallocated buffer to use\n\t *\n\t *  @return compressed buffer with its actual size in dstlen (must be freeded by Buffer::deleter if not preallocated)\n\t */\n\tEXPORT uint8_t *compress(uint32_t compression, uint32_t &dstlen, const uint8_t *src, uint32_t srclen, uint8_t *buffer=nullptr);\n\n}\n\n#endif /* LILU_COMPRESSION_SUPPORT */\n\n#endif /* kern_compression_hpp */\n"
  },
  {
    "path": "EFI_DEBUG/EFI/OC/Kexts/Lilu.kext/Contents/Resources/Headers/kern_config.hpp",
    "content": "//\n//  kern_config.hpp\n//  Lilu\n//\n//  Copyright © 2016-2017 vit9696. All rights reserved.\n//\n\n#ifndef kern_config_hpp\n#define kern_config_hpp\n\n/**\n *  Enable kext patching support\n */\n#define LILU_KEXTPATCH_SUPPORT 1\n\n/**\n *  Enable compression and decompression support\n */\n#define LILU_COMPRESSION_SUPPORT 1\n\n/**\n *  Enable advanced disassembly API based on capstone\n */\n// #define LILU_ADVANCED_DISASSEMBLY 1\n\n/**\n *  Specify custom initialisation code\n *  Use these in plugins in Xcode Project Preprocessor Macros section.\n */\n// #define LILU_CUSTOM_IOKIT_INIT 1\n// #define LILU_CUSTOM_KMOD_INIT 1\n\n#endif /* kern_config_hpp */\n"
  },
  {
    "path": "EFI_DEBUG/EFI/OC/Kexts/Lilu.kext/Contents/Resources/Headers/kern_cpu.hpp",
    "content": "//\n//  kern_cpu.hpp\n//  Lilu\n//\n//  Copyright © 2018 vit9696. All rights reserved.\n//\n\n#ifndef kern_cpu_h\n#define kern_cpu_h\n\n#include <Headers/kern_config.hpp>\n#include <Headers/kern_iokit.hpp>\n#include <Headers/kern_util.hpp>\n\n#include <IOKit/IOService.h>\n\n/**\n *  XNU CPU-related exports missing from headers\n */\nextern \"C\" {\n\tint cpu_number(void);\n\tvoid mp_rendezvous_no_intrs(void (*action_func)(void *), void *arg);\n};\n\nnamespace CPUInfo {\n\t/**\n\t *  Keep this in sync to XNU MAX_CPUS from osfmk/i386/mp.h\n\t */\n\tstatic constexpr size_t MaxCpus {64};\n\n\t/**\n\t *  Contents of CPUID(1) eax register contents describing model version\n\t */\n\tstruct CpuVersion {\n\t\tuint32_t stepping       : 4;\n\t\tuint32_t model          : 4;\n\t\tuint32_t family         : 4;\n\t\tuint32_t type           : 2;\n\t\tuint32_t reserved1      : 2;\n\t\tuint32_t extendedModel  : 4;\n\t\tuint32_t extendedFamily : 8;\n\t\tuint32_t reserved2      : 4;\n\t};\n\n\tstatic_assert(sizeof(CpuVersion) == sizeof(uint32_t), \"CpuVersion size mismatch!\");\n\n\t/**\n\t *  Intel CPU models as returned by CPUID\n\t *  The list is synchronised and updated with XNU source code (osfmk/i386/cpuid.h).\n\t *  Names are altered to avoid conflicts just in case.\n\t *  Last update: xnu-4903.221.2\n\t *  Some details could be found on http://instlatx64.atw.hu and https://en.wikichip.org/wiki/64-bit_architecture#x86\n\t *  Also: https://www.intel.com/content/dam/www/public/us/en/documents/sa00115-microcode-update-guidance.pdf\n\t */\n\tenum CpuModel {\n\t\tCPU_MODEL_UNKNOWN        =  0x00,\n\t\tCPU_MODEL_PENRYN         =  0x17,\n\t\tCPU_MODEL_NEHALEM        =  0x1A,\n\t\tCPU_MODEL_FIELDS         =  0x1E, /* Lynnfield, Clarksfield */\n\t\tCPU_MODEL_DALES          =  0x1F, /* Havendale, Auburndale */\n\t\tCPU_MODEL_NEHALEM_EX     =  0x2E,\n\t\tCPU_MODEL_DALES_32NM     =  0x25, /* Clarkdale, Arrandale */\n\t\tCPU_MODEL_WESTMERE       =  0x2C, /* Gulftown, Westmere-EP/-WS */\n\t\tCPU_MODEL_WESTMERE_EX    =  0x2F,\n\t\tCPU_MODEL_SANDYBRIDGE    =  0x2A,\n\t\tCPU_MODEL_JAKETOWN       =  0x2D,\n\t\tCPU_MODEL_IVYBRIDGE      =  0x3A,\n\t\tCPU_MODEL_IVYBRIDGE_EP   =  0x3E,\n\t\tCPU_MODEL_CRYSTALWELL    =  0x46,\n\t\tCPU_MODEL_HASWELL        =  0x3C,\n\t\tCPU_MODEL_HASWELL_EP     =  0x3F,\n\t\tCPU_MODEL_HASWELL_ULT    =  0x45,\n\t\tCPU_MODEL_BROADWELL      =  0x3D,\n\t\tCPU_MODEL_BROADWELL_ULX  =  0x3D,\n\t\tCPU_MODEL_BROADWELL_ULT  =  0x3D,\n\t\tCPU_MODEL_BRYSTALWELL    =  0x47,\n\t\tCPU_MODEL_SKYLAKE        =  0x4E,\n\t\tCPU_MODEL_SKYLAKE_ULT    =  0x4E,\n\t\tCPU_MODEL_SKYLAKE_ULX    =  0x4E,\n\t\tCPU_MODEL_BROADWELL_EP   =  0x4F,\n\t\tCPU_MODEL_SKYLAKE_DT     =  0x5E,\n\t\tCPU_MODEL_SKYLAKE_W      =  0x55,\n\t\tCPU_MODEL_KABYLAKE       =  0x8E,\n\t\tCPU_MODEL_KABYLAKE_ULT   =  0x8E,\n\t\tCPU_MODEL_KABYLAKE_ULX   =  0x8E,\n\t\tCPU_MODEL_KABYLAKE_DT    =  0x9E,\n\t\tCPU_MODEL_CANNONLAKE     =  0x66,\n\t\tCPU_MODEL_ICELAKE_Y      =  0x7D,\n\t\tCPU_MODEL_ICELAKE_U      =  0x7E,\n\t\tCPU_MODEL_ICELAKE_SP     =  0x9F, /* Some variation of Ice Lake */\n\t\tCPU_MODEL_COMETLAKE_S    =  0xA5, /* desktop CometLake */\n\t\tCPU_MODEL_COMETLAKE_Y    =  0xA5, /* aka 10th generation Amber Lake Y */\n\t\tCPU_MODEL_COMETLAKE_U    =  0xA6,\n\t\tCPU_MODEL_ROCKETLAKE_S   =  0xA7, /* desktop RocketLake */\n\t\tCPU_MODEL_TIGERLAKE_U    =  0x8C,\n\t\tCPU_MODEL_ALDERLAKE_S    =  0x97,\n\t\tCPU_MODEL_RAPTORLAKE_S   =  0xB7, /* Raptor Lake B0 stepping */\n\t\tCPU_MODEL_RAPTORLAKE_HX  =  0xBF, /* Raptor Lake C0 stepping */\n\t\tCPU_MODEL_ARROWLAKE_HX   =  0xC5,\n\t\tCPU_MODEL_ARROWLAKE_S    =  0xC6, /* desktop ArrowLake */\n\t\tCPU_MODEL_ARROWLAKE_U    =  0xB5,\n\t};\n\n\t/**\n\t *  Known CPU vendors\n\t */\n\tenum class CpuVendor {\n\t\tUnknown,\n\t\tAMD,\n\t\tIntel\n\t\t/* Add more processors here if needed */\n\t};\n\n\t/**\n\t *  Intel CPU generations (starting from 0)\n\t */\n\tenum class CpuGeneration {\n\t\tUnknown,\n\t\tPenryn,\n\t\tNehalem,\n\t\tWestmere,\n\t\tSandyBridge,\n\t\tIvyBridge,\n\t\tHaswell,\n\t\tBroadwell,\n\t\tSkylake,\n\t\tKabyLake,\n\t\tCoffeeLake,\n\t\tCannonLake,\n\t\tIceLake,\n\t\tCometLake,\n\t\tRocketLake,\n\t\tTigerLake,\n\t\tAlderLake,\n\t\tRaptorLake,\n\t\tArrowLake,\n\t\tMaxGeneration\n\t};\n\n\t/* Responses identification request with %eax 0 */\n\t/* AMD:     \"AuthenticAMD\" */\n\tstatic constexpr uint32_t signature_AMD_ebx = 0x68747541;\n\tstatic constexpr uint32_t signature_AMD_edx = 0x69746e65;\n\tstatic constexpr uint32_t signature_AMD_ecx = 0x444d4163;\n\t/* CENTAUR: \"CentaurHauls\" */\n\tstatic constexpr uint32_t signature_CENTAUR_ebx = 0x746e6543;\n\tstatic constexpr uint32_t signature_CENTAUR_edx = 0x48727561;\n\tstatic constexpr uint32_t signature_CENTAUR_ecx = 0x736c7561;\n\t/* CYRIX:   \"CyrixInstead\" */\n\tstatic constexpr uint32_t signature_CYRIX_ebx = 0x69727943;\n\tstatic constexpr uint32_t signature_CYRIX_edx = 0x736e4978;\n\tstatic constexpr uint32_t signature_CYRIX_ecx = 0x64616574;\n\t/* INTEL:   \"GenuineIntel\" */\n\tstatic constexpr uint32_t signature_INTEL_ebx = 0x756e6547;\n\tstatic constexpr uint32_t signature_INTEL_edx = 0x49656e69;\n\tstatic constexpr uint32_t signature_INTEL_ecx = 0x6c65746e;\n\t/* TM1:     \"TransmetaCPU\" */\n\tstatic constexpr uint32_t signature_TM1_ebx = 0x6e617254;\n\tstatic constexpr uint32_t signature_TM1_edx = 0x74656d73;\n\tstatic constexpr uint32_t signature_TM1_ecx = 0x55504361;\n\t/* TM2:     \"GenuineTMx86\" */\n\tstatic constexpr uint32_t signature_TM2_ebx = 0x756e6547;\n\tstatic constexpr uint32_t signature_TM2_edx = 0x54656e69;\n\tstatic constexpr uint32_t signature_TM2_ecx = 0x3638784d;\n\t/* NSC:     \"Geode by NSC\" */\n\tstatic constexpr uint32_t signature_NSC_ebx = 0x646f6547;\n\tstatic constexpr uint32_t signature_NSC_edx = 0x43534e20;\n\tstatic constexpr uint32_t signature_NSC_ecx = 0x79622065;\n\t/* NEXGEN:  \"NexGenDriven\" */\n\tstatic constexpr uint32_t signature_NEXGEN_ebx = 0x4778654e;\n\tstatic constexpr uint32_t signature_NEXGEN_edx = 0x72446e65;\n\tstatic constexpr uint32_t signature_NEXGEN_ecx = 0x6e657669;\n\t/* RISE:    \"RiseRiseRise\" */\n\tstatic constexpr uint32_t signature_RISE_ebx = 0x65736952;\n\tstatic constexpr uint32_t signature_RISE_edx = 0x65736952;\n\tstatic constexpr uint32_t signature_RISE_ecx = 0x65736952;\n\t/* SIS:     \"SiS SiS SiS \" */\n\tstatic constexpr uint32_t signature_SIS_ebx = 0x20536953;\n\tstatic constexpr uint32_t signature_SIS_edx = 0x20536953;\n\tstatic constexpr uint32_t signature_SIS_ecx = 0x20536953;\n\t/* UMC:     \"UMC UMC UMC \" */\n\tstatic constexpr uint32_t signature_UMC_ebx = 0x20434d55;\n\tstatic constexpr uint32_t signature_UMC_edx = 0x20434d55;\n\tstatic constexpr uint32_t signature_UMC_ecx = 0x20434d55;\n\t/* VIA:     \"VIA VIA VIA \" */\n\tstatic constexpr uint32_t signature_VIA_ebx = 0x20414956;\n\tstatic constexpr uint32_t signature_VIA_edx = 0x20414956;\n\tstatic constexpr uint32_t signature_VIA_ecx = 0x20414956;\n\t/* VORTEX:  \"Vortex86 SoC\" */\n\tstatic constexpr uint32_t signature_VORTEX_ebx = 0x74726f56;\n\tstatic constexpr uint32_t signature_VORTEX_edx = 0x36387865;\n\tstatic constexpr uint32_t signature_VORTEX_ecx = 0x436f5320;\n\n\t/* Features in %ecx for leaf 1 */\n\tstatic constexpr uint32_t bit_SSE3        = 0x00000001;\n\tstatic constexpr uint32_t bit_PCLMULQDQ   = 0x00000002;\n\tstatic constexpr uint32_t bit_DTES64      = 0x00000004;\n\tstatic constexpr uint32_t bit_MONITOR     = 0x00000008;\n\tstatic constexpr uint32_t bit_DSCPL       = 0x00000010;\n\tstatic constexpr uint32_t bit_VMX         = 0x00000020;\n\tstatic constexpr uint32_t bit_SMX         = 0x00000040;\n\tstatic constexpr uint32_t bit_EIST        = 0x00000080;\n\tstatic constexpr uint32_t bit_TM2         = 0x00000100;\n\tstatic constexpr uint32_t bit_SSSE3       = 0x00000200;\n\tstatic constexpr uint32_t bit_CNXTID      = 0x00000400;\n\tstatic constexpr uint32_t bit_FMA         = 0x00001000;\n\tstatic constexpr uint32_t bit_CMPXCHG16B  = 0x00002000;\n\tstatic constexpr uint32_t bit_xTPR        = 0x00004000;\n\tstatic constexpr uint32_t bit_PDCM        = 0x00008000;\n\tstatic constexpr uint32_t bit_PCID        = 0x00020000;\n\tstatic constexpr uint32_t bit_DCA         = 0x00040000;\n\tstatic constexpr uint32_t bit_SSE41       = 0x00080000;\n\tstatic constexpr uint32_t bit_SSE42       = 0x00100000;\n\tstatic constexpr uint32_t bit_x2APIC      = 0x00200000;\n\tstatic constexpr uint32_t bit_MOVBE       = 0x00400000;\n\tstatic constexpr uint32_t bit_POPCNT      = 0x00800000;\n\tstatic constexpr uint32_t bit_TSCDeadline = 0x01000000;\n\tstatic constexpr uint32_t bit_AESNI       = 0x02000000;\n\tstatic constexpr uint32_t bit_XSAVE       = 0x04000000;\n\tstatic constexpr uint32_t bit_OSXSAVE     = 0x08000000;\n\tstatic constexpr uint32_t bit_AVX         = 0x10000000;\n\tstatic constexpr uint32_t bit_F16C        = 0x20000000;\n\tstatic constexpr uint32_t bit_RDRND       = 0x40000000;\n\n\t/* Features in %edx for leaf 1 */\n\tstatic constexpr uint32_t bit_FPU         = 0x00000001;\n\tstatic constexpr uint32_t bit_VME         = 0x00000002;\n\tstatic constexpr uint32_t bit_DE          = 0x00000004;\n\tstatic constexpr uint32_t bit_PSE         = 0x00000008;\n\tstatic constexpr uint32_t bit_TSC         = 0x00000010;\n\tstatic constexpr uint32_t bit_MSR         = 0x00000020;\n\tstatic constexpr uint32_t bit_PAE         = 0x00000040;\n\tstatic constexpr uint32_t bit_MCE         = 0x00000080;\n\tstatic constexpr uint32_t bit_CX8         = 0x00000100;\n\tstatic constexpr uint32_t bit_APIC        = 0x00000200;\n\tstatic constexpr uint32_t bit_SEP         = 0x00000800;\n\tstatic constexpr uint32_t bit_MTRR        = 0x00001000;\n\tstatic constexpr uint32_t bit_PGE         = 0x00002000;\n\tstatic constexpr uint32_t bit_MCA         = 0x00004000;\n\tstatic constexpr uint32_t bit_CMOV        = 0x00008000;\n\tstatic constexpr uint32_t bit_PAT         = 0x00010000;\n\tstatic constexpr uint32_t bit_PSE36       = 0x00020000;\n\tstatic constexpr uint32_t bit_PSN         = 0x00040000;\n\tstatic constexpr uint32_t bit_CLFSH       = 0x00080000;\n\tstatic constexpr uint32_t bit_DS          = 0x00200000;\n\tstatic constexpr uint32_t bit_ACPI        = 0x00400000;\n\tstatic constexpr uint32_t bit_MMX         = 0x00800000;\n\tstatic constexpr uint32_t bit_FXSR        = 0x01000000;\n\tstatic constexpr uint32_t bit_SSE         = 0x02000000;\n\tstatic constexpr uint32_t bit_SSE2        = 0x04000000;\n\tstatic constexpr uint32_t bit_SS          = 0x08000000;\n\tstatic constexpr uint32_t bit_HTT         = 0x10000000;\n\tstatic constexpr uint32_t bit_TM          = 0x20000000;\n\tstatic constexpr uint32_t bit_PBE         = 0x80000000;\n\n\t/* Features in %ebx for leaf 7 sub-leaf 0 */\n\tstatic constexpr uint32_t bit_FSGSBASE    = 0x00000001;\n\tstatic constexpr uint32_t bit_SGX         = 0x00000004;\n\tstatic constexpr uint32_t bit_BMI         = 0x00000008;\n\tstatic constexpr uint32_t bit_HLE         = 0x00000010;\n\tstatic constexpr uint32_t bit_AVX2        = 0x00000020;\n\tstatic constexpr uint32_t bit_SMEP        = 0x00000080;\n\tstatic constexpr uint32_t bit_BMI2        = 0x00000100;\n\tstatic constexpr uint32_t bit_ENH_MOVSB   = 0x00000200;\n\tstatic constexpr uint32_t bit_RTM         = 0x00000800;\n\tstatic constexpr uint32_t bit_MPX         = 0x00004000;\n\tstatic constexpr uint32_t bit_AVX512F     = 0x00010000;\n\tstatic constexpr uint32_t bit_AVX512DQ    = 0x00020000;\n\tstatic constexpr uint32_t bit_RDSEED      = 0x00040000;\n\tstatic constexpr uint32_t bit_ADX         = 0x00080000;\n\tstatic constexpr uint32_t bit_AVX512IFMA  = 0x00200000;\n\tstatic constexpr uint32_t bit_CLFLUSHOPT  = 0x00800000;\n\tstatic constexpr uint32_t bit_CLWB        = 0x01000000;\n\tstatic constexpr uint32_t bit_AVX512PF    = 0x04000000;\n\tstatic constexpr uint32_t bit_AVX51SER    = 0x08000000;\n\tstatic constexpr uint32_t bit_AVX512CD    = 0x10000000;\n\tstatic constexpr uint32_t bit_SHA         = 0x20000000;\n\tstatic constexpr uint32_t bit_AVX512BW    = 0x40000000;\n\tstatic constexpr uint32_t bit_AVX512VL    = 0x80000000;\n\n\t/* Features in %ecx for leaf 7 sub-leaf 0 */\n\tstatic constexpr uint32_t bit_PREFTCHWT1  = 0x00000001;\n\tstatic constexpr uint32_t bit_AVX512VBMI  = 0x00000002;\n\tstatic constexpr uint32_t bit_PKU         = 0x00000004;\n\tstatic constexpr uint32_t bit_OSPKE       = 0x00000010;\n\tstatic constexpr uint32_t bit_AVX512VPOPCNTDQ  = 0x00004000;\n\tstatic constexpr uint32_t bit_RDPID       = 0x00400000;\n\n\t/* Features in %edx for leaf 7 sub-leaf 0 */\n\tstatic constexpr uint32_t bit_AVX5124VNNIW  = 0x00000004;\n\tstatic constexpr uint32_t bit_AVX5124FMAPS  = 0x00000008;\n\n\t/* Features in %eax for leaf 13 sub-leaf 1 */\n\tstatic constexpr uint32_t bit_XSAVEOPT    = 0x00000001;\n\tstatic constexpr uint32_t bit_XSAVEC      = 0x00000002;\n\tstatic constexpr uint32_t bit_XSAVES      = 0x00000008;\n\n\t/* Features in %ecx for leaf = 0x80000001 */;\n\tstatic constexpr uint32_t bit_LAHF_LM     = 0x00000001;\n\tstatic constexpr uint32_t bit_ABM         = 0x00000020;\n\tstatic constexpr uint32_t bit_SSE4a       = 0x00000040;\n\tstatic constexpr uint32_t bit_PRFCHW      = 0x00000100;\n\tstatic constexpr uint32_t bit_XOP         = 0x00000800;\n\tstatic constexpr uint32_t bit_LWP         = 0x00008000;\n\tstatic constexpr uint32_t bit_FMA4        = 0x00010000;\n\tstatic constexpr uint32_t bit_TBM         = 0x00200000;\n\tstatic constexpr uint32_t bit_MWAITX      = 0x20000000;\n\n\t/* Features in %edx for leaf = 0x80000001 */;\n\tstatic constexpr uint32_t bit_MMXEXT      = 0x00400000;\n\tstatic constexpr uint32_t bit_LM          = 0x20000000;\n\tstatic constexpr uint32_t bit_3DNOWP      = 0x40000000;\n\tstatic constexpr uint32_t bit_3DNOW       = 0x80000000;\n\n\t/* Features in %ebx for leaf = 0x80000001 */;\n\tstatic constexpr uint32_t bit_CLZERO      = 0x00000001;\n\n\t/**\n\t *  Reads CPU information and other data.\n\t */\n\tvoid init();\n\n\t/**\n\t *  Installed CPU information mapping\n\t */\n\tstruct CpuTopology {\n\t\t/**\n\t\t *  Number of physical processors installed\n\t\t */\n\t\tuint8_t packageCount {0};\n\n\t\t/**\n\t\t *  Number of physical cores per package\n\t\t */\n\t\tuint8_t physicalCount[MaxCpus] {};\n\n\t\t/**\n\t\t *  Number of logical cores per package\n\t\t */\n\t\tuint8_t logicalCount[MaxCpus] {};\n\n\t\t/**\n\t\t *  Total number of physical cores\n\t\t */\n\t\tinline uint8_t totalPhysical() {\n\t\t\tuint8_t count = physicalCount[0];\n\t\t\tfor (uint8_t i = 1; i < packageCount; i++)\n\t\t\t\tcount += physicalCount[i];\n\t\t\treturn count;\n\t\t}\n\n\t\t/**\n\t\t *  Total number of logical cores\n\t\t */\n\t\tinline uint8_t totalLogical() {\n\t\t\tuint8_t count = logicalCount[0];\n\t\t\tfor (uint8_t i = 1; i < packageCount; i++)\n\t\t\t\tcount += logicalCount[i];\n\t\t\treturn count;\n\t\t}\n\n\t\t/**\n\t\t *  Mapping of cpu_number() to CPU package from 0 to packageCount\n\t\t */\n\t\tuint8_t numberToPackage[MaxCpus] {};\n\n\t\t/**\n\t\t *  Mapping of cpu_number() to physical core from 0 to physicalCount in package\n\t\t */\n\t\tuint8_t numberToPhysical[MaxCpus] {};\n\n\t\t/**\n\t\t *  Mapping of cpu_number() to physical cores from 0 to totalPhysical.\n\t\t */\n\t\tinline uint8_t numberToPhysicalUnique(uint8_t i) {\n\t\t\tuint8_t num = 0;\n\t\t\tuint8_t package = numberToPackage[i];\n\t\t\tfor (uint8_t i = 0; i < package; i++)\n\t\t\t\tnum += physicalCount[i];\n\t\t\treturn num + numberToPhysical[i];\n\t\t}\n\n\t\t/**\n\t\t *  Mapping of cpu_number() to logical thread from 0 to logicalCount in package\n\t\t *  Note, that the list is sorted, and the first physicalCount logical threads\n\t\t *  correspond to their corresponding physical cores.\n\t\t */\n\t\tuint8_t numberToLogical[MaxCpus] {};\n\t};\n\n\t/**\n\t *  Get running CPU generation.\n\t *\n\t *  @param ofamily    a pointer to store CPU family in\n\t *  @param omodel     a pointer to store CPU model in\n\t *  @param ostepping  a pointer to store CPU stepping in\n\t *\n\t *  @return detected Intel CPU generation\n\t */\n\tEXPORT CpuGeneration getGeneration(uint32_t *ofamily=nullptr, uint32_t *omodel=nullptr, uint32_t *ostepping=nullptr)  DEPRECATE(\"Use BaseDeviceInfo\");;\n\n\t/**\n\t *  Obtain CPU topology.\n\t *\n\t *  @param topology  parsed cpu topology, must be passed zeroed.\n\t *\n\t *  @return true on success\n\t */\n\tEXPORT bool getCpuTopology(CpuTopology &topology);\n\n\t/**\n\t *  Obtain cpuid registers\n\t *\n\t *  @param no     cpuid number\n\t *  @param count  cpuid count\n\t *  @param a      eax output pointer (optional)\n\t *  @param b      ebx output pointer (optional)\n\t *  @param c      ecx output pointer (optional)\n\t *  @param d      edx output pointer (optional)\n\t *\n\t *  @return true if supported\n\t */\n\tEXPORT bool getCpuid(uint32_t no, uint32_t count, uint32_t *a, uint32_t *b=nullptr, uint32_t *c=nullptr, uint32_t *d=nullptr);\n}\n\n#endif /* kern_cpu_h */\n"
  },
  {
    "path": "EFI_DEBUG/EFI/OC/Kexts/Lilu.kext/Contents/Resources/Headers/kern_crypto.hpp",
    "content": "//\n//  kern_crypto.hpp\n//  Lilu\n//\n//  Copyright © 2017 vit9696. All rights reserved.\n//\n\n#ifndef kern_crypto_h\n#define kern_crypto_h\n\n#include <Headers/kern_config.hpp>\n#include <Headers/kern_util.hpp>\n#include <stdint.h>\n\nnamespace Crypto {\n\t/**\n\t *  Currently this is equal to both key size and block size\n\t */\n\tstatic constexpr uint32_t BlockSize = 16;\n\n\t/**\n\t *  Currently this is guaranteed hash size\n\t */\n\tstatic constexpr uint32_t MinDigestSize = 32;\n\n\t/**\n\t *  Encrypted data format\n\t */\n\tstruct PACKED Encrypted {\n\t\tuint8_t iv[BlockSize];                         // Initialisation vector\n\t\tstruct PACKED Data {\n\t\t\tuint32_t size;\t\t\t\t               // Actual encrypted buffer size\n\t\t\tuint8_t buf[BlockSize - sizeof(uint32_t)]; // Encrypted buffer >= BlockSize\n\t\t};\n\n\t\tunion {\n\t\t\tData enc;\n\t\t\tuint8_t buf[BlockSize];\n\t\t};\n\t};\n\n\t/**\n\t *  Securely erase memory buffer\n\t *  Based off cc_clear from corecrypto (src/cc_clear.c)\n\t *\n\t *  @param len buffer length\n\t *  @param dst buffer pointer\n\t */\n\tinline void zeroMemory(size_t len, void *dst) {\n\t\tauto vptr = reinterpret_cast<volatile char *>(dst);\n\t\twhile (len--)\n\t\t\t*vptr++ = '\\0';\n\t}\n\n\t/**\n\t *  Generates cryptographically secure encryption key (from /dev/random)\n\t *\n\t *  @return generated key of at least BlockSize bits long (must be freeded by Buffer::deleter) or nullptr\n\t */\n\tEXPORT uint8_t *genUniqueKey(uint32_t size=BlockSize);\n\n\t/**\n\t *  Encrypts data of specified size and stores in Encrypted format\n\t *\n\t *  @param key  encryption key returned by genUniqueKey\n\t *  @param src  source data\n\t *  @param size data size, encrypted size is returned on success\n\t *\n\t *  @return encrypted data in Encrypted format (must be freed by Buffer::deleter) or nullptr\n\t */\n\tEXPORT uint8_t *encrypt(const uint8_t *key, const uint8_t *src, uint32_t &size);\n\n\t/**\n\t *  Decrypts data of specified size stored in Encrypted format\n\t *\n\t *  @param key  encryption key returned by genUniqueKey\n\t *  @param src  source data\n\t *  @param size data size, decrypted size is returned on success\n\t *\n\t *  @return decrypted data (must be freed by Buffer::deleter) or nullptr\n\t */\n\tEXPORT uint8_t *decrypt(const uint8_t *key, const uint8_t *src, uint32_t &size);\n\n\t/**\n\t *  Calculate digest of given size\n\t *\n\t *  @param src  source data\n\t *  @param size data size\n\t *\n\t *  @return digest hash of at least MinDigestSize bytes (must be freeded by Buffer::deleter) or nullptr\n\t */\n\tEXPORT uint8_t *hash(const uint8_t *src, uint32_t size);\n}\n\n#endif /* kern_crypto_h */\n"
  },
  {
    "path": "EFI_DEBUG/EFI/OC/Kexts/Lilu.kext/Contents/Resources/Headers/kern_devinfo.hpp",
    "content": "//\n//  kern_devinfo.hpp\n//  Lilu\n//\n//  Copyright © 2018-2020 vit9696. All rights reserved.\n//\n\n#ifndef kern_devinfo_h\n#define kern_devinfo_h\n\n#include <Headers/kern_config.hpp>\n#include <Headers/kern_cpu.hpp>\n#include <Headers/kern_iokit.hpp>\n#include <Headers/kern_util.hpp>\n#include <IOKit/IOService.h>\n\n/**\n *  Obtain installed devices split into categories.\n *  Should be used from onPatcherLoad and onwards.\n */\nclass DeviceInfo {\n\t/**\n\t *  Updates reportedLayoutId\n\t */\n\tvoid updateLayoutId();\n\n\t/**\n\t *  Updates reportedFramebufferId\n\t */\n\tvoid updateFramebufferId();\n\n\t/**\n\t *  Obtains devices from PCI root\n\t *\n\t *  @param pciRoot  PCI root instance (commonly PCI0@0 device)\n\t */\n\tvoid grabDevicesFromPciRoot(IORegistryEntry *pciRoot);\n\n\t/**\n\t *  Await for PCI device publishing in IODeviceTree plane\n\t *\n\t *  @param obj  wait for (PCI) object publishing\n\t */\n\tvoid awaitPublishing(IORegistryEntry *obj);\n\t\n\t/**\n\t *  Checks if an ATIAMD object is an AMD iGPU\n\t *\n\t *  @param obj  Object to run the check on.\n\t */\n\tbool checkForAndSetAMDiGPU(IORegistryEntry *obj);\n\npublic:\n\t/**\n\t *  Obtains autodetected legacy framebuffer if applicable\n\t *\n\t *  @return framebuffer or 0xFFFFFFFF\n\t */\n\tstatic uint32_t getLegacyFramebufferId();\n\n\t/**\n\t *  Checks whether the framebuffer has connectors or not.\n\t *\n\t *  @return true if the framebuffer has no connectors\n\t */\n\tstatic bool isConnectorLessPlatformId(uint32_t id);\n\n\t/**\n\t *  Common external GPU parameter list\n\t */\n\tstruct ExternalVideo {\n\t\t/**\n\t\t *  Aka GFX0 device\n\t\t */\n\t\tIORegistryEntry *video {nullptr};\n\n\t\t/**\n\t\t *  Aka HDAU device\n\t\t */\n\t\tIORegistryEntry *audio {nullptr};\n\n\t\t/**\n\t\t *  External GPU vendor\n\t\t */\n\t\tuint32_t vendor {0};\n\t};\n\n\t/**\n\t *  Aka HDEF device\n\t */\n\tIORegistryEntry *audioBuiltinAnalog {nullptr};\n\n\t/**\n\t *  Aka HDAU device for builtin GPU\n\t */\n\tIORegistryEntry *audioBuiltinDigital {nullptr};\n\n\t/**\n\t *  Aka IGPU device\n\t */\n\tIORegistryEntry *videoBuiltin {nullptr};\n\n\t/**\n\t *  Aka IMEI device\n\t */\n\tIORegistryEntry *managementEngine {nullptr};\n\n\t/**\n\t *  Aka GFX0 devices (kept in sync with audioExternal)\n\t */\n\tevector<ExternalVideo&> videoExternal;\n\nprivate:\n\t/**\n\t *  This is the default reported layout-id passed to reportedLayoutId.\n\t *  The reason for choosing 7 is its presence in 10.14 and the fact\n\t *  Apple frameworks still communicate to the files present on disk.\n\t *  For information purposes only! Use reportedLayoutId!\n\t */\n\tstatic constexpr uint32_t DefaultReportedLayoutId = 7;\n\n\t/**\n\t *  The boot-arg to override the reported layout-id to AppleHDA.\n\t *  For user configuration only! Use reportedLayoutId!\n\t */\n\tstatic constexpr const char *ReportedLayoutIdArg = \"alcapplid\";\n\n\t/**\n\t *  The property to override the reported layout-id to AppleHDA.\n\t *  For user configuration only! Use reportedLayoutId!\n\t */\n\tstatic constexpr const char *ReportedLayoutIdName = \"apple-layout-id\";\n\npublic:\n\t/**\n\t *  Layout id to be reported by all audio devices (you must update it yourself).\n\t *  This follows the standard convention initially found in AppleALC:\n\t *\talcapplid=X boot-arg has highest priority and overrides any other value.\n\t *  apple-layout-id HDEF prop has normal priority, you may use it if you need.\n\t *  DefaultReportedLayoutId will be used if both of the above are not set.\n\t */\n\tuint32_t reportedLayoutId {0};\n\nprivate:\n\t/**\n\t *  The boot-arg to override the reported AAPL,ig-platform-id to Intel drivers.\n\t *  For user configuration only! Use reportedFramebufferId!\n\t */\n\tstatic constexpr const char *ReportedFrameIdArg = \"igfxframe\";\n\n\t/**\n\t *  The boot-arg to override the reported AAPL,ig-platform-id to Intel drivers.\n\t *  Sets VESA framebuffer id (0xFFFFFFFF).\n\t *  For user configuration only! Use reportedFramebufferId!\n\t */\n\tstatic constexpr const char *ReportedVesaIdArg = \"-igfxvesa\";\n\n\t/**\n\t *  The boot-arg to force-disable any external GPU if found.\n\t *  For user configuration only! Use requestedExternalSwitchOff!\n\t */\n\tstatic constexpr const char *RequestedExternalSwitchOffArg {\"-wegnoegpu\"};\n\n\t/**\n\t *  The boot-arg to force-disable any internal GPU if found.\n\t *  For user configuration only! Use requestedInternalSwitchOff!\n\t */\n\tstatic constexpr const char *RequestedInternalSwitchOffArg {\"-wegnoigpu\"};\n\n\t/**\n\t *  The boot-arg to force-disable any internal GPU if external GPU found.\n\t *  For user configuration only! Use requestedGpuSwitch!!\n\t */\n\tstatic constexpr const char *RequestedGpuSwitchArg {\"-wegswitchgpu\"};\n\n\t/**\n\t *  The property to set your platform id for Intel drivers (Ivy and newer).\n\t *  For user configuration only! Use reportedFramebufferName!\n\t */\n\tstatic constexpr const char *ReportedFrameIdName = \"AAPL,ig-platform-id\";\n\n\t/**\n\t *  The property to set your platform id for Intel drivers (Sandy).\n\t *  For user configuration only! Use reportedFramebufferName!\n\t */\n\tstatic constexpr const char *ReportedFrameIdLegacyName = \"AAPL,snb-platform-id\";\n\n\t/**\n\t *  The IGPU property to force-disable any external GPU if found.\n\t *  For user configuration only! Use processSwitchOff()!\n\t */\n\tstatic constexpr const char *RequestedExternalSwitchOffName {\"disable-external-gpu\"};\n\n\t/**\n\t *  The IGPU property to force-disable the IGPU if any external GPU is found.\n\t *  For user configuration only! Use processSwitchOff()!\n\t */\n\tstatic constexpr const char *RequestedGpuSwitchName {\"switch-to-external-gpu\"};\n\n\t/**\n\t *  The GPU property to force-disable any external or internal GPU.\n\t *  For user configuration only! Use processSwitchOff()!\n\t */\n\tstatic constexpr const char *RequestedGpuSwitchOffName {\"disable-gpu\"};\n\n\t/**\n\t *  The GPU property to force-disable any this external GPU with minimum kernel version (inclusive).\n\t *  For user configuration only! Use processSwitchOff()!\n\t */\n\tstatic constexpr const char *RequestedGpuSwitchOffMinKernelName {\"disable-gpu-min\"};\n\n\t/**\n\t *  The GPU property to force-disable any this external GPU with maximum kernel version (inclusive).\n\t *  For user configuration only! Use processSwitchOff()!\n\t */\n\tstatic constexpr const char *RequestedGpuSwitchOffMaxKernelName {\"disable-gpu-max\"};\n\n\n\t/**\n\t *  Known platform ids used by Intel GPU kexts\n\t *  For user configuration only!\n\t */\n\tstatic constexpr uint32_t DefaultAppleSkylakePlatformId {0x19120000};\n\tstatic constexpr uint32_t DefaultAppleKabyLakePlatformId {0x59160000};\n\tstatic constexpr uint32_t DefaultAppleCoffeeLakePlatformId {0x3EA50000};\n\tstatic constexpr uint32_t DefaultAppleCannonLakePlatformId {0x5A520000};\n\tstatic constexpr uint32_t DefaultAppleIceLakeRealPlatformId {0x8A520000};\n\tstatic constexpr uint32_t DefaultAppleIceLakeSimulatorPlatformId {0xFF050000};\n\n\t/**\n\t *  Framebuffers without any ports used for hardware acceleration only\n\t *  Note 1: Broadwell framebuffers all have connectors added.\n\t *  Note 2: Coffee Lake framebuffers without connectors are only present in 10.14.\n\t *  Note 3: prerelease Cannon Lake and Ice Lake framebuffers are without connectors.\n\t *  For user configuration only!\n\t */\n\tstatic constexpr uint32_t ConnectorLessSandyBridgePlatformId1 {0x00030030};\n\tstatic constexpr uint32_t ConnectorLessSandyBridgePlatformId2 {0x00050000};\n\tstatic constexpr uint32_t ConnectorLessIvyBridgePlatformId1 {0x01620006};\n\tstatic constexpr uint32_t ConnectorLessIvyBridgePlatformId2 {0x01620007};\n\tstatic constexpr uint32_t ConnectorLessHaswellPlatformId1 {0x04120004};\n\tstatic constexpr uint32_t ConnectorLessHaswellPlatformId2 {0x0412000B};\n\tstatic constexpr uint32_t ConnectorLessSkylakePlatformId1 {0x19020001};\n\tstatic constexpr uint32_t ConnectorLessSkylakePlatformId2 {0x19170001};\n\tstatic constexpr uint32_t ConnectorLessSkylakePlatformId3 {0x19120001};\n\tstatic constexpr uint32_t ConnectorLessSkylakePlatformId4 {0x19320001};\n\tstatic constexpr uint32_t ConnectorLessKabyLakePlatformId1 {0x59180002};\n\tstatic constexpr uint32_t ConnectorLessKabyLakePlatformId2 {0x59120003};\n\tstatic constexpr uint32_t ConnectorLessCoffeeLakePlatformId1 {0x3E920003};\n\tstatic constexpr uint32_t ConnectorLessCoffeeLakePlatformId2 {0x3E910003};\n\tstatic constexpr uint32_t ConnectorLessCoffeeLakePlatformId3 {0x3E980003};\n\tstatic constexpr uint32_t ConnectorLessCoffeeLakePlatformId4 {0x9BC80003};\n\tstatic constexpr uint32_t ConnectorLessCoffeeLakePlatformId5 {0x9BC50003};\n\tstatic constexpr uint32_t ConnectorLessCoffeeLakePlatformId6 {0x9BC40003};\n\n\t/**\n\t * Kaveri, and also catches the new Granite Ridge rDNA 2 iGPU.\n\t */\n\tstatic constexpr uint32_t GenericAMDKvGr = 0x1300;\n\n\t/**\n\t * Kabini, Mullins, Carrizo, Stoney Ridge, Wrestler.\n\t */\n\tstatic constexpr uint32_t GenericAMDKbMlCzStnWr = 0x9800;\n\n\t/**\n\t * Van Gogh's other Device ID, specifically: 0x1435 rev 0xAE.\n\t */\n\tstatic constexpr uint32_t GenericAMDVanGogh2 = 0x1400;\n\n\t/**\n\t * Raven/Raven2, Picasso, Barcelo, Phoenix, Phoenix 2 (possibly Hawk Point)  & Strix (0x150E)\n\t */\n\tstatic constexpr uint32_t GenericAMDRvPcBcPhn = 0x1500;\n\n\t/**\n\t * Renoir, Cezanne, Lucienne, Van Gogh, Rembrandt, Raphael.\n\t */\n\tstatic constexpr uint32_t GenericAMDRnCznLcVghRmbRph = 0x1600;\n\n\t/**\n\t * Trinity\n\t */\n\tstatic constexpr uint32_t GenericAMDTrinity = 0x9900;\n\n\t/**\n\t * Sumo & Sumo2?\n\t */\n\tstatic constexpr uint32_t GenericAMDSumo = 0x9600;\n\n\t/**\n\t * Phoenix.\n\t */\n\tstatic constexpr uint32_t GenericAMDPhoenix2 = 0x1900;\n\npublic:\n\t/**\n\t *  Vesa framebuffer identifier\n\t */\n\tstatic constexpr uint32_t DefaultVesaPlatformId {0xFFFFFFFF};\n\n\t/**\n\t *  Framebuffer id to be reported to IGPU.\n\t *  This follows the standard convention initially found in IntelGraphicsFixup:\n\t *  igfxframe=X boot-arg has highest priority and overrides any other value.\n\t *  -igfxvesa forces 0xFFFFFFFF frame to get into VESA mode.\n\t *  Manually specified AAPL,ig-platform-id or AAPL,snb-platform-id go next.\n\t *  On Sandy Bridge processors a default AAPL,snb-platform-id will be tried afterwards.\n\t *  On Skylake and Kaby Lake processors some default id will be tried afterwards.\n\t */\n\tuint32_t reportedFramebufferId {0};\n\n\t/**\n\t *  Compatible platform id property name for this IGPU\n\t */\n\tconst char *reportedFramebufferName {nullptr};\n\n\t/**\n\t *  Set to true if the framebuffer has no connectors\n\t */\n\tbool reportedFramebufferIsConnectorLess {false};\n\n\t/**\n\t *  Known variants of firmware vendors\n\t *  Please note, that it may not be possible to always detect the right vendor\n\t */\n\tenum class FirmwareVendor {\n\t\tUnknown,\n\t\tApple,\n\t\tVMware,\n\t\tEDKII,\n\t\tParallels,\n\t\tAMI,\n\t\tInsyde,\n\t\tPhoenix,\n\t\tHP\n\t};\n\n\t/**\n\t *  Firmware vendor manufacturer\n\t */\n\tFirmwareVendor firmwareVendor {FirmwareVendor::Unknown};\n\n\t/**\n\t *  Requested external GPU switchoff\n\t */\n\tbool requestedExternalSwitchOff {false};\n\n\t/**\n\t *  Requested internal GPU switchoff\n\t */\n\tbool requestedInternalSwitchOff {false};\n\n\t/**\n\t *  Requested GPU switch\n\t */\n\tbool requestedGpuSwitch {false};\n\t/**\n\t *  Allocate and initialise cached device list.\n\t *\n\t *  @return device list or nullptr\n\t */\n\tstatic DeviceInfo *createCached();\n\n\t/**\n\t *  Allocate and initialise the device list.\n\t *\n\t *  @return device list or nullptr\n\t */\n\tEXPORT static DeviceInfo *create();\n\n\t/**\n\t *  Release initialised device list.\n\t *\n\t *  @param d  device list\n\t */\n\tEXPORT static void deleter(DeviceInfo *d NONNULL);\n\n\t/**\n\t *  Perform device switch-off as prescribed by the properties injected.\n\t */\n\tEXPORT void processSwitchOff();\n};\n\n/**\n *  Simple device information available at early stage.\n */\nclass BaseDeviceInfo {\n\t/**\n\t *  Updates firmwareVendor\n\t */\n\tvoid updateFirmwareVendor();\n\n\t/**\n\t *  Updates model information\n\t */\n\tvoid updateModelInfo();\npublic:\n\t/**\n\t *  Board identifier board-id (VMware has \"440BX Desktop Reference Platform\", eek)\n\t */\n\tchar boardIdentifier[48] {};\n\n\t/**\n\t *  Model identifier\n\t */\n\tchar modelIdentifier[48] {};\n\n\t/**\n\t * Computer model type.\n\t */\n\tint modelType {WIOKit::ComputerModel::ComputerAny};\n\n\t/**\n\t *  Firmware vendor manufacturer\n\t */\n\tDeviceInfo::FirmwareVendor firmwareVendor {DeviceInfo::FirmwareVendor::Unknown};\n\n\t/**\n\t *  Known variants of bootloader vendors\n\t *  Please note, that it may not be possible to always detect the right vendor\n\t */\n\tenum class BootloaderVendor {\n\t\tUnknown,\n\t\tAcidanthera,\n\t\tClover\n\t};\n\n\t/**\n\t *  Bootloader vendor\n\t */\n\tBootloaderVendor bootloaderVendor {BootloaderVendor::Unknown};\n\n\t/**\n\t *  CPU vendor\n\t */\n\tCPUInfo::CpuVendor cpuVendor {CPUInfo::CpuVendor::Unknown};\n\n\t/**\n\t *  CPU generation\n\t */\n\tCPUInfo::CpuGeneration cpuGeneration {CPUInfo::CpuGeneration::Unknown};\n\n\t/**\n\t *  CPU family\n\t */\n\tuint32_t cpuFamily {};\n\n\t/**\n\t *  CPU model\n\t */\n\tuint32_t cpuModel {};\n\n\t/**\n\t *  CPU stepping\n\t */\n\tuint32_t cpuStepping {};\n\n\t/**\n\t *  CPU max level\n\t */\n\tuint32_t cpuMaxLevel {};\n\n\t/**\n\t *  CPU max level (ext)\n\t */\n\tuint32_t cpuMaxLevelExt {0x80000000};\n\n\t/**\n\t *  AVX 2.0 support\n\t */\n\tbool cpuHasAvx2 {false};\n\n\t/**\n\t *  Obtain base device info.\n\t */\n\tEXPORT static const BaseDeviceInfo &get();\n\n\t/**\n\t *  Initialize global base device info.\n\t */\n\tstatic void init();\n};\n\n#endif /* kern_devinfo_h */\n"
  },
  {
    "path": "EFI_DEBUG/EFI/OC/Kexts/Lilu.kext/Contents/Resources/Headers/kern_disasm.hpp",
    "content": "//\n//  kern_disasm.hpp\n//  Lilu\n//\n//  Copyright © 2016-2017 vit9696. All rights reserved.\n//\n\n#ifndef kern_disasm_hpp\n#define kern_disasm_hpp\n\n#include <Headers/kern_config.hpp>\n#include <Headers/kern_util.hpp>\n\n#if defined(__i386__)\n#include <Headers/hde32.h>\n#elif defined(__x86_64__)\n#include <Headers/hde64.h>\n#else\n#error Unsupported arch.\n#endif\n\n#ifdef LILU_ADVANCED_DISASSEMBLY\n#ifndef CAPSTONE_HAS_OSXKERNEL\n#define CAPSTONE_HAS_OSXKERNEL 1\n#endif\n#include <Headers/capstone/capstone.h>\n#endif /* LILU_ADVANCED_DISASSEMBLY */\n\n#include <sys/types.h>\n#include <mach/vm_types.h>\n\nclass Disassembler {\n#ifdef LILU_ADVANCED_DISASSEMBLY\n\t/**\n\t *  Because captsone handle can be 0\n\t */\n\tbool initialised {false};\n\n\t/**\n\t *  Internal capstone handle\n\t */\n\tsize_t handle {};\n#endif\n\n\t/**\n\t *  Max instruction size\n\t */\n\tstatic constexpr size_t MaxInstruction {15};\npublic:\n\n#if defined(__i386__)\n\tusing hde_t = hde32s;\n\tstatic constexpr auto hde_disasm = hde32_disasm;\n#elif defined(__x86_64__)\n\tusing hde_t = hde64s;\n\tstatic constexpr auto hde_disasm = hde64_disasm;\n#else\n#error Unsupported arch.\n#endif\n\n\t/**\n\t *  Return the real instruction size contained within min bytes\n\t *  Unlike instructionSize this uses HDE engine and at the cost of reduced compatibility it is much faster\n\t *  Note: instruction pointer should point to at least min + 32 valid bytes.\n\t *\n\t *  @param ptr instruction pointer\n\t *  @param min minimal possible size\n\t *\n\t *  @return instruction size >= min on success or 0\n\t */\n\tEXPORT static size_t quickInstructionSize(mach_vm_address_t ptr, size_t min);\n\n\t/* Note, code should point to at least 32 valid bytes. */\n\tEXPORT static size_t hdeDisasm(mach_vm_address_t code, hde_t *hs);\n\n#ifdef LILU_ADVANCED_DISASSEMBLY\n\n\t/**\n\t *  Initialise advanced dissassembling framework\n\t *\n\t *  @param detailed  debugging output necessity\n\t *\n\t *  @return true on success\n\t */\n\tEXPORT bool init(bool detailed=false);\n\n\t/**\n\t *  Deinitialise advanced dissassembling framework, must be called regardless of the init error\n\t */\n\tEXPORT void deinit();\n\n\t/**\n\t *  Reads size bytes from addr and disassembles them.\n\t *\n\t *  @param addr        Address to read from\n\t *  @param size        Size of buffer to read\n\t *  @param result      Disassembled instructions array. You must free it\n\t *\n\t *  @return size of result\n\t */\n\tEXPORT size_t disasmBuf(mach_vm_address_t addr, size_t size, cs_insn **result);\n\n\t/**\n\t *  Return the real instruction size contained within min bytes\n\t *\n\t *  @param ptr instruction pointer\n\t *  @param min minimal possible size\n\t *\n\t *  @return instruction size >= min on success or 0\n\t */\n\tEXPORT size_t instructionSize(mach_vm_address_t ptr, size_t min);\n\n\t/**\n\t *  Reads lookup_size bytes from addr and disassembles them.\n\t *  After disassembling, tries to find num-th entry with call instruction, which argument is an immediate value (some address).\n\t *\n\t *  @param addr        Address to read from\n\t *  @param num         Number of call instruction to search for\n\t *  @param lookup_size Number of bytes to read\n\t *\n\t *  @note It is assumed that the operand contains a positive relative address.\n\t *\n\t *  @return direct address of num-th call instruction on success, else 0\n\t */\n\tEXPORT mach_vm_address_t disasmNthSub(mach_vm_address_t addr, size_t num, size_t lookup_size);\n\n\t/**\n\t *  @brief  Reads lookup_size bytes from addr and disassembles them.\n\t *\n\t *  After disassembling, tries to find num-th entry with jmp instruction, which argument is an immediate value (some address).\n\t *\n\t *  @param addr        Address to read from\n\t *  @param num         Number of jmp instruction to search for\n\t *  @param lookup_size Number of bytes to read\n\t *\n\t *  @note It is assumed that the operand contains a positive relative address.\n\t *\n\t *  @return direct address of num-th jmp instruction on success, else 0\n\t */\n\tEXPORT mach_vm_address_t disasmNthJmp(mach_vm_address_t addr, size_t num, size_t lookup_size);\n\n\t/**\n\t *  Reads lookup_size bytes from addr and disassembles them.\n\t *  After disassembling, tries to find num-th entry of inst instruction.\n\t *\n\t *  @param addr        Addres to read from\n\t *  @param ins         Instruction code\n\t *  @param num         Number of ins instruction to search for\n\t *  @param lookup_size Number of bytes to read\n\t *\n\t *  @return address of found instruction on success, else 0\n\t */\n\tEXPORT mach_vm_address_t disasmNthIns(mach_vm_address_t addr, x86_insn ins, size_t num, size_t lookup_size);\n\n\t/**\n\t *  Disassembly matching structure\n\t */\n\tstruct DisasmSig {\n\t\tx86_insn ins;       // instruction\n\t\tbool sub;           // relevant only for X86_INS_CALL, if its arg is X86_OP_IMM\n\t\tbool addr;          // if you want to return the address of exact inst in sig\n\n\t\tstatic DisasmSig *create() { return new DisasmSig; }\n\t\tstatic void deleter(DisasmSig *sig NONNULL) { delete sig; }\n\t};\n\n\t/**\n\t *  Reads lookup_size bytes from addr and disassembles them.\n\t *  After disassembling, tries to find num-th entry of sig instruction pattern.\n\t *\n\t *  @param addr        Address to read from\n\t *  @param sig         Instruction pattern\n\t *  @param num         Order of pattern to search for\n\t *  @param lookup_size Number of bytes to read\n\t *\n\t *  @return direct address of pattern start on success, else 0\n\t */\n\tEXPORT mach_vm_address_t disasmSig(mach_vm_address_t addr, evector<DisasmSig *, DisasmSig::deleter> &sig, size_t num, size_t lookup_size);\n\n#endif /* LILU_ADVANCED_DISASSEMBLY */\n};\n\n#endif /* kern_disasm_hpp */\n"
  },
  {
    "path": "EFI_DEBUG/EFI/OC/Kexts/Lilu.kext/Contents/Resources/Headers/kern_efi.hpp",
    "content": "//\n//  kern_efi.hpp\n//  Lilu\n//\n//  Copyright © 2018 vit9696. All rights reserved.\n//\n\n#ifndef kern_efi_h\n#define kern_efi_h\n\n#include <Headers/kern_util.hpp>\n\n#include <pexpert/i386/efi.h>\n\n/**\n *  Convert 32-bit EFI errors provided by Apple to 64-bit EFI errors\n */\n#define EFI_ERROR64(x) (((x) & ~(1ULL << 31)) | (1ULL << 63))\nstatic_assert(EFI_LOAD_ERROR == 0x80000001 && EFI_ERROR64(EFI_LOAD_ERROR) == 0x8000000000000001,\n\t\"Apple has finally upgraded EFI headers!\");\n\nclass EfiRuntimeServices {\n\tIOLock *accessLock {nullptr};\n\tstatic EfiRuntimeServices *instance;\nprivate:\n\tbool is32BitEFI {false};\n\tvoid *efiRuntimeServices {nullptr};\n\t\n\t/**\n\t *  Set EFI runtime services table pointer\n\t */\n\tvoid setRuntimeServices();\n\t\npublic:\n\t/**\n\t *  Activates EFI Runtime Services\n\t */\n\tstatic void activate();\n\n\t/**\n\t *  Lilu custom GUIDs exports, see OcSupportPkg/Include/Guid/OcVariables.h\n\t */\n\tEXPORT static const EFI_GUID LiluVendorGuid;\n\tEXPORT static const EFI_GUID LiluReadOnlyGuid;\n\tEXPORT static const EFI_GUID LiluWriteOnlyGuid;\n\n\t/**\n\t *  Get EFI Runtime Services wrapper if supported\n\t *\n\t *  @param lock  lock instance during the run, must be put back\n\t *\n\t *  @return wrapper instance\n\t */\n\tEXPORT static EfiRuntimeServices *get(bool lock=false);\n\n\t/**\n\t *  Put EFI Runtime Services wrapper to unlock\n\t */\n\tEXPORT void put();\n\n\t/**\n\t *  Perform system reset (does not return on success)\n\t *\n\t *  @param type reset type\n\t */\n\tEXPORT void resetSystem(EFI_RESET_TYPE type);\n\n\t/**\n\t *  Obtain EFI variable, invokes EFI_RUNTIME_SERVICES::GetVariable.\n\t *\n\t *  @param name  variable name\n\t *  @param guid  vendor guid\n\t *  @param attr  variable attributes\n\t *  @param size  data buffer size updated on read\n\t *  @param data  read data\n\t *\n\t *  @return EFI_STATUS code\n\t */\n\tEXPORT uint64_t getVariable(const char16_t *name, const EFI_GUID *guid, uint32_t *attr, uint64_t *size, void *data);\n\n\t/**\n\t *  Set EFI variable, invokes EFI_RUNTIME_SERVICES::SetVariable.\n\t *\n\t *  @param name  variable name\n\t *  @param guid  vendor guid\n\t *  @param attr  variable attributes\n\t *  @param size  data buffer size\n\t *  @param data  data to write\n\t *\n\t *  @return EFI_STATUS code\n\t */\n\tEXPORT uint64_t setVariable(const char16_t *name, const EFI_GUID *guid, uint32_t attr, uint64_t size, void *data);\n};\n\n#endif /* kern_efi_h */\n"
  },
  {
    "path": "EFI_DEBUG/EFI/OC/Kexts/Lilu.kext/Contents/Resources/Headers/kern_file.hpp",
    "content": "//\n//  kern_file.hpp\n//  Lilu\n//\n//  Copyright © 2016-2017 vit9696. All rights reserved.\n//\n\n#ifndef kern_file_hpp\n#define kern_file_hpp\n\n#include <Headers/kern_config.hpp>\n#include <Headers/kern_util.hpp>\n\n#include <sys/kernel_types.h>\n#include <sys/fcntl.h>\n\nnamespace FileIO {\n\t/**\n\t *  Reads file data at path\n\t *\n\t *  @param path full file path\n\t *  @param size bytes read\n\t *\n\t *  @return allocated buffer on success or nullptr on error\n\t */\n\tEXPORT uint8_t *readFileToBuffer(const char *path, size_t &size);\n\n\t/**\n\t *  Read file data from a vnode\n\t *\n\t *  @param buffer output buffer\n\t *  @param off    file offset\n\t *  @param sz     bytes to read\n\t *  @param vnode  file node\n\t *  @param ctxt   filesystem context\n\t *\n\t *  @return 0 on success\n\t */\n\tEXPORT int readFileData(void *buffer, off_t off, size_t sz, vnode_t vnode, vfs_context_t ctxt);\n\n\t/**\n\t *  Read file size from a vnode\n\t *\n\t *  @param vnode file node\n\t *  @param ctxt  filesystem context\n\t *\n\t *  @return file size or 0\n\t */\n\tEXPORT size_t readFileSize(vnode_t vnode, vfs_context_t ctxt);\n\n\t/**\n\t *  Writes buffer to a file at path\n\t *\n\t *  @param path   full file path\n\t *  @param buffer input buffer\n\t *  @param size   bytes write\n\t *  @param fmode  file opening mode\n\t *  @param cmode  file permissions\n\t *\n\t *  @return 0 on success\n\t */\n\tEXPORT int writeBufferToFile(const char *path, void *buffer, size_t size, int fmode=O_TRUNC | O_CREAT | FWRITE | O_NOFOLLOW, int cmode=S_IRUSR | S_IWUSR | S_IRGRP | S_IWGRP | S_IROTH | S_IWOTH);\n\n\t/**\n\t *  Write file data to a vnode\n\t *\n\t *  @param buffer input buffer\n\t *  @param off    file offset\n\t *  @param size   bytes to write\n\t *  @param vnode  file node\n\t *  @param ctxt   filesystem context\n\t *\n\t *  @return 0 on success\n\t */\n\tEXPORT int writeFileData(void *buffer, off_t off, size_t size, vnode_t vnode, vfs_context_t ctxt);\n\n\t/**\n\t *  Perform file i/o through a vnode\n\t *\n\t *  @param buffer input buffer\n\t *  @param off    file offset\n\t *  @param size   bytes to write\n\t *  @param vnode  file node\n\t *  @param ctxt   filesystem context\n\t *  @param write  write to buffer otherwise read\n\t *\n\t *  @return 0 on success\n\t */\n\tint performFileIO(void *buffer, off_t off, size_t size, vnode_t vnode, vfs_context_t ctxt, bool write);\n}\n\n#endif /* kern_file_hpp */\n"
  },
  {
    "path": "EFI_DEBUG/EFI/OC/Kexts/Lilu.kext/Contents/Resources/Headers/kern_iokit.hpp",
    "content": "//\n//  kern_iokit.hpp\n//  Lilu\n//\n//  Copyright © 2016-2017 vit9696. All rights reserved.\n//\n\n#ifndef kern_iokit_hpp\n#define kern_iokit_hpp\n\n#include <Headers/kern_config.hpp>\n#include <Headers/kern_util.hpp>\n#include <Headers/kern_patcher.hpp>\n\n#include <libkern/c++/OSSerialize.h>\n#include <IOKit/IORegistryEntry.h>\n\nnamespace WIOKit {\n\n\t/**\n\t *  AppleHDAEngine::getLocation teaches us to use loop infinitely when talking to IOReg\n\t *  This feels mad and insane, since it may prevent the system from booting.\n\t *  Although this had never happened, we will use a far bigger fail-safe stop value.\n\t */\n\tstatic constexpr size_t bruteMax {40000000};\n\n\t/**\n\t *  Read typed OSData\n\t *\n\t *  @param obj    read object\n\t *  @param value  read value\n\t *  @param name   propert name\n\t *\n\t *  @return true on success\n\t */\n\ttemplate <typename T>\n\tinline bool getOSDataValue(const OSObject *obj, const char *name, T &value) {\n\t\tif (obj) {\n\t\t\tauto data = OSDynamicCast(OSData, obj);\n\t\t\tif (data && data->getLength() == sizeof(T)) {\n\t\t\t\tvalue = *static_cast<const T *>(data->getBytesNoCopy());\n\t\t\t\tDBGLOG(\"iokit\", \"getOSData %s has %llX value\", name, static_cast<uint64_t>(value));\n\t\t\t\treturn true;\n\t\t\t} else {\n\t\t\t\tSYSLOG(\"iokit\", \"getOSData %s has unexpected format\", name);\n\t\t\t}\n\t\t} else {\n\t\t\tDBGLOG(\"iokit\", \"getOSData %s was not found\", name);\n\t\t}\n\t\treturn false;\n\t}\n\n\t/**\n\t *  Read typed OSData through a temp type\n\t *\n\t *  @param obj    read object\n\t *  @param value  read value\n\t *  @param name   propert name\n\t *\n\t *  @return true on success\n\t */\n\ttemplate <typename AS, typename T>\n\tinline bool getOSDataValue(const OSObject *obj, const char *name, T &value) {\n\t\tAS tmp;\n\t\tif (getOSDataValue(obj, name, tmp)) {\n\t\t\tvalue = static_cast<T>(tmp);\n\t\t\treturn true;\n\t\t}\n\n\t\treturn false;\n\t}\n\n\t/**\n\t *  Read typed OSData from IORegistryEntry\n\t *\n\t *  @see getOSDataValue\n\t */\n\ttemplate <typename T>\n\tinline bool getOSDataValue(const IORegistryEntry *sect, const char *name, T &value) {\n\t\treturn getOSDataValue(sect->getProperty(name), name, value);\n\t}\n\n\t/**\n\t *  Read typed OSData from IORegistryEntry\n\t *\n\t *  @see getOSDataValue\n\t */\n\ttemplate <typename AS, typename T>\n\tinline bool getOSDataValue(const IORegistryEntry *sect, const char *name, T &value) {\n\t\treturn getOSDataValue<AS>(sect->getProperty(name), name, value);\n\t}\n\n\t/**\n\t *  Read typed OSData from IORegistryEntry\n\t *\n\t *  @see getOSDataValue\n\t */\n\ttemplate <typename T>\n\tinline bool getOSDataValue(const OSDictionary *dict, const char *name, T &value) {\n\t\treturn getOSDataValue(dict->getObject(name), name, value);\n\t}\n\n\t/**\n\t *  Read typed OSData from IORegistryEntry\n\t *\n\t *  @see getOSDataValue\n\t */\n\ttemplate <typename AS, typename T>\n\tinline bool getOSDataValue(const OSDictionary *dict, const char *name, T &value) {\n\t\treturn getOSDataValue<AS>(dict->getObject(name), name, value);\n\t}\n\n\t/**\n\t *  Retrieve property object\n\t *\n\t *  @param entry    IORegistry entry\n\t *  @param property property name\n\t *\n\t *  @return property object (must be released) or nullptr\n\t */\n\tEXPORT LIBKERN_RETURNS_RETAINED OSSerialize *getProperty(IORegistryEntry *entry, const char *property);\n\n\t/**\n\t *  Model variants\n\t */\n\tstruct ComputerModel {\n\t\tenum {\n\t\t\tComputerInvalid = 0x0,\n\t\t\tComputerLaptop  = 0x1,\n\t\t\tComputerDesktop = 0x2,\n\t\t\tComputerAny = ComputerLaptop | ComputerDesktop\n\t\t};\n\t};\n\n\t/**\n\t *  PCI GPU Vendor identifiers\n\t */\n\tstruct VendorID {\n\t\tenum : uint16_t {\n\t\t\tATIAMD = 0x1002,\n\t\t\tAMDZEN = 0x1022,\n\t\t\tNVIDIA = 0x10DE,\n\t\t\tIntel  = 0x8086,\n\t\t\tVMware = 0x15AD,\n\t\t\tQEMU   = 0x1B36,\n\t\t};\n\t};\n\n\t/**\n\t *  PCI class codes\n\t */\n\tstruct ClassCode {\n\t\tenum : uint32_t {\n\t\t\tVGAController     = 0x030000,\n\t\t\t// I have never seen this one, but laptops are evil.\n\t\t\tXGAController     = 0x030100,\n\t\t\t// Some laptops use this for Optimus GPUs.\n\t\t\tEx3DController    = 0x030200,\n\t\t\tDisplayController = 0x038000,\n\t\t\tPCIBridge         = 0x060400,\n\t\t\t// HDA device on some laptops like Acer Aspire VN7-592G (INSYDE).\n\t\t\tHDAMmDevice       = 0x040100,\n\t\t\t// Watch out for PCISubclassMask, 0x040380 is common on laptops.\n\t\t\tHDADevice         = 0x040300,\n\t\t\t// This does not seem to be documented. It works on Haswell at least.\n\t\t\tIMEI              = 0x078000,\n\t\t\t// To ignore device subclasses.\n\t\t\tPCISubclassMask   = 0xFFFF00,\n\t\t};\n\t};\n\n\t/**\n\t *  Definitions of PCI Config Registers\n\t */\n\tenum PCIRegister : uint8_t {\n\t\tkIOPCIConfigVendorID                = 0x00,\n\t\tkIOPCIConfigDeviceID                = 0x02,\n\t\tkIOPCIConfigCommand                 = 0x04,\n\t\tkIOPCIConfigStatus                  = 0x06,\n\t\tkIOPCIConfigRevisionID              = 0x08,\n\t\tkIOPCIConfigClassCode               = 0x09,\n\t\tkIOPCIConfigCacheLineSize           = 0x0C,\n\t\tkIOPCIConfigLatencyTimer            = 0x0D,\n\t\tkIOPCIConfigHeaderType              = 0x0E,\n\t\tkIOPCIConfigBIST                    = 0x0F,\n\t\tkIOPCIConfigBaseAddress0            = 0x10,\n\t\tkIOPCIConfigBaseAddress1            = 0x14,\n\t\tkIOPCIConfigBaseAddress2            = 0x18,\n\t\tkIOPCIConfigBaseAddress3            = 0x1C,\n\t\tkIOPCIConfigBaseAddress4            = 0x20,\n\t\tkIOPCIConfigBaseAddress5            = 0x24,\n\t\tkIOPCIConfigCardBusCISPtr           = 0x28,\n\t\tkIOPCIConfigSubSystemVendorID       = 0x2C,\n\t\tkIOPCIConfigSubSystemID             = 0x2E,\n\t\tkIOPCIConfigExpansionROMBase        = 0x30,\n\t\tkIOPCIConfigCapabilitiesPtr         = 0x34,\n\t\tkIOPCIConfigInterruptLine           = 0x3C,\n\t\tkIOPCIConfigInterruptPin            = 0x3D,\n\t\tkIOPCIConfigMinimumGrant            = 0x3E,\n\t\tkIOPCIConfigMaximumLatency          = 0x3F,\n\t\tkIOPCIConfigGraphicsControl         = 0x50\n\t};\n\n\t/**\n\t *  Fixed offsets for PCI Config I/O virtual methods\n\t */\n\tstruct PCIConfigOffset {\n\t\tenum : size_t {\n\t\t\tConfigRead32      = 0x10A,\n\t\t\tConfigWrite32     = 0x10B,\n\t\t\tConfigRead16      = 0x10C,\n\t\t\tConfigWrite16     = 0x10D,\n\t\t\tConfigRead8       = 0x10E,\n\t\t\tConfigWrite8      = 0x10F,\n\t\t\tGetBusNumber      = 0x11D,\n\t\t\tGetDeviceNumber   = 0x11E,\n\t\t\tGetFunctionNumber = 0x11F\n\t\t};\n\t};\n\n\t/**\n\t *  PCI Config I/O method prototypes\n\t */\n\tusing t_PCIConfigRead32 = uint32_t (*)(IORegistryEntry *service, uint32_t space, uint8_t offset);\n\tusing t_PCIConfigRead16 = uint16_t (*)(IORegistryEntry *service, uint32_t space, uint8_t offset);\n\tusing t_PCIConfigRead8  = uint8_t  (*)(IORegistryEntry *service, uint32_t space, uint8_t offset);\n\tusing t_PCIConfigWrite32 = void (*)(IORegistryEntry *service, uint32_t space, uint8_t offset, uint32_t data);\n\tusing t_PCIConfigWrite16 = void (*)(IORegistryEntry *service, uint32_t space, uint8_t offset, uint16_t data);\n\tusing t_PCIConfigWrite8  = void (*)(IORegistryEntry *service, uint32_t space, uint8_t offset, uint8_t data);\n\tusing t_PCIGetBusNumber = uint8_t (*)(IORegistryEntry *service);\n\tusing t_PCIGetDeviceNumber = uint8_t (*)(IORegistryEntry *service);\n\tusing t_PCIGetFunctionNumber = uint8_t (*)(IORegistryEntry *service);\n\n\t/**\n\t *  Await for device publishing in IOService plane\n\t *\n\t *  @param obj  wait for (PCI) object publishing\n\t *\n\t *  @retval true on success\n\t */\n\tEXPORT bool awaitPublishing(IORegistryEntry *obj);\n\n\t/**\n\t *  Read PCI Config register\n\t *\n\t *  @param service  IOPCIDevice-compatible service.\n\t *  @param reg      PCI config register\n\t *  @param space    adress space\n\t *  @param size     read size for reading custom registers\n\t *\n\t *  @return value read\n\t */\n\tEXPORT uint32_t readPCIConfigValue(IORegistryEntry *service, uint32_t reg, uint32_t space = 0, uint32_t size = 0);\n\n\t/**\n\t *  Retrieve PCI device address\n\t *\n\t *  @param service   IOPCIDevice-compatible service.\n\t *  @param bus       bus address\n\t *  @param device    device address\n\t *  @param function  function address\n\t */\n\tEXPORT void getDeviceAddress(IORegistryEntry *service, uint8_t &bus, uint8_t &device, uint8_t &function);\n\n\t/**\n\t *  Retrieve the computer type\n\t *\n\t *  @return valid computer type or ComputerAny\n\t */\n\tEXPORT int getComputerModel() DEPRECATE(\"Use BaseDeviceInfo\");\n\n\t/**\n\t *  Retrieve computer model and/or board-id properties\n\t *\n\t *  @param model    model name output buffer or null\n\t *  @param modelsz  model name output buffer size\n\t *  @param board    board identifier output buffer or null\n\t *  @param boardsz  board identifier output buffer size\n\t *\n\t *  @return true if relevant properties already are available, otherwise buffers are unchanged\n\t */\n\tEXPORT bool getComputerInfo(char *model, size_t modelsz, char *board, size_t boardsz) DEPRECATE(\"Use BaseDeviceInfo\");\n\n\t/**\n\t *  Retrieve an ioreg entry by path/prefix\n\t *\n\t *  @param path    an exact lookup path\n\t *  @param prefix  entry prefix at path\n\t *  @param plane   plane to lookup in\n\t *  @param proc    process every found entry with the method\n\t *  @param brute   kick ioreg until a value is found\n\t *  @param user    pass some value to the callback function\n\t *\n\t *  @return entry pointer (must NOT be released) or nullptr (on failure or in proc mode)\n\t */\n\tEXPORT LIBKERN_RETURNS_NOT_RETAINED IORegistryEntry *findEntryByPrefix(const char *path, const char *prefix, const IORegistryPlane *plane, bool (*proc)(void *, IORegistryEntry *)=nullptr, bool brute=false, void *user=nullptr);\n\n\t/**\n\t *  Retrieve an ioreg entry by path/prefix\n\t *\n\t *  @param entry   an ioreg entry to look in\n\t *  @param prefix  entry prefix at path\n\t *  @param plane   plane to lookup in\n\t *  @param proc    process every found entry with the method\n\t *  @param brute   kick ioreg until a value is found\n\t *  @param user    pass some value to the callback function\n\t *\n\t *  @return entry pointer (must NOT be released) or nullptr (on failure or in proc mode)\n\t */\n\tEXPORT LIBKERN_RETURNS_NOT_RETAINED IORegistryEntry *findEntryByPrefix(IORegistryEntry *entry, const char *prefix, const IORegistryPlane *plane, bool (*proc)(void *, IORegistryEntry *)=nullptr, bool brute=false, void *user=nullptr);\n\n\t/**\n\t *  Check if we are using prelinked kernel/kexts or not\n\t *\n\t *  @return true when confirmed that we definitely are\n\t */\n\tEXPORT bool usingPrelinkedCache();\n\n\t/**\n\t *  Properly rename the device\n\t *\n\t *  @param  entry   device to rename\n\t *  @param  name    new name\n\t *  @param  compat  correct compatible\n\t *\n\t *  @return true on success\n\t */\n\tEXPORT bool renameDevice(IORegistryEntry *entry, const char *name, bool compat=true);\n}\n\n#endif /* kern_iokit_hpp */\n"
  },
  {
    "path": "EFI_DEBUG/EFI/OC/Kexts/Lilu.kext/Contents/Resources/Headers/kern_mach.hpp",
    "content": "//\n//  kern_mach.hpp\n//  Lilu\n//\n//  Certain parts of code are the subject of\n//   copyright © 2011, 2012, 2013, 2014 fG!, reverser@put.as - http://reverse.put.as\n//  Copyright © 2016-2017 vit9696. All rights reserved.\n//\n\n#ifndef kern_mach_hpp\n#define kern_mach_hpp\n\n#include <Headers/kern_config.hpp>\n#include <Headers/kern_util.hpp>\n\n#include <sys/time.h>\n#include <sys/types.h>\n#include <sys/vnode.h>\n#include <mach-o/loader.h>\n#include <mach/vm_param.h>\n#include <libkern/c++/OSDictionary.h>\n\nclass MachInfo {\n#if defined(__i386__)\n\tusing mach_header_native = mach_header;\n\tusing segment_command_native = segment_command;\n\tusing nlist_native = struct nlist;\n\t\n\tstatic constexpr uint8_t SegmentTypeNative {LC_SEGMENT};\n\tstatic constexpr uint32_t MachMagicNative {MH_MAGIC};\n\tstatic constexpr uint32_t MachCpuTypeNative {CPU_TYPE_I386};\n\n#elif defined(__x86_64__)\n\tusing mach_header_native = mach_header_64;\n\tusing segment_command_native = segment_command_64;\n\tusing nlist_native = struct nlist_64;\n\t\n\tstatic constexpr uint8_t SegmentTypeNative {LC_SEGMENT_64};\n\tstatic constexpr uint32_t MachMagicNative {MH_MAGIC_64};\n\tstatic constexpr uint32_t MachCpuTypeNative {CPU_TYPE_X86_64};\n\n#else\n#error Unsupported arch.\n#endif\n\t\n\tmach_vm_address_t running_text_addr {0}; // the address of running __TEXT segment\n\tmach_vm_address_t disk_text_addr {0};    // the same address at from a file\n\tmach_vm_address_t kaslr_slide {0};       // the kernel aslr slide, computed as the difference between above's addresses\n\tuint8_t *file_buf {nullptr};             // read file data\n\tOSDictionary *prelink_dict {nullptr};    // read prealinked kext dictionary\n\tuint8_t *prelink_addr {nullptr};         // prelink text base address\n\tmach_vm_address_t prelink_vmaddr {0};    // prelink text base vm address (for kexts this is their actual slide)\n\tuint32_t file_buf_size {0};              // read file data size\n\tuint8_t *sym_buf {nullptr};              // pointer to buffer (normally __LINKEDIT) containing symbols to solve\n\tbool sym_buf_ro {false};                 // sym_buf is read-only (not copy).\n\tuint64_t sym_fileoff {0};                // file offset of symbols (normally __LINKEDIT) so we can read\n\tsize_t sym_size {0};\n\tuint32_t symboltable_fileoff {0};        // file offset to symbol table - used to position inside the __LINKEDIT buffer\n\tuint32_t symboltable_nr_symbols {0};\n\tuint32_t stringtable_fileoff {0};        // file offset to string table\n\tuint32_t stringtable_size {0};\n\tmach_header_native *running_mh {nullptr};    // pointer to mach-o header of running kernel item\n\tmach_vm_address_t address_slots {0};     // pointer after mach-o header to store pointers\n\tmach_vm_address_t address_slots_end {0}; // pointer after mach-o header to store pointers\n\toff_t fat_offset {0};                    // additional fat offset\n\tsize_t memory_size {HeaderSize};         // memory size\n\tbool kaslr_slide_set {false};            // kaslr can be null, used for disambiguation\n\tbool allow_decompress {true};            // allows mach decompression\n\tbool prelink_slid {false};               // assume kaslr-slid kext addresses\n\tbool kernel_collection {false};          // kernel collection (11.0+)\n\tuint64_t self_uuid[2] {};                // saved uuid of the loaded kext or kernel\n\n\t/**\n\t *  Kernel slide is aligned by 20 bits\n\t */\n\tstatic constexpr size_t KASLRAlignment {0x100000};\n\n\t/**\n\t *  Retrieve LC_UUID command value from a mach header\n\t *\n\t *  @param header mach header pointer\n\t *\n\t *  @return UUID or nullptr\n\t */\n\tuint64_t *getUUID(void *header);\n\n\t/**\n\t *  Retrieve and preserve LC_UUID command value from a mach header\n\t *\n\t *  @param header mach header pointer\n\t *\n\t *  @return true on success\n\t */\n\tbool loadUUID(void *header);\n\n\t/**\n\t *  Enable/disable the Write Protection bit in CR0 register\n\t *\n\t *  @param enable the desired value\n\t *\n\t *  @return KERN_SUCCESS if succeeded\n\t */\n\tstatic kern_return_t setWPBit(bool enable);\n\n\t/**\n\t *  Retrieve the first pages of a binary at disk into a buffer\n\t *  Version that uses KPI VFS functions and a ripped uio_createwithbuffer() from XNU\n\t *\n\t *  @param buffer     allocated buffer sized no less than HeaderSize\n\t *  @param vnode      file node\n\t *  @param ctxt       filesystem context\n\t *  @param decompress enable decompression\n\t *  @param off        fat offset or 0\n\t *\n\t *  @return KERN_SUCCESS if the read data contains 64-bit mach header\n\t */\n\tkern_return_t readMachHeader(uint8_t *buffer, vnode_t vnode, vfs_context_t ctxt, off_t off=0);\n\n\t/**\n\t *  Retrieve the whole symbol table (typically contained within the linkedit segment) into target buffer from kernel binary at disk\n\t *\n\t *  @param vnode file node\n\t *  @param ctxt  filesystem context\n\t *\n\t *  @return KERN_SUCCESS on success\n\t */\n\tkern_return_t readSymbols(vnode_t vnode, vfs_context_t ctxt);\n\n\t/**\n\t *  Retrieve necessary mach-o header information from the mach header\n\t *\n\t *  @param header read header sized no less than HeaderSize\n\t */\n\tvoid processMachHeader(void *header);\n\n\t/**\n\t *  Load kext info dictionary and addresses if they were not loaded previously\n\t */\n\tvoid updatePrelinkInfo();\n\n\t/**\n\t *  Lookup mach image in prelinked image\n\t *\n\t *  @param identifier  identifier\n\t *  @param imageSize   size of the returned buffer\n\t *  @param slide       actual slide for symbols (normally kaslr or 0)\n\t *  @param missing     set to true on successful prelink parsing when image is not needed\n\t *\n\t *  @return pointer to const buffer on success or nullptr\n\t */\n\tuint8_t *findImage(const char *identifier, uint32_t &imageSize, mach_vm_address_t &slide, bool &missing);\n\n\tMachInfo(bool asKernel, const char *id) : isKernel(asKernel), objectId(id) {\n\t\tDBGLOG(\"mach\", \"MachInfo asKernel %d object constructed\", asKernel);\n\t}\n\tMachInfo(const MachInfo &) = delete;\n\tMachInfo &operator =(const MachInfo &) = delete;\n\n\t/**\n\t *  Resolve mach data in the kernel via prelinked cache\n\t *\n\t *  @param prelink    prelink information source (i.e. Kernel MachInfo)\n\t *\n\t *  @return KERN_SUCCESS if loaded\n\t */\n\tkern_return_t initFromPrelinked(MachInfo *prelink);\n\n\t/**\n\t *  Resolve mach data in the kernel via filesystem access\n\t *\n\t *  @param paths      filesystem paths for lookup\n\t *  @param num        the number of paths passed\n\t *\n\t *  @return KERN_SUCCESS if loaded\n\t */\n\tkern_return_t initFromFileSystem(const char * const paths[], size_t num);\n\n\t/**\n\t *  Resolve mach data in the kernel via memory access\n\t *\n\t *  @return KERN_SUCCESS if loaded\n\t */\n\tkern_return_t initFromMemory();\n\npublic:\n\n\t/**\n\t *  Each header is assumed to fit two pages\n\t */\n\tstatic constexpr size_t HeaderSize {PAGE_SIZE_64*2};\n\n\t/**\n\t *  Representation mode (kernel/kext)\n\t */\n\tEXPORT const bool isKernel;\n\n\t/**\n\t *  Specified file identifier\n\t */\n\tEXPORT const char *objectId {nullptr};\n\n\t/**\n\t *  MachInfo object generator\n\t *\n\t *  @param asKernel this MachInfo represents a kernel\n\t *  @param id       kinfo identifier (e.g. CFBundleIdentifier)\n\t *\n\t *  @return MachInfo object or nullptr\n\t */\n\tstatic MachInfo *create(bool asKernel=false, const char *id=nullptr) { return new MachInfo(asKernel, id); }\n\tstatic void deleter(MachInfo *i NONNULL) { delete i; }\n\n\t/**\n\t *  Resolve mach data in the kernel\n\t *\n\t *  @param paths      filesystem paths for lookup\n\t *  @param num        the number of paths passed\n\t *  @param prelink    prelink information source (i.e. Kernel MachInfo)\n\t *  @param fsfallback fallback to reading from filesystem if prelink failed\n\t *\n\t *  @return KERN_SUCCESS if loaded\n\t */\n\tEXPORT kern_return_t init(const char * const paths[], size_t num = 1, MachInfo *prelink=nullptr, bool fsfallback=false);\n\n\t/**\n\t *  Release the allocated memory, must be called regardless of the init error\n\t */\n\tEXPORT void deinit();\n\n\t/**\n\t *  Retrieve the mach header and __TEXT addresses for KC mode\n\t *\n\t *  @param slide load slide if calculating for kexts\n\t *\n\t *  @return KERN_SUCCESS on success\n\t */\n\tkern_return_t kcGetRunningAddresses(mach_vm_address_t slide);\n\n\t/**\n\t *  Get address slot if present\n\t *\n\t *  @return address slot on success\n\t *  @return NULL on success\n\t */\n\tmach_vm_address_t getAddressSlot();\n\n\t/**\n\t *  Retrieve the mach header and __TEXT addresses\n\t *\n\t *  @param slide load slide if calculating for kexts\n\t *  @param size  memory size\n\t *  @param force force address recalculation\n\t *\n\t *  @return KERN_SUCCESS on success\n\t */\n\tEXPORT kern_return_t getRunningAddresses(mach_vm_address_t slide=0, size_t size=0, bool force=false);\n\n\t/**\n\t *  Set the mach header address\n\t *\n\t *  @param slide load address\n\t *  @param size  memory size\n\t *\n\t *  @return KERN_SUCCESS on success\n\t */\n\tEXPORT kern_return_t setRunningAddresses(mach_vm_address_t slide=0, size_t size=0);\n\n\t/**\n\t *  Retrieve running mach positions\n\t *\n\t *  @param header pointer to header\n\t *  @param size   file size\n\t */\n\tEXPORT void getRunningPosition(uint8_t * &header, size_t &size);\n\n\t/**\n\t *  Solve a mach symbol (running addresses must be calculated)\n\t *\n\t *  @param symbol symbol to solve\n\t *\n\t *  @return running symbol address or 0\n\t */\n\tEXPORT mach_vm_address_t solveSymbol(const char *symbol);\n\n\t/**\n\t *  Find the kernel base address (mach-o header)\n\t *\n\t *  @return kernel base address or 0\n\t */\n\tEXPORT mach_vm_address_t findKernelBase();\n\n\t/**\n\t *  Compare the loaded kernel with the current UUID (see loadUUID)\n\t *\n\t *  @param base  image base, pass 0 to use kernel base\n\t *\n\t *  @return true if image uuids match\n\t */\n\tEXPORT bool isCurrentBinary(mach_vm_address_t base=0);\n\n\t/**\n\t *  Enable/disable interrupt handling\n\t *  this is similar to ml_set_interrupts_enabled except the return value\n\t *\n\t *  @param enable the desired value\n\t *\n\t *  @return true if changed the value and false if it is unchanged\n\t */\n\tEXPORT static bool setInterrupts(bool enable);\n\n\t/**\n\t *  Enable/disable kernel memory write protection\n\t *\n\t *  @param enable  the desired value\n\t *  @param lock    use spinlock to disable cpu preemption (see KernelPatcher::kernelWriteLock)\n\t *\n\t *  @return KERN_SUCCESS if succeeded\n\t */\n\tEXPORT static kern_return_t setKernelWriting(bool enable, IOSimpleLock *lock);\n\n\t/**\n\t *  Find section bounds in a passed binary for provided cpu\n\t *\n\t *  @param ptr         pointer to a complete mach-o binary\n\t *  @param sourceSize  size of the mach-o binary\n\t *  @param vmsegment   returned vm segment pointer\n\t *  @param vmsection   returned vm section pointer\n\t *  @param sectionptr  returned section pointer\n\t *  @param sectionSize returned section size or 0 on failure\n\t *  @param segmentName segment name\n\t *  @param sectionName section name\n\t *  @param cpu         cpu to look for in case of fat binaries\n\t */\n\tEXPORT static void findSectionBounds(void *ptr, size_t sourceSize, vm_address_t &vmsegment, vm_address_t &vmsection, void *&sectionptr, size_t &sectionSize, const char *segmentName=\"__TEXT\", const char *sectionName=\"__text\", cpu_type_t cpu=CPU_TYPE_X86_64);\n\n\t/**\n\t *  Request to free file buffer resources (not including linkedit symtable)\n\t */\n\tvoid freeFileBufferResources();\n\n\t/**\n\t *  Get fat offset of the initialised image\n\t */\n\toff_t getFatOffset() {\n\t\treturn fat_offset;\n\t}\n};\n\n#endif /* kern_mach_hpp */\n"
  },
  {
    "path": "EFI_DEBUG/EFI/OC/Kexts/Lilu.kext/Contents/Resources/Headers/kern_nvram.hpp",
    "content": "//\n//  kern_nvram.hpp\n//  Lilu\n//\n//  Copyright © 2017 vit9696. All rights reserved.\n//\n\n#ifndef kern_nvram_hpp\n#define kern_nvram_hpp\n\n#include <Headers/kern_util.hpp>\n#include <IOKit/IOService.h>\n#include <libkern/c++/OSSymbol.h>\n#include <libkern/libkern.h>\n#include <stdint.h>\n\n/**\n *  Some of the most common GUIDs used for variable storage on macOS\n */\n#define NVRAM_GLOBAL_GUID \"8BE4DF61-93CA-11D2-AA0D-00E098032B8C\"\n#define NVRAM_APPLE_BOOT_GUID \"7C436110-AB2A-4BBB-A880-FE41995C9F82\"\n#define NVRAM_APPLE_VENDOR_GUID \"4D1EDE05-38C7-4A6A-9CC6-4BCCA8B38C14\"\n#define NVRAM_APPLE_FILEVAULT_GUID \"8D63D4FE-BD3C-4AAD-881D-86FD974BC1DF\"\n#define NVRAM_APPLE_PASSWORD_UI_GUID \"9EBA2D25-BBE3-4AC2-A2C6-C87F44A1278C\"\n\n/**\n *  Custom GUIDs used for Lilu preferences\n *  Must be kept in sync to OcSupportPkg/Include/Guid/OcVariables.h\n */\n#define LILU_VENDOR_GUID \"4D1FDA02-38C7-4A6A-9CC6-4BCCA8B30102\"\n#define LILU_READ_ONLY_GUID \"E09B9297-7928-4440-9AAB-D1F8536FBF0A\"\n#define LILU_WRITE_ONLY_GUID \"F0B9AF8F-2222-4840-8A37-ECF7CC8C12E1\"\n\n/**\n *  Prefix variable name with a GUID\n */\n#define NVRAM_PREFIX(x, y) x \":\" y\n\nclass NVStorage {\n\t/**\n\t *  Local nvram controller reference\n\t */\n\tIORegistryEntry *dtEntry {nullptr};\n\npublic:\n\t/**\n\t *  Compress data with a default compression algorithm\n\t *\n\t *  @param src        source data\n\t *  @param size       data size (updated with new size)\n\t *  @param sensitive  contains sensitive data\n\t *\n\t *  @return compressed data (must be freed with Buffer::deleter) or nullptr\n\t */\n\tEXPORT uint8_t *compress(const uint8_t *src, uint32_t &size, bool sensitive=false);\n\n\t/**\n\t *  Decompress data compressed with compress\n\t *\n\t *  @param src        compressed data\n\t *  @param size       data size (updated with new size)\n\t *  @param sensitive  contains sensitive data\n\t *\n\t *  @return decompressed data (must be freed with Buffer::deleter) or nullptr\n\t */\n\tEXPORT uint8_t *decompress(const uint8_t *src, uint32_t &size, bool sensitive=false);\n\n\t/**\n\t *  Value storage options\n\t */\n\tenum Options {\n\t\tOptAuto         = 0,  // Default options\n\t\tOptRaw          = 1,  // i/o as raw buffer\n\t\tOptCompressed   = 2,  // Apply compression (see kern_compression.hpp)\n\t\tOptEncrypted    = 4,  // Apply encryption with device-unique key (see kern_crypto.hpp)\n\t\tOptChecksum     = 8,  // Append CRC32 checksum to the end\n\t\tOptSensitive    = 16  // Value contains sensitive data\n\t};\n\n\t/**\n\t *  Prepended value header unless OptRaw is used\n\t *  After the header the following fields should go:\n\t *  uint8_t iv[16]; aes initialisation vector (if OptEncrypted is set)\n\t *  uint32_t size;  decryption size           (if OptEncrypted is set, encrypted)\n\t *  uint32_t size;  decompression size        (if OptCompressed is set, encrypted if OptEncrypted)\n\t *  uint8_t data[]; content data              (encrypted if OptEncrypted)\n\t *  uint32_t crc32; CRC32 cheksum             (if OptChecksum is set)\n\t */\n\tstruct PACKED Header {\n\t\tstatic constexpr uint16_t Magic = 0xC717;\n\t\tstatic constexpr uint8_t MaxVer = 1;\n\t\tusing Checksum = uint32_t;\n\n\t\tuint16_t magic {Magic};\n\t\tuint8_t version {MaxVer};\n\t\tuint8_t opts {OptAuto};\n\t};\n\n\t/**\n\t *  Attempt to connect to active nvram, may fail at early stages\n\t *\n\t *  @return true on success\n\t */\n\tEXPORT bool init();\n\n\t/**\n\t *  Relinquish resources used, must be called regardless of the init error\n\t */\n\tEXPORT void deinit();\n\n\t/**\n\t *  Read data from nvram\n\t *\n\t *  @param key    key name\n\t *  @param size   amount of data read\n\t *  @param opts   bitmask of Options, may set option requirements\n\t *  @param enckey encryption key (platform-defined if OptEncrypted is set)\n\t *\n\t *  @return pointer to data (must be freed via Buffer::deleter), nullptr on failure\n\t */\n\tEXPORT uint8_t *read(const char *key, uint32_t &size, uint8_t opts=OptAuto, const uint8_t *enckey=nullptr);\n\n\t/**\n\t *  Read data from nvram\n\t *\n\t *  @param key    key name\n\t *  @param opts   bitmask of Options, may set option requirements\n\t *  @param enckey encryption key (platform-defined if OptEncrypted is set)\n\t *\n\t *  @return pointer to data (must be freed via OSData::release), nullptr on failure\n\t */\n\tEXPORT OSData *read(const char *key, uint8_t opts=OptAuto, const uint8_t *enckey=nullptr);\n\n\t/**\n\t *  Write data to nvram\n\t *\n\t *  @param key    key name\n\t *  @param src    source buffer\n\t *  @param size   buffer size\n\t *  @param opts   bitmask of Options\n\t *  @param enckey encryption key (platform-defined if OptEncrypted is set)\n\t *\n\t *  @return true on success\n\t */\n\tEXPORT bool write(const char *key, const uint8_t *src, uint32_t sz, uint8_t opts=OptAuto, const uint8_t *enckey=nullptr);\n\n\t/**\n\t *  Write data to nvram\n\t *\n\t *  @param key    key name\n\t *  @param data   data object to write\n\t *  @param opts   bitmask of Options\n\t *  @param enckey encryption key (platform-defined if OptEncrypted is set)\n\t *\n\t *  @return true on success\n\t */\n\tEXPORT bool write(const char *key, const OSData *data, uint8_t opts=OptAuto, const uint8_t *enckey=nullptr);\n\n\t/**\n\t *  Delete key from nvram\n\t *\n\t *  @param key        key name\n\t *  @param sensitive  sensitive data\n\t *\n\t *  @return true on successful deletion or if key is missing\n\t */\n\tEXPORT bool remove(const char *key, bool sensitive=false);\n\n\t/**\n\t *  Synchronize with nvram controller\n\t *  This method might fail if synchronisation was done recently.\n\t *\n\t *  @return true if synchronised\n\t */\n\tEXPORT bool sync();\n\n\t/**\n\t *  Exports nvram to a plist file\n\t *\n\t *  @param filename  file path\n\t *  @oaram max       max output size\n\t *  @param sensitive contains sensitive data\n\t *\n\t *  @return true if saved\n\t */\n\tEXPORT bool save(const char *filename, uint32_t max=0x20000, bool sensitive=false);\n\n\t/**\n\t *  Check whether key exists\n\t *\n\t *  @param key        key name\n\t *\n\t *  @return true if key exists\n\t */\n\tEXPORT bool exists(const char *key);\n};\n\n#endif /* kern_nvram_hpp */\n"
  },
  {
    "path": "EFI_DEBUG/EFI/OC/Kexts/Lilu.kext/Contents/Resources/Headers/kern_patcher.hpp",
    "content": "//\n//  kern_patcher.hpp\n//  Lilu\n//\n//  Copyright © 2016-2017 vit9696. All rights reserved.\n//\n\n#ifndef kern_patcher_hpp\n#define kern_patcher_hpp\n\n#include <Headers/kern_config.hpp>\n#include <Headers/kern_compat.hpp>\n#include <Headers/kern_util.hpp>\n#include <Headers/kern_mach.hpp>\n#include <Headers/kern_disasm.hpp>\n\n#include <mach/mach_types.h>\n\nnamespace Patch { union All; void deleter(All * NONNULL); }\n#ifdef LILU_KEXTPATCH_SUPPORT\nunion OSKextLoadedKextSummaryHeaderAny;\n#endif /* LILU_KEXTPATCH_SUPPORT */\n\nclass KernelPatcher {\npublic:\n\n\t/**\n\t *  Errors set by functions\n\t */\n\tenum class Error {\n\t\tNoError,\n\t\tNoKinfoFound,\n\t\tNoSymbolFound,\n\t\tKernInitFailure,\n\t\tKernRunningInitFailure,\n\t\tKextListeningFailure,\n\t\tDisasmFailure,\n\t\tMemoryIssue,\n\t\tMemoryProtection,\n\t\tPointerRange,\n\t\tAlreadyDone,\n\t\tLockError,\n\t\tUnsupported,\n\t\tInvalidSymbolFound\n\t};\n\n\t/**\n\t *  Get last error\n\t *\n\t *  @return error code\n\t */\n\tEXPORT Error getError();\n\n\t/**\n\t *  Reset all the previous errors\n\t */\n\tEXPORT void clearError();\n\n\t/**\n\t *  Initialise KernelPatcher, prepare for modifications\n\t */\n\tvoid init();\n\n\t/**\n\t *  Deinitialise KernelPatcher, must be called regardless of the init error\n\t */\n\tvoid deinit();\n\n\t/**\n\t *  Kernel write lock used for performing kernel & kext writes to disable cpu preemption\n\t *  See MachInfo::setKernelWriting\n\t */\n\tEXPORT static IOSimpleLock *kernelWriteLock;\n\n\t/**\n\t *  Kext information\n\t */\n\tstruct KextInfo;\n\n#ifdef LILU_KEXTPATCH_SUPPORT\n\tstruct KextInfo {\n\t\tstatic constexpr size_t Unloaded {0};\n\t\tenum SysFlags : uint64_t {\n\t\t\tLoaded,      // invoke for kext if it is already loaded\n\t\t\tReloadable,  // allow the kext to unload and get patched again\n\t\t\tDisabled,    // do not load this kext (formerly achieved pathNum = 0, this no longer works)\n\t\t\tFSOnly,      // do not use prelinkedkernel (kextcache) as a symbol source\n\t\t\tFSFallback,  // perform fs fallback if kextcache failed\n\t\t\tReserved,\n\t\t\tSysFlagNum,\n\t\t};\n\t\tstatic constexpr uint64_t UserFlagNum {sizeof(uint64_t)-SysFlagNum};\n\t\tstatic_assert(UserFlagNum > 0, \"There should be at least one user flag\");\n\t\tconst char *id {nullptr};\n\t\tconst char **paths {nullptr};\n\t\tsize_t pathNum {0};\n\t\tbool sys[SysFlagNum] {};\n\t\tbool user[UserFlagNum] {};\n\t\tsize_t loadIndex {Unloaded}; // Updated after loading\n\n\t\t/**\n\t\t *  Disable this info from being used\n\t\t *  May be called from onPatcherLoad callbacks to disable certain kexts\n\t\t */\n\t\tvoid switchOff() {\n\t\t\tsys[KernelPatcher::KextInfo::Disabled] = true;\n\t\t}\n\t};\n\n\tstatic_assert(sizeof(KextInfo) == 4 * sizeof(size_t) + sizeof(uint64_t), \"KextInfo is no longer ABI compatible\");\n#endif /* LILU_KEXTPATCH_SUPPORT */\n\n\t/**\n\t *  Loads and stores kinfo information locally\n\t *\n\t *  @param id         kernel item identifier\n\t *  @param paths      item filesystem path array\n\t *  @param num        number of path entries\n\t *  @param isKernel   kinfo is kernel info\n\t *  @param fsonly     avoid using prelinkedkernel for kexts\n\t *  @param fsfallback fallback to reading from filesystem if prelink failed\n\t *\n\t *  @return loaded kinfo id\n\t */\n\tEXPORT size_t loadKinfo(const char *id, const char * const paths[], size_t num=1, bool isKernel=false, bool fsonly=false, bool fsfallback=false);\n\n#ifdef LILU_KEXTPATCH_SUPPORT\n\t/**\n\t *  Loads and stores kinfo information locally\n\t *\n\t *  @param info kext to load, updated on success\n\t *\n\t *  @return loaded kinfo id\n\t */\n\tEXPORT size_t loadKinfo(KextInfo *info);\n#endif /* LILU_KEXTPATCH_SUPPORT */\n\n\t/**\n\t *  Kernel kinfo id\n\t */\n\tstatic constexpr size_t KernelID {0};\n\n\t/**\n\t *  Update running information\n\t *\n\t *  @param id    loaded kinfo id\n\t *  @param slide loaded slide\n\t *  @param size  loaded memory size\n\t *  @param force force recalculatiob\n\t *\n\t *  @return new size\n\t */\n\tEXPORT size_t updateRunningInfo(size_t id, mach_vm_address_t slide=0, size_t size=0, bool force=false);\n\n\t/**\n\t *  Any kernel\n\t */\n\tstatic constexpr uint32_t KernelAny {0};\n\n\t/**\n\t *  Check kernel compatibility\n\t *\n\t *  @param min minimal requested version or KernelAny\n\t *  @param max maximum supported version or KernelAny\n\t *\n\t *  @return true on success\n\t */\n\tEXPORT static bool compatibleKernel(uint32_t min, uint32_t max);\n\n\t/**\n\t *  Erase coverage instruction prefix (like inc qword ptr[]), that causes function routing to fail\n\t *\n\t *  @param addr   address to valid instruction code\n\t *  @param count  amount of instructions to inspect\n\t */\n\tEXPORT void eraseCoverageInstPrefix(mach_vm_address_t addr, size_t count=5);\n\n\t/**\n\t *  Erase coverage instruction prefix (like inc qword ptr[]), that causes function routing to fail\n\t *\n\t *  @param addr   address to valid instruction code\n\t *  @param count  amount of instructions to inspect\n\t *  @param limit  amount of bytes to inspect\n\t */\n\tEXPORT void eraseCoverageInstPrefix(mach_vm_address_t addr, size_t count, off_t limit);\n\n\t/**\n\t *  Solve a kinfo symbol\n\t *\n\t *  @param id      loaded kinfo id\n\t *  @param symbol  symbol to solve\n\t *\n\t *  @return running symbol address or 0\n\t */\n\tEXPORT mach_vm_address_t solveSymbol(size_t id, const char *symbol);\n\n\t/**\n\t *  Solve a kinfo symbol in range with designated type\n\t *\n\t *  @param id      loaded kinfo id\n\t *  @param symbol  symbol to solve\n\t *  @param start   start address range\n\t *  @param size    address range size\n\t *  @param crash   kernel panic on invalid non-zero address\n\t *\n\t *  @return running symbol address or 0 casted to type T (mach_vm_address_t)\n\t */\n\ttemplate <typename T = mach_vm_address_t>\n\tinline T solveSymbol(size_t id, const char *symbol, mach_vm_address_t start, size_t size, bool crash=false) {\n\t\tauto addr = solveSymbol(id, symbol);\n\t\tif (addr) {\n\t\t\tif (addr >= start && addr < start + size)\n\t\t\t\treturn (T)addr;\n\n\t\t\tcode = Error::InvalidSymbolFound;\n\t\t\tSYSTRACE(\"patcher\", \"address \" PRIKADDR \" is out of range \" PRIKADDR \" with size %lX\",\n\t\t\t\tCASTKADDR(addr), CASTKADDR(start), size);\n\n\t\t\tPANIC_COND(crash, \"patcher\", \"address \" PRIKADDR \" is out of range \" PRIKADDR \" with size %lX\",\n\t\t\t\tCASTKADDR(addr), CASTKADDR(start), size);\n\t\t}\n\n\t\treturn (T)nullptr;\n\t}\n    \n    /**\n     *  Solve request to resolve multiple symbols in one shot and simplify error handling\n     *\n     *  @seealso solveMultiple().\n     */\n    struct SolveRequest {\n        /**\n         *  The symbol to solve\n         */\n        const char *symbol {nullptr};\n        \n        /**\n         *  The symbol address on success, otherwise NULL.\n         */\n        mach_vm_address_t *address {nullptr};\n        \n        /**\n         *  Construct a solve request conveniently\n         */\n        template <typename T>\n        SolveRequest(const char *s, T &addr) :\n\t\t\tsymbol(s), address(reinterpret_cast<mach_vm_address_t*>(&addr)) { }\n    };\n\t\n\t/**\n\t *  Solve multiple functions with basic error handling\n\t *\n\t *  @param id        loaded kinfo id\n\t *  @param requests  an array of requests to solve\n\t *  @param num       requests array size\n\t *  @param start     start address range\n\t *  @param size      address range size\n\t *  @param crash     kernel panic on invalid non-zero address\n\t *  @param force     continue on first error\n\t *\n\t *  @return false if at least one symbol cannot be solved.\n\t */\n\tinline bool solveMultiple(size_t id, SolveRequest *requests, size_t num, mach_vm_address_t start, size_t size, bool crash=false, bool force=false) {\n\t\tfor (size_t index = 0; index < num; index++) {\n\t\t\tauto result = solveSymbol(id, requests[index].symbol, start, size, crash);\n\t\t\tif (result) {\n\t\t\t\t*requests[index].address = result;\n\t\t\t} else {\n\t\t\t\tclearError();\n\t\t\t\tif (!force) return false;\n\t\t\t}\n\t\t}\n\t\treturn true;\n\t}\n\t\n\t/**\n\t *  Solve multiple functions with basic error handling\n\t *\n\t *  @param id        loaded kinfo id\n\t *  @param requests  an array of requests to solve\n\t *  @param start     start address range\n\t *  @param size      address range size\n\t *  @param crash     kernel panic on invalid non-zero address\n\t *  @param force     continue on first error\n\t *\n\t *  @return false if at least one symbol cannot be solved.\n\t */\n\ttemplate <size_t N>\n\tinline bool solveMultiple(size_t id, SolveRequest (&requests)[N], mach_vm_address_t start, size_t size, bool crash=false, bool force=false) {\n\t\treturn solveMultiple(id, requests, N, start, size, crash, force);\n\t}\n\n\t/**\n\t *  Hook kext loading and unloading to access kexts at early stage\n\t */\n\tEXPORT void setupKextListening();\n\n\t/**\n\t *  Free file buffer resources and effectively make prelinked kext loading impossible\n\t */\n\tvoid freeFileBufferResources();\n\n\t/**\n\t *  Activates monitoring functions if necessary\n\t */\n\tvoid activate();\n\n\t/**\n\t *  Load handling structure\n\t */\n\tclass KextHandler {\n\t\tusing t_handler = void (*)(KextHandler *);\n\t\tKextHandler(const char * const i, size_t idx, t_handler h, bool l, bool r) :\n\t\t\tid(i), index(idx), handler(h), loaded(l), reloadable(r) {}\n\tpublic:\n\t\tstatic KextHandler *create(const char * const i, size_t idx, t_handler h, bool l=false, bool r=false) {\n\t\t\treturn new KextHandler(i, idx, h, l, r);\n\t\t}\n\t\tstatic void deleter(KextHandler *i NONNULL) {\n\t\t\tdelete i;\n\t\t}\n\n\t\tvoid *self {nullptr};\n\t\tconst char * const id {nullptr};\n\t\tsize_t index {0};\n\t\tmach_vm_address_t address {0};\n\t\tsize_t size {0};\n\t\tt_handler handler {nullptr};\n\t\tbool loaded {false};\n\t\tbool reloadable {false};\n\t};\n\n#ifdef LILU_KEXTPATCH_SUPPORT\n\t/**\n\t *  Enqueue handler processing at kext loading\n\t *\n\t *  @param handler  handler to process\n\t */\n\tEXPORT void waitOnKext(KextHandler *handler);\n\n\t/**\n\t *  Update kext handler features\n\t *\n\t *  @param info  loaded kext info with features\n\t */\n\tvoid updateKextHandlerFeatures(KextInfo *info);\n\n\t/**\n\t *  Arbitrary kext find/replace patch\n\t */\n\tstruct LookupPatch {\n\t\tKextInfo *kext;\n\t\tconst uint8_t *find;\n\t\tconst uint8_t *replace;\n\t\tsize_t size;\n\t\tsize_t count;\n\t};\n\n\t/**\n\t *  Apply a find/replace patch\n\t *\n\t *  @param patch patch to apply\n\t */\n\tEXPORT void applyLookupPatch(const LookupPatch *patch);\n\n\t/**\n\t *  Apply a find/replace patch with additional constraints\n\t *\n\t *  @param patch              patch to apply\n\t *  @param startingAddress    start with this address (or kext/kernel lowest address)\n\t *  @param maxSize            maximum size to lookup (or kext/kernel max size)\n\t */\n\tEXPORT void applyLookupPatch(const LookupPatch *patch, uint8_t *startingAddress, size_t maxSize);\n#endif /* LILU_KEXTPATCH_SUPPORT */\n\n\t/**\n\t *  Route function to function\n\t *\n\t *  @param from         function to route\n\t *  @param to           routed function\n\t *  @param buildWrapper create entrance wrapper\n\t *  @param kernelRoute  kernel change requiring memory protection changes and patch reverting at unload\n\t *  @param revertible   patches could be reverted\n\t *\n\t *  @return wrapper pointer or 0 on success\n\t */\n\tEXPORT mach_vm_address_t routeFunction(mach_vm_address_t from, mach_vm_address_t to, bool buildWrapper=false, bool kernelRoute=true, bool revertible=true) DEPRECATE(\"Use routeMultiple where possible\");\n\n\t/**\n\t *  Route function to function with long jump\n\t *\n\t *  @param from         function to route\n\t *  @param to           routed function\n\t *  @param buildWrapper create entrance wrapper\n\t *  @param kernelRoute  kernel change requiring memory protection changes and patch reverting at unload\n\t *  @param revertible   patches could be reverted\n\t *\n\t *  @return wrapper pointer or 0 on success\n\t */\n\tEXPORT mach_vm_address_t routeFunctionLong(mach_vm_address_t from, mach_vm_address_t to, bool buildWrapper=false, bool kernelRoute=true, bool revertible=true) DEPRECATE(\"Use routeMultiple where possible\");\n\n\t/**\n\t *  Route function to function with short jump\n\t *\n\t *  @param from         function to route\n\t *  @param to           routed function\n\t *  @param buildWrapper create entrance wrapper\n\t *  @param kernelRoute  kernel change requiring memory protection changes and patch reverting at unload\n\t *  @param revertible   patches could be reverted\n\t *\n\t *  @return wrapper pointer or 0 on success\n\t */\n\tEXPORT mach_vm_address_t routeFunctionShort(mach_vm_address_t from, mach_vm_address_t to, bool buildWrapper=false, bool kernelRoute=true, bool revertible=true) DEPRECATE(\"Use routeMultiple where possible\");\n\n\t/**\n\t *  Route block at assembly level\n\t *\n\t *  @param from         address to route\n\t *  @param opcodes      opcodes to insert\n\t *  @param opnum        number of opcodes\n\t *  @param buildWrapper create entrance wrapper\n\t *  @param kernelRoute  kernel change requiring memory protection changes and patch reverting at unload\n\t *\n\t *  @return wrapper pointer or 0 on success\n\t */\n\tEXPORT mach_vm_address_t routeBlock(mach_vm_address_t from, const uint8_t *opcodes, size_t opnum, bool buildWrapper=false, bool kernelRoute=true);\n\n\t/**\n\t *  Route virtual function to function\n\t *\n\t *  @param obj      OSObject-compatible instance\n\t *  @param off      function offset in a virtual table (arch-neutral, i.e. divided by sizeof(uintptr_t)\n\t *  @param func     function to replace with\n\t *  @param orgFunc  pointer to store the original function\n\t *\n\t *  @return true on success\n\t */\n\ttemplate <typename T>\n\tstatic inline bool routeVirtual(void *obj, size_t off, T func, T *orgFunc=nullptr) {\n\t\t// First OSObject (and similar) field is its virtual table.\n\t\tauto vt = obj ? reinterpret_cast<T **>(obj)[0] : nullptr;\n\t\tif (vt) {\n\t\t\t// Do not try to replace twice!\n\t\t\tif (vt[off] == func)\n\t\t\t\treturn false;\n\t\t\tif (orgFunc) *orgFunc = vt[off];\n\t\t\tvt[off] = func;\n\t\t\treturn true;\n\t\t}\n\t\treturn false;\n\t}\n\n\t/**\n\t *  Route request to simplify casting and error handling\n\t *  See routeMultiple.\n\t *\n\t *  symbol  symbol to lookup\n\t *  from    solved symbol (assigned by routeMultiple)\n\t *  to      destination address\n\t *  org     trampoline storage to the original symbol\n\t */\n\tstruct RouteRequest {\n\t\tconst char *symbol {nullptr};\n\t\tmach_vm_address_t from {0};\n\t\tconst mach_vm_address_t to {0};\n\t\tmach_vm_address_t *org {nullptr};\n\n\t\t/**\n\t\t *  Construct RouteRequest for wrapping a function\n\t\t *  @param s  symbol to lookup\n\t\t *  @param t  destination address\n\t\t *  @param o  trampoline storage to the original symbol\n\t\t */\n\t\ttemplate <typename T>\n\t\tRouteRequest(const char *s, T t, mach_vm_address_t &o) :\n\t\t\tsymbol(s), to(reinterpret_cast<mach_vm_address_t>(t)), org(&o) { }\n\t\t\n\t\t/**\n\t\t *  Construct RouteRequest for wrapping a function\n\t\t *  @param s  symbol to lookup\n\t\t *  @param t  destination address\n\t\t *  @param o  trampoline storage to the original symbol\n\t\t */\n\t\ttemplate <typename T, typename O>\n\t\tRouteRequest(const char *s, T t, O &o) :\n\t\t\tRouteRequest(s, t, reinterpret_cast<mach_vm_address_t&>(o)) { }\n\n\t\t/**\n\t\t *  Construct RouteRequest for routing a function\n\t\t *  @param s  symbol to lookup\n\t\t *  @param t  destination address\n\t\t */\n\t\ttemplate <typename T>\n\t\tRouteRequest(const char *s, T t) :\n\t\t\tsymbol(s), to(reinterpret_cast<mach_vm_address_t>(t)) { }\n\t};\n\n\t/**\n\t *  Simple route multiple functions with basic error handling\n\t *\n\t *  @param id           kernel item identifier\n\t *  @param requests     an array of requests to replace\n\t *  @param num          requests array size\n\t *  @param start        start address range\n\t *  @param size         address range size\n\t *  @param kernelRoute  kernel change requiring memory protection changes and patch reverting at unload\n\t *  @param force        continue on first error\n\t *\n\t *  @return false if it at least one error happened\n\t */\n\tEXPORT bool routeMultiple(size_t id, RouteRequest *requests, size_t num, mach_vm_address_t start=0, size_t size=0, bool kernelRoute=true, bool force=false);\n\n\t/**\n\t *  Simple route multiple functions with basic error handling with long routes\n\t *\n\t *  @param id           kernel item identifier\n\t *  @param requests     an array of requests to replace\n\t *  @param num          requests array size\n\t *  @param start        start address range\n\t *  @param size         address range size\n\t *  @param kernelRoute  kernel change requiring memory protection changes and patch reverting at unload\n\t *  @param force        continue on first error\n\t *\n\t *  @return false if it at least one error happened\n\t */\n\tEXPORT bool routeMultipleLong(size_t id, RouteRequest *requests, size_t num, mach_vm_address_t start=0, size_t size=0, bool kernelRoute=true, bool force=false);\n\n\t/**\n\t *  Simple route multiple functions with basic error handling with short routes\n\t *\n\t *  @param id           kernel item identifier\n\t *  @param requests     an array of requests to replace\n\t *  @param num          requests array size\n\t *  @param start        start address range\n\t *  @param size         address range size\n\t *  @param kernelRoute  kernel change requiring memory protection changes and patch reverting at unload\n\t *  @param force        continue on first error\n\t *\n\t *  @return false if it at least one error happened\n\t */\n\tEXPORT bool routeMultipleShort(size_t id, RouteRequest *requests, size_t num, mach_vm_address_t start=0, size_t size=0, bool kernelRoute=true, bool force=false);\n\n\t/**\n\t *  Simple route multiple functions with basic error handling\n\t *\n\t *  @param id           kernel item identifier\n\t *  @param requests     an array of requests to replace\n\t *  @param start        start address range\n\t *  @param size         address range size\n\t *  @param kernelRoute  kernel change requiring memory protection changes and patch reverting at unload\n\t *  @param force        continue on first error\n\t *\n\t *  @return false if it at least one error happened\n\t */\n\ttemplate <size_t N>\n\tinline bool routeMultiple(size_t id, RouteRequest (&requests)[N], mach_vm_address_t start=0, size_t size=0, bool kernelRoute=true, bool force=false) {\n\t\treturn routeMultiple(id, requests, N, start, size, kernelRoute, force);\n\t}\n\n\t/**\n\t *  Simple route multiple functions with basic error handling with long routes\n\t *\n\t *  @param id           kernel item identifier\n\t *  @param requests     an array of requests to replace\n\t *  @param start        start address range\n\t *  @param size         address range size\n\t *  @param kernelRoute  kernel change requiring memory protection changes and patch reverting at unload\n\t *  @param force        continue on first error\n\t *\n\t *  @return false if it at least one error happened\n\t */\n\ttemplate <size_t N>\n\tinline bool routeMultipleLong(size_t id, RouteRequest (&requests)[N], mach_vm_address_t start=0, size_t size=0, bool kernelRoute=true, bool force=false) {\n\t\treturn routeMultipleLong(id, requests, N, start, size, kernelRoute, force);\n\t}\n\n\t/**\n\t *  Simple route multiple functions with basic error handling with long routes\n\t *\n\t *  @param id           kernel item identifier\n\t *  @param requests     an array of requests to replace\n\t *  @param start        start address range\n\t *  @param size         address range size\n\t *  @param kernelRoute  kernel change requiring memory protection changes and patch reverting at unload\n\t *  @param force        continue on first error\n\t *\n\t *  @return false if it at least one error happened\n\t */\n\ttemplate <size_t N>\n\tinline bool routeMultipleShort(size_t id, RouteRequest (&requests)[N], mach_vm_address_t start=0, size_t size=0, bool kernelRoute=true, bool force=false) {\n\t\treturn routeMultipleShort(id, requests, N, start, size, kernelRoute, force);\n\t}\n\n\t/**\n\t *  Find one pattern with optional masking within a block of memory\n\t *\n\t *  @param pattern           pattern to search\n\t *  @param patternMask           pattern mask\n\t *  @param patternSize           size of pattern\n\t *  @param data           a block of memory\n\t *  @param dataSize           size of memory\n\t *  @param dataOffset           data offset, to be set by this function\n\t *\n\t *  @return true if pattern is found in data\n\t */\n\tEXPORT static bool findPattern(const void *pattern, const void *patternMask, size_t patternSize, const void *data, size_t dataSize, size_t *dataOffset);\n\n\t/**\n\t *  Simple find and replace with masking in kernel memory.\n\t */\n\tEXPORT static bool findAndReplaceWithMask(void *data, size_t dataSize, const void *find, size_t findSize, const void *findMask, size_t findMaskSize, const void *replace, size_t replaceSize, const void *replaceMask, size_t replaceMaskSize, size_t count=0, size_t skip=0);\n\n\t/**\n\t *  Simple find and replace in kernel memory.\n\t */\n\tstatic inline bool findAndReplace(void *data, size_t dataSize, const void *find, size_t findSize, const void *replace, size_t replaceSize) {\n\t\treturn findAndReplaceWithMask(data, dataSize, find, findSize, nullptr, 0, replace, replaceSize, nullptr, 0, 0, 0);\n\t}\n\n\t/**\n\t *  Simple find and replace in kernel memory but require both `find` and `replace` buffers to have the same length\n\t */\n\ttemplate <size_t N>\n\tstatic inline bool findAndReplace(void *data, size_t dataSize, const uint8_t (&find)[N], const uint8_t (&replace)[N]) {\n\t\treturn findAndReplace(data, dataSize, find, N, replace, N);\n\t}\n\n\t/**\n\t *  Simple find and replace with masking in kernel memory but require both `find` and `replace` buffers and masking buffers to have the same length\n\t */\n\ttemplate <size_t N>\n\tstatic inline bool findAndReplaceWithMask(void *data, size_t dataSize, const uint8_t (&find)[N], const uint8_t (&findMask)[N], const uint8_t (&replace)[N], const uint8_t (&replaceMask)[N], size_t count, size_t skip) {\n\t\treturn findAndReplaceWithMask(data, dataSize, find, N, findMask, N, replace, N, replaceMask, N, count, skip);\n\t}\n\nprivate:\n\t/**\n\t *  Jump type for routing\n\t */\n\tenum class JumpType {\n\t\tAuto,\n\t\tLong,\n\t\tShort,\n\t\tMedium\n\t};\n\n\t/**\n\t *  The minimal reasonable memory requirement\n\t */\n\tstatic constexpr size_t TempExecutableMemorySize {4096};\n\n\t/**\n\t *  As of 10.12 we seem to be not allowed to call vm_ functions from several places including onKextSummariesUpdated.\n\t */\n\tstatic uint8_t tempExecutableMemory[TempExecutableMemorySize];\n\n\t/**\n\t *  Offset to tempExecutableMemory that is safe to use\n\t */\n\tsize_t tempExecutableMemoryOff {0};\n\n\t/**\n\t *  Patcher status\n\t */\n\t_Atomic(bool) activated = false;\n\n\t/**\n\t *  Read previous jump destination from function\n\t *\n\t *  @param from          formerly routed function\n\t *  @param jumpType previous jump type\n\t *\n\t *  @return wrapper pointer on success or 0\n\t */\n\tmach_vm_address_t readChain(mach_vm_address_t from, JumpType &jumpType);\n\n\t/**\n\t *  Created routed trampoline page\n\t *\n\t *  @param func     original area\n\t *  @param min      minimal amount of bytes that will be overwritten\n\t *  @param opcodes  opcodes to insert before function\n\t *  @param opnum    number of opcodes\n\t *\n\t *  @return trampoline pointer or 0\n\t */\n\tmach_vm_address_t createTrampoline(mach_vm_address_t func, size_t min, const uint8_t *opcodes=nullptr, size_t opnum=0);\n\n\t/**\n\t *  Route function to function\n\t *\n\t *  @param from         function to route\n\t *  @param to           routed function\n\t *  @param buildWrapper create entrance wrapper\n\t *  @param kernelRoute  kernel change requiring memory protection changes and patch reverting at unload\n\t *  @param revertible   patches could be reverted\n\t *  @param jumpType     jump type to use, relative short or absolute long\n\t *  @param info         info to access address slots to use for shorter routing\n\t *  @param org          write pointer to this variable\n\t *\n\t *  @return wrapper pointer or 0 on success\n\t */\n\tmach_vm_address_t routeFunctionInternal(mach_vm_address_t from, mach_vm_address_t to, bool buildWrapper=false, bool kernelRoute=true, bool revertible=true, JumpType jumpType=JumpType::Auto, MachInfo *info=nullptr, mach_vm_address_t *org=nullptr);\n\n\t/**\n\t *  Simple route multiple functions with basic error handling with long routes\n\t *\n\t *  @param id           kernel item identifier\n\t *  @param requests     an array of requests to replace\n\t *  @param num          requests array size\n\t *  @param start        start address range\n\t *  @param size         address range size\n\t *  @param kernelRoute  kernel change requiring memory protection changes and patch reverting at unload\n\t *  @param force        continue on first error\n\t *  @param jumpType     jump type to use, relative short or absolute long\n\t *\n\t *  @return false if it at least one error happened\n\t */\n\tbool routeMultipleInternal(size_t id, RouteRequest *requests, size_t num, mach_vm_address_t start=0, size_t size=0, bool kernelRoute=true, bool force=false, JumpType jumpType=JumpType::Auto);\n\n#ifdef LILU_KEXTPATCH_SUPPORT\n\t/**\n\t *  Process loaded kext\n\t */\n\tvoid processKext(kmod_info_t *kmod, bool loaded);\n\t\n\t/**\n\t *  Process already loaded kexts once at the start\n\t *\n\t */\n\tvoid processAlreadyLoadedKexts();\n\n\t/**\n\t *  Pointer to loaded kmods for kexts\n\t */\n\tkmod_info_t **kextKmods {nullptr};\n\n\t/**\n\t *  Called at kext unloading if kext listening is enabled on macOS 10.6 and newer\n\t */\n\tstatic OSReturn onOSKextUnload(void *thisKext);\n\n\t/**\n\t *  A pointer to OSKext::unload()\n\t */\n\tmach_vm_address_t orgOSKextUnload {};\n\n\t/**\n\t *  Called at kext loading and unloading if kext listening is enabled on macOS 10.6 and newer\n\t */\n\tstatic void onOSKextSaveLoadedKextPanicList();\n\n\t/**\n\t *  A pointer to OSKext::saveLoadedKextPanicList()\n\t */\n\tmach_vm_address_t orgOSKextSaveLoadedKextPanicList {};\n\t\n#if defined(__i386__)\n\t/**\n\t *  Called at kext loading if kext listening is enabled on macOS 10.4 and 10.5\n\t */\n\tstatic kern_return_t onKmodCreateInternal(kmod_info_t *kmod, kmod_t *id);\n\t\n\t/**\n\t *  A pointer to kmod_create_internal()\n\t */\n\tmach_vm_address_t orgKmodCreateInternal {};\n#endif\n\n#endif /* LILU_KEXTPATCH_SUPPORT */\n\n\t/**\n\t *  Kernel prelink image in case prelink is used\n\t */\n\tMachInfo *prelinkInfo {nullptr};\n\n\t/**\n\t *  Loaded kernel items\n\t */\n\tevector<MachInfo *, MachInfo::deleter> kinfos;\n\n\t/**\n\t *  Applied patches\n\t */\n\tevector<Patch::All *, Patch::deleter> kpatches;\n\n#ifdef LILU_KEXTPATCH_SUPPORT\t\n\t/**\n\t *  Awaiting kext notificators\n\t */\n\tevector<KextHandler *, KextHandler::deleter> khandlers;\n\n\t/**\n\t *  Awaiting already loaded kext list\n\t */\n\tbool waitingForAlreadyLoadedKexts {false};\n\n\t/**\n\t *  Flag to prevent kext processing during an unload\n\t */\n\tbool isKextUnloading {false};\n\n#endif /* LILU_KEXTPATCH_SUPPORT */\n\n\t/**\n\t *  Current error code\n\t */\n\tError code {Error::NoError};\n\tstatic constexpr size_t INVALID {0};\n\n\t/**\n\t *  Jump instruction sizes\n\t */\n\tstatic constexpr size_t SmallJump {1 + sizeof(int32_t)};\n\tstatic constexpr size_t LongJump {6 + sizeof(uintptr_t)};\n\tstatic constexpr size_t MediumJump {6};\n\tstatic constexpr uint8_t SmallJumpPrefix {0xE9};\n\tstatic constexpr uint16_t LongJumpPrefix {0x25FF};\n\n\t/**\n\t * Atomic trampoline generator, wraps jumper into 64-bit or 128-bit storage\n\t */\n\tunion FunctionPatch {\n\t\tstruct PACKED LongPatch {\n\t\t\tuint16_t  opcode;\n\t\t\tuint32_t  argument;\n\t\t\tuintptr_t disp;\n\t\t\tuint8_t   org[sizeof(uint64_t) - sizeof(uintptr_t) + sizeof(uint16_t)];\n\t\t} l;\n\t\tstatic_assert(sizeof(l) == (sizeof(uint64_t) * 2), \"Invalid long patch rounding\");\n\t\tstruct PACKED MediumPatch {\n\t\t\tuint16_t opcode;\n\t\t\tuint32_t argument;\n\t\t\tuint8_t  org[2];\n\t\t} m;\n\t\tstatic_assert(sizeof(m) == sizeof(uint64_t), \"Invalid medium patch rounding\");\n\t\tstruct PACKED SmallPatch {\n\t\t\tuint8_t opcode;\n\t\t\tuint32_t argument;\n\t\t\tuint8_t org[3];\n\t\t} s;\n\t\tstatic_assert(sizeof(s) == sizeof(uint64_t), \"Invalid small patch rounding\");\n\t\ttemplate <typename T>\n\t\tinline void sourceIt(mach_vm_address_t source) {\n\t\t\t// Note, this one violates strict aliasing, but we play with the memory anyway.\n\t\t\tfor (size_t i = 0; i < sizeof(T::org); ++i)\n\t\t\t\treinterpret_cast<volatile T *>(this)->org[i] = *reinterpret_cast<uint8_t *>(source + offsetof(T, org) + i);\n\t\t}\n\t\tuint64_t value64;\n#if defined(__x86_64__)\n\t\tunsigned __int128 value128;\n#endif\n\t} patch;\n\n\t/**\n\t *  Possible kernel paths\n\t */\n#ifdef LILU_COMPRESSION_SUPPORT\n\tconst char *prelinkKernelPaths[7] {\n\t\t// This is the usual kernel cache place, which often the best thing to use\n\t\t\"/System/Library/Caches/com.apple.kext.caches/Startup/kernelcache\",\n\t\t// Otherwise fallback to one of the prelinked kernels\n\t\t// Since we always verify the LC_UUID value, trying the kernels could be done in any order.\n\t\t\"/System/Library/PrelinkedKernels/prelinkedkernel\", // normal\n\t\t\"/macOS Install Data/Locked Files/Boot Files/prelinkedkernel\", // 10.13 installer\n\t\t\"/com.apple.boot.R/prelinkedkernel\", // 10.12+ fusion drive installer\n\t\t\"/com.apple.boot.S/System/Library/PrelinkedKernels/prelinkedkernel\", // 10.11 fusion drive installer\n\t\t\"/com.apple.recovery.boot/prelinkedkernel\", // recovery\n\t\t\"/kernelcache\" // 10.7 installer\n\t};\n#endif\n\n\tconst char *kernelPaths[2] {\n\t\t\"/System/Library/Kernels/kernel\",\t//since 10.10\n\t\t\"/mach_kernel\"\n\t};\n};\n\n#endif /* kern_patcher_hpp */\n"
  },
  {
    "path": "EFI_DEBUG/EFI/OC/Kexts/Lilu.kext/Contents/Resources/Headers/kern_policy.hpp",
    "content": "//\n//  kern_policy.hpp\n//  Lilu\n//\n//  Copyright © 2016-2017 vit9696. All rights reserved.\n//\n\n#ifndef kern_policy_hpp\n#define kern_policy_hpp\n\n#include <Headers/kern_config.hpp>\n\n#include <sys/types.h>\n#include <sys/proc.h>\n\n#include <security/mac_framework.h>\n#include <security/mac_policy.h>\n#include <Headers/kern_util.hpp>\n\n#if defined(__x86_64__)\nclass Policy {\n\t/**\n\t *  TrustedBSD Policy handle\n\t */\n\tmac_policy_handle_t policyHandle {0};\n\n\t/**\n\t *  TrustedBSD policy configuration\n\t */\n\tmac_policy_conf policyConf;\npublic:\n\t/**\n\t *  Compile-time policy constructor\n\t *\n\t *  @param name  policy name literal\n\t *  @param descr policy description literal\n\t *  @param ops   policy functions\n\t */\n\tconstexpr Policy(const char *name, const char *descr, struct mac_policy_ops *ops) : policyConf{\n\t\t.mpc_name\t\t\t\t= name,\n\t\t.mpc_fullname\t\t\t= descr,\n\t\t.mpc_labelnames\t\t\t= nullptr,\n\t\t.mpc_labelname_count\t= 0,\n\t\t.mpc_ops\t\t\t\t= ops,\n\t\t// Our policies are loaded very early and are static. We cannot unload them.\n\t\t.mpc_loadtime_flags\t\t= 0 /*MPC_LOADTIME_FLAG_UNLOADOK*/,\n\t\t.mpc_field_off\t\t\t= nullptr,\n\t\t.mpc_runtime_flags\t\t= 0\n\t} { }\n\n\t/**\n\t *  Registers TrustedBSD policy\n\t *\n\t *  @return true on success\n\t */\n\tEXPORT bool registerPolicy();\n\n\t/**\n\t *  Unregisters TrustedBSD policy if allowed\n\t *\n\t *  @return true on success\n\t */\n\tEXPORT bool unregisterPolicy();\n};\n#endif\n\n#endif /* kern_policy_hpp */\n"
  },
  {
    "path": "EFI_DEBUG/EFI/OC/Kexts/Lilu.kext/Contents/Resources/Headers/kern_rtc.hpp",
    "content": "//\n//  kern_rtc.hpp\n//  Lilu\n//\n//  Copyright © 2018 vit9696. All rights reserved.\n//\n\n#ifndef kern_rtc_h\n#define kern_rtc_h\n\n#include <Headers/kern_util.hpp>\n#include <IOKit/IOService.h>\n#include <IOKit/acpi/IOACPIPlatformDevice.h>\n#include <IOKit/IOUserClient.h>\n\nclass RTCStorage {\n\t/**\n\t *  Apple-specific RTC checksum addresses\n\t */\n\tstatic constexpr uint8_t APPLERTC_HASHED_ADDR = 0x0E;\n\tstatic constexpr uint8_t APPLERTC_CHECKSUM_ADDR1 = 0x58;\n\tstatic constexpr uint8_t APPLERTC_CHECKSUM_ADDR2 = 0x59;\n\n\t/**\n\t *  AppleRTC service handle\n\t */\n\tIOService *rtcSrv {nullptr};\n\n\t/**\n\t *  Low-level RTC read (does not check memory availability).\n\t *\n\t *  @param dev     RTC ACPI device\n\t *  @param offset  offset\n\t *\n\t *  @result read value\n\t */\n\tstatic uint8_t readByte(IOACPIPlatformDevice *dev, uint8_t offset);\n\n\t/**\n\t *  Low-level RTC write (does not check memory availability).\n\t *\n\t *  @param dev     RTC ACPI device\n\t *  @param offset  offset\n\t *  @param value   value\n\t */\n\tstatic void writeByte(IOACPIPlatformDevice *dev, uint8_t offset, uint8_t value);\npublic:\n\t/**\n\t *  General access RTC ports on x86 systems.\n\t */\n\tstatic constexpr uint8_t R_PCH_RTC_INDEX = 0x70;\n\tstatic constexpr uint8_t R_PCH_RTC_TARGET = 0x71;\n\tstatic constexpr uint8_t R_PCH_RTC_EXT_INDEX = 0x72;\n\tstatic constexpr uint8_t R_PCH_RTC_EXT_TARGET = 0x73;\n\n\t/**\n\t *  RTC has N banks (we support up to 2) of memory.\n\t */\n\tstatic constexpr uint8_t RTC_BANK_SIZE = 0x80;\n\n\t/**\n\t *  Non-ext RTC index register uses higher bit for nmi.\n\t */\n\tstatic constexpr uint8_t RTC_DATA_MASK = 0x7F;\n\tstatic constexpr uint8_t RTC_NMI_MASK = 0x80;\n\n\t/**\n\t *  Time offsets.\n\t */\n\tstatic constexpr uint8_t RTC_SEC = 0x00;\n\tstatic constexpr uint8_t RTC_MIN = 0x02;\n\tstatic constexpr uint8_t RTC_HOUR = 0x04;\n\n\tstatic constexpr uint8_t RTC_DAY = 0x07;\n\tstatic constexpr uint8_t RTC_MON = 0x08;\n\tstatic constexpr uint8_t RTC_YEAR = 0x09;\n\t\n#if __MAC_OS_X_VERSION_MIN_REQUIRED < __MAC_10_5\n\tusing t_UserClientExternalMethod = IOReturn (*)(IORegistryEntry *service, uint32_t selector, IOExternalMethodArguments * arguments,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tIOExternalMethodDispatch * dispatch, OSObject * target, void * reference);\n\tstatic constexpr size_t UserClientExternalMethodIndex = 0x129;\n#endif\n\n\t/**\n\t *  Attempt to connect to active RTC service\n\t *\n\t *  @param wait  wait for service availability\n\t *\n\t *  @return true on success\n\t */\n\tEXPORT bool init(bool wait=true);\n\n\t/**\n\t *  Release obtained RTC service\n\t */\n\tEXPORT void deinit();\n\n\t/**\n\t *  Check whether extended (higher 128 bytes) is available\n\t *\n\t *  @return true on success\n\t */\n\tEXPORT bool checkExtendedMemory();\n\n\t/**\n\t *  Read memory from RTC\n\t *\n\t *  @param off     offset to read data from\n\t *  @param size    data size\n\t *  @param buffer  data buffer to read to\n\t *\n\t *  @return true on success\n\t */\n\tEXPORT bool read(uint64_t off, uint32_t size, uint8_t *buffer);\n\n\t/**\n\t *  Write memory to RTC\n\t *\n\t *  @param off     offset to write data to\n\t *  @param size    data size\n\t *  @param buffer  data buffer to write from\n\t *\n\t *  @return true on success\n\t */\n\tEXPORT bool write(uint64_t off, uint32_t size, uint8_t *buffer);\n\n\t/**\n\t *  Obtain RTC device for direct writing.\n\t *  Written as inline to avoid IOACPIPlatformDevice dependency.\n\t *\n\t *  @param name  device name\n\t *\n\t *  @return RTC ACPI device for I/O access, must be released\n\t */\n\tstatic inline IOACPIPlatformDevice *getRTCDevice(const char *name = \"PNP0B00\") {\n\t\tIOService *rtcDev = nullptr;\n\t\tauto matching = IOService::nameMatching(name);\n\t\tif (matching) {\n#if __MAC_OS_X_VERSION_MIN_REQUIRED < __MAC_10_6\n\t\t\trtcDev = IOService::waitForService(matching);\n\t\t\tif (rtcDev)\n\t\t\t\trtcDev->retain();\n#else\n\t\t\trtcDev = IOService::waitForMatchingService(matching);\n\t\t\tmatching->release();\n#endif\n\n\t\t} else {\n\t\t\tSYSLOG(\"rtc\", \"failed to allocate rtc device matching\");\n\t\t}\n\n\t\tif (rtcDev) {\n\t\t\tDBGLOG(\"rtc\", \"got rtc device\");\n\t\t\tauto acpiDev = OSDynamicCast(IOACPIPlatformDevice, rtcDev);\n\t\t\tif (acpiDev) {\n\t\t\t\tDBGLOG(\"rtc\", \"got rtc acpi device\");\n\t\t\t\treturn acpiDev;\n\t\t\t} else {\n\t\t\t\tSYSLOG(\"rtc\", \"failed to obtain rtc acpi device\");\n\t\t\t\trtcDev->release();\n\t\t\t}\n\t\t}\n\n\t\tSYSLOG(\"rtc\", \"failed to get rtc device\");\n\t\treturn nullptr;\n\t}\n\n\t/**\n\t *  Directly read RTC memory (UNSAFE, usage with caution!)\n\t *\n\t *  @param dev      RTC device\n\t *  @param off      offset to read data from\n\t *  @param size     data size\n\t *  @param buffer   data buffer to read to\n\t *  @param introff  turn interrupts off\n\t *\n\t *  @return true on success\n\t */\n\tEXPORT static void readDirect(IOACPIPlatformDevice *dev, uint8_t off, uint16_t size, uint8_t *buffer, bool introff);\n\n\t/**\n\t *  Directly write RTC memory (UNSAFE, usage with caution!)\n\t *\n\t *  @param dev      RTC device\n\t *  @param off        offset to read data from\n\t *  @param size       data size\n\t *  @param buffer     data buffer to read to\n\t *  @param updatecrc  recalculate crc on write\n\t *  @param introff    turn interrupts off\n\t *\n\t *  @return true on success\n\t */\n\tEXPORT static void writeDirect(IOACPIPlatformDevice *dev, uint8_t off, uint16_t size, uint8_t *buffer, bool updatecrc, bool introff);\n\n\n\t/**\n\t *  Directly read RTC memory (UNSAFE, usage with caution!), this is just a compatibility function.\n\t *\n\t *  @param off      offset to read data from\n\t *  @param size     data size\n\t *  @param buffer   data buffer to read to\n\t *  @param introff  turn interrupts off\n\t *\n\t *  @return true on success\n\t */\n\tstatic inline bool readDirect(uint8_t off, uint16_t size, uint8_t *buffer, bool introff) {\n\t\tif (size > RTC_BANK_SIZE*2 - off) {\n\t\t\tSYSLOG(\"rtc\", \"reading unsupported size\");\n\t\t\treturn false;\n\t\t}\n\n\t\tauto rtc = getRTCDevice();\n\t\tif (rtc) {\n\t\t\treadDirect(rtc, off, size, buffer, introff);\n\t\t\trtc->release();\n\t\t\treturn true;\n\t\t}\n\n\t\treturn false;\n\t}\n\n\t/**\n\t *  Directly write RTC memory (UNSAFE, usage with caution!), this is just a compatibility function.\n\t *\n\t *  @param off        offset to read data from\n\t *  @param size       data size\n\t *  @param buffer     data buffer to read to\n\t *  @param updatecrc  recalculate crc on write\n\t *  @param introff    turn interrupts off\n\t *\n\t *  @return true on success\n\t */\n\tstatic inline bool writeDirect(uint8_t off, uint16_t size, uint8_t *buffer, bool updatecrc, bool introff) {\n\t\tif (size > RTC_BANK_SIZE*2 - off) {\n\t\t\tSYSLOG(\"rtc\", \"writing unsupported size\");\n\t\t\treturn false;\n\t\t}\n\n\t\tauto rtc = getRTCDevice();\n\t\tif (rtc) {\n\t\t\twriteDirect(rtc, off, size, buffer, updatecrc, introff);\n\t\t\trtc->release();\n\t\t\treturn true;\n\t\t}\n\n\t\treturn false;\n\t}\n};\n\n#endif /* kern_rtc_h */\n"
  },
  {
    "path": "EFI_DEBUG/EFI/OC/Kexts/Lilu.kext/Contents/Resources/Headers/kern_time.hpp",
    "content": "//\n//  kern_time.hpp\n//  Lilu\n//\n//  Copyright © 2018 vit9696. All rights reserved.\n//\n\n#ifndef kern_time_hpp\n#define kern_time_hpp\n\n#include <kern/clock.h>\n\n/**\n *  Obtain current system time in nanoseconds\n *\n *  @return current time\n */\ninline uint64_t getCurrentTimeNs() {\n\tuint64_t currt = 0;\n\tabsolutetime_to_nanoseconds(mach_absolute_time(), &currt);\n\treturn currt;\n}\n\n/**\n *  Obtain current calendar system time in nanoseconds\n *\n *  @return current time\n */\ninline uint64_t getCalendarTimeNs() {\n\tclock_sec_t sc;\n\tclock_nsec_t ns;\n\tclock_get_calendar_nanotime(&sc, &ns);\n\treturn static_cast<uint64_t>(sc) * NSEC_PER_SEC + ns;\n}\n\n/**\n *  Obtain time passed since some timestamp in nanoseconds\n *\n *  @param start   starting timestamp\n *  @param current timestamp to check against (pass 0 for current time)\n *\n *  @return delta or 0 (if current time equals or precedeces the start)\n */\ninline uint64_t getTimeSinceNs(uint64_t start, uint64_t current = 0) {\n\tif (current == 0)\n\t\tcurrent = getCurrentTimeNs();\n\tif (current > start)\n\t\treturn current - start;\n\treturn 0;\n}\n\n/**\n *  Obtain time left till a timestamp in the future in nanoseconds\n *\n *  @param start   starting timestamp\n *  @param timeout timeout for the event\n *  @param current timestamp to check against (pass 0 for current time)\n *\n *  @return delta or 0 (if the timeout is over)\n */\ninline uint64_t getTimeLeftNs(uint64_t start, uint64_t timeout, uint64_t current = 0) {\n\tif (current == 0)\n\t\tcurrent = getCurrentTimeNs();\n\tif (start + timeout > current)\n\t\treturn start + timeout - current;\n\treturn 0;\n}\n\n/**\n *  Convert from nanoseconds to milliseconds\n *\n *  @param t timestamp in ns\n *\n *  @return timestamp in ms\n */\nconstexpr  uint64_t convertNsToMs(uint64_t t) {\n\treturn t / 1000000;\n}\n\n/**\n *  Convert from nanoseconds to seconds\n *\n *  @param t timestamp in ns\n *\n *  @return timestamp in s\n */\nconstexpr uint64_t convertNsToSc(uint64_t t) {\n\treturn t / 1000000000;\n}\n\n/**\n *  Convert from milliseconds to seconds\n *\n *  @param t timestamp in ms\n *\n *  @return timestamp in s\n */\nconstexpr uint64_t convertMsToSc(uint64_t t) {\n\treturn t / 1000;\n}\n\n/**\n *  Convert from milliseconds to nanoseconds\n *\n *  @param t timestamp in ms\n *\n *  @return timestamp in ns\n */\nconstexpr uint64_t convertMsToNs(uint64_t t) {\n\treturn t * 1000000;\n}\n\n/**\n *  Convert from seconds to nanoseconds\n *\n *  @param t timestamp in s\n *\n *  @return timestamp in ns\n */\nconstexpr uint64_t convertScToNs(uint64_t t) {\n\treturn t * 1000000000;\n}\n\n/**\n *  Convert from seconds to milliseconds\n *\n *  @param t timestamp in s\n *\n *  @return timestamp in ms\n */\nconstexpr uint64_t convertScToMs(uint64_t t) {\n\treturn t * 1000;\n}\n\n#endif /* kern_time_hpp */\n"
  },
  {
    "path": "EFI_DEBUG/EFI/OC/Kexts/Lilu.kext/Contents/Resources/Headers/kern_user.hpp",
    "content": "//\n//  kern_user.hpp\n//  Lilu\n//\n//  Copyright © 2016-2017 vit9696. All rights reserved.\n//\n\n#ifndef kern_user_hpp\n#define kern_user_hpp\n\n#include <Headers/kern_config.hpp>\n#include <Headers/kern_patcher.hpp>\n\n#include <mach/shared_region.h>\n#include <sys/kauth.h>\n\nclass UserPatcher {\npublic:\n\t/**\n\t *  Initialise UserPatcher, prepare for modifications\n\t *\n\t *  @param patcher        kernel patcher instance\n\t *  @param preferSlowMode policy boot type\n\t *\n\t *  @return true on success\n\t */\n\tbool init(KernelPatcher &patcher, bool preferSlowMode);\n\n\t/**\n\t *  Deinitialise UserPatcher, must be called regardless of the init error\n\t */\n\tvoid deinit();\n\n\t/**\n\t *  Obtain page protection\n\t *\n\t *  @param map  vm map\n\t *  @param addr map offset\n\t *\n\t *  @return protection\n\t */\n\tEXPORT vm_prot_t getPageProtection(vm_map_t map, vm_map_address_t addr);\n\n\t/**\n\t *  Mach segment/section references for patch locations\n\t */\n\tenum FileSegment : uint32_t {\n\t\tSegmentsTextStart,\n\t\tSegmentTextText = SegmentsTextStart,\n\t\tSegmentTextStubs,\n\t\tSegmentTextConst,\n\t\tSegmentTextCstring,\n\t\tSegmentTextUstring,\n\t\tSegmentsTextEnd = SegmentTextUstring,\n\t\tSegmentsDataStart,\n\t\tSegmentDataConst = SegmentsDataStart,\n\t\tSegmentDataCfstring,\n\t\tSegmentDataCommon,\n\t\tSegmentsDataEnd = SegmentDataCommon,\n\t\tSegmentTotal\n\t};\n\n\t/**\n\t *  Mach segment names kept in sync with FileSegment\n\t */\n\tconst char *fileSegments[SegmentTotal] {\n\t\t\"__TEXT\",\n\t\t\"__TEXT\",\n\t\t\"__TEXT\",\n\t\t\"__TEXT\",\n\t\t\"__TEXT\",\n\t\t\"__DATA\",\n\t\t\"__DATA\",\n\t\t\"__DATA\"\n\t};\n\n\t/**\n\t *  Mach section names kept in sync with FileSegment\n\t */\n\tconst char *fileSections[SegmentTotal] {\n\t\t\"__text\",\n\t\t\"__stubs\",\n\t\t\"__const\",\n\t\t\"__cstring\",\n\t\t\"__ustring\",\n\t\t\"__const\",\n\t\t\"__cfstring\",\n\t\t\"__common\"\n\t};\n\n\t/**\n\t * Binary modification patches flags\n\t */\n\tenum BinaryModPatchFlags {\n\t\t/*\n\t\t * Only applies to one process, not globally.\n\t\t */\n\t\tLocalOnly = 1\n\t};\n\n\t/**\n\t *  Structure holding lookup-style binary patches\n\t */\n\tstruct BinaryModPatch {\n\t\tcpu_type_t cpu;\n\t\tuint32_t flags;\n\t\tconst uint8_t *find;\n\t\tconst uint8_t *replace;\n\t\tsize_t size;\n\t\tsize_t skip;\n\t\tsize_t count;\n\t\tFileSegment segment;\n\t\tuint32_t section;\n\t};\n\n#if defined(__i386__)\n\tstatic_assert(sizeof(BinaryModPatch) == 36, \"BinaryModPatch 32-bit ABI compatibility failure\");\n#elif defined(__x86_64__)\n\tstatic_assert(sizeof(BinaryModPatch) == 56, \"BinaryModPatch 64-bit ABI compatibility failure\");\n#else\n#error Unsupported arch.\n#endif\n\n\t/**\n\t *  Structure describing the modifications for the binary\n\t */\n\tstruct BinaryModInfo {\n\t\tconst char *path;\n\t\tBinaryModPatch *patches;\n\t\tsize_t count;\n\t\tvm_address_t startTEXT;\n\t\tvm_address_t endTEXT;\n\t\tvm_address_t startDATA;\n\t\tvm_address_t endDATA;\n\t};\n\n\t/**\n\t *  Structure describing relevant processes run\n\t */\n\tstruct ProcInfo {\n\t\t/**\n\t\t *  Process matching flags\n\t\t */\n\t\tenum ProcFlags {\n\t\t\tMatchExact  = 0,\n\t\t\tMatchAny    = 1,\n\t\t\tMatchPrefix = 2,\n\t\t\tMatchSuffix = 4,\n\t\t\tMatchMask   = MatchExact | MatchAny | MatchPrefix | MatchSuffix\n\t\t};\n\n\t\t/**\n\t\t *  Unused (aka disabled) proc info section\n\t\t */\n\t\tstatic constexpr uint32_t SectionDisabled {0};\n\n\t\tconst char *path {nullptr};\n\t\tuint32_t len {0};\n\t\tuint32_t section {SectionDisabled};\n\t\tuint32_t flags {MatchExact};\n\t};\n\n\t/**\n\t *  External callback type for on process invocation\n\t *\n\t *  @param user    user provided pointer at registering\n\t *  @param patcher user patcher instance\n\t *  @param map     process image vm_map\n\t *  @param path    path to the binary absolute or relative\n\t *  @param len     path length excluding null terminator\n\t */\n\tusing t_BinaryLoaded = void (*)(void *user, UserPatcher &patcher, vm_map_t map, const char *path, size_t len);\n\n\t/**\n\t *  Instructs user patcher to do further actions\n\t *\n\t *  @param procs    process list\n\t *  @param procNum  process list size\n\t *  @param mods     modification list\n\t *  @param modNum   modification list size\n\t *  @param callback callback function\n\t *  @param user     pointer that will be passed to the callback function\n\t */\n\tbool registerPatches(ProcInfo **procs, size_t procNum, BinaryModInfo **mods, size_t modNum, t_BinaryLoaded callback, void *user);\n\n\t/**\n\t *  Reads current process header\n\t *\n\t *  @param map     vm map\n\t *  @param header  Mach-O header\n\t *\n\t *  @return false on failure\n\t */\n\tEXPORT bool getTaskHeader(vm_map_t map, mach_header_64 &header);\n\n\t/**\n\t *  Disables dyld_shared_cache for the current process\n\t *\n\t *  @param map  vm map\n\t *\n\t *  @return false on mach image failure\n\t */\n\tEXPORT bool injectRestrict(vm_map_t map);\n\n\t/**\n\t *  Injects payload into the process right after the header with EP replacement.\n\t *\n\t *  @param map      vm map\n\t *  @param payload  code\n\t *  @param size     code size (up to PAGE_SIZE)\n\t *  @param ep       original entrypoint (may be written to code before copying)\n\t *\n\t *  @return false on mach image failure\n\t */\n\tEXPORT bool injectPayload(vm_map_t map, uint8_t *payload, size_t size, void *ep=nullptr);\n\n\t/**\n\t *  Allocates a new segment in the process.\n\t *\n\t *  @param map      vm map\n\t *  @param addr     allocation address (e.g. a little below SHARED_REGION_BASE_X86_64)\n\t *  @param payload  code\n\t *  @param size     code size (must be PAGE_SIZE-aligned)\n\t *  @param prot     segment protection\n\t *\n\t *  @return allocated address or 0 on failure\n\t */\n\tEXPORT vm_address_t injectSegment(vm_map_t taskPort, vm_address_t addr, uint8_t *payload, size_t size, vm_prot_t prot);\n\n\t/**\n\t *  Activates monitoring functions if necessary\n\t */\n\tvoid activate();\n\n\t/**\n\t *  Get active dyld shared cache path.\n\t *\n\t *  @return shared cache path constant\n\t */\n\tEXPORT static const char *getSharedCachePath() DEPRECATE(\"Use matchSharedCachePath, macOS 12 has multiple caches\");\n\n\t/**\n\t *  Check if the supplied path matches dyld shared cache path.\n\t *\n\t *  @param path  image path\n\t *\n\t *  @return shared cache path constant\n\t */\n\tEXPORT static bool matchSharedCachePath(const char *path);\n\nprivate:\n\n\t/**\n\t *  Kernel function prototypes\n\t */\n\tusing vm_shared_region_t = void *;\n\tusing shared_file_mapping_np = void *;\n\tusing t_currentMap = vm_map_t (*)(void);\n\tusing t_getTaskMap = vm_map_t (*)(task_t);\n\tusing t_getMapMin = vm_map_offset_t (*)(vm_map_t);\n\tusing t_vmMapSwitchProtect = void (*)(vm_map_t, boolean_t);\n\tusing t_vmMapCheckProtection = boolean_t (*)(vm_map_t, vm_map_offset_t, vm_map_offset_t, vm_prot_t);\n\tusing t_vmMapReadUser = kern_return_t (*)(vm_map_t, vm_map_address_t, const void *, vm_size_t);\n\tusing t_vmMapWriteUser = kern_return_t (*)(vm_map_t, const void *, vm_map_address_t, vm_size_t);\n\n\t/**\n\t *  Original kernel function trampolines\n\t */\n\tmach_vm_address_t orgCodeSignValidatePageWrapper {};\n\tmach_vm_address_t orgCodeSignValidateRangeWrapper {};\n\tmach_vm_address_t orgVmSharedRegionMapFile {};\n\tmach_vm_address_t orgVmSharedRegionSlide {};\n\tmach_vm_address_t orgVmSharedRegionSlideMojave {};\n\tt_currentMap orgCurrentMap {nullptr};\n\tt_getMapMin orgGetMapMin {nullptr};\n\tt_getTaskMap orgGetTaskMap {nullptr};\n\tt_vmMapSwitchProtect orgVmMapSwitchProtect {nullptr};\n\tt_vmMapCheckProtection orgVmMapCheckProtection {nullptr};\n\tt_vmMapReadUser orgVmMapReadUser {nullptr};\n\tt_vmMapWriteUser orgVmMapWriteUser {nullptr};\n\tmach_vm_address_t orgTaskSetMainThreadQos {};\n\n\t/**\n\t *  Kernel function wrappers\n\t */\n\tstatic boolean_t codeSignValidatePageWrapper(void *blobs, memory_object_t pager, memory_object_offset_t page_offset, const void *data, unsigned *tainted);\n\tstatic boolean_t codeSignValidateRangeWrapper(void *blobs, memory_object_t pager, memory_object_offset_t range_offset, const void *data, memory_object_size_t data_size, unsigned *tainted);\n\tstatic vm_map_t swapTaskMap(task_t task, thread_t thread, vm_map_t map, boolean_t doswitch);\n\tstatic vm_map_t vmMapSwitch(vm_map_t map);\n\tstatic kern_return_t vmSharedRegionMapFile(vm_shared_region_t shared_region, unsigned int mappings_count, shared_file_mapping_np *mappings, memory_object_control_t file_control, memory_object_size_t file_size, void *root_dir, uint32_t slide, user_addr_t slide_start, user_addr_t slide_size);\n\tstatic void execsigs(proc_t p, thread_t thread);\n\tstatic int vmSharedRegionSlide(uint32_t slide, mach_vm_offset_t entry_start_address, mach_vm_size_t entry_size, mach_vm_offset_t slide_start, mach_vm_size_t slide_size, memory_object_control_t sr_file_control);\n\tstatic int vmSharedRegionSlideMojave(uint32_t slide, mach_vm_offset_t entry_start_address, mach_vm_size_t entry_size, mach_vm_offset_t slide_start, mach_vm_size_t slide_size, mach_vm_offset_t slid_mapping, memory_object_control_t sr_file_control);\n\tstatic void taskSetMainThreadQos(task_t task, thread_t main_thread);\n\n\t/**\n\t *  Applies page patches to the memory range\n\t *\n\t *  @param data_ptr  pages in kernel memory\n\t *  @param data_size data size divisible by PAGE_SIZE\n\t */\n\tvoid performPagePatch(const void *data_ptr, size_t data_size);\n\n\t/**\n\t * dyld shared cache map entry structure\n\t */\n\tstruct MapEntry {\n\t\tconst char *filename;\n\t\tsize_t length;\n\t\tvm_address_t startTEXT;\n\t\tvm_address_t endTEXT;\n\t\tvm_address_t startDATA;\n\t\tvm_address_t endDATA;\n\t};\n\n\t/**\n\t *  Obtains __TEXT addresses from .map files\n\t *\n\t *  @param mapBuf     read .map file\n\t *  @param mapSz      .map file size\n\t *  @param mapEntries entries to look for\n\t *  @param nentries   number of entries\n\t *\n\t *  @return number of entries found\n\t */\n\tsize_t mapAddresses(const char *mapBuf, MapEntry *mapEntries, size_t nentries);\n\n\t/**\n\t *  Stored ASLR slide of dyld shared cache\n\t */\n\tuint32_t storedSharedCacheSlide {0};\n\n\t/**\n\t *  Set once shared cache slide is defined\n\t */\n\tbool sharedCacheSlideStored {false};\n\n\t/**\n\t *  Set on init to decide on whether to use __RESTRICT or patch dyld shared cache\n\t */\n\tbool patchDyldSharedCache {false};\n\n\t/**\n\t *  Kernel patcher instance\n\t */\n\tKernelPatcher *patcher {nullptr};\n\n\t/**\n\t *  Pending callback entry\n\t */\n\tstruct PendingUser {\n\t\t/**\n\t\t *  Patch requested for path\n\t\t */\n\t\tchar path[MAXPATHLEN] {};\n\n\t\t/**\n\t\t *  Patch requested for path\n\t\t */\n\t\tuint32_t pathLen {0};\n\t};\n\n\t/**\n\t *  Stored pending callback\n\t */\n\tThreadLocal<PendingUser *, 32> pending;\n\n\t/**\n\t *  Current minimal proc name length\n\t */\n\tuint32_t currentMinProcLength {0};\n\n\t/**\n\t *  Provided binary modification list\n\t */\n\tBinaryModInfo **binaryMod {nullptr};\n\n\t/**\n\t *  Amount of provided binary modifications\n\t */\n\tsize_t binaryModSize {0};\n\n\t/**\n\t *  Provided process list\n\t */\n\tProcInfo **procInfo {nullptr};\n\n\t/**\n\t *  Amount of provided processes\n\t */\n\tsize_t procInfoSize {0};\n\n\t/**\n\t *  Provided global callback for on proc invocation\n\t */\n\tppair<t_BinaryLoaded, void *> userCallback {};\n\n\t/**\n\t *  Applies dyld shared cache patches\n\t *\n\t *  @param map     current process map\n\t *  @param slide   ASLR offset\n\t *  @param cpu     cache cpu type\n\t *  @param restore true to rollback the changes\n\t */\n\tvoid patchSharedCache(vm_map_t map, uint32_t slide, cpu_type_t cpu, bool applyChanges=true);\n\n\t/**\n\t *  Structure holding userspace lookup patches\n\t */\n\tstruct LookupStorage {\n\t\tstruct PatchRef {\n\t\t\tsize_t i {0};\n\t\t\tevector<off_t> pageOffs;\n\t\t\tevector<off_t> segOffs;\n\t\t\tstatic PatchRef *create() {\n\t\t\t\treturn new PatchRef;\n\t\t\t}\n\t\t\tstatic void deleter(PatchRef *r NONNULL) {\n\t\t\t\tr->pageOffs.deinit();\n\t\t\t\tr->segOffs.deinit();\n\t\t\t\tdelete r;\n\t\t\t}\n\t\t};\n\n\t\tconst BinaryModInfo *mod {nullptr};\n\t\tevector<PatchRef *, PatchRef::deleter> refs;\n\t\tPage *page {nullptr};\n\t\tvm_address_t pageOff {0};\n\n\t\tstatic LookupStorage *create() {\n\t\t\tauto p = new LookupStorage;\n\t\t\tif (p) {\n\t\t\t\tp->page = Page::create();\n\t\t\t\tif (!p->page) {\n\t\t\t\t\tdeleter(p);\n\t\t\t\t\tp = nullptr;\n\t\t\t\t}\n\t\t\t}\n\t\t\treturn p;\n\t\t}\n\n\t\tstatic void deleter(LookupStorage *p NONNULL) {\n\t\t\tif (p->page) {\n\t\t\t\tPage::deleter(p->page);\n\t\t\t\tp->page = nullptr;\n\t\t\t}\n\t\t\tp->refs.deinit();\n\t\t\tdelete p;\n\t\t}\n\t};\n\n\tstruct Lookup {\n\t\tuint32_t offs[4] {};\n\t\tstatic constexpr size_t matchNum {4};\n\t\tevector<uint64_t> c[matchNum];\n\t};\n\n\tevector<LookupStorage *, LookupStorage::deleter> lookupStorage;\n\tLookup lookup;\n\t\n\t/**\n\t *  Restrict 64-bit entry overlapping DYLD_SHARED_CACHE to enforce manual library loading\n\t */\n\tsegment_command_64 restrictSegment64 {\n\t\tLC_SEGMENT_64,\n\t\tsizeof(segment_command_64),\n\t\t\"__RESTRICT\",\n\t\tSHARED_REGION_BASE_X86_64,\n\t\t1, 0, 0, 0, 0, 0, 0\n\t};\n\n\t/**\n\t *  Restrict 32-bit entry overlapping DYLD_SHARED_CACHE to enforce manual library loading\n\t */\n\tsegment_command restrictSegment32 {\n\t\tLC_SEGMENT,\n\t\tsizeof(segment_command),\n\t\t\"__RESTRICT\",\n\t\tSHARED_REGION_BASE_I386,\n\t\t1, 0, 0, 0, 0, 0, 0\n\t};\n\n\t/**\n\t *  Temporary buffer for reading image data\n\t */\n\tuint8_t tmpBufferData[PAGE_SIZE*3] {};\n\n\t/**\n\t *  Kernel auth listener handle\n\t */\n\tkauth_listener_t listener {nullptr};\n\n\t/**\n\t *  Patcher status\n\t */\n\t_Atomic(bool) activated = false;\n\n\t/**\n\t *  Validation cookie\n\t */\n\tvoid *cookie {nullptr};\n\n\t/**\n\t *  Flags for codesign (PL) offset in struct proc. (uint32_t p_csflags)\n\t */\n\tsize_t csFlagsOffset {0};\n\n\t/**\n\t *  Exec callback\n\t *\n\t *  @param credential kauth credential\n\t *  @param idata      cookie\n\t *  @param action     passed action, we only need KAUTH_FILEOP_EXEC\n\t *  @param arg0       pointer to vnode (vnode *) for executable\n\t *  @param arg1       pointer to path (char *) to executable\n\t *\n\t *  @return 0 to allow further execution\n\t */\n\tstatic int execListener(kauth_cred_t /* credential */, void *idata, kauth_action_t action, uintptr_t /* arg0 */, uintptr_t arg1, uintptr_t, uintptr_t);\n\n\t/**\n\t *  Unrestricted vm_protect, that takes care of Mojave codesign limitations for everyone's good.\n\t *  See vm_protect description.\n\t */\n\tkern_return_t vmProtect(vm_map_t map, vm_offset_t start, vm_size_t size, boolean_t set_maximum, vm_prot_t new_protection);\n\n\t/**\n\t *  Callback invoked at process loading\n\t *\n\t *  @param path binary path\n\t *  @param len  path length\n\t */\n\tvoid onPath(const char *path, uint32_t len);\n\n\t/**\n\t *  Reads files from BinaryModInfos and prepares lookupStorage\n\t *\n\t *  @return true on success\n\t */\n\tbool loadFilesForPatching();\n\n\t/**\n\t *  Reads dyld shared cache and obtains segment offsets\n\t *\n\t *  @return true on success\n\t */\n\tbool loadDyldSharedCacheMapping();\n\n\t/**\n\t *  Prepares quick page lookup based on lookupStorage values\n\t *\n\t *  @return true on success\n\t */\n\tbool loadLookups();\n\n\t/**\n\t *  Hooks memory access to get ready for patching\n\t *\n\t *  @return true on success\n\t */\n\tbool hookMemoryAccess();\n\n\t/**\n\t *  Peforms the actual binary patching\n\t *\n\t *  @param map  vm map\n\t *  @param path binary path\n\t *  @param len  path length\n\t */\n\tvoid patchBinary(vm_map_t map, const char *path, uint32_t len);\n\n\t/**\n\t *  DYLD shared cache map path for 10.10+ on Haswell\n\t */\n\tstatic constexpr const char *SharedCacheMapHaswell {\"/private/var/db/dyld/dyld_shared_cache_x86_64h.map\"};\n\n\t/**\n\t *  DYLD shared cache map path for all other systems and older CPUs\n\t */\n\tstatic constexpr const char *SharedCacheMapLegacy {\"/private/var/db/dyld/dyld_shared_cache_x86_64.map\"};\n\n\t/**\n\t *  DYLD shared cache path on Haswell+ before Big Sur\n\t */\n\tstatic constexpr const char *sharedCacheHaswell {\"/private/var/db/dyld/dyld_shared_cache_x86_64h\"};\n\n\t/**\n\t *  DYLD shared cache path on older systems before Big Sur\n\t */\n\tstatic constexpr const char *sharedCacheLegacy {\"/private/var/db/dyld/dyld_shared_cache_x86_64\"};\n\t\n\t/**\n\t *  DYLD shared cache map path on Haswell+ on Big Sur\n\t */\n\tstatic constexpr const char *bigSurSharedCacheMapHaswell {\"/System/Library/dyld/dyld_shared_cache_x86_64h.map\"};\n\t\n\t/**\n\t *  DYLD shared cache map path on older systems on Big Sur\n\t */\n\tstatic constexpr const char *bigSurSharedCacheMapLegacy {\"/System/Library/dyld/dyld_shared_cache_x86_64.map\"};\n\n\t/**\n\t *  DYLD shared cache path on Haswell+ on Big Sur\n\t */\n\tstatic constexpr const char *bigSurSharedCacheHaswell {\"/System/Library/dyld/dyld_shared_cache_x86_64h\"};\n\n\t/**\n\t *  DYLD shared cache path on older systems on Big Sur\n\t */\n\tstatic constexpr const char *bigSurSharedCacheLegacy {\"/System/Library/dyld/dyld_shared_cache_x86_64\"};\n\n\t/**\n\t *  DYLD shared cache map path on Haswell+ on Ventura\n\t */\n\tstatic constexpr const char *venturaSharedCacheMapHaswell {\"/System/Volumes/Preboot/Cryptexes/OS/System/Library/dyld/dyld_shared_cache_x86_64h.map\"};\n\t\n\t/**\n\t *  DYLD shared cache map path on older systems on Ventura\n\t */\n\tstatic constexpr const char *venturaSharedCacheMapLegacy {\"/System/Volumes/Preboot/Cryptexes/OS/System/Library/dyld/dyld_shared_cache_x86_64.map\"};\n\n\t/**\n\t *  DYLD shared cache path on Haswell+ on Ventura\n\t */\n\tstatic constexpr const char *venturaSharedCacheHaswell {\"/System/Volumes/Preboot/Cryptexes/OS/System/Library/dyld/dyld_shared_cache_x86_64h\"};\n\n\t/**\n\t *  DYLD shared cache path on older systems on Ventura\n\t */\n\tstatic constexpr const char *venturaSharedCacheLegacy {\"/System/Volumes/Preboot/Cryptexes/OS/System/Library/dyld/dyld_shared_cache_x86_64\"};\n\n};\n\n#endif /* kern_user_hpp */\n"
  },
  {
    "path": "EFI_DEBUG/EFI/OC/Kexts/Lilu.kext/Contents/Resources/Headers/kern_util.hpp",
    "content": "//\n//  kern_util.hpp\n//  Lilu\n//\n//  Copyright © 2016-2017 vit9696. All rights reserved.\n//\n\n#ifndef kern_util_hpp\n#define kern_util_hpp\n\n#include <Headers/kern_config.hpp>\n#include <Headers/kern_compat.hpp>\n\n#include <libkern/libkern.h>\n#include <libkern/c++/OSObject.h>\n#include <libkern/OSDebug.h>\n#include <mach/vm_types.h>\n#include <mach/vm_prot.h>\n#include <sys/proc.h>\n#include <IOKit/IOLib.h>\n#include <stdatomic.h>\n\n#define xStringify(a) Stringify(a)\n#define Stringify(a) #a\n\n#define xConcat(a, b) Concat(a, b)\n#define Concat(a, b) a ## b\n\n/**\n *  Prefix name with your plugin name (to ease symbolication and avoid conflicts)\n */\n#define ADDPR(a) xConcat(xConcat(PRODUCT_NAME, _), a)\n\n/**\n *  Debugging state exported for your plugin\n */\nextern bool ADDPR(debugEnabled);\n\n/**\n *  Debugging print delay used as an ugly hack around printf bufferisation,\n *  which results in messages not appearing in the boot log.\n *  Use liludelay=1000 (1 second) boot-arg to put a second after each message.\n */\nextern uint32_t ADDPR(debugPrintDelay);\n\n/**\n *  Kernel version major\n */\nextern const int version_major;\n\n/**\n *  Kernel version minor\n */\nextern const int version_minor;\n\n/**\n *  Kernel map\n */\nextern vm_map_t kernel_map;\n\n/**\n *  Kernel proc\n */\nextern proc_t kernproc;\n\n/**\n *  For noreturn failures\n */\n#define UNREACHABLE() do { __builtin_unreachable(); } while (0)\n\n/**\n *  Conditional logging to system log prefixed with you plugin name\n *\n *  @param cond  precondition\n *  @param str   printf-like string\n */\n#define SYSLOG_COND(cond, module, str, ...)                                                                \t\t\t  \\\n\tdo {                                                                                                   \t\t\t  \\\n\t    if (cond)                                                                                          \t\t\t  \\\n\t        lilu_os_log( \"%s%10s: @ \" str \"\\n\", xStringify(PRODUCT_NAME), safeString(module), ## __VA_ARGS__);\t\t  \\\n\t} while (0)\n\n/**\n *  Write to system log prefixed with you plugin name\n *\n *  @param module log module\n *  @param str    printf-like string\n */\n#define SYSLOG(module, str, ...) SYSLOG_COND(true, module, str, ## __VA_ARGS__)\n\n/**\n *  Conditional tracing to system log prefixed with you plugin name\n *\n *  @param cond   precondition\n *  @param module log module\n *  @param str    printf-like string\n */\n#define SYSTRACE_COND(cond, module, str, ...)                                                                        \t\t\t \\\n\tdo {                                                                                                             \t\t\t \\\n\t    if (cond) {                                                                                                  \t\t\t \\\n\t        SYSLOG(module, str, ## __VA_ARGS__);                                                                     \t\t\t \\\n\t\t    OSReportWithBacktrace( \"%s%10s: @ \" str \"\\n\", xStringify(PRODUCT_NAME), safeString(module), ## __VA_ARGS__);\t\t\t \\\n\t    }                                                                                                            \t\t\t \\\n\t} while (0)\n\n/**\n *  Write call trace to system log prefixed with you plugin name\n *\n *  @param module log module\n *  @param str    printf-like string\n */\n#define SYSTRACE(module, str, ...) SYSTRACE_COND(true, module, str, ## __VA_ARGS__)\n\n/**\n *  Conditional panic prefixed with you plugin name\n *\n *  @param cond   precondition\n *  @param module log module\n *  @param str    printf-like string\n */\n#define PANIC_COND(cond, module, str, ...)                                                             \t\t\\\n\tdo {                                                                                               \t\t\\\n\t    if (cond) {                                                                                    \t\t\\\n\t        (panic)( \"%s%10s: @ \" str \"\\n\", xStringify(PRODUCT_NAME), safeString(module), ## __VA_ARGS__);  \\\n\t        UNREACHABLE();                                                                             \t\t\\\n\t    }                                                                                              \t\t\\\n\t} while (0)\n\n/**\n *  Cause immediate kernel panic prefixed with you plugin name\n *\n *  @param module log module\n *  @param str    printf-like string\n */\n#define PANIC(module, str, ...)  PANIC_COND(true, module, str, ## __VA_ARGS__)\n\n#ifdef DEBUG\n\n/**\n *  Conditional debug logging to system log prefixed with you plugin name\n *\n *  @param cond   precondition\n *  @param module log module\n *  @param str    printf-like string\n */\n#define DBGLOG_COND(cond, module, str, ...)                                                     \\\n\tdo {                                                                                        \\\n\t    SYSLOG_COND(ADDPR(debugEnabled) && (cond), module, \"%s\" str, \"(DBG) \", ## __VA_ARGS__); \\\n\t} while (0)\n\n/**\n *  Write debug message to system log prefixed with you plugin name\n *\n *  @param module log module\n *  @param str    printf-like string\n */\n#define DBGLOG(module, str, ...) DBGLOG_COND(true, module, str, ## __VA_ARGS__)\n\n/**\n *  Conditional debug tracing to system log prefixed with you plugin name\n *\n *  @param cond   precondition\n *  @param module log module\n *  @param str    printf-like string\n */\n#define DBGTRACE_COND(cond, module, str, ...)                                                     \\\n\tdo {                                                                                          \\\n\t    SYSTRACE_COND(ADDPR(debugEnabled) && (cond), module, \"%s\" str, \"(DBG) \", ## __VA_ARGS__); \\\n\t} while (0)\n\n/**\n *  Write debug call trace to system log prefixed with you plugin name\n *\n *  @param module log module\n *  @param str    printf-like string\n */\n#define DBGTRACE(module, str, ...) DBGTRACE_COND(true, module, str, ## __VA_ARGS__)\n\n#else /* DEBUG */\n\n#define DBGLOG_COND(module, str, ...) do { } while (0)\n#define DBGLOG(module, str, ...) do { } while (0)\n#define DBGTRACE_COND(module, str, ...) do { } while (0)\n#define DBGTRACE(module, str, ...) do { } while (0)\n\n#endif\n\n/**\n *  Macros to bypass kernel address printing protection\n */\n#define PRIKADDR \"0x%08X%08X\"\n#define CASTKADDR(x) \\\n\tstatic_cast<uint32_t>(reinterpret_cast<uint64_t>(x) >> 32), \\\n\tstatic_cast<uint32_t>(reinterpret_cast<uint64_t>(x))\n\n/**\n *  Ugly floating point printing macros\n */\n#define PRIFRAC \"%lld.%04lld\"\n#define CASTFRAC(x) static_cast<int64_t>(x), static_cast<int64_t>(((x) - static_cast<int64_t>(x)) * 10000)\n\n/**\n *  Macros to print the UUID\n */\n#define PRIUUID \"%02X%02X%02X%02X-%02X%02X-%02X%02X-%02X%02X-%02X%02X%02X%02X%02X%02X\"\n#define CASTUUID(uuid) \\\n\treinterpret_cast<const uint8_t *>(uuid)[0], \\\n\treinterpret_cast<const uint8_t *>(uuid)[1], \\\n\treinterpret_cast<const uint8_t *>(uuid)[2], \\\n\treinterpret_cast<const uint8_t *>(uuid)[3], \\\n\treinterpret_cast<const uint8_t *>(uuid)[4], \\\n\treinterpret_cast<const uint8_t *>(uuid)[5], \\\n\treinterpret_cast<const uint8_t *>(uuid)[6], \\\n\treinterpret_cast<const uint8_t *>(uuid)[7], \\\n\treinterpret_cast<const uint8_t *>(uuid)[8], \\\n\treinterpret_cast<const uint8_t *>(uuid)[9], \\\n\treinterpret_cast<const uint8_t *>(uuid)[10], \\\n\treinterpret_cast<const uint8_t *>(uuid)[11], \\\n\treinterpret_cast<const uint8_t *>(uuid)[12], \\\n\treinterpret_cast<const uint8_t *>(uuid)[13], \\\n\treinterpret_cast<const uint8_t *>(uuid)[14], \\\n\treinterpret_cast<const uint8_t *>(uuid)[15]\n\n/**\n *  Export function or symbol for linking\n */\n#define EXPORT __attribute__((visibility(\"default\")))\n\n/**\n *  Ensure the symbol is not exported\n */\n#define PRIVATE __attribute__((visibility(\"hidden\")))\n\n/**\n *  For private fallback symbol definition\n */\n#define WEAKFUNC __attribute__((weak))\n\n/**\n *  Remove padding between fields\n */\n#define PACKED __attribute__((packed))\n\n/**\n *  Deprecate the interface\n */\n#define DEPRECATE(x) __attribute__((deprecated(x)))\n\n/**\n *  Non-null argument\n */\n#define NONNULL __attribute__((nonnull))\n\n/**\n *  Compiler hints regarding branching\n */\n#define LIKELY(x) __builtin_expect(!!(x), 1)\n#define UNLIKELY(x) __builtin_expect(!!(x), 0)\n\n/**\n *  This function is supposed to workaround missing entries in the system log.\n *  By providing its own buffer for logging data.\n *\n *  @param format  formatted string\n */\nEXPORT extern \"C\" void lilu_os_log(const char *format, ...) __printflike(1, 2);\n\n/**\n *  Two-way substring search\n *\n *  @param stack    String to search in\n *  @param needle   Substring to search for\n *  @param len      Length of substring\n *\n *  @return substring address if there or nullptr\n */\nEXPORT const char *strstr(const char *stack, const char *needle, size_t len=0);\n\n/**\n *  Reverse character search\n *\n *  @param stack    String to search in\n *  @param ch       Character to search for\n *\n *  @return character address if there or null\n */\nEXPORT char *strrchr(const char *stack, int ch);\n\n/**\n *  XNU kernel implementation of a C-standard qsort function normally not exported by the kernel.\n *\n *  @param a    array to sort\n *  @param n    array length\n *  @param es   array element size\n *  @param cmp  array element comparator\n */\nEXPORT void qsort(void *a, size_t n, size_t es, int (*cmp)(const void *, const void *));\n\n/**\n *  Portable implementation of memmem function performing byte sequence (needle) search in another byte sequence (haystack).\n *\n *  @param h0    haystack\n *  @param k    haystack size\n *  @param n0   needle\n *  @param l  needle size\n *\n *  @return pointer to found sequence or NULL\n */\nEXPORT void *lilu_os_memmem(const void *h0, size_t k, const void *n0, size_t l);\n\n/**\n *  Portable implementation of memchr function performing byte search in a byte sequence.\n *\n *  @param src    source to search in\n *  @param c    byte to find\n *  @param n   source size in bytes\n *\n *  @return pointer to found byte or NULL\n */\nEXPORT void *lilu_os_memchr(const void *src, int c, size_t n);\n\n/**\n *  Count array elements\n *\n *  @param array   Array to process\n *\n *  @return number of elements\n */\ntemplate <class T, size_t N>\nconstexpr size_t arrsize(const T (&array)[N]) {\n\treturn N;\n}\n\n/**\n *  C-style memory management from libkern, missing from headers\n */\nextern \"C\" {\n\tvoid *kern_os_malloc(size_t size);\n\tvoid *kern_os_calloc(size_t num, size_t size);\n\tvoid kern_os_free(void *addr);\n\tvoid *kern_os_realloc(void *addr, size_t nsize);\n\t// kern_os_free does not check its argument for nullptr\n\tEXPORT void lilu_os_free(void *addr);\n}\n\n#if defined(__i386__)\n/**\n *  ml_get_interrupts_enabled implementation as ml_get_interrupts_enabled is not exported on 10.5 or older\n */\ninline bool lilu_get_interrupts_enabled() {\n\tuint32_t flags;\n\n\t__asm__ volatile (\"pushf; pop\t%0\" :  \"=r\" (flags));\n\treturn (flags & EFL_IF) != 0;\n}\n\n/**\n *  Wrapper around PE_parse_boot_arg as PE_parse_boot_argn is not exported in 10.4\n */\ninline bool lilu_get_boot_args(const char *arg_string, void *arg_ptr, int max_len) {\n\treturn PE_parse_boot_arg(arg_string, arg_ptr);\n}\n\n/**\n *  Implementation of strlcpy for 32-bit as strlcpy is not exported in 10.4\n */\nEXPORT size_t lilu_strlcpy(char *dst, const char *src, size_t siz);\n\n#elif defined(__x86_64__)\n#define lilu_get_interrupts_enabled   ml_get_interrupts_enabled\n#define lilu_get_boot_args            PE_parse_boot_argn\n#define lilu_strlcpy                  strlcpy\n\n#else\n#error Unsupported arch.\n#endif\n\n/**\n *  Known kernel versions\n */\nenum KernelVersion {\n\tTiger         = 8,\n\tLeopard       = 9,\n\tSnowLeopard   = 10,\n\tLion          = 11,\n\tMountainLion  = 12,\n\tMavericks     = 13,\n\tYosemite      = 14,\n\tElCapitan     = 15,\n\tSierra        = 16,\n\tHighSierra    = 17,\n\tMojave        = 18,\n\tCatalina      = 19,\n\tBigSur        = 20,\n\tMonterey      = 21,\n\tVentura       = 22,\n\tSonoma        = 23,\n\tSequoia       = 24,\n\tTahoe         = 25,\n};\n\n/**\n *  Kernel minor version for symmetry\n */\nusing KernelMinorVersion = int;\n\n/**\n *  Obtain major kernel version\n *\n *  @return numeric kernel version\n */\ninline KernelVersion getKernelVersion() {\n\treturn static_cast<KernelVersion>(version_major);\n}\n\n/**\n *  Obtain minor kernel version\n *\n *  @return numeric minor kernel version\n */\ninline KernelMinorVersion getKernelMinorVersion() {\n\treturn static_cast<KernelMinorVersion>(version_minor);\n}\n\n/**\n *  Check whether kernel boot argument is passed ignoring the value (e.g. -arg or arg).\n *\n *  @param name  argument name\n *\n *  @return true if argument was passed\n */\ninline bool checkKernelArgument(const char *name) {\n\tint val[16];\n\treturn lilu_get_boot_args(name, val, sizeof(val));\n}\n\n/**\n *  Parse apple version at compile time\n *\n *  @param version string literal representing apple version (e.g. 1.1.1)\n *\n *  @return numeric kernel version\n */\nconstexpr size_t parseModuleVersion(const char *version) {\n\treturn (size_t)(version[0] - '0') * 100 + (version[2] - '0') * 10 + (version[4] - '0');\n}\n\n/**\n *  Access struct member by its offset\n *\n *  @param T     pointer to the field you need\n *  @param that  pointer to struct\n *  @param off   offset in bytes to the member\n *\n *  @return reference to the struct member\n */\ntemplate <typename T>\ninline T &getMember(void *that, size_t off) {\n\treturn *reinterpret_cast<T *>(static_cast<uint8_t *>(that) + off);\n}\n\n/**\n *  Align value by align (page size by default)\n *\n *  @param size  value\n *\n *  @return algined value\n */\ntemplate <typename T>\ninline T alignValue(T size, T align = 4096) {\n\treturn (size + align - 1) & (~(align - 1));\n}\n\n/**\n *  Check pointer alignment for type T\n *\n *  @param p  pointer\n *\n *  @return true if properly aligned\n */\ntemplate<typename T>\ninline bool isAligned(T *p) {\n\treturn reinterpret_cast<uintptr_t>(p) % alignof(T) == 0;\n}\n\n/**\n *  Obtain bit value of size sizeof(T)\n *  Warning, you are suggested to always pass the type explicitly!\n *\n *  @param n  bit no\n *\n *  @return bit value\n */\ntemplate <typename T>\nconstexpr T getBit(T n) {\n\treturn static_cast<T>(1U) << n;\n}\n\n/**\n *  Obtain bit mask of size sizeof(T)\n *  Warning, you are suggested to always pass the type explicitly!\n *\n *  @param hi  starting high bit\n *  @param lo  ending low bit\n *\n *  @return bit mask\n */\ntemplate <typename T>\nconstexpr T getBitMask(T hi, T lo) {\n\treturn (getBit(hi)|(getBit(hi)-1U)) & ~(getBit(lo)-1U);\n}\n\n/**\n *  Obtain bit field of size sizeof(T)\n *  Warning, you are suggested to always pass the type explicitly!\n *\n *  @param so  source\n *  @param hi  starting high bit\n *  @param lo  ending low bit\n *\n *  @return bit field value\n */\ntemplate <typename T>\nconstexpr T getBitField(T so, T hi, T lo) {\n\treturn (so & getBitMask(hi, lo)) >> lo;\n}\n\n/**\n *  Set bit field of size sizeof(T)\n *  Warning, you are suggested to always pass the type explicitly!\n *\n *  @param va  value\n *  @param hi  starting high bit\n *  @param lo  ending low bit\n *\n *  @return bit field value\n */\ntemplate <typename T>\nconstexpr T setBitField(T so, T hi, T lo) {\n\treturn (so << lo) & getBitMask(hi, lo);\n}\n\n/**\n *  This is an ugly replacement to std::find_if, allowing you\n *  to check whether a container consists only of value values.\n *\n *  @param in     container\n *  @param size   container size\n *  @param value  value to look for\n *\n *  @return true if an element different from value was found\n */\ntemplate <typename T, typename Y>\ninline bool findNotEquals(T &in, size_t size, Y value) {\n\tfor (size_t i = 0; i < size; i++)\n\t\tif (in[i] != value)\n\t\t\treturn true;\n\treturn false;\n}\n\n/**\n *  Returns non-null string when they can be null\n *\n *  @param str  original string\n *\n *  @return non-null string\n */\ninline const char *safeString(const char *str) {\n\treturn str ? str : \"(null)\";\n}\n\n/**\n *  A shorter form of writing reinterpret_cast<decltype(&org)>(ptr)\n */\ntemplate <typename T>\ninline T FunctionCast(T org, mach_vm_address_t ptr) {\n\treturn reinterpret_cast<T>(ptr);\n}\n\n/**\n *  Reference cleaner\n */\ntemplate<class T> struct remove_reference      {typedef T type;};\ntemplate<class T> struct remove_reference<T&>  {typedef T type;};\ntemplate<class T> struct remove_reference<T&&> {typedef T type;};\n\n\n/**\n *  Typed buffer allocator\n */\nnamespace Buffer {\n\t/**\n\t *  Allocating more than 1 GB is unreasonable for stability purposes.\n\t */\n\tstatic constexpr size_t BufferMax = 1024*1024*1024;\n\n\ttemplate <typename T>\n\tinline T *create(size_t size) {\n\t\tsize_t s = sizeof(T) * size;\n\t\tif (s > BufferMax) return nullptr;\n\t\treturn static_cast<T *>(kern_os_malloc(s));\n\t}\n\n\ttemplate <typename T>\n\tinline bool resize(T *&buf, size_t size) {\n\t\tsize_t s = sizeof(T) * size;\n\t\tif (s > BufferMax) return false;\n\t\tauto nbuf = static_cast<T *>(kern_os_realloc(buf, s));\n\t\tif (nbuf) {\n\t\t\tbuf = nbuf;\n\t\t\treturn true;\n\t\t}\n\n\t\treturn false;\n\t}\n\n\ttemplate <typename T>\n\tinline void deleter(T *buf NONNULL) {\n\t\tlilu_os_free(buf);\n\t}\n}\n\n/**\n *  Dynamically allocated page\n */\nstruct Page {\n\t/**\n\t *  Allocates a page\n\t *\n\t *  @return true on success\n\t */\n\tEXPORT bool alloc();\n\n\t/**\n\t *  Sets page protection\n\t *\n\t *  @param prot protection bitmask\n\t *\n\t *  @return true on success\n\t */\n\tEXPORT bool protect(vm_prot_t prot);\n\n\t/**\n\t *  Deletes the page\n\t *\n\t *  @param p page\n\t */\n\tEXPORT static void deleter(Page *p NONNULL);\n\n\t/**\n\t *  Creates a page object\n\t *\n\t *  @return pointer to new page object or nullptr\n\t */\n\tEXPORT static Page *create();\n\n\t/**\n\t *  Page buffer\n\t */\n\tuint8_t *p {nullptr};\n};\n\n/**\n *  Thread specific container of T values in up to N threads\n */\ntemplate <typename T, size_t N>\nclass ThreadLocal {\n\t/**\n\t *  A list of tread identifiers\n\t */\n\t_Atomic(thread_t) threads[N] {};\n\n\t/**\n\t *  A list of value references\n\t */\n\tT values[N] {};\n\npublic:\n\t/**\n\t *  Initialise storage\n\t */\n\tvoid init() {}\n\n\t/**\n\t *  Deinitialise storage\n\t */\n\tvoid deinit() {\n\t\tfor (size_t i = 0; i < N; i++) {\n\t\t\tatomic_store_explicit(&threads[i], nullptr, memory_order_relaxed);\n\t\t\tvalues[i] = {};\n\t\t}\n\t}\n\n\t/**\n\t *  Set or overwrite thread specific value\n\t *\n\t *  @param value  value to store\n\t *\n\t *  @return true on success\n\t */\n\tbool set(T value) {\n\t\tauto currThread = current_thread();\n\t\tT *ptr = nullptr;\n\n\t\t// Find previous value if any\n\t\tfor (size_t i = 0; ptr == nullptr && i < N; i++)\n\t\t\tif (atomic_load_explicit(&threads[i], memory_order_acquire) == currThread)\n\t\t\t\tptr = &values[i];\n\n\t\t// Find null value if any\n\t\tfor (size_t i = 0; ptr == nullptr && i < N; i++) {\n\t\t\tthread_t nullThread = nullptr;\n\t\t\tif (atomic_compare_exchange_strong_explicit(&threads[i], &nullThread, currThread,\n\t\t\t\tmemory_order_acq_rel, memory_order_acquire))\n\t\t\t\tptr = &values[i];\n\t\t}\n\n\t\t// Insert if we can\n\t\tif (ptr) *ptr = value;\n\n\t\treturn ptr != nullptr;\n\t}\n\n\t/**\n\t *  Get thread specific value\n\t *\n\t *  @return pointer to stored value on success\n\t */\n\tT *get() {\n\t\tauto currThread = current_thread();\n\n\t\tfor (size_t i = 0; i < N; i++)\n\t\t\tif (atomic_load_explicit(&threads[i], memory_order_acquire) == currThread)\n\t\t\t\treturn &values[i];\n\n\t\treturn nullptr;\n\t}\n\n\t/**\n\t *  Unset thread specific value if present\n\t *\n\t *  @return true on success\n\t */\n\tbool erase() {\n\t\tauto currThread = current_thread();\n\n\t\tfor (size_t i = 0; i < N; i++) {\n\t\t\tif (atomic_load_explicit(&threads[i], memory_order_acquire) == currThread) {\n\t\t\t\tvalues[i] = {};\n\t\t\t\tthread_t nullThread = nullptr;\n\t\t\t\treturn atomic_compare_exchange_strong_explicit(&threads[i], &currThread,\n\t\t\t\t\tnullThread, memory_order_acq_rel, memory_order_acquire);\n\t\t\t}\n\t\t}\n\n\t\treturn false;\n\t}\n};\n\n/**\n *  Use this deleter when storing scalar types\n */\ntemplate <typename T>\nstatic void emptyDeleter(T) { /* no dynamic alloc */ }\n\ntemplate <typename T, typename Y, void (*deleterT)(T)=emptyDeleter<T>, void (*deleterY)(Y)=emptyDeleter<Y>>\nstruct ppair {\n\tT first;\n\tY second;\n\n\tstatic ppair *create() {\n\t\treturn new ppair;\n\t}\n\n\tstatic void deleter(ppair *p NONNULL) {\n\t\tdeleterT(p->first);\n\t\tdeleterY(p->second);\n\t\tdelete p;\n\t}\n};\n\n/**\n *  Embedded vector-like container\n *  You must call deinit before destruction\n *  Ugh, someone, please, port libc++ to XNU...\n *\n *  @param T        held type\n *  @param P        destructible type\n *  @param deleter  type destructor\n */\ntemplate <typename T, typename P, void (*deleter)(P)=emptyDeleter<P>>\nclass evector_base {\n\tT *ptr {nullptr};\n\tsize_t cnt {0};\n\tsize_t rsvd {0};\npublic:\n\t/**\n\t *  Return evector size\n\t *\n\t *  @return element count\n\t */\n\tsize_t size() const {\n\t\treturn cnt;\n\t}\n\n\t/**\n\t *  Return pointer to the elements\n\t *  Valid until evector contents change\n\t *\n\t *  @return elements ptr\n\t */\n\tT *data() const {\n\t\treturn ptr;\n\t}\n\n\t/**\n\t *  Return last element id\n\t *\n\t *  @return element id\n\t */\n\tsize_t last() const {\n\t\treturn cnt-1;\n\t}\n\n\t/**\n\t *  Return evector element reference\n\t *\n\t *  @param index array index\n\t *\n\t *  @return the element at provided index\n\t */\n\tT &operator [](size_t index) {\n\t\treturn ptr[index];\n\t}\n\n\t/**\n\t *  Return evector const element reference\n\t *\n\t *  @param index array index\n\t *\n\t *  @return the element at provided index\n\t */\n\tconst T &operator [](size_t index) const {\n\t\treturn ptr[index];\n\t}\n\n\t/**\n\t *  Reserve memory for at least N elements\n\t *\n\t *  @param num  amount of elements\n\t *\n\t *  @return elements ptr or null\n\t */\n\ttemplate <size_t MUL = 1>\n\tT *reserve(size_t num) {\n\t\tif (rsvd < num) {\n\t\t\tT *nPtr = static_cast<T *>(kern_os_realloc(ptr, MUL * num * sizeof(T)));\n\t\t\tif (nPtr) {\n\t\t\t\tptr = nPtr;\n\t\t\t\trsvd = MUL * num;\n\t\t\t} else {\n\t\t\t\treturn nullptr;\n\t\t\t}\n\t\t}\n\n\t\treturn ptr;\n\t}\n\n\t/**\n\t *  Erase evector element\n\t *\n\t *  @param index element index\n\t */\n\tvoid erase(size_t index, bool free=true) {\n\t\tdeleter(ptr[index]);\n\t\tif (--cnt != index)\n\t\t\tlilu_os_memmove(&ptr[index], &ptr[index + 1], (cnt - index) * sizeof(T));\n\n\t\tif (free && cnt == 0) {\n\t\t\tkern_os_free(ptr);\n\t\t\tptr = nullptr;\n\t\t\trsvd = 0;\n\t\t}\n\t}\n\n\t/**\n\t *  Add an element to evector end\n\t *\n\t *  @param &element an element to add\n\t *\n\t *  @return true on success\n\t */\n\ttemplate <size_t MUL = 1>\n\tbool push_back(T &element) {\n\t\tif (reserve<MUL>(cnt+1)) {\n\t\t\tptr[cnt] = element;\n\t\t\tcnt++;\n\t\t\treturn true;\n\t\t}\n\n\t\tSYSLOG(\"evector\", \"insertion failure\");\n\t\treturn false;\n\t}\n\n\t/**\n\t *  Add an element to evector end\n\t *\n\t *  @param &element an element to add\n\t *\n\t *  @return true on success\n\t */\n\ttemplate <size_t MUL = 1>\n\tbool push_back(T &&element) {\n\t\tif (reserve<MUL>(cnt+1)) {\n\t\t\tptr[cnt] = element;\n\t\t\tcnt++;\n\t\t\treturn true;\n\t\t}\n\n\t\tSYSLOG(\"evector\", \"insertion failure\");\n\t\treturn false;\n\t}\n\n\tevector_base() = default;\n\tevector_base(const evector_base &) = delete;\n\tevector_base operator =(const evector_base &) = delete;\n\n\t/**\n\t * Free the used memory\n\t */\n\tvoid deinit() {\n\t\tif (ptr) {\n\t\t\tfor (size_t i = 0; i < cnt; i++)\n\t\t\t\tdeleter(ptr[i]);\n\t\t\tkern_os_free(ptr);\n\t\t\tptr = nullptr;\n\t\t\tcnt = rsvd = 0;\n\t\t}\n\t}\n};\n\n/**\n*  Embedded vector-like container, simplified specialisation\n*  You must call deinit before destruction\n*\n*  @param T        held type\n*  @param deleter  type destructor\n*/\ntemplate <typename T, void (*deleter)(T)=emptyDeleter<T>>\nclass evector : public evector_base<typename remove_reference<T>::type, T, deleter> { };\n\n/**\n *  Represents a circular buffer protected by a recursive mutex lock\n */\ntemplate <typename T>\nstruct CircularBuffer {\nprivate:\n\t/**\n\t *  The internal storage\n\t */\n\tT *storage {nullptr};\n\t\n\t/**\n\t *  The buffer capacity\n\t */\n\tIOItemCount size {0};\n\t\n\t/**\n\t *  The current index for the next read operation\n\t */\n\tIOItemCount indexr {0};\n\t\n\t/**\n\t *  The current index for the next write operation\n\t */\n\tIOItemCount indexw {0};\n\t\n\t/**\n\t *  The current number of elements in the buffer\n\t */\n\tIOItemCount count {0};\n\t\n\t/**\n\t *  The recursive mutex lock that protects the buffer\n\t */\n\tIORecursiveLock *lock {nullptr};\n\t\npublic:\n\t/**\n\t *  Initialize a circular buffer\n\t *\n\t *  @param buffer A non-null storage buffer\n\t *  @param capacity The total number of elements\n\t *  @return `true` on success, `false` otherwise.\n\t *  @warning The caller is responsbile for managing the lifecycle of the given storage buffer.\n\t */\n\tbool init(T *buffer, IOItemCount capacity) {\n\t\tstorage = buffer;\n\t\tsize = capacity;\n\t\tlock = IORecursiveLockAlloc();\n\t\treturn lock != nullptr;\n\t}\n\t\n\t/**\n\t *  Initialize a circular buffer\n\t *\n\t *  @param storage A storage buffer\n\t *  @return `true` on success, `false` otherwise.\n\t *  @warning The caller is responsbile for managing the lifecycle of the given storage buffer.\n\t */\n\ttemplate <size_t N>\n\tbool init(T (&storage)[N]) {\n\t\treturn init(storage, N);\n\t}\n\t\n\t/**\n\t *  Deinitialize the circular buffer\n\t */\n\tvoid deinit() {\n\t\tIORecursiveLockFree(lock);\n\t}\n\t\n\t/**\n\t *  Create a circular buffer with the given capacity\n\t *\n\t *  @param size The total number of elements\n\t *  @return A non-null instance on success, `nullptr` if no memory.\n\t *  @warning The caller must invoke `CircularBuffer::destory()` to release the returned buffer.\n\t */\n\tstatic CircularBuffer<T> *withCapacity(IOItemCount size) {\n\t\tauto storage = Buffer::create<T>(size);\n\t\tif (storage == nullptr)\n\t\t\treturn nullptr;\n\t\t\n\t\tauto instance = new CircularBuffer<T>();\n\t\tif (instance == nullptr) {\n\t\t\tBuffer::deleter(storage);\n\t\t\treturn nullptr;\n\t\t}\n\t\t\n\t\tif (!instance->init(storage, size)) {\n\t\t\tdelete instance;\n\t\t\tBuffer::deleter(storage);\n\t\t\treturn nullptr;\n\t\t}\n\t\t\n\t\treturn instance;\n\t}\n\t\n\t/**\n\t *  Destroy the given circular buffer\n\t *\n\t *  @param buffer A non-null circular buffer returned by `CircularBuffer::withCapacity()`.\n\t */\n\tstatic void deleter(CircularBuffer<T> *buffer NONNULL) {\n\t\tBuffer::deleter(buffer->storage);\n\t\tbuffer->deinit();\n\t\tdelete buffer;\n\t}\n\t\n\t/**\n\t *  Destory the given circular buffer if it is non-null and set it to nullptr\n\t *\n\t *  @param buffer A nullable circular buffer returned by `CircularBuffer::withCapacity()`.\n\t *  @note This function mimics the macro `OSSafeReleaseNULL()`.\n\t */\n\tstatic void safeDeleter(CircularBuffer<T> *&buffer) {\n\t\tif (buffer != nullptr) {\n\t\t\tdeleter(buffer);\n\t\t\tbuffer = nullptr;\n\t\t}\n\t}\n\t\n\t/**\n\t *  Check whether the circular buffer is empty\n\t *\n\t *  @return `true` if the buffer is empty, `false` otherwise.\n\t */\n\tbool isEmpty() {\n\t\tIORecursiveLockLock(lock);\n\t\tbool retVal = (count == 0) && (indexr == indexw);\n\t\tIORecursiveLockUnlock(lock);\n\t\treturn retVal;\n\t}\n\t\n\t/**\n\t *  Check whether the circular buffer is full\n\t *\n\t *  @return `true` if the buffer is full, `false` otherwise.\n\t */\n\tbool isFull() {\n\t\tIORecursiveLockLock(lock);\n\t\tbool retVal = (count == size) && (indexr == indexw);\n\t\tIORecursiveLockUnlock(lock);\n\t\treturn retVal;\n\t}\n\t\n\t/**\n\t *  Get the number of elements in the circular buffer\n\t *\n\t *  @return The current number of elements in the buffer.\n\t */\n\tIOItemCount getCount() {\n\t\tIORecursiveLockLock(lock);\n\t\tIOItemCount retVal = count;\n\t\tIORecursiveLockUnlock(lock);\n\t\treturn retVal;\n\t}\n\t\n\t/**\n\t *  Write the given element to the circular buffer\n\t *\n\t *  @param element The element to write\n\t *  @return `true` on success, `false` if the buffer is full.\n\t */\n\tbool push(const T &element) {\n\t\tIORecursiveLockLock(lock);\n\t\tif (isFull()) {\n\t\t\tIORecursiveLockUnlock(lock);\n\t\t\treturn false;\n\t\t}\n\t\tstorage[indexw] = element;\n\t\tindexw += 1;\n\t\tindexw %= size;\n\t\tcount += 1;\n\t\tIORecursiveLockUnlock(lock);\n\t\treturn true;\n\t}\n\t\n\t/**\n\t *  Read the next element from the circular buffer\n\t *\n\t *  @param element The element read from the buffer\n\t *  @return `true` on success, `false` if the buffer is empty.\n\t */\n\tbool pop(T& element) {\n\t\tIORecursiveLockLock(lock);\n\t\tif (isEmpty()) {\n\t\t\tIORecursiveLockUnlock(lock);\n\t\t\treturn false;\n\t\t}\n\t\telement = storage[indexr];\n\t\tindexr += 1;\n\t\tindexr %= size;\n\t\tcount -= 1;\n\t\tIORecursiveLockUnlock(lock);\n\t\treturn true;\n\t}\n};\n\n/**\n *  Wrap an object that is not an instance of OSObject\n */\nclass EXPORT OSObjectWrapper: public OSObject {\n\t/**\n\t *  Constructors & Destructors\n\t */\n\tOSDeclareDefaultStructors(OSObjectWrapper);\n\t\n\tusing super = OSObject;\n\t\n\t/**\n\t *  Wrapped object\n\t */\n\tvoid *object {nullptr};\n\t\npublic:\n\t/**\n\t *  Initialize the wrapper with the given object\n\t *\n\t *  @param object The wrapped object that is not an `OSObject`\n\t *  @return `true` on success, `false` otherwise.\n\t */\n\tEXPORT bool init(void *object);\n\t\n\t/**\n\t *  Reinterpret the wrapped object as the given type\n\t *\n\t *  @return The wrapped object of the given type.\n\t */\n\ttemplate <typename T>\n\tT *get() {\n\t\treturn reinterpret_cast<T *>(object);\n\t}\n\t\n\t/**\n\t *  Create a wrapper for the given object that is not an `OSObject`\n\t *\n\t *  @param object A non-null object\n\t *  @return A non-null wrapper on success, `nullptr` otherwise.\n\t *  @warning The caller is responsbile for managing the lifecycle of the given object.\n\t */\n\tEXPORT static OSObjectWrapper *with(void *object);\n};\n\nnamespace Value {\n\ttemplate <typename T>\n\tstruct Value {\n\t\tconst T &value;\n\n\t\texplicit Value(const T &value) : value(value) {}\n\n\t#if __cplusplus >= 201703L\n\t\t// Available as of C++17\n\t\ttemplate<typename... Ts>\n\t\tbool isOneOf(const Ts&... args) {\n\t\t\treturn ((value == args) || ...);\n\t\t}\n\n\t\t// Available as of C++17\n\t\ttemplate <typename... Ts>\n\t\tbool isNotOneOf(const Ts&... args) {\n\t\t\treturn ((value != args) && ...);\n\t\t}\n\t#endif\n\t};\n\t\n\ttemplate <typename T>\n\tstatic Value<T> of(const T &value) {\n\t\treturn Value<T>(value);\n\t}\n}\n\n#endif /* kern_util_hpp */\n"
  },
  {
    "path": "EFI_DEBUG/EFI/OC/Kexts/Lilu.kext/Contents/Resources/Headers/kern_version.hpp",
    "content": "//\n//  kern_version.hpp\n//  Lilu\n//\n//  Copyright © 2016-2020 vit9696. All rights reserved.\n//\n\n#ifndef kern_version_hpp\n#define kern_version_hpp\n\n#include <Headers/kern_util.hpp>\n\n#include <stdint.h>\n#include <sys/types.h>\n\n/**\n *  Slightly non-standard helpers to get the date in a YYYY-MM-DD format.\n */\ntemplate <size_t i>\ninline constexpr char getBuildYear() {\n\tstatic_assert(i < 4, \"Year consists of four digits\");\n\treturn __DATE__[7+i];\n}\n\ntemplate <size_t i>\ninline constexpr char getBuildMonth() {\n\tstatic_assert(i < 2, \"Month consists of two digits\");\n\tauto mon = static_cast<uint32_t>(__DATE__[0])\n\t\t| (static_cast<uint32_t>(__DATE__[1]) << 8U)\n\t\t| (static_cast<uint32_t>(__DATE__[2]) << 16U)\n\t\t| (static_cast<uint32_t>(__DATE__[3]) << 24U);\n\tswitch (mon) {\n\t\tcase ' naJ':\n\t\t\treturn \"01\"[i];\n\t\tcase ' beF':\n\t\t\treturn \"02\"[i];\n\t\tcase ' raM':\n\t\t\treturn \"03\"[i];\n\t\tcase ' rpA':\n\t\t\treturn \"04\"[i];\n\t\tcase ' yaM':\n\t\t\treturn \"05\"[i];\n\t\tcase ' nuJ':\n\t\t\treturn \"06\"[i];\n\t\tcase ' luJ':\n\t\t\treturn \"07\"[i];\n\t\tcase ' guA':\n\t\t\treturn \"08\"[i];\n\t\tcase ' peS':\n\t\t\treturn \"09\"[i];\n\t\tcase ' tcO':\n\t\t\treturn \"10\"[i];\n\t\tcase ' voN':\n\t\t\treturn \"11\"[i];\n\t\tcase ' ceD':\n\t\t\treturn \"12\"[i];\n\t\tdefault:\n\t\t\treturn '0';\n\t}\n}\n\ntemplate <size_t i>\ninline constexpr char getBuildDay() {\n\tstatic_assert(i < 2, \"Day consists of two digits\");\n\tif (i == 0 && __DATE__[4+i] == ' ')\n\t\treturn '0';\n\treturn __DATE__[4+i];\n}\n\n#if !defined(LILU_CUSTOM_KMOD_INIT) || !defined(LILU_CUSTOM_IOKIT_INIT) || defined(LILU_USE_KEXT_VERSION)\n\nstatic const char kextVersion[] {\n#ifdef DEBUG\n\t'D', 'B', 'G', '-',\n#else\n\t'R', 'E', 'L', '-',\n#endif\n\txStringify(MODULE_VERSION)[0], xStringify(MODULE_VERSION)[2], xStringify(MODULE_VERSION)[4], '-',\n\tgetBuildYear<0>(), getBuildYear<1>(), getBuildYear<2>(), getBuildYear<3>(), '-',\n\tgetBuildMonth<0>(), getBuildMonth<1>(), '-', getBuildDay<0>(), getBuildDay<1>(), '\\0'\n};\n\n#endif\n\n#endif /* kern_version_hpp */\n"
  },
  {
    "path": "EFI_DEBUG/EFI/OC/Kexts/Lilu.kext/Contents/Resources/Headers/plugin_start.hpp",
    "content": "//\n//  kern_start.hpp\n//  AppleALC\n//\n//  Copyright © 2016 vit9696. All rights reserved.\n//\n\n#ifndef kern_start_hpp\n#define kern_start_hpp\n\n#include <Headers/kern_util.hpp>\n\n#include <IOKit/IOService.h>\n#include <sys/types.h>\n\nstruct PluginConfiguration {\n\tconst char *product;        // Product name (e.g. xStringify(PRODUCT_NAME))\n\tsize_t version;             // Product version (e.g. parseModuleVersion(xStringify(MODULE_VERSION)))\n\tuint32_t runmode;           // Product supported environments (e.g. LiluAPI::AllowNormal)\n\tconst char **disableArg;    // Pointer to disabling boot arguments array\n\tsize_t disableArgNum;       // Number of disabling boot arguments\n\tconst char **debugArg;      // Pointer to debug boot arguments array\n\tsize_t debugArgNum;         // Number of debug boot arguments\n\tconst char **betaArg;       // Pointer to beta boot arguments array\n\tsize_t betaArgNum;          // Number of beta boot arguments\n\tKernelVersion minKernel;    // Minimal required kernel version\n\tKernelVersion maxKernel;    // Maximum supported kernel version\n\tvoid (*pluginStart)();      // Main function\n};\n\n#ifndef LILU_CUSTOM_KMOD_INIT\n\nextern PluginConfiguration ADDPR(config);\n\nextern bool ADDPR(startSuccess);\n\n#endif /* LILU_CUSTOM_KMOD_INIT */\n\n#ifndef LILU_CUSTOM_IOKIT_INIT\n\nclass EXPORT PRODUCT_NAME : public IOService {\n\tOSDeclareDefaultStructors(PRODUCT_NAME)\npublic:\n\tIOService *probe(IOService *provider, SInt32 *score) override;\n\tbool start(IOService *provider) override;\n\tvoid stop(IOService *provider) override;\n};\n\nextern PRODUCT_NAME *ADDPR(selfInstance);\n\n#endif /* LILU_CUSTOM_IOKIT_INIT */\n\n#endif /* kern_start_hpp */\n"
  },
  {
    "path": "EFI_DEBUG/EFI/OC/Kexts/Lilu.kext/Contents/Resources/Library/plugin_start.cpp",
    "content": "//\n//  plugin_start.cpp\n//  Lilu\n//\n//  Copyright © 2016-2017 vit9696. All rights reserved.\n//\n\n#include <Headers/plugin_start.hpp>\n#include <Headers/kern_api.hpp>\n#include <Headers/kern_util.hpp>\n#include <Headers/kern_version.hpp>\n\n#ifndef LILU_CUSTOM_KMOD_INIT\nbool ADDPR(startSuccess) = false;\n#else\n// Workaround custom kmod code and enable by default\nbool ADDPR(startSuccess) = true;\n#endif /* LILU_CUSTOM_KMOD_INIT */\n\nbool ADDPR(debugEnabled) = false;\nuint32_t ADDPR(debugPrintDelay) = 0;\n\n#ifndef LILU_CUSTOM_IOKIT_INIT\n\nOSDefineMetaClassAndStructors(PRODUCT_NAME, IOService)\n\nPRODUCT_NAME *ADDPR(selfInstance) = nullptr;\n\nIOService *PRODUCT_NAME::probe(IOService *provider, SInt32 *score) {\n\tADDPR(selfInstance) = this;\n\tsetProperty(\"VersionInfo\", kextVersion);\n\tauto service = IOService::probe(provider, score);\n\treturn ADDPR(startSuccess) ? service : nullptr;\n}\n\nbool PRODUCT_NAME::start(IOService *provider) {\n\tADDPR(selfInstance) = this;\n\tif (!IOService::start(provider)) {\n\t\tSYSLOG(\"init\", \"failed to start the parent\");\n\t\treturn false;\n\t}\n\n\treturn ADDPR(startSuccess);\n}\n\nvoid PRODUCT_NAME::stop(IOService *provider) {\n\tADDPR(selfInstance) = nullptr;\n\tIOService::stop(provider);\n}\n\n#endif /* LILU_CUSTOM_IOKIT_INIT */\n\n#ifndef LILU_CUSTOM_KMOD_INIT\n\nEXPORT extern \"C\" kern_return_t ADDPR(kern_start)(kmod_info_t *, void *) {\n\t// This is an ugly hack necessary on some systems where buffering kills most of debug output.\n\tlilu_get_boot_args(\"liludelay\", &ADDPR(debugPrintDelay), sizeof(ADDPR(debugPrintDelay)));\n\n\tauto error = lilu.requestAccess();\n\tif (error == LiluAPI::Error::NoError) {\n\t\terror = lilu.shouldLoad(ADDPR(config).product, ADDPR(config).version, ADDPR(config).runmode, ADDPR(config).disableArg, ADDPR(config).disableArgNum,\n\t\t\t\t\t\t\t\tADDPR(config).debugArg, ADDPR(config).debugArgNum, ADDPR(config).betaArg, ADDPR(config).betaArgNum, ADDPR(config).minKernel,\n\t\t\t\t\t\t\t\tADDPR(config).maxKernel, ADDPR(debugEnabled));\n\n\t\tif (error == LiluAPI::Error::NoError) {\n\t\t\tDBGLOG(\"init\", \"%s bootstrap %s\", xStringify(PRODUCT_NAME), kextVersion);\n\t\t\t(void)kextVersion;\n\t\t\tADDPR(startSuccess) = true;\n\t\t\tADDPR(config).pluginStart();\n\t\t} else {\n\t\t\tSYSLOG(\"init\", \"parent said we should not continue %d\", error);\n\t\t}\n\n\t\tlilu.releaseAccess();\n\t} else {\n\t\tSYSLOG(\"init\", \"failed to call parent %d\", error);\n\t}\n\t\n\tfor (size_t i = 0; i < ADDPR(config).debugArgNum; i++) {\n\t\tif (checkKernelArgument(ADDPR(config).debugArg[i])) {\n\t\t\tADDPR(debugEnabled) = true;\n\t\t\tbreak;\n\t\t}\n\t}\n\n\tif (checkKernelArgument(\"-liludbgall\"))\n\t\tADDPR(debugEnabled) = true;\n\n\t// Report success but actually do not start and let I/O Kit unload us.\n\t// This works better and increases boot speed in some cases.\n\treturn KERN_SUCCESS;\n}\n\nEXPORT extern \"C\" kern_return_t ADDPR(kern_stop)(kmod_info_t *, void *) {\n\t// It is not safe to unload Lilu plugins unless they were disabled!\n\treturn ADDPR(startSuccess) ? KERN_FAILURE : KERN_SUCCESS;\n}\n\n#endif /* LILU_CUSTOM_KMOD_INIT */\n"
  },
  {
    "path": "EFI_DEBUG/EFI/OC/Kexts/Lilu.kext/Contents/Resources/Library/wrappers/build.tool",
    "content": "#!/bin/bash\n#\n#  build.tool\n#  Lilu\n#\n#  Copyright © 2018 vit9696. All rights reserved.\n#\n\ncd $(dirname \"$0\") || exit 1\n\nrm -f *.o *.bin wrappers.inc entry32 entry64\n\nclang -m32 -c entry32.S || exit 1\nclang -m64 -c entry64.S || exit 1\n\nclang -m32 entry32.o -o entry32 || exit 1\nclang -m64 entry64.o -o entry64 || exit 1\n\nif [ \"$(nm entry32.o | grep '00000000 T _main')\" == \"\" ] || [ \"$(nm entry64.o | grep '0000000000000000 T _main')\" == \"\" ]; then\n  echo \"Invalid main address\"\n  exit 1\nfi\n\notool -t entry32 | grep -E '^0000' | sed 's#^[0-9a-f]*##' | xxd -r -p > entry32.bin\notool -t entry64 | grep -E '^0000' | sed 's#^[0-9a-f]*##' | xxd -r -p > entry64.bin\n\nsz32=$(stat -f '%z' entry32.bin)\nsz64=$(stat -f '%z' entry64.bin)\n\nbtr32=$(nm entry32.o | grep -E 't booter$' | cut -f1 -d' ')\nbtr64=$(nm entry64.o | grep -E 't booter$' | cut -f1 -d' ')\n\nep32=$(nm entry32.o | grep -E 't entrypoint$' | cut -f1 -d' ')\nep64=$(nm entry64.o | grep -E 't entrypoint$' | cut -f1 -d' ')\n\necho '//' > wrappers.inc\necho '//  wrappers.inc' >> wrappers.inc\necho '//  Lilu' >> wrappers.inc\necho '//' >> wrappers.inc\necho '//  Copyright © 2018 vit9696. All rights reserved.' >> wrappers.inc\necho '//' >> wrappers.inc\necho '' >> wrappers.inc\necho '// This is an autogenerated file, do not edit!' >> wrappers.inc\necho 'static uint8_t entryWrapper32[] = {' >> wrappers.inc\ncat entry32.bin | xxd -i >> wrappers.inc\necho '};' >> wrappers.inc\necho 'static uint8_t entryWrapper64[] = {' >> wrappers.inc\ncat entry64.bin | xxd -i >> wrappers.inc\necho '};' >> wrappers.inc\necho \"static_assert(sizeof(entryWrapper32) == ${sz32}, \\\"Invalid entryWrapper32 size\\\");\" >> wrappers.inc\necho \"static_assert(sizeof(entryWrapper64) == ${sz64}, \\\"Invalid entryWrapper64 size\\\");\" >> wrappers.inc\necho \"static constexpr size_t EntryWrapper32Booter {0x${btr32}};\" >> wrappers.inc\necho \"static constexpr size_t EntryWrapper64Booter {0x${btr64}};\" >> wrappers.inc\necho \"static constexpr size_t EntryWrapper32Entry {0x${ep32}};\" >> wrappers.inc\necho \"static constexpr size_t EntryWrapper64Entry {0x${ep64}};\" >> wrappers.inc\n\nrm -f *.o *.bin entry32 entry64\n"
  },
  {
    "path": "EFI_DEBUG/EFI/OC/Kexts/Lilu.kext/Contents/Resources/Library/wrappers/entry32.S",
    "content": "#\n#  entry32.S\n#  Lilu\n#\n#  Copyright © 2018 vit9696. All rights reserved.\n#\n\n.text\n.global _main\n_main:\n  push  %ebp\n  mov   %esp, %ebp\n  # ensure 16-byte alignment\n  and   $0xfffffff0, %esp\n  # int main(int argc, const char* argv[], const char* envp[], const char* apple[]);\n  push  20(%ebp)\n  push  16(%ebp)\n  push  12(%ebp)\n  push  8(%ebp)\n  call  get_booter\n# entrypoint-compatible wrapper\nbooter:\n  .word 0xFFFF\n  .word 0xFFFF\nget_booter:\n  pop   %edx\n  mov   (%edx), %edx\n  call  *%edx\n  xor   %eax, %eax\n  mov   %ebp, %esp\n  pop   %ebp\n  call  get_entrypoint\n# original entrypoint (main)\nentrypoint:\n  .word 0xFFFF\n  .word 0xFFFF\nget_entrypoint:\n  pop   %edx\n  mov   (%edx), %edx\n  jmp   *%edx\n_end:\n"
  },
  {
    "path": "EFI_DEBUG/EFI/OC/Kexts/Lilu.kext/Contents/Resources/Library/wrappers/entry64.S",
    "content": "#\n#  entry64.S\n#  Lilu\n#\n#  Copyright © 2018 vit9696. All rights reserved.\n#\n\n.text\n.global _main\n_main:\n  push  %rbp\n  mov   %rsp, %rbp\n  # ensure 16-byte alignment\n  and   $0xfffffffffffffff0, %rsp\n  # int main(int argc, const char* argv[], const char* envp[], const char* apple[]);\n  push  %rdi\n  push  %rsi\n  push  %rdx\n  push  %rcx\n  call  *booter(%rip)\n  xor   %eax, %eax\n  pop   %rcx\n  pop   %rdx\n  pop   %rsi\n  pop   %rdi\n  mov   %rbp, %rsp\n  pop   %rbp\n  jmp   *entrypoint(%rip)\n# original entrypoint (main)\nentrypoint:\n  .word 0xFFFF\n  .word 0xFFFF\n  .word 0xFFFF\n  .word 0xFFFF\n# entrypoint-compatible wrapper\nbooter:\n  .word 0xFFFF\n  .word 0xFFFF\n  .word 0xFFFF\n  .word 0xFFFF\n_end:\n"
  },
  {
    "path": "EFI_DEBUG/EFI/OC/Kexts/Lilu.kext/Contents/Resources/Library/wrappers/wrappers.inc",
    "content": "//\n//  wrappers.inc\n//  Lilu\n//\n//  Copyright © 2018 vit9696. All rights reserved.\n//\n\n// This is an autogenerated file, do not edit!\nstatic uint8_t entryWrapper32[] = {\n  0x55, 0x89, 0xe5, 0x83, 0xe4, 0xf0, 0xff, 0x75, 0x14, 0xff, 0x75, 0x10,\n  0xff, 0x75, 0x0c, 0xff, 0x75, 0x08, 0xe8, 0x04, 0x00, 0x00, 0x00, 0xff,\n  0xff, 0xff, 0xff, 0x5a, 0x8b, 0x12, 0xff, 0xd2, 0x31, 0xc0, 0x89, 0xec,\n  0x5d, 0xe8, 0x04, 0x00, 0x00, 0x00, 0xff, 0xff, 0xff, 0xff, 0x5a, 0x8b,\n  0x12, 0xff, 0xe2\n};\nstatic uint8_t entryWrapper64[] = {\n  0x55, 0x48, 0x89, 0xe5, 0x48, 0x83, 0xe4, 0xf0, 0x57, 0x56, 0x52, 0x51,\n  0xff, 0x15, 0x18, 0x00, 0x00, 0x00, 0x31, 0xc0, 0x59, 0x5a, 0x5e, 0x5f,\n  0x48, 0x89, 0xec, 0x5d, 0xff, 0x25, 0x00, 0x00, 0x00, 0x00, 0xff, 0xff,\n  0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,\n  0xff, 0xff\n};\nstatic_assert(sizeof(entryWrapper32) == 51, \"Invalid entryWrapper32 size\");\nstatic_assert(sizeof(entryWrapper64) == 50, \"Invalid entryWrapper64 size\");\nstatic constexpr size_t EntryWrapper32Booter {0x00000017};\nstatic constexpr size_t EntryWrapper64Booter {0x000000000000002a};\nstatic constexpr size_t EntryWrapper32Entry {0x0000002a};\nstatic constexpr size_t EntryWrapper64Entry {0x0000000000000022};\n"
  },
  {
    "path": "EFI_DEBUG/EFI/OC/Kexts/VirtualSMC.kext/Contents/Info.plist",
    "content": "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<!DOCTYPE plist PUBLIC \"-//Apple//DTD PLIST 1.0//EN\" \"http://www.apple.com/DTDs/PropertyList-1.0.dtd\">\n<plist version=\"1.0\">\n<dict>\n\t<key>BuildMachineOSBuild</key>\n\t<string>23H626</string>\n\t<key>CFBundleDevelopmentRegion</key>\n\t<string>en</string>\n\t<key>CFBundleExecutable</key>\n\t<string>VirtualSMC</string>\n\t<key>CFBundleIdentifier</key>\n\t<string>as.vit9696.VirtualSMC</string>\n\t<key>CFBundleInfoDictionaryVersion</key>\n\t<string>6.0</string>\n\t<key>CFBundleName</key>\n\t<string>VirtualSMC</string>\n\t<key>CFBundlePackageType</key>\n\t<string>KEXT</string>\n\t<key>CFBundleShortVersionString</key>\n\t<string>1.3.7</string>\n\t<key>CFBundleSignature</key>\n\t<string>????</string>\n\t<key>CFBundleSupportedPlatforms</key>\n\t<array>\n\t\t<string>MacOSX</string>\n\t</array>\n\t<key>CFBundleVersion</key>\n\t<string>1.3.7</string>\n\t<key>DTCompiler</key>\n\t<string>com.apple.compilers.llvm.clang.1_0</string>\n\t<key>DTPlatformBuild</key>\n\t<string></string>\n\t<key>DTPlatformName</key>\n\t<string>macosx</string>\n\t<key>DTPlatformVersion</key>\n\t<string>14.2</string>\n\t<key>DTSDKBuild</key>\n\t<string>23C53</string>\n\t<key>DTSDKName</key>\n\t<string>macosx14.2</string>\n\t<key>DTXcode</key>\n\t<string>1520</string>\n\t<key>DTXcodeBuild</key>\n\t<string>15C500b</string>\n\t<key>IOKitPersonalities</key>\n\t<dict>\n\t\t<key>as.vit9696.VirtualSMC</key>\n\t\t<dict>\n\t\t\t<key>CFBundleIdentifier</key>\n\t\t\t<string>as.vit9696.VirtualSMC</string>\n\t\t\t<key>IOClass</key>\n\t\t\t<string>VirtualSMC</string>\n\t\t\t<key>IODeviceMemory</key>\n\t\t\t<array>\n\t\t\t\t<array>\n\t\t\t\t\t<dict>\n\t\t\t\t\t\t<key>address</key>\n\t\t\t\t\t\t<integer>768</integer>\n\t\t\t\t\t\t<key>length</key>\n\t\t\t\t\t\t<integer>32</integer>\n\t\t\t\t\t</dict>\n\t\t\t\t</array>\n\t\t\t\t<array>\n\t\t\t\t\t<dict>\n\t\t\t\t\t\t<key>address</key>\n\t\t\t\t\t\t<integer>4277141504</integer>\n\t\t\t\t\t\t<key>length</key>\n\t\t\t\t\t\t<integer>65536</integer>\n\t\t\t\t\t</dict>\n\t\t\t\t</array>\n\t\t\t</array>\n\t\t\t<key>IOInterruptControllers</key>\n\t\t\t<array>\n\t\t\t\t<string>io-apic-0</string>\n\t\t\t</array>\n\t\t\t<key>IOInterruptSpecifiers</key>\n\t\t\t<array>\n\t\t\t\t<data>\n\t\t\t\tBgAAAAAAAAA=\n\t\t\t\t</data>\n\t\t\t</array>\n\t\t\t<key>IOMatchCategory</key>\n\t\t\t<string>IOACPIPlatformDevice</string>\n\t\t\t<key>IOName</key>\n\t\t\t<string>SMC</string>\n\t\t\t<key>IOProbeScore</key>\n\t\t\t<integer>60000</integer>\n\t\t\t<key>IOProviderClass</key>\n\t\t\t<string>AppleACPIPlatformExpert</string>\n\t\t\t<key>Keystore</key>\n\t\t\t<dict>\n\t\t\t\t<key>Generic</key>\n\t\t\t\t<array>\n\t\t\t\t\t<dict>\n\t\t\t\t\t\t<key>attr</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tiA==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t\t<key>comment</key>\n\t\t\t\t\t\t<string>Total fan number, this should be put to a plugin</string>\n\t\t\t\t\t\t<key>name</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tRk51bQ==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t\t<key>type</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tdWk4IA==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t\t<key>value</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tAA==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t</dict>\n\t\t\t\t\t<dict>\n\t\t\t\t\t\t<key>attr</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tgA==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t\t<key>comment</key>\n\t\t\t\t\t\t<string>CPU plimit</string>\n\t\t\t\t\t\t<key>name</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tTVNUYw==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t\t<key>type</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tdWk4IA==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t\t<key>value</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tAA==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t</dict>\n\t\t\t\t\t<dict>\n\t\t\t\t\t\t<key>attr</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tgA==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t\t<key>comment</key>\n\t\t\t\t\t\t<string>FAN plimit (supposedly)</string>\n\t\t\t\t\t\t<key>name</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tTVNUZg==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t\t<key>type</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tdWk4IA==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t\t<key>value</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tAA==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t</dict>\n\t\t\t\t\t<dict>\n\t\t\t\t\t\t<key>attr</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tgA==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t\t<key>comment</key>\n\t\t\t\t\t\t<string>Memory plimit</string>\n\t\t\t\t\t\t<key>name</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tTVNUbQ==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t\t<key>type</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tdWk4IA==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t\t<key>value</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tAA==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t</dict>\n\t\t\t\t\t<dict>\n\t\t\t\t\t\t<key>attr</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tgA==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t\t<key>comment</key>\n\t\t\t\t\t\t<string>This should be 1 on laptops, and is overriden by sensors</string>\n\t\t\t\t\t\t<key>name</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tQkFUUA==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t\t<key>type</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tZmxhZw==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t\t<key>value</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tAA==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t</dict>\n\t\t\t\t\t<dict>\n\t\t\t\t\t\t<key>attr</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tgA==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t\t<key>comment</key>\n\t\t\t\t\t\t<string>Only MacPros have custom illumination controllers</string>\n\t\t\t\t\t\t<key>name</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tTHNOTQ==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t\t<key>type</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tdWk4IA==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t\t<key>value</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tAA==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t</dict>\n\t\t\t\t</array>\n\t\t\t\t<key>GenericDesktopV1</key>\n\t\t\t\t<array/>\n\t\t\t\t<key>GenericDesktopV2</key>\n\t\t\t\t<array/>\n\t\t\t\t<key>GenericLaptopV1</key>\n\t\t\t\t<array/>\n\t\t\t\t<key>GenericLaptopV2</key>\n\t\t\t\t<array/>\n\t\t\t\t<key>GenericV1</key>\n\t\t\t\t<array>\n\t\t\t\t\t<dict>\n\t\t\t\t\t\t<key>attr</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tgA==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t\t<key>comment</key>\n\t\t\t\t\t\t<string>GPU plimit</string>\n\t\t\t\t\t\t<key>name</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tTVNUZw==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t\t<key>type</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tdWk4IA==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t\t<key>value</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tAA==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t</dict>\n\t\t\t\t</array>\n\t\t\t\t<key>GenericV2</key>\n\t\t\t\t<array>\n\t\t\t\t\t<dict>\n\t\t\t\t\t\t<key>attr</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tgA==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t\t<key>comment</key>\n\t\t\t\t\t\t<string>E plimit (???)</string>\n\t\t\t\t\t\t<key>name</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tTVNUZQ==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t\t<key>type</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tdWk4IA==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t\t<key>value</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tAA==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t</dict>\n\t\t\t\t\t<dict>\n\t\t\t\t\t\t<key>attr</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tgA==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t\t<key>comment</key>\n\t\t\t\t\t\t<string>I plimit (???)</string>\n\t\t\t\t\t\t<key>name</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tTVNUaQ==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t\t<key>type</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tdWk4IA==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t\t<key>value</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tAA==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t</dict>\n\t\t\t\t\t<dict>\n\t\t\t\t\t\t<key>attr</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tgA==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t\t<key>comment</key>\n\t\t\t\t\t\t<string>J plimit (???)</string>\n\t\t\t\t\t\t<key>name</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tTVNUag==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t\t<key>type</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tdWk4IA==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t\t<key>value</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tAA==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t</dict>\n\t\t\t\t</array>\n\t\t\t</dict>\n\t\t\t<key>ModelInfo</key>\n\t\t\t<dict>\n\t\t\t\t<key>GenericV1</key>\n\t\t\t\t<dict>\n\t\t\t\t\t<key>branch</key>\n\t\t\t\t\t<data>\n\t\t\t\t\tajUyAAAAAAA=\n\t\t\t\t\t</data>\n\t\t\t\t\t<key>hwname</key>\n\t\t\t\t\t<data>\n\t\t\t\t\tc21jLXBpa2V0b24A\n\t\t\t\t\t</data>\n\t\t\t\t\t<key>platform</key>\n\t\t\t\t\t<data>\n\t\t\t\t\tajUyAAAAAAA=\n\t\t\t\t\t</data>\n\t\t\t\t\t<key>rev</key>\n\t\t\t\t\t<data>\n\t\t\t\t\tAXQPAAAE\n\t\t\t\t\t</data>\n\t\t\t\t\t<key>revfb</key>\n\t\t\t\t\t<data>\n\t\t\t\t\tAXQPAAAE\n\t\t\t\t\t</data>\n\t\t\t\t\t<key>revfu</key>\n\t\t\t\t\t<data>\n\t\t\t\t\tAXQPAAAE\n\t\t\t\t\t</data>\n\t\t\t\t</dict>\n\t\t\t\t<key>GenericV2</key>\n\t\t\t\t<dict>\n\t\t\t\t\t<key>branch</key>\n\t\t\t\t\t<data>\n\t\t\t\t\tajUyAAAAAAA=\n\t\t\t\t\t</data>\n\t\t\t\t\t<key>hwname</key>\n\t\t\t\t\t<data>\n\t\t\t\t\tc21jLWh1cm9ucml2ZXIA\n\t\t\t\t\t</data>\n\t\t\t\t\t<key>platform</key>\n\t\t\t\t\t<data>\n\t\t\t\t\tajUyAAAAAAA=\n\t\t\t\t\t</data>\n\t\t\t\t\t<key>rev</key>\n\t\t\t\t\t<data>\n\t\t\t\t\tAigPAAAH\n\t\t\t\t\t</data>\n\t\t\t\t\t<key>revfb</key>\n\t\t\t\t\t<data>\n\t\t\t\t\tAigPAAAH\n\t\t\t\t\t</data>\n\t\t\t\t\t<key>revfu</key>\n\t\t\t\t\t<data>\n\t\t\t\t\tAigPAAAH\n\t\t\t\t\t</data>\n\t\t\t\t</dict>\n\t\t\t\t<key>GenericV3</key>\n\t\t\t\t<dict>\n\t\t\t\t\t<key>hwname</key>\n\t\t\t\t\t<data>\n\t\t\t\t\tc21jLWh1cm9ucml2ZXIA\n\t\t\t\t\t</data>\n\t\t\t\t\t<key>platform</key>\n\t\t\t\t\t<data>\n\t\t\t\t\tajUyAAAAAAA=\n\t\t\t\t\t</data>\n\t\t\t\t</dict>\n\t\t\t</dict>\n\t\t\t<key>_STA</key>\n\t\t\t<integer>11</integer>\n\t\t\t<key>name</key>\n\t\t\t<data>\n\t\t\tQVBQMDAwMQA=\n\t\t\t</data>\n\t\t</dict>\n\t</dict>\n\t<key>LSMinimumSystemVersion</key>\n\t<string>10.6</string>\n\t<key>NSHumanReadableCopyright</key>\n\t<string>Copyright © 2017 vit9696. All rights reserved.</string>\n\t<key>OSBundleCompatibleVersion</key>\n\t<string>1.0</string>\n\t<key>OSBundleLibraries</key>\n\t<dict>\n\t\t<key>as.vit9696.Lilu</key>\n\t\t<string>1.2.0</string>\n\t\t<key>com.apple.iokit.IOACPIFamily</key>\n\t\t<string>1.0.0d1</string>\n\t\t<key>com.apple.kernel.6.0</key>\n\t\t<string>7.9.9</string>\n\t\t<key>com.apple.kpi.bsd</key>\n\t\t<string>8.0.0</string>\n\t\t<key>com.apple.kpi.iokit</key>\n\t\t<string>8.0.0</string>\n\t\t<key>com.apple.kpi.libkern</key>\n\t\t<string>8.0.0</string>\n\t\t<key>com.apple.kpi.mach</key>\n\t\t<string>8.0.0</string>\n\t\t<key>com.apple.kpi.unsupported</key>\n\t\t<string>8.0.0</string>\n\t</dict>\n\t<key>OSBundleLibraries_x86_64</key>\n\t<dict>\n\t\t<key>as.vit9696.Lilu</key>\n\t\t<string>1.2.0</string>\n\t\t<key>com.apple.iokit.IOACPIFamily</key>\n\t\t<string>1.0.0d1</string>\n\t\t<key>com.apple.kpi.bsd</key>\n\t\t<string>10.0.0</string>\n\t\t<key>com.apple.kpi.iokit</key>\n\t\t<string>10.0.0</string>\n\t\t<key>com.apple.kpi.libkern</key>\n\t\t<string>10.0.0</string>\n\t\t<key>com.apple.kpi.mach</key>\n\t\t<string>10.0.0</string>\n\t\t<key>com.apple.kpi.unsupported</key>\n\t\t<string>10.0.0</string>\n\t</dict>\n\t<key>OSBundleRequired</key>\n\t<string>Root</string>\n</dict>\n</plist>\n"
  },
  {
    "path": "EFI_DEBUG/EFI/OC/Kexts/VoodooPS2Controller.kext/Contents/Info.plist",
    "content": "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<!DOCTYPE plist PUBLIC \"-//Apple//DTD PLIST 1.0//EN\" \"http://www.apple.com/DTDs/PropertyList-1.0.dtd\">\n<plist version=\"1.0\">\n<dict>\n\t<key>BuildMachineOSBuild</key>\n\t<string>23H222</string>\n\t<key>CFBundleExecutable</key>\n\t<string>VoodooPS2Controller</string>\n\t<key>CFBundleGetInfoString</key>\n\t<string>2.3.7, Copyright Apple Computer, Inc. 2000-2003, David Elliot 2007, RehabMan 2012-2013</string>\n\t<key>CFBundleIdentifier</key>\n\t<string>as.acidanthera.voodoo.driver.PS2Controller</string>\n\t<key>CFBundleInfoDictionaryVersion</key>\n\t<string>6.0</string>\n\t<key>CFBundleName</key>\n\t<string>Voodoo PS/2 Controller</string>\n\t<key>CFBundlePackageType</key>\n\t<string>KEXT</string>\n\t<key>CFBundleShortVersionString</key>\n\t<string>2.3.7</string>\n\t<key>CFBundleSignature</key>\n\t<string>????</string>\n\t<key>CFBundleSupportedPlatforms</key>\n\t<array>\n\t\t<string>MacOSX</string>\n\t</array>\n\t<key>CFBundleVersion</key>\n\t<string>2.3.7</string>\n\t<key>DTCompiler</key>\n\t<string>com.apple.compilers.llvm.clang.1_0</string>\n\t<key>DTPlatformBuild</key>\n\t<string></string>\n\t<key>DTPlatformName</key>\n\t<string>macosx</string>\n\t<key>DTPlatformVersion</key>\n\t<string>14.2</string>\n\t<key>DTSDKBuild</key>\n\t<string>23C53</string>\n\t<key>DTSDKName</key>\n\t<string>macosx14.2</string>\n\t<key>DTXcode</key>\n\t<string>1520</string>\n\t<key>DTXcodeBuild</key>\n\t<string>15C500b</string>\n\t<key>IOKitPersonalities</key>\n\t<dict>\n\t\t<key>ACPI PS/2 Nub</key>\n\t\t<dict>\n\t\t\t<key>CFBundleIdentifier</key>\n\t\t\t<string>as.acidanthera.voodoo.driver.PS2Controller</string>\n\t\t\t<key>FindMouseDelay</key>\n\t\t\t<integer>100</integer>\n\t\t\t<key>IOClass</key>\n\t\t\t<string>AppleACPIPS2Nub</string>\n\t\t\t<key>IONameMatch</key>\n\t\t\t<array>\n\t\t\t\t<string>PNP0303</string>\n\t\t\t\t<string>PNP030B</string>\n\t\t\t\t<string>PNP0320</string>\n\t\t\t</array>\n\t\t\t<key>IOProviderClass</key>\n\t\t\t<string>IOACPIPlatformDevice</string>\n\t\t\t<key>MouseNameMatch</key>\n\t\t\t<array>\n\t\t\t\t<string>PNP0F03</string>\n\t\t\t\t<string>PNP0F0B</string>\n\t\t\t\t<string>PNP0F0E</string>\n\t\t\t\t<string>PNP0F13</string>\n\t\t\t</array>\n\t\t</dict>\n\t\t<key>ApplePS2Controller</key>\n\t\t<dict>\n\t\t\t<key>CFBundleIdentifier</key>\n\t\t\t<string>as.acidanthera.voodoo.driver.PS2Controller</string>\n\t\t\t<key>IOClass</key>\n\t\t\t<string>ApplePS2Controller</string>\n\t\t\t<key>IONameMatch</key>\n\t\t\t<string>ps2controller</string>\n\t\t\t<key>IOProviderClass</key>\n\t\t\t<string>IOPlatformDevice</string>\n\t\t\t<key>Platform Profile</key>\n\t\t\t<dict>\n\t\t\t\t<key>Default</key>\n\t\t\t\t<dict>\n\t\t\t\t\t<key>MouseWakeFirst</key>\n\t\t\t\t\t<false/>\n\t\t\t\t\t<key>WakeDelay</key>\n\t\t\t\t\t<integer>10</integer>\n\t\t\t\t</dict>\n\t\t\t\t<key>HPQOEM</key>\n\t\t\t\t<dict>\n\t\t\t\t\t<key>1411</key>\n\t\t\t\t\t<string>ProBook</string>\n\t\t\t\t\t<key>1619</key>\n\t\t\t\t\t<string>ProBook</string>\n\t\t\t\t\t<key>161C</key>\n\t\t\t\t\t<string>ProBook</string>\n\t\t\t\t\t<key>164F</key>\n\t\t\t\t\t<string>ProBook</string>\n\t\t\t\t\t<key>167C</key>\n\t\t\t\t\t<string>ProBook</string>\n\t\t\t\t\t<key>167E</key>\n\t\t\t\t\t<string>ProBook</string>\n\t\t\t\t\t<key>1680</key>\n\t\t\t\t\t<string>ProBook</string>\n\t\t\t\t\t<key>179B</key>\n\t\t\t\t\t<string>ProBook</string>\n\t\t\t\t\t<key>179C</key>\n\t\t\t\t\t<string>ProBook</string>\n\t\t\t\t\t<key>17A9</key>\n\t\t\t\t\t<string>ProBook</string>\n\t\t\t\t\t<key>17F0</key>\n\t\t\t\t\t<string>ProBook</string>\n\t\t\t\t\t<key>17F3</key>\n\t\t\t\t\t<string>ProBook</string>\n\t\t\t\t\t<key>17F6</key>\n\t\t\t\t\t<string>ProBook</string>\n\t\t\t\t\t<key>1942</key>\n\t\t\t\t\t<string>ProBook</string>\n\t\t\t\t\t<key>1949</key>\n\t\t\t\t\t<string>ProBook</string>\n\t\t\t\t\t<key>198F</key>\n\t\t\t\t\t<string>ProBook</string>\n\t\t\t\t\t<key>ProBook</key>\n\t\t\t\t\t<dict>\n\t\t\t\t\t\t<key>WakeDelay</key>\n\t\t\t\t\t\t<integer>0</integer>\n\t\t\t\t\t</dict>\n\t\t\t\t\t<key>ProBook-102</key>\n\t\t\t\t\t<string>ProBook</string>\n\t\t\t\t\t<key>ProBook-87</key>\n\t\t\t\t\t<string>ProBook</string>\n\t\t\t\t</dict>\n\t\t\t</dict>\n\t\t\t<key>RM,deliverNotifications</key>\n\t\t\t<true/>\n\t\t</dict>\n\t</dict>\n\t<key>LSMinimumSystemVersion</key>\n\t<string>10.10</string>\n\t<key>OSBundleCompatibleVersion</key>\n\t<string>2.3.7</string>\n\t<key>OSBundleLibraries</key>\n\t<dict>\n\t\t<key>com.apple.iokit.IOACPIFamily</key>\n\t\t<string>1.0.0d1</string>\n\t\t<key>com.apple.kpi.bsd</key>\n\t\t<string>8.0.0</string>\n\t\t<key>com.apple.kpi.iokit</key>\n\t\t<string>8.0.0</string>\n\t\t<key>com.apple.kpi.libkern</key>\n\t\t<string>8.0.0</string>\n\t\t<key>com.apple.kpi.mach</key>\n\t\t<string>8.0.0</string>\n\t\t<key>com.apple.kpi.unsupported</key>\n\t\t<string>8.0.0</string>\n\t</dict>\n\t<key>OSBundleRequired</key>\n\t<string>Console</string>\n</dict>\n</plist>\n"
  },
  {
    "path": "EFI_DEBUG/EFI/OC/Kexts/VoodooPS2Controller.kext/Contents/PlugIns/VoodooPS2Keyboard.kext/Contents/Info.plist",
    "content": "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<!DOCTYPE plist PUBLIC \"-//Apple//DTD PLIST 1.0//EN\" \"http://www.apple.com/DTDs/PropertyList-1.0.dtd\">\n<plist version=\"1.0\">\n<dict>\n\t<key>BuildMachineOSBuild</key>\n\t<string>23H222</string>\n\t<key>CFBundleExecutable</key>\n\t<string>VoodooPS2Keyboard</string>\n\t<key>CFBundleGetInfoString</key>\n\t<string>2.3.7, Copyright Apple Computer, Inc. 2000-2003, RehabMan 2012-2013</string>\n\t<key>CFBundleIdentifier</key>\n\t<string>as.acidanthera.voodoo.driver.PS2Keyboard</string>\n\t<key>CFBundleInfoDictionaryVersion</key>\n\t<string>6.0</string>\n\t<key>CFBundleName</key>\n\t<string>Voodoo PS/2 Keyboard</string>\n\t<key>CFBundlePackageType</key>\n\t<string>KEXT</string>\n\t<key>CFBundleShortVersionString</key>\n\t<string>2.3.7</string>\n\t<key>CFBundleSignature</key>\n\t<string>????</string>\n\t<key>CFBundleSupportedPlatforms</key>\n\t<array>\n\t\t<string>MacOSX</string>\n\t</array>\n\t<key>CFBundleVersion</key>\n\t<string>2.3.7</string>\n\t<key>DTCompiler</key>\n\t<string>com.apple.compilers.llvm.clang.1_0</string>\n\t<key>DTPlatformBuild</key>\n\t<string></string>\n\t<key>DTPlatformName</key>\n\t<string>macosx</string>\n\t<key>DTPlatformVersion</key>\n\t<string>14.2</string>\n\t<key>DTSDKBuild</key>\n\t<string>23C53</string>\n\t<key>DTSDKName</key>\n\t<string>macosx14.2</string>\n\t<key>DTXcode</key>\n\t<string>1520</string>\n\t<key>DTXcodeBuild</key>\n\t<string>15C500b</string>\n\t<key>IOKitPersonalities</key>\n\t<dict>\n\t\t<key>ApplePS2Keyboard</key>\n\t\t<dict>\n\t\t\t<key>CFBundleIdentifier</key>\n\t\t\t<string>as.acidanthera.voodoo.driver.PS2Keyboard</string>\n\t\t\t<key>IOClass</key>\n\t\t\t<string>ApplePS2Keyboard</string>\n\t\t\t<key>IOProviderClass</key>\n\t\t\t<string>ApplePS2KeyboardDevice</string>\n\t\t\t<key>Platform Profile</key>\n\t\t\t<dict>\n\t\t\t\t<key>DELL</key>\n\t\t\t\t<dict>\n\t\t\t\t\t<key>Dell-Keys</key>\n\t\t\t\t\t<dict>\n\t\t\t\t\t\t<key>Breakless PS2</key>\n\t\t\t\t\t\t<array>\n\t\t\t\t\t\t\t<string>e005</string>\n\t\t\t\t\t\t\t<string>e006</string>\n\t\t\t\t\t\t</array>\n\t\t\t\t\t\t<key>Function Keys Special</key>\n\t\t\t\t\t\t<array>\n\t\t\t\t\t\t\t<string>;The following 12 items map Fn+fkeys to fkeys</string>\n\t\t\t\t\t\t\t<string>e020=3b</string>\n\t\t\t\t\t\t\t<string>e02e=3c</string>\n\t\t\t\t\t\t\t<string>e030=3d</string>\n\t\t\t\t\t\t\t<string>e022=3e</string>\n\t\t\t\t\t\t\t<string>;Fn+f5 macro</string>\n\t\t\t\t\t\t\t<string>;Fn+f6 macro</string>\n\t\t\t\t\t\t\t<string>;Fn+f7 macro</string>\n\t\t\t\t\t\t\t<string>;Fn+f8 macro</string>\n\t\t\t\t\t\t\t<string>;Fn+f9 macro</string>\n\t\t\t\t\t\t\t<string>;Fn+f10 no code</string>\n\t\t\t\t\t\t\t<string>e005=57</string>\n\t\t\t\t\t\t\t<string>e006=58</string>\n\t\t\t\t\t\t\t<string>;The following 12 items map fkeys to Fn+fkeys</string>\n\t\t\t\t\t\t\t<string>3b=e020</string>\n\t\t\t\t\t\t\t<string>3c=e02e</string>\n\t\t\t\t\t\t\t<string>3d=e030</string>\n\t\t\t\t\t\t\t<string>3e=e022</string>\n\t\t\t\t\t\t\t<string>;Fn+f5 macro</string>\n\t\t\t\t\t\t\t<string>;Fn+f6 macro</string>\n\t\t\t\t\t\t\t<string>;Fn+f7 macro</string>\n\t\t\t\t\t\t\t<string>;Fn+f8 macro</string>\n\t\t\t\t\t\t\t<string>;Fn+f9 macro</string>\n\t\t\t\t\t\t\t<string>;Fn+f10 no code</string>\n\t\t\t\t\t\t\t<string>57=e005</string>\n\t\t\t\t\t\t\t<string>58=e006</string>\n\t\t\t\t\t\t</array>\n\t\t\t\t\t\t<key>Function Keys Standard</key>\n\t\t\t\t\t\t<array>\n\t\t\t\t\t\t\t<string>;The following 12 items map Fn+fkeys to Fn+fkeys</string>\n\t\t\t\t\t\t\t<string>e020=e020</string>\n\t\t\t\t\t\t\t<string>e02e=e02e</string>\n\t\t\t\t\t\t\t<string>e030=e030</string>\n\t\t\t\t\t\t\t<string>e022=e022</string>\n\t\t\t\t\t\t\t<string>;Fn+f5 macro</string>\n\t\t\t\t\t\t\t<string>;Fn+f6 macro</string>\n\t\t\t\t\t\t\t<string>;Fn+f7 macro</string>\n\t\t\t\t\t\t\t<string>;Fn+f8 macro</string>\n\t\t\t\t\t\t\t<string>;Fn+f9 macro</string>\n\t\t\t\t\t\t\t<string>;Fn+f10 no code</string>\n\t\t\t\t\t\t\t<string>e005=e005</string>\n\t\t\t\t\t\t\t<string>e006=e006</string>\n\t\t\t\t\t\t\t<string>;The following 12 items map fkeys to fkeys</string>\n\t\t\t\t\t\t\t<string>3b=3b</string>\n\t\t\t\t\t\t\t<string>3c=3c</string>\n\t\t\t\t\t\t\t<string>3d=3d</string>\n\t\t\t\t\t\t\t<string>3e=3e</string>\n\t\t\t\t\t\t\t<string>3f=3f</string>\n\t\t\t\t\t\t\t<string>40=40</string>\n\t\t\t\t\t\t\t<string>41=41</string>\n\t\t\t\t\t\t\t<string>42=42</string>\n\t\t\t\t\t\t\t<string>43=43</string>\n\t\t\t\t\t\t\t<string>44=44</string>\n\t\t\t\t\t\t\t<string>57=57</string>\n\t\t\t\t\t\t\t<string>58=58</string>\n\t\t\t\t\t\t</array>\n\t\t\t\t\t</dict>\n\t\t\t\t\t<key>HSW-LPT</key>\n\t\t\t\t\t<string>Dell-Keys</string>\n\t\t\t\t\t<key>SNB-CPT</key>\n\t\t\t\t\t<dict>\n\t\t\t\t\t\t<key>ActionSwipeDown</key>\n\t\t\t\t\t\t<string>63 d, 63 u</string>\n\t\t\t\t\t\t<key>ActionSwipeUp</key>\n\t\t\t\t\t\t<string>61 d, 61 u</string>\n\t\t\t\t\t\t<key>Breakless PS2</key>\n\t\t\t\t\t\t<array>\n\t\t\t\t\t\t\t<string>e01e;Touchpad Fn+f3 is breakless</string>\n\t\t\t\t\t\t\t<string>e06e;REVIEW: temporary for case that macro inversion does not work...</string>\n\t\t\t\t\t\t</array>\n\t\t\t\t\t\t<key>Custom ADB Map</key>\n\t\t\t\t\t\t<array>\n\t\t\t\t\t\t\t<string>e009=83;Dell Support to Launchpad</string>\n\t\t\t\t\t\t\t<string>e0f1=71;Call brightens up w RKA1 for special mode (was =90)</string>\n\t\t\t\t\t\t\t<string>e0f2=6b;Call brightens down w RKA2 for special mode (was =91)</string>\n\t\t\t\t\t\t\t<string>e06e=70;Map vidmirror key for special mode default is adb90</string>\n\t\t\t\t\t\t</array>\n\t\t\t\t\t\t<key>Custom PS2 Map</key>\n\t\t\t\t\t\t<array>\n\t\t\t\t\t\t\t<string>e01e=e037;Map tp disable to Fn+f3</string>\n\t\t\t\t\t\t\t<string>e037=e01e;Prevent PrntScr from triggering tp disable</string>\n\t\t\t\t\t\t</array>\n\t\t\t\t\t\t<key>Function Keys Special</key>\n\t\t\t\t\t\t<array>\n\t\t\t\t\t\t\t<string>;The following 12 items map Fn+fkeys to fkeys</string>\n\t\t\t\t\t\t\t<string>e06e=3b</string>\n\t\t\t\t\t\t\t<string>e008=3c</string>\n\t\t\t\t\t\t\t<string>e01e=3d</string>\n\t\t\t\t\t\t\t<string>e005=3e</string>\n\t\t\t\t\t\t\t<string>e006=3f</string>\n\t\t\t\t\t\t\t<string>e00c=40</string>\n\t\t\t\t\t\t\t<string>;Fn+f7 no dedicated macro</string>\n\t\t\t\t\t\t\t<string>e010=42</string>\n\t\t\t\t\t\t\t<string>e022=43</string>\n\t\t\t\t\t\t\t<string>e019=44</string>\n\t\t\t\t\t\t\t<string>e02e=57</string>\n\t\t\t\t\t\t\t<string>e030=58</string>\n\t\t\t\t\t\t\t<string>;The following 12 items map fkeys to Fn+fkeys</string>\n\t\t\t\t\t\t\t<string>3b=e06e;Map vidmirror key to f1</string>\n\t\t\t\t\t\t\t<string>3c=e0f0;Map radio toggle action from EC query to f2</string>\n\t\t\t\t\t\t\t<string>3d=e037;Map touchpad toggle button to f3</string>\n\t\t\t\t\t\t\t<string>3e=e0f2;Map acpi RKA2 to f4 brightness down</string>\n\t\t\t\t\t\t\t<string>3f=e0f1;Map acpi RKA1 to f5 brightness up</string>\n\t\t\t\t\t\t\t<string>40=e0f3;Map acpi RKA3 to f6 keyboard backlight</string>\n\t\t\t\t\t\t\t<string>;Fn+f7 no macro</string>\n\t\t\t\t\t\t\t<string>42=e010</string>\n\t\t\t\t\t\t\t<string>43=e022</string>\n\t\t\t\t\t\t\t<string>44=e019</string>\n\t\t\t\t\t\t\t<string>57=e02e</string>\n\t\t\t\t\t\t\t<string>58=e030</string>\n\t\t\t\t\t\t</array>\n\t\t\t\t\t\t<key>Function Keys Standard</key>\n\t\t\t\t\t\t<array>\n\t\t\t\t\t\t\t<string>;The following 12 items map Fn+fkeys to Fn+fkeys</string>\n\t\t\t\t\t\t\t<string>e06e=e06e;Fn+f1 macro translated</string>\n\t\t\t\t\t\t\t<string>e008=e008;Fn+f2 regular scancode and EC query call q8c</string>\n\t\t\t\t\t\t\t<string>e01e=e037;Fn+f3 regular scancode and EC controls LED</string>\n\t\t\t\t\t\t\t<string>e005=e005;Fn+f4 no ps2scancode and EC query call q81</string>\n\t\t\t\t\t\t\t<string>e006=e006;Fn+f5 no ps2scancode and EC query call q80</string>\n\t\t\t\t\t\t\t<string>e00c=e00c;Fn+f6 no ps2scancode and EC query call q8a</string>\n\t\t\t\t\t\t\t<string>;Fn+f7 no macro just regular f key</string>\n\t\t\t\t\t\t\t<string>e010=e010; Fn+f8 regular scancode</string>\n\t\t\t\t\t\t\t<string>e022=e022; Fn+f9 regular scancode</string>\n\t\t\t\t\t\t\t<string>e019=e019;Fn+f10 regular scancode</string>\n\t\t\t\t\t\t\t<string>e02e=e02e;Fn+f11 regular scancode</string>\n\t\t\t\t\t\t\t<string>e030=e030;Fn+f12 regular scancode</string>\n\t\t\t\t\t\t\t<string>;Fn+f13 is mute dedicated button that always produces e020 regardless of Fn</string>\n\t\t\t\t\t\t\t<string>;The following 12 items map fkeys to fkeys</string>\n\t\t\t\t\t\t\t<string>3b=3b</string>\n\t\t\t\t\t\t\t<string>3c=3c</string>\n\t\t\t\t\t\t\t<string>3d=3d</string>\n\t\t\t\t\t\t\t<string>3e=3e</string>\n\t\t\t\t\t\t\t<string>3f=3f</string>\n\t\t\t\t\t\t\t<string>40=40</string>\n\t\t\t\t\t\t\t<string>41=41</string>\n\t\t\t\t\t\t\t<string>42=42</string>\n\t\t\t\t\t\t\t<string>43=43</string>\n\t\t\t\t\t\t\t<string>44=44</string>\n\t\t\t\t\t\t\t<string>57=57</string>\n\t\t\t\t\t\t\t<string>58=58</string>\n\t\t\t\t\t\t</array>\n\t\t\t\t\t\t<key>Macro Inversion</key>\n\t\t\t\t\t\t<array>\n\t\t\t\t\t\t\t<string>;This section maps ps2 codes (packet format) received quickly (macros) into fake ps2 codes (packet format)</string>\n\t\t\t\t\t\t\t<string>;Fn+F1</string>\n\t\t\t\t\t\t\t<data>\n\t\t\t\t\t\t\t//8CbgAAAAACWwEZ\n\t\t\t\t\t\t\t</data>\n\t\t\t\t\t\t\t<data>\n\t\t\t\t\t\t\t//8C7gAAAAAC2wGZ\n\t\t\t\t\t\t\t</data>\n\t\t\t\t\t\t\t<data>\n\t\t\t\t\t\t\t//8C7gAAAAABmQLb\n\t\t\t\t\t\t\t</data>\n\t\t\t\t\t\t</array>\n\t\t\t\t\t\t<key>MaximumMacroTime</key>\n\t\t\t\t\t\t<integer>35000000</integer>\n\t\t\t\t\t\t<key>Note-Author</key>\n\t\t\t\t\t\t<string>TimeWalker aka TimeWalker75a</string>\n\t\t\t\t\t\t<key>Note-Comment</key>\n\t\t\t\t\t\t<string>Keyboard Profile for DELL SandyBridge SecureCore Tiano based laptops (Vostro 3450 &amp; 3750, Inspiron N4110, XPS L502x &amp; L702x &amp; L511z)</string>\n\t\t\t\t\t</dict>\n\t\t\t\t\t<key>WN09</key>\n\t\t\t\t\t<dict>\n\t\t\t\t\t\t<key>Breakless PS2</key>\n\t\t\t\t\t\t<array>\n\t\t\t\t\t\t\t<string>e01b</string>\n\t\t\t\t\t\t\t<string>e008</string>\n\t\t\t\t\t\t\t<string>e01e</string>\n\t\t\t\t\t\t\t<string>e005</string>\n\t\t\t\t\t\t\t<string>e06e</string>\n\t\t\t\t\t\t\t<string>e006</string>\n\t\t\t\t\t\t</array>\n\t\t\t\t\t\t<key>Custom ADB Map</key>\n\t\t\t\t\t\t<array>\n\t\t\t\t\t\t\t<string>e01b=70</string>\n\t\t\t\t\t\t\t<string>e06e=83</string>\n\t\t\t\t\t\t</array>\n\t\t\t\t\t\t<key>Custom PS2 Map</key>\n\t\t\t\t\t\t<array>\n\t\t\t\t\t\t\t<string>56=2b</string>\n\t\t\t\t\t\t\t<string>29=56</string>\n\t\t\t\t\t\t\t<string>2b=29</string>\n\t\t\t\t\t\t\t<string>e01e=e037</string>\n\t\t\t\t\t\t\t<string>e037=e01e</string>\n\t\t\t\t\t\t</array>\n\t\t\t\t\t</dict>\n\t\t\t\t\t<key>WN09a</key>\n\t\t\t\t\t<dict>\n\t\t\t\t\t\t<key>Breakless PS2</key>\n\t\t\t\t\t\t<array>\n\t\t\t\t\t\t\t<string>e01b</string>\n\t\t\t\t\t\t\t<string>e008</string>\n\t\t\t\t\t\t\t<string>e01e</string>\n\t\t\t\t\t\t\t<string>e005</string>\n\t\t\t\t\t\t\t<string>e06e</string>\n\t\t\t\t\t\t\t<string>e006</string>\n\t\t\t\t\t\t</array>\n\t\t\t\t\t\t<key>Custom ADB Map</key>\n\t\t\t\t\t\t<array>\n\t\t\t\t\t\t\t<string>e01b=70</string>\n\t\t\t\t\t\t\t<string>e06e=83</string>\n\t\t\t\t\t\t</array>\n\t\t\t\t\t\t<key>Custom PS2 Map</key>\n\t\t\t\t\t\t<array>\n\t\t\t\t\t\t\t<string>e01e=e037</string>\n\t\t\t\t\t\t\t<string>e037=e01e</string>\n\t\t\t\t\t\t</array>\n\t\t\t\t\t</dict>\n\t\t\t\t</dict>\n\t\t\t\t<key>Default</key>\n\t\t\t\t<dict>\n\t\t\t\t\t<key>Breakless PS2</key>\n\t\t\t\t\t<array>\n\t\t\t\t\t\t<string>;Items must be strings in the form of breaklessscan (in hex)</string>\n\t\t\t\t\t</array>\n\t\t\t\t\t<key>Custom ADB Map</key>\n\t\t\t\t\t<array>\n\t\t\t\t\t\t<string>;Items must be strings in the form of scanfrom=adbto (in hex)</string>\n\t\t\t\t\t</array>\n\t\t\t\t\t<key>Custom PS2 Map</key>\n\t\t\t\t\t<array>\n\t\t\t\t\t\t<string>;Items must be strings in the form of scanfrom=scanto (in hex)</string>\n\t\t\t\t\t\t<string>e027=0;disable discrete fnkeys toggle</string>\n\t\t\t\t\t\t<string>e028=0;disable discrete trackpad toggle</string>\n\t\t\t\t\t</array>\n\t\t\t\t\t<key>HIDF12EjectDelay</key>\n\t\t\t\t\t<integer>250</integer>\n\t\t\t\t\t<key>LogScanCodes</key>\n\t\t\t\t\t<integer>0</integer>\n\t\t\t\t\t<key>Make Application key into Apple Fn key</key>\n\t\t\t\t\t<false/>\n\t\t\t\t\t<key>Make Application key into right windows</key>\n\t\t\t\t\t<true/>\n\t\t\t\t\t<key>Make right modifier keys into Hangul and Hanja</key>\n\t\t\t\t\t<false/>\n\t\t\t\t\t<key>SleepPressTime</key>\n\t\t\t\t\t<integer>0</integer>\n\t\t\t\t\t<key>Swap capslock and left control</key>\n\t\t\t\t\t<false/>\n\t\t\t\t\t<key>Swap command and option</key>\n\t\t\t\t\t<false/>\n\t\t\t\t\t<key>Use ISO layout keyboard</key>\n\t\t\t\t\t<false/>\n\t\t\t\t\t<key>alt_handler_id</key>\n\t\t\t\t\t<integer>3</integer>\n\t\t\t\t</dict>\n\t\t\t\t<key>HPQOEM</key>\n\t\t\t\t<dict>\n\t\t\t\t\t<key>1411</key>\n\t\t\t\t\t<string>ProBook-102;ProBook 4520s</string>\n\t\t\t\t\t<key>1619</key>\n\t\t\t\t\t<string>ProBook-87;ProBook 6560b</string>\n\t\t\t\t\t<key>161C</key>\n\t\t\t\t\t<string>ProBook-87;ProBook 8460p</string>\n\t\t\t\t\t<key>164F</key>\n\t\t\t\t\t<string>ProBook-87;ProBook 5330m</string>\n\t\t\t\t\t<key>167C</key>\n\t\t\t\t\t<string>ProBook-102;ProBook 4530s</string>\n\t\t\t\t\t<key>167E</key>\n\t\t\t\t\t<string>ProBook-102;ProBook 4330s</string>\n\t\t\t\t\t<key>1680</key>\n\t\t\t\t\t<string>ProBook-102;ProBook 4230s</string>\n\t\t\t\t\t<key>179B</key>\n\t\t\t\t\t<string>ProBook-87;ProBook 6470b</string>\n\t\t\t\t\t<key>179C</key>\n\t\t\t\t\t<string>ProBook-87;ProBook 6470b</string>\n\t\t\t\t\t<key>17A9</key>\n\t\t\t\t\t<string>ProBook-87;ProBook 8570b</string>\n\t\t\t\t\t<key>17F0</key>\n\t\t\t\t\t<string>ProBook-102;ProBook 4340s</string>\n\t\t\t\t\t<key>17F3</key>\n\t\t\t\t\t<string>ProBook-102;ProBook 4440s</string>\n\t\t\t\t\t<key>17F6</key>\n\t\t\t\t\t<string>ProBook-102;ProBook 4540s</string>\n\t\t\t\t\t<key>1942</key>\n\t\t\t\t\t<string>ProBook-87;ProBook 450s G1</string>\n\t\t\t\t\t<key>1949</key>\n\t\t\t\t\t<string>ProBook-87;ProBook 450s G1</string>\n\t\t\t\t\t<key>1962</key>\n\t\t\t\t\t<string>Haswell-Envy;HP Envy 15-j063cl</string>\n\t\t\t\t\t<key>1963</key>\n\t\t\t\t\t<string>Haswell-Envy;HP Envy 15-j063cl</string>\n\t\t\t\t\t<key>1965</key>\n\t\t\t\t\t<string>Haswell-Envy;HP Envy 17t-j100</string>\n\t\t\t\t\t<key>1966</key>\n\t\t\t\t\t<string>Haswell-Envy;HP Envy 17t-j000</string>\n\t\t\t\t\t<key>198F</key>\n\t\t\t\t\t<string>ProBook-87;ProBook 450s G0</string>\n\t\t\t\t\t<key>Haswell-Envy</key>\n\t\t\t\t\t<dict>\n\t\t\t\t\t\t<key>Custom ADB Map</key>\n\t\t\t\t\t\t<array>\n\t\t\t\t\t\t\t<string>e019=42;next</string>\n\t\t\t\t\t\t\t<string>e010=4d;previous</string>\n\t\t\t\t\t\t</array>\n\t\t\t\t\t\t<key>Custom PS2 Map</key>\n\t\t\t\t\t\t<array>\n\t\t\t\t\t\t\t<string>e045=e037</string>\n\t\t\t\t\t\t\t<string>e0ab=0;bogus Fn+F2/F3</string>\n\t\t\t\t\t\t</array>\n\t\t\t\t\t</dict>\n\t\t\t\t\t<key>ProBook-102</key>\n\t\t\t\t\t<dict>\n\t\t\t\t\t\t<key>Custom PS2 Map</key>\n\t\t\t\t\t\t<array>\n\t\t\t\t\t\t\t<string>e005=0</string>\n\t\t\t\t\t\t</array>\n\t\t\t\t\t\t<key>Function Keys Special</key>\n\t\t\t\t\t\t<array>\n\t\t\t\t\t\t\t<string>;The following 12 items map Fn+fkeys to fkeys</string>\n\t\t\t\t\t\t\t<string>e05f=3b</string>\n\t\t\t\t\t\t\t<string>e012=3c</string>\n\t\t\t\t\t\t\t<string>e017=3d</string>\n\t\t\t\t\t\t\t<string>e06e=3e</string>\n\t\t\t\t\t\t\t<string>e00a=3f</string>\n\t\t\t\t\t\t\t<string>e009=40</string>\n\t\t\t\t\t\t\t<string>e020=41</string>\n\t\t\t\t\t\t\t<string>e02e=42</string>\n\t\t\t\t\t\t\t<string>e030=43</string>\n\t\t\t\t\t\t\t<string>e010=44</string>\n\t\t\t\t\t\t\t<string>e022=57</string>\n\t\t\t\t\t\t\t<string>e019=58</string>\n\t\t\t\t\t\t\t<string>;The following 12 items map fkeys to Fn+fkeys</string>\n\t\t\t\t\t\t\t<string>3b=e05f</string>\n\t\t\t\t\t\t\t<string>3c=e012</string>\n\t\t\t\t\t\t\t<string>3d=e017</string>\n\t\t\t\t\t\t\t<string>3e=e06e</string>\n\t\t\t\t\t\t\t<string>3f=e00a</string>\n\t\t\t\t\t\t\t<string>40=e009</string>\n\t\t\t\t\t\t\t<string>41=e020</string>\n\t\t\t\t\t\t\t<string>42=e02e</string>\n\t\t\t\t\t\t\t<string>43=e030</string>\n\t\t\t\t\t\t\t<string>44=e010</string>\n\t\t\t\t\t\t\t<string>57=e022</string>\n\t\t\t\t\t\t\t<string>58=e019</string>\n\t\t\t\t\t\t</array>\n\t\t\t\t\t\t<key>Function Keys Standard</key>\n\t\t\t\t\t\t<array>\n\t\t\t\t\t\t\t<string>;The following 12 items map Fn+fkeys to Fn+fkeys</string>\n\t\t\t\t\t\t\t<string>e05f=e05f</string>\n\t\t\t\t\t\t\t<string>e012=e012</string>\n\t\t\t\t\t\t\t<string>e017=e017</string>\n\t\t\t\t\t\t\t<string>e06e=e06e</string>\n\t\t\t\t\t\t\t<string>e00a=e00a</string>\n\t\t\t\t\t\t\t<string>e009=e009</string>\n\t\t\t\t\t\t\t<string>e020=e020</string>\n\t\t\t\t\t\t\t<string>e02e=e02e</string>\n\t\t\t\t\t\t\t<string>e030=e030</string>\n\t\t\t\t\t\t\t<string>e010=e010</string>\n\t\t\t\t\t\t\t<string>e022=e022</string>\n\t\t\t\t\t\t\t<string>e019=e019</string>\n\t\t\t\t\t\t\t<string>;The following 12 items map fkeys to fkeys</string>\n\t\t\t\t\t\t\t<string>3b=3b</string>\n\t\t\t\t\t\t\t<string>3c=3c</string>\n\t\t\t\t\t\t\t<string>3d=3d</string>\n\t\t\t\t\t\t\t<string>3e=3e</string>\n\t\t\t\t\t\t\t<string>3f=3f</string>\n\t\t\t\t\t\t\t<string>40=40</string>\n\t\t\t\t\t\t\t<string>41=41</string>\n\t\t\t\t\t\t\t<string>42=42</string>\n\t\t\t\t\t\t\t<string>43=43</string>\n\t\t\t\t\t\t\t<string>44=44</string>\n\t\t\t\t\t\t\t<string>57=57</string>\n\t\t\t\t\t\t\t<string>58=58</string>\n\t\t\t\t\t\t</array>\n\t\t\t\t\t\t<key>SleepPressTime</key>\n\t\t\t\t\t\t<integer>3000</integer>\n\t\t\t\t\t</dict>\n\t\t\t\t\t<key>ProBook-87</key>\n\t\t\t\t\t<dict>\n\t\t\t\t\t\t<key>Custom ADB Map</key>\n\t\t\t\t\t\t<array>\n\t\t\t\t\t\t\t<string>46=4d;scroll =&gt; Previous-track</string>\n\t\t\t\t\t\t\t<string>e045=34;pause =&gt; Play-Pause</string>\n\t\t\t\t\t\t\t<string>e052=42;insert =&gt; Next-track</string>\n\t\t\t\t\t\t\t<string>e046=92;break =&gt; Eject</string>\n\t\t\t\t\t\t</array>\n\t\t\t\t\t\t<key>Custom PS2 Map</key>\n\t\t\t\t\t\t<array>\n\t\t\t\t\t\t\t<string>e005=0</string>\n\t\t\t\t\t\t</array>\n\t\t\t\t\t\t<key>Function Keys Special</key>\n\t\t\t\t\t\t<array>\n\t\t\t\t\t\t\t<string>;The following 8 items map Fn+fkeys to fkeys</string>\n\t\t\t\t\t\t\t<string>e05f=3d</string>\n\t\t\t\t\t\t\t<string>e06e=3e</string>\n\t\t\t\t\t\t\t<string>e02e=40</string>\n\t\t\t\t\t\t\t<string>e030=41</string>\n\t\t\t\t\t\t\t<string>e009=42</string>\n\t\t\t\t\t\t\t<string>e012=43</string>\n\t\t\t\t\t\t\t<string>e017=44</string>\n\t\t\t\t\t\t\t<string>e033=57</string>\n\t\t\t\t\t\t\t<string>;The following 8 items map fkeys to Fn+fkeys</string>\n\t\t\t\t\t\t\t<string>3d=e05f</string>\n\t\t\t\t\t\t\t<string>3e=e06e</string>\n\t\t\t\t\t\t\t<string>40=e02e</string>\n\t\t\t\t\t\t\t<string>41=e030</string>\n\t\t\t\t\t\t\t<string>42=e037</string>\n\t\t\t\t\t\t\t<string>43=e012</string>\n\t\t\t\t\t\t\t<string>44=e017</string>\n\t\t\t\t\t\t</array>\n\t\t\t\t\t\t<key>Function Keys Standard</key>\n\t\t\t\t\t\t<array>\n\t\t\t\t\t\t\t<string>;The following 8 items map Fn+fkeys to Fn+fkeys</string>\n\t\t\t\t\t\t\t<string>e05f=e05f</string>\n\t\t\t\t\t\t\t<string>e06e=e06e</string>\n\t\t\t\t\t\t\t<string>e02e=e02e</string>\n\t\t\t\t\t\t\t<string>e030=e030</string>\n\t\t\t\t\t\t\t<string>e009=e009</string>\n\t\t\t\t\t\t\t<string>e012=e012</string>\n\t\t\t\t\t\t\t<string>e017=e017</string>\n\t\t\t\t\t\t\t<string>e033=e033</string>\n\t\t\t\t\t\t\t<string>;The following 8 items map fkeys to fkeys</string>\n\t\t\t\t\t\t\t<string>3d=3d</string>\n\t\t\t\t\t\t\t<string>3e=3e</string>\n\t\t\t\t\t\t\t<string>40=40</string>\n\t\t\t\t\t\t\t<string>41=41</string>\n\t\t\t\t\t\t\t<string>42=42</string>\n\t\t\t\t\t\t\t<string>43=43</string>\n\t\t\t\t\t\t\t<string>44=44</string>\n\t\t\t\t\t\t</array>\n\t\t\t\t\t\t<key>SleepPressTime</key>\n\t\t\t\t\t\t<integer>3000</integer>\n\t\t\t\t\t</dict>\n\t\t\t\t</dict>\n\t\t\t\t<key>Intel</key>\n\t\t\t\t<dict>\n\t\t\t\t\t<key>CALPELLA</key>\n\t\t\t\t\t<string>SamsungKeys</string>\n\t\t\t\t\t<key>SamsungKeys</key>\n\t\t\t\t\t<dict>\n\t\t\t\t\t\t<key>Breakless PS2</key>\n\t\t\t\t\t\t<array>\n\t\t\t\t\t\t\t<string>e003</string>\n\t\t\t\t\t\t\t<string>e002</string>\n\t\t\t\t\t\t\t<string>e004</string>\n\t\t\t\t\t\t\t<string>e020</string>\n\t\t\t\t\t\t\t<string>;e031</string>\n\t\t\t\t\t\t\t<string>e033</string>\n\t\t\t\t\t\t\t<string>e006</string>\n\t\t\t\t\t\t\t<string>e077</string>\n\t\t\t\t\t\t\t<string>e079</string>\n\t\t\t\t\t\t\t<string>e008</string>\n\t\t\t\t\t\t\t<string>e009</string>\n\t\t\t\t\t\t</array>\n\t\t\t\t\t\t<key>Custom ADB Map</key>\n\t\t\t\t\t\t<array>\n\t\t\t\t\t\t\t<string>e002=70</string>\n\t\t\t\t\t\t\t<string>e006=80</string>\n\t\t\t\t\t\t\t<string>e008=71 (was =90)</string>\n\t\t\t\t\t\t\t<string>e009=6b (was =91)</string>\n\t\t\t\t\t\t</array>\n\t\t\t\t\t\t<key>Function Keys Special</key>\n\t\t\t\t\t\t<array>\n\t\t\t\t\t\t\t<string>;The following 12 items map Fn+fkeys to fkeys</string>\n\t\t\t\t\t\t\t<string>;fn+f1 no code</string>\n\t\t\t\t\t\t\t<string>e003=3c</string>\n\t\t\t\t\t\t\t<string>;fn+f3 weird code</string>\n\t\t\t\t\t\t\t<string>e002=3e</string>\n\t\t\t\t\t\t\t<string>e004=3f</string>\n\t\t\t\t\t\t\t<string>e020=40</string>\n\t\t\t\t\t\t\t<string>e031=41</string>\n\t\t\t\t\t\t\t<string>e033=42</string>\n\t\t\t\t\t\t\t<string>e006=43</string>\n\t\t\t\t\t\t\t<string>;fn+f10 weird code</string>\n\t\t\t\t\t\t\t<string>;fn+f11 no code</string>\n\t\t\t\t\t\t\t<string>;fn+f12 scrolllock</string>\n\t\t\t\t\t\t\t<string>;The following 12 items map fkeys to Fn+fkeys</string>\n\t\t\t\t\t\t\t<string>;fn+f1 no code</string>\n\t\t\t\t\t\t\t<string>3c=e003</string>\n\t\t\t\t\t\t\t<string>;fn+f3 weird code</string>\n\t\t\t\t\t\t\t<string>3e=e002</string>\n\t\t\t\t\t\t\t<string>3f=e004</string>\n\t\t\t\t\t\t\t<string>40=e020</string>\n\t\t\t\t\t\t\t<string>41=e031</string>\n\t\t\t\t\t\t\t<string>42=e033</string>\n\t\t\t\t\t\t\t<string>43=e006</string>\n\t\t\t\t\t\t\t<string>;fn+f10 weird code</string>\n\t\t\t\t\t\t\t<string>;fn+f11 no code</string>\n\t\t\t\t\t\t\t<string>;fn+f12 scrolllock</string>\n\t\t\t\t\t\t</array>\n\t\t\t\t\t\t<key>Function Keys Standard</key>\n\t\t\t\t\t\t<array>\n\t\t\t\t\t\t\t<string>;The following 12 items map Fn+fkeys to Fn+fkeys</string>\n\t\t\t\t\t\t\t<string>;fn+f1 no code</string>\n\t\t\t\t\t\t\t<string>e003=e003</string>\n\t\t\t\t\t\t\t<string>;fn+f3 weird code</string>\n\t\t\t\t\t\t\t<string>e002=e002</string>\n\t\t\t\t\t\t\t<string>e004=e004</string>\n\t\t\t\t\t\t\t<string>e020=e020</string>\n\t\t\t\t\t\t\t<string>e031=e031</string>\n\t\t\t\t\t\t\t<string>e033=e033</string>\n\t\t\t\t\t\t\t<string>e006=e006</string>\n\t\t\t\t\t\t\t<string>;fn+f10 weird code</string>\n\t\t\t\t\t\t\t<string>;fn+f11 no code</string>\n\t\t\t\t\t\t\t<string>;fn+f12 scrolllock</string>\n\t\t\t\t\t\t\t<string>;The following 12 items map fkeys to fkeys</string>\n\t\t\t\t\t\t\t<string>3b=3b</string>\n\t\t\t\t\t\t\t<string>3c=3c</string>\n\t\t\t\t\t\t\t<string>3d=3d</string>\n\t\t\t\t\t\t\t<string>3e=3e</string>\n\t\t\t\t\t\t\t<string>3f=3f</string>\n\t\t\t\t\t\t\t<string>40=40</string>\n\t\t\t\t\t\t\t<string>41=41</string>\n\t\t\t\t\t\t\t<string>42=42</string>\n\t\t\t\t\t\t\t<string>43=43</string>\n\t\t\t\t\t\t\t<string>44=44</string>\n\t\t\t\t\t\t\t<string>57=57</string>\n\t\t\t\t\t\t\t<string>58=58</string>\n\t\t\t\t\t\t</array>\n\t\t\t\t\t</dict>\n\t\t\t\t</dict>\n\t\t\t\t<key>SECCSD</key>\n\t\t\t\t<dict>\n\t\t\t\t\t<key>LH43STAR</key>\n\t\t\t\t\t<string>SamsungKeys</string>\n\t\t\t\t\t<key>SamsungKeys</key>\n\t\t\t\t\t<dict>\n\t\t\t\t\t\t<key>Breakless PS2</key>\n\t\t\t\t\t\t<array>\n\t\t\t\t\t\t\t<string>e020</string>\n\t\t\t\t\t\t\t<string>e02e</string>\n\t\t\t\t\t\t\t<string>e030</string>\n\t\t\t\t\t\t</array>\n\t\t\t\t\t</dict>\n\t\t\t\t</dict>\n\t\t\t</dict>\n\t\t</dict>\n\t</dict>\n\t<key>LSMinimumSystemVersion</key>\n\t<string>10.10</string>\n\t<key>OSBundleLibraries</key>\n\t<dict>\n\t\t<key>as.acidanthera.voodoo.driver.PS2Controller</key>\n\t\t<string>2.3.7</string>\n\t\t<key>com.apple.iokit.IOHIDFamily</key>\n\t\t<string>1.0.0b1</string>\n\t\t<key>com.apple.kpi.bsd</key>\n\t\t<string>8.0.0</string>\n\t\t<key>com.apple.kpi.iokit</key>\n\t\t<string>8.0.0</string>\n\t\t<key>com.apple.kpi.libkern</key>\n\t\t<string>8.0.0</string>\n\t\t<key>com.apple.kpi.mach</key>\n\t\t<string>8.0.0</string>\n\t\t<key>com.apple.kpi.unsupported</key>\n\t\t<string>8.0.0</string>\n\t</dict>\n\t<key>OSBundleRequired</key>\n\t<string>Console</string>\n</dict>\n</plist>\n"
  },
  {
    "path": "EFI_DEBUG/EFI/OC/Kexts/WhateverGreen.kext/Contents/Info.plist",
    "content": "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<!DOCTYPE plist PUBLIC \"-//Apple//DTD PLIST 1.0//EN\" \"http://www.apple.com/DTDs/PropertyList-1.0.dtd\">\n<plist version=\"1.0\">\n<dict>\n\t<key>BuildMachineOSBuild</key>\n\t<string>23H626</string>\n\t<key>CFBundleDevelopmentRegion</key>\n\t<string>en</string>\n\t<key>CFBundleExecutable</key>\n\t<string>WhateverGreen</string>\n\t<key>CFBundleIdentifier</key>\n\t<string>as.vit9696.WhateverGreen</string>\n\t<key>CFBundleInfoDictionaryVersion</key>\n\t<string>6.0</string>\n\t<key>CFBundleName</key>\n\t<string>WhateverGreen</string>\n\t<key>CFBundlePackageType</key>\n\t<string>KEXT</string>\n\t<key>CFBundleShortVersionString</key>\n\t<string>1.7.0</string>\n\t<key>CFBundleSignature</key>\n\t<string>????</string>\n\t<key>CFBundleSupportedPlatforms</key>\n\t<array>\n\t\t<string>MacOSX</string>\n\t</array>\n\t<key>CFBundleVersion</key>\n\t<string>1.7.0</string>\n\t<key>DTCompiler</key>\n\t<string>com.apple.compilers.llvm.clang.1_0</string>\n\t<key>DTPlatformBuild</key>\n\t<string></string>\n\t<key>DTPlatformName</key>\n\t<string>macosx</string>\n\t<key>DTPlatformVersion</key>\n\t<string>14.2</string>\n\t<key>DTSDKBuild</key>\n\t<string>23C53</string>\n\t<key>DTSDKName</key>\n\t<string>macosx14.2</string>\n\t<key>DTXcode</key>\n\t<string>1520</string>\n\t<key>DTXcodeBuild</key>\n\t<string>15C500b</string>\n\t<key>IOKitPersonalities</key>\n\t<dict>\n\t\t<key>NVHDAEnabler</key>\n\t\t<dict>\n\t\t\t<key>CFBundleIdentifier</key>\n\t\t\t<string>as.vit9696.WhateverGreen</string>\n\t\t\t<key>IOClass</key>\n\t\t\t<string>NVHDAEnabler</string>\n\t\t\t<key>IOMatchCategory</key>\n\t\t\t<string>IOFramebuffer</string>\n\t\t\t<key>IOPCIClassMatch</key>\n\t\t\t<string>0x03000000&amp;0xff000000</string>\n\t\t\t<key>IOPCIMatch</key>\n\t\t\t<string>0x000010de&amp;0x0000ffff</string>\n\t\t\t<key>IOProbeScore</key>\n\t\t\t<integer>300000</integer>\n\t\t\t<key>IOProviderClass</key>\n\t\t\t<string>IOPCIDevice</string>\n\t\t</dict>\n\t\t<key>as.vit9696.WhateverGreen</key>\n\t\t<dict>\n\t\t\t<key>CFBundleIdentifier</key>\n\t\t\t<string>as.vit9696.WhateverGreen</string>\n\t\t\t<key>IOClass</key>\n\t\t\t<string>WhateverGreen</string>\n\t\t\t<key>IOMatchCategory</key>\n\t\t\t<string>WhateverGreen</string>\n\t\t\t<key>IOProviderClass</key>\n\t\t\t<string>IOResources</string>\n\t\t\t<key>IOResourceMatch</key>\n\t\t\t<string>IOKit</string>\n\t\t</dict>\n\t</dict>\n\t<key>LSMinimumSystemVersion</key>\n\t<string>10.6</string>\n\t<key>NSHumanReadableCopyright</key>\n\t<string>Copyright © 2018 vit9696. All rights reserved.</string>\n\t<key>OSBundleCompatibleVersion</key>\n\t<string>1.0</string>\n\t<key>OSBundleLibraries</key>\n\t<dict>\n\t\t<key>as.vit9696.Lilu</key>\n\t\t<string>1.2.0</string>\n\t\t<key>com.apple.iokit.IOPCIFamily</key>\n\t\t<string>1.0.0b1</string>\n\t\t<key>com.apple.kpi.bsd</key>\n\t\t<string>10.0.0</string>\n\t\t<key>com.apple.kpi.dsep</key>\n\t\t<string>10.0.0</string>\n\t\t<key>com.apple.kpi.iokit</key>\n\t\t<string>10.0.0</string>\n\t\t<key>com.apple.kpi.libkern</key>\n\t\t<string>10.0.0</string>\n\t\t<key>com.apple.kpi.mach</key>\n\t\t<string>10.0.0</string>\n\t\t<key>com.apple.kpi.unsupported</key>\n\t\t<string>10.0.0</string>\n\t</dict>\n\t<key>OSBundleRequired</key>\n\t<string>Root</string>\n</dict>\n</plist>\n"
  },
  {
    "path": "EFI_DEBUG/EFI/OC/Resources/Font/Terminus.hex",
    "content": "0000:0000EEC600C6C6C600C6C6EE00000000\n0020:00000000000000000000000000000000\n0021:00001818181818181800181800000000\n0022:00666666000000000000000000000000\n0023:00006C6C6CFE6C6CFE6C6C6C00000000\n0024:0018187EDBD8D87E1B1BDB7E18180000\n0025:000066D66C0C181830366B6600000000\n0026:0000386C6C3876DCCCCCDC7600000000\n0027:00181818000000000000000000000000\n0028:00000C18303030303030180C00000000\n0029:000030180C0C0C0C0C0C183000000000\n002A:00000000006C38FE386C000000000000\n002B:000000000018187E1818000000000000\n002C:00000000000000000000181830000000\n002D:00000000000000FE0000000000000000\n002E:00000000000000000000181800000000\n002F:000006060C0C18183030606000000000\n0030:00007CC6C6CEDEF6E6C6C67C00000000\n0031:00001838781818181818187E00000000\n0032:00007CC6C6060C183060C0FE00000000\n0033:00007CC6C6063C0606C6C67C00000000\n0034:0000060E1E3666C6FE06060600000000\n0035:0000FEC0C0C0FC060606C67C00000000\n0036:00003C60C0C0FCC6C6C6C67C00000000\n0037:0000FE06060C0C181830303000000000\n0038:00007CC6C6C67CC6C6C6C67C00000000\n0039:00007CC6C6C6C67E06060C7800000000\n003A:00000000001818000000181800000000\n003B:00000000001818000000181830000000\n003C:000000060C18306030180C0600000000\n003D:0000000000FE0000FE00000000000000\n003E:0000006030180C060C18306000000000\n003F:00007CC6C6C60C181800181800000000\n0040:00007EC3CFDBDBDBDBCFC07F00000000\n0041:00007CC6C6C6C6FEC6C6C6C600000000\n0042:0000FCC6C6C6FCC6C6C6C6FC00000000\n0043:00007CC6C6C0C0C0C0C6C67C00000000\n0044:0000F8CCC6C6C6C6C6C6CCF800000000\n0045:0000FEC0C0C0F8C0C0C0C0FE00000000\n0046:0000FEC0C0C0F8C0C0C0C0C000000000\n0047:00007CC6C6C0C0DEC6C6C67C00000000\n0048:0000C6C6C6C6FEC6C6C6C6C600000000\n0049:00003C18181818181818183C00000000\n004A:00001E0C0C0C0C0C0CCCCC7800000000\n004B:0000C6C6CCD8F0F0D8CCC6C600000000\n004C:0000C0C0C0C0C0C0C0C0C0FE00000000\n004D:000081C3E7FFDBC3C3C3C3C300000000\n004E:0000C6C6C6E6F6DECEC6C6C600000000\n004F:00007CC6C6C6C6C6C6C6C67C00000000\n0050:0000FCC6C6C6C6FCC0C0C0C000000000\n0051:00007CC6C6C6C6C6C6C6DE7C06000000\n0052:0000FCC6C6C6C6FCF0D8CCC600000000\n0053:00007CC6C0C07C0606C6C67C00000000\n0054:0000FF18181818181818181800000000\n0055:0000C6C6C6C6C6C6C6C6C67C00000000\n0056:0000C6C6C6C6C66C6C6C383800000000\n0057:0000C3C3C3C3C3DBFFE7C38100000000\n0058:0000C6C66C6C38386C6CC6C600000000\n0059:0000C3C366663C181818181800000000\n005A:0000FE06060C183060C0C0FE00000000\n005B:00003C30303030303030303C00000000\n005C:00006060303018180C0C060600000000\n005D:00003C0C0C0C0C0C0C0C0C3C00000000\n005E:00183C66000000000000000000000000\n005F:00000000000000000000000000FE0000\n0060:30180000000000000000000000000000\n0061:00000000007C067EC6C6C67E00000000\n0062:0000C0C0C0FCC6C6C6C6C6FC00000000\n0063:00000000007CC6C0C0C0C67C00000000\n0064:00000606067EC6C6C6C6C67E00000000\n0065:00000000007CC6C6FEC0C07C00000000\n0066:00001E3030FC30303030303000000000\n0067:00000000007EC6C6C6C6C67E06067C00\n0068:0000C0C0C0FCC6C6C6C6C6C600000000\n0069:00001818003818181818183C00000000\n006A:00000606000E06060606060666663C00\n006B:0000C0C0C0C6CCD8F0D8CCC600000000\n006C:00003818181818181818183C00000000\n006D:0000000000FEDBDBDBDBDBDB00000000\n006E:0000000000FCC6C6C6C6C6C600000000\n006F:00000000007CC6C6C6C6C67C00000000\n0070:0000000000FCC6C6C6C6C6FCC0C0C000\n0071:00000000007EC6C6C6C6C67E06060600\n0072:0000000000DEF0E0C0C0C0C000000000\n0073:00000000007EC0C07C0606FC00000000\n0074:0000303030FC30303030301E00000000\n0075:0000000000C6C6C6C6C6C67E00000000\n0076:0000000000C6C6C66C6C383800000000\n0077:0000000000C3C3DBDBDBDB7E00000000\n0078:0000000000C6C66C386CC6C600000000\n0079:0000000000C6C6C6C6C6C67E06067C00\n007A:0000000000FE0C183060C0FE00000000\n007B:00001C30303060303030301C00000000\n007C:00001818181818181818181800000000\n007D:0000701818180C181818187000000000\n007E:0073DBCE000000000000000000000000\n00A0:00000000000000000000000000000000\n00A1:00001818001818181818181800000000\n00A2:00000018187EDBD8D8D8DB7E18180000\n00A3:0000386C6060F860606066FE00000000\n00A4:00000000663C6666663C660000000000\n00A5:0000C3C3663C187E187E181800000000\n00A6:00001818181800001818181800000000\n00A7:003C6660386C6666361C06663C000000\n00A8:6C6C0000000000000000000000000000\n00A9:0000007E8199A5A1A599817E00000000\n00AA:003C063E663E007E0000000000000000\n00AB:00000000001B366CD86C361B00000000\n00AC:0000000000FE06060600000000000000\n00AD:000000000000007C0000000000000000\n00AE:0000007E81B9A5B9A9A5817E00000000\n00AF:7C000000000000000000000000000000\n00B0:00386C6C380000000000000000000000\n00B1:000000000018187E1818007E00000000\n00B2:00386C0C18307C000000000000000000\n00B3:00780C380C0C78000000000000000000\n00B4:18300000000000000000000000000000\n00B5:0000000000C6C6C6C6C6CEF6C0C0C000\n00B6:00007FDBDBDBDB7B1B1B1B1B00000000\n00B7:00000000000000181800000000000000\n00B8:00000000000000000000000030306000\n00B9:0018381818183C000000000000000000\n00BA:003C6666663C007E0000000000000000\n00BB:0000000000D86C361B366CD800000000\n00BC:0060E062666C183066CE9A3E06060000\n00BD:0060E062666C183060CE9B060C1F0000\n00BE:00E0306236EC183066CE9A3E06060000\n00BF:0000303000303060C6C6C67C00000000\n00C0:3018007CC6C6C6FEC6C6C6C600000000\n00C1:1830007CC6C6C6FEC6C6C6C600000000\n00C2:386C007CC6C6C6FEC6C6C6C600000000\n00C3:76DC007CC6C6C6FEC6C6C6C600000000\n00C4:6C6C007CC6C6C6FEC6C6C6C600000000\n00C5:386C387CC6C6C6FEC6C6C6C600000000\n00C6:00007FCCCCCCFFCCCCCCCCCF00000000\n00C7:00007CC6C6C0C0C0C0C6C67C30306000\n00C8:301800FEC0C0C0F8C0C0C0FE00000000\n00C9:183000FEC0C0C0F8C0C0C0FE00000000\n00CA:386C00FEC0C0C0F8C0C0C0FE00000000\n00CB:6C6C00FEC0C0C0F8C0C0C0FE00000000\n00CC:3018003C181818181818183C00000000\n00CD:0C18003C181818181818183C00000000\n00CE:386C003C181818181818183C00000000\n00CF:6666003C181818181818183C00000000\n00D0:00007C666363FB636363667C00000000\n00D1:76DC00C6C6E6F6DECEC6C6C600000000\n00D2:3018007CC6C6C6C6C6C6C67C00000000\n00D3:1830007CC6C6C6C6C6C6C67C00000000\n00D4:386C007CC6C6C6C6C6C6C67C00000000\n00D5:76DC007CC6C6C6C6C6C6C67C00000000\n00D6:6C6C007CC6C6C6C6C6C6C67C00000000\n00D7:0000000000C66C38386CC60000000000\n00D8:00007CC7C6CEDEF6E6C6C67C00000000\n00D9:3018C6C6C6C6C6C6C6C6C67C00000000\n00DA:1830C6C6C6C6C6C6C6C6C67C00000000\n00DB:386C00C6C6C6C6C6C6C6C67C00000000\n00DC:6C6C00C6C6C6C6C6C6C6C67C00000000\n00DD:0C18C3C366663C181818181800000000\n00DE:0000C0C0FCC6C6C6C6FCC0C000000000\n00DF:000078CCCCC8FCC6C6C6E6DC00000000\n00E0:00003018007C067EC6C6C67E00000000\n00E1:00001830007C067EC6C6C67E00000000\n00E2:0000386C007C067EC6C6C67E00000000\n00E3:000076DC007C067EC6C6C67E00000000\n00E4:00006C6C007C067EC6C6C67E00000000\n00E5:0000386C387C067EC6C6C67E00000000\n00E6:0000000000761B7BDFD8D86E00000000\n00E7:00000000007CC6C0C0C0C67C30306000\n00E8:00003018007CC6C6FEC0C07C00000000\n00E9:00001830007CC6C6FEC0C07C00000000\n00EA:0000386C007CC6C6FEC0C07C00000000\n00EB:00006C6C007CC6C6FEC0C07C00000000\n00EC:00003018003818181818183C00000000\n00ED:00000C18003818181818183C00000000\n00EE:0000386C003818181818183C00000000\n00EF:00006C6C003818181818183C00000000\n00F0:00006830587CC6C6C6C6C67C00000000\n00F1:000076DC00FCC6C6C6C6C6C600000000\n00F2:00003018007CC6C6C6C6C67C00000000\n00F3:00001830007CC6C6C6C6C67C00000000\n00F4:0000386C007CC6C6C6C6C67C00000000\n00F5:000076DC007CC6C6C6C6C67C00000000\n00F6:00006C6C007CC6C6C6C6C67C00000000\n00F7:000000001818007E0018180000000000\n00F8:00000000003D676E7E76E6BC00000000\n00F9:0000301800C6C6C6C6C6C67E00000000\n00FA:0000183000C6C6C6C6C6C67E00000000\n00FB:0000386C00C6C6C6C6C6C67E00000000\n00FC:00006C6C00C6C6C6C6C6C67E00000000\n00FD:0000183000C6C6C6C6C6C67E06067C00\n00FE:0000C0C0C0FCC6C6C6C6C6FCC0C0C000\n00FF:00006C6C00C6C6C6C6C6C67E06067C00\n0100:7C007CC6C6C6C6FEC6C6C6C600000000\n0101:0000007C007C067EC6C6C67E00000000\n0102:6C38007CC6C6C6FEC6C6C6C600000000\n0103:00006C38007C067EC6C6C67E00000000\n0104:00007CC6C6C6C6FEC6C6C6C6060C0700\n0105:00000000007C067EC6C6C67E060C0700\n0106:1830007CC6C6C0C0C0C6C67C00000000\n0107:00001830007CC6C0C0C0C67C00000000\n0108:386C007CC6C6C0C0C0C6C67C00000000\n0109:0000386C007CC6C0C0C0C67C00000000\n010A:1818007CC6C6C0C0C0C6C67C00000000\n010B:00001818007CC6C0C0C0C67C00000000\n010C:6C38007CC6C6C0C0C0C6C67C00000000\n010D:00006C38007CC6C0C0C0C67C00000000\n010E:6C3800F8CCC6C6C6C6C6CCF800000000\n010F:6C380606067EC6C6C6C6C67E00000000\n0110:00007C666363FB636363667C00000000\n0111:0000061F067EC6C6C6C6C67E00000000\n0112:7C00FEC0C0C0F8C0C0C0C0FE00000000\n0113:0000007C007CC6C6FEC0C07C00000000\n0114:6C3800FEC0C0C0F8C0C0C0FE00000000\n0115:00006C38007CC6C6FEC0C07C00000000\n0116:181800FEC0C0C0F8C0C0C0FE00000000\n0117:00001818007CC6C6FEC0C07C00000000\n0118:0000FEC0C0C0F8C0C0C0C0FE060C0700\n0119:00000000007CC6C6FEC0C07C18301C00\n011A:6C3800FEC0C0C0F8C0C0C0FE00000000\n011B:00006C38007CC6C6FEC0C07C00000000\n011C:386C007CC6C0C0DEC6C6C67C00000000\n011D:0000386C007EC6C6C6C6C67E06067C00\n011E:6C38007CC6C0C0DEC6C6C67C00000000\n011F:00006C38007EC6C6C6C6C67E06067C00\n0120:1818007CC6C0C0DEC6C6C67C00000000\n0121:00001818007EC6C6C6C6C67E06067C00\n0122:00007CC6C6C0C0DEC6C6C67C00303060\n0123:000C1818007EC6C6C6C6C67E06067C00\n0124:386C00C6C6C6C6FEC6C6C6C600000000\n0125:1C36C0C0C0FCC6C6C6C6C6C600000000\n0126:000066FF66667E666666666600000000\n0127:000060F8607E63636363636300000000\n0128:76DC003C181818181818183C00000000\n0129:000076DC003818181818183C00000000\n012A:7E003C18181818181818183C00000000\n012B:0000007C003818181818183C00000000\n012C:6C38003C181818181818183C00000000\n012D:00006C38003818181818183C00000000\n012E:00003C18181818181818183C18301C00\n012F:00001818003818181818183C18301C00\n0130:1818003C181818181818183C00000000\n0131:00000000003818181818183C00000000\n0132:0000CFC6C6C6C6C6C6F6F6DC00000000\n0133:0000C6C600C6C6C6C6C6C6C636361C00\n0134:1C36001E0C0C0C0C0CCCCC7800000000\n0135:00000E1B000E06060606060666663C00\n0136:0000C6C6CCD8F0F0D8CCC6C600303060\n0137:0000C0C0C0C6CCD8F0D8CCC600303060\n0138:0000000000C6CCD8F0D8CCC600000000\n0139:60C000C0C0C0C0C0C0C0C0FE00000000\n013A:0C180038181818181818183C00000000\n013B:0000C0C0C0C0C0C0C0C0C0FE00303060\n013C:00003818181818181818183C00181830\n013D:6C38C0C0C0C0C0C0C0C0C0FE00000000\n013E:6C380038181818181818183C00000000\n013F:0000C0C0C0C0CCCCC0C0C0FE00000000\n0140:0000381818181B1B1818183C00000000\n0141:00006060606070E06060607F00000000\n0142:0000381818181C381818183C00000000\n0143:1830C6C6C6E6F6DECEC6C6C600000000\n0144:0000183000FCC6C6C6C6C6C600000000\n0145:0000C6C6C6E6F6DECEC6C6C600303060\n0146:0000000000FCC6C6C6C6C6C600303060\n0147:6C38C6C6C6E6F6DECEC6C6C600000000\n0148:00006C3800FCC6C6C6C6C6C600000000\n0149:006060C000FCC6C6C6C6C6C600000000\n014A:0000C6C6C6E6F6DECEC6C6C606061C00\n014B:0000000000FCC6C6C6C6C6C606061C00\n014C:7C007CC6C6C6C6C6C6C6C67C00000000\n014D:0000007C007CC6C6C6C6C67C00000000\n014E:6C38007CC6C6C6C6C6C6C67C00000000\n014F:00006C38007CC6C6C6C6C67C00000000\n0150:366C007CC6C6C6C6C6C6C67C00000000\n0151:0000366C007CC6C6C6C6C67C00000000\n0152:00007FCCCCCCCFCCCCCCCC7F00000000\n0153:00000000007EDBDBDFD8D87E00000000\n0154:183000FCC6C6C6FCF0D8CCC600000000\n0155:0000183000DEF0E0C0C0C0C000000000\n0156:0000FCC6C6C6C6FCF0D8CCC600303060\n0157:00000000006F787060606060006060C0\n0158:6C3800FCC6C6C6FCF0D8CCC600000000\n0159:00006C3800DEF0E0C0C0C0C000000000\n015A:1830007CC6C0C07C0606C67C00000000\n015B:00000C18007EC0C07C0606FC00000000\n015C:386C007CC6C0C07C0606C67C00000000\n015D:0000386C007EC0C07C0606FC00000000\n015E:00007CC6C0C07C0606C6C67C30306000\n015F:00000000007EC0C07C0606FC30306000\n0160:6C38007CC6C0C07C0606C67C00000000\n0161:00006C38007EC0C07C0606FC00000000\n0162:0000FF1818181818181818180C0C1800\n0163:0000303030FC30303030301E0C0C1800\n0164:6C3800FF181818181818181800000000\n0165:6C38003030FC30303030301E00000000\n0166:0000FF1818187E181818181800000000\n0167:0000303030FC30783030301E00000000\n0168:76DC00C6C6C6C6C6C6C6C67C00000000\n0169:000076DC00C6C6C6C6C6C67E00000000\n016A:7C00C6C6C6C6C6C6C6C6C67C00000000\n016B:0000007C00C6C6C6C6C6C67E00000000\n016C:6C38C6C6C6C6C6C6C6C6C67C00000000\n016D:00006C3800C6C6C6C6C6C67E00000000\n016E:386C38C6C6C6C6C6C6C6C67C00000000\n016F:0000386C38C6C6C6C6C6C67E00000000\n0170:366C00C6C6C6C6C6C6C6C67C00000000\n0171:0000366C00C6C6C6C6C6C67E00000000\n0172:0000C6C6C6C6C6C6C6C6C67C18301C00\n0173:0000000000C6C6C6C6C6C67E060C0700\n0174:386C00C3C3C3C3DBFFE7C38100000000\n0175:0000386C00C3C3DBDBDBDB7E00000000\n0176:386C00C3C366663C1818181800000000\n0177:0000386C00C6C6C6C6C6C67E06067C00\n0178:666600C3C366663C1818181800000000\n0179:183000FE060C183060C0C0FE00000000\n017A:0000183000FE0C183060C0FE00000000\n017B:181800FE060C183060C0C0FE00000000\n017C:0000181800FE0C183060C0FE00000000\n017D:6C3800FE060C183060C0C0FE00000000\n017E:00006C3800FE0C183060C0FE00000000\n017F:00001E30303030303030303000000000\n0186:00007CC6C606060606C6C67C00000000\n018E:0000FE0606063E06060606FE00000000\n018F:00007CC60606FEC6C6C6C67C00000000\n0190:00007CC6C6C078C0C0C6C67C00000000\n0192:00000E1B18187E181818181818D87000\n019D:0000636363737B6F676363636060C000\n019E:0000000000FCC6C6C6C6C6C606060600\n01B5:0000FE060C18FE3060C0C0FE00000000\n01B6:0000000000FE0C18FC3060FE00000000\n01B7:0000FE060C183C0606C6C67C00000000\n01CD:6C38007CC6C6C6FEC6C6C6C600000000\n01CE:00006C38007C067EC6C6C67E00000000\n01CF:6C38003C181818181818183C00000000\n01D0:00006C38003818181818183C00000000\n01D1:6C38007CC6C6C6C6C6C6C67C00000000\n01D2:00006C38007CC6C6C6C6C67C00000000\n01D3:6C38C6C6C6C6C6C6C6C6C67C00000000\n01D4:00006C3800C6C6C6C6C6C67E00000000\n01E2:7E007FCCCCCCFFCCCCCCCCCF00000000\n01E3:0000007E00761B7BDFD8D86E00000000\n01E4:00007CC6C6C0C0DEC6DFC67C00000000\n01E5:00000000007EC6C6DFC6C67E06067C00\n01E6:6C38007CC6C0C0DEC6C6C67C00000000\n01E7:00006C38007EC6C6C6C6C67E06067C00\n01E8:6C38C6C6CCD8F0F0D8CCC6C600000000\n01E9:6C38C0C0C0C6CCD8F0D8CCC600000000\n01EA:00007CC6C6C6C6C6C6C6C67C18301C00\n01EB:00000000007CC6C6C6C6C67C18301C00\n01EC:7C007CC6C6C6C6C6C6C6C67C18301C00\n01ED:0000007C007CC6C6C6C6C67C18301C00\n01EE:6C3800FE0C183C0606C6C67C00000000\n01EF:00006C3800FE060C183C0606C6C67C00\n01F0:00001B0E000E06060606060666663C00\n01F4:1830007CC6C0C0DEC6C6C67C00000000\n01F5:00000C18007EC6C6C6C6C67E06067C00\n01FC:0C18007FCCCCCCFFCCCCCCCF00000000\n01FD:00000C1800761B7BDFD8D86E00000000\n01FE:1830007CC7C6CEDEF6E6C67C00000000\n01FF:00001830003D676E7E76E6BC00000000\n0218:00007CC6C0C07C0606C6C67C00303060\n0219:00000000007EC0C07C0606FC00303060\n021A:0000FF18181818181818181800181830\n021B:0000303030FC30303030301E000C0C18\n0232:7E00C3C366663C181818181800000000\n0233:0000007C00C6C6C6C6C6C67E06067C00\n0237:00000000000E06060606060666663C00\n0254:00000000007CC6060606C67C00000000\n0258:00000000007CC6C6FE06067C00000000\n0259:00000000007C0606FEC6C67C00000000\n025B:00000000007CC6C078C0C67C00000000\n0272:00000000007E6363636363636060C000\n0292:0000000000FE060C183C0606C6C67C00\n02BB:18303000000000000000000000000000\n02BC:18183000000000000000000000000000\n02BD:30301800000000000000000000000000\n02C6:386C0000000000000000000000000000\n02C7:6C380000000000000000000000000000\n02D8:6C380000000000000000000000000000\n02D9:18180000000000000000000000000000\n02DB:00000000000000000000000018301C00\n02DC:76DC0000000000000000000000000000\n02DD:366C0000000000000000000000000000\n0300:30180000000000000000000000000000\n0301:18300000000000000000000000000000\n0302:386C0000000000000000000000000000\n0303:76DC0000000000000000000000000000\n0304:7C000000000000000000000000000000\n0305:FE000000000000000000000000000000\n0306:6C380000000000000000000000000000\n0307:18180000000000000000000000000000\n0308:6C6C0000000000000000000000000000\n030A:386C3800000000000000000000000000\n030B:366C0000000000000000000000000000\n030C:6C380000000000000000000000000000\n0329:00000000000000000000000000181800\n0384:60C00000000000000000000000000000\n0385:1830006C000000000000000000000000\n0386:60C07CC6C6C6C6FEC6C6C6C600000000\n0387:00000000001818000000000000000000\n0388:60C000FEC0C0C0F8C0C0C0FE00000000\n0389:60C000C6C6C6C6FEC6C6C6C600000000\n038A:60C03C18181818181818183C00000000\n038C:60C07CC6C6C6C6C6C6C6C67C00000000\n038E:60C000C3C366663C1818181800000000\n038F:60C07CC6C6C6C6C6C66C6CEE00000000\n0390:1830D8D8007030303030301C00000000\n0391:00007CC6C6C6C6FEC6C6C6C600000000\n0392:0000FCC6C6C6FCC6C6C6C6FC00000000\n0393:0000FEC0C0C0C0C0C0C0C0C000000000\n0394:000018183C3C666666C3C3FF00000000\n0395:0000FEC0C0C0F8C0C0C0C0FE00000000\n0396:0000FE06060C183060C0C0FE00000000\n0397:0000C6C6C6C6FEC6C6C6C6C600000000\n0398:00007CC6C6C6D6D6C6C6C67C00000000\n0399:00003C18181818181818183C00000000\n039A:0000C6C6CCD8F0F0D8CCC6C600000000\n039B:000018183C3C666666C3C3C300000000\n039C:000081C3E7FFDBC3C3C3C3C300000000\n039D:0000C6C6C6E6F6DECEC6C6C600000000\n039E:0000FE0000007C00000000FE00000000\n039F:00007CC6C6C6C6C6C6C6C67C00000000\n03A0:0000FEC6C6C6C6C6C6C6C6C600000000\n03A1:0000FCC6C6C6C6FCC0C0C0C000000000\n03A3:0000FEC0603018183060C0FE00000000\n03A4:0000FF18181818181818181800000000\n03A5:0000C3C366663C181818181800000000\n03A6:0000187EDBDBDBDBDBDB7E1800000000\n03A7:0000C6C66C6C38386C6CC6C600000000\n03A8:0000DBDBDBDBDBDBDB7E181800000000\n03A9:00007CC6C6C6C6C6C66C6CEE00000000\n03AA:6666003C181818181818183C00000000\n03AB:666600C3C366663C1818181800000000\n03AC:00001830007BCECCCCCCCE7B00000000\n03AD:00001830007CC6C078C0C67C00000000\n03AE:0000183000FCC6C6C6C6C6C606060600\n03AF:00001830007030303030301C00000000\n03B0:1830006C00C6C6C6C6C6C67C00000000\n03B1:00000000007BCECCCCCCCE7B00000000\n03B2:000078CCCCC8FCC6C6C6C6FCC0C0C000\n03B3:0000000000C3C366663C3C1818181800\n03B4:00007E30187CC6C6C6C6C67C00000000\n03B5:00000000007CC6C078C0C67C00000000\n03B6:0000FE0C183060C0C0C0C07C06060C00\n03B7:0000000000FCC6C6C6C6C6C606060600\n03B8:00003C6666667E666666663C00000000\n03B9:00000000007030303030301C00000000\n03BA:0000000000C6CCD8F0D8CCC600000000\n03BB:0000303018183C3C6666C3C300000000\n03BC:0000000000C6C6C6C6C6CEF6C0C0C000\n03BD:0000000000C6C6C66C6C383800000000\n03BE:00007EC0C0C07CC0C0C0C07C06060C00\n03BF:00000000007CC6C6C6C6C67C00000000\n03C0:0000000000FEC6C6C6C6C6C600000000\n03C1:00000000007CC6C6C6C6C6FCC0C0C000\n03C2:00000000007CC6C0C0C0C07C06060C00\n03C3:00000000003F66666666663C00000000\n03C4:0000000000FF18181818180E00000000\n03C5:0000000000C6C6C6C6C6C67C00000000\n03C6:00000000004EDBDBDBDBDB7E18181800\n03C7:0000000000C6C66C6C38386C6CC6C600\n03C8:0000000000DBDBDBDBDBDB7E18181800\n03C9:000000000066C3DBDBDBFF6600000000\n03CA:0000D8D8007030303030301C00000000\n03CB:00006C6C00C6C6C6C6C6C67C00000000\n03CC:00001830007CC6C6C6C6C67C00000000\n03CD:0000183000C6C6C6C6C6C67C00000000\n03CE:00000C180066C3DBDBDBFF6600000000\n03D1:00003C6666663F06E666663C00000000\n03D5:00000000187EDBDBDBDBDB7E18000000\n03F0:0000000000E3361C18386CC700000000\n03F1:00000000007CC6C6C6C6C6FCC0C07C00\n03F2:00000000007CC6C0C0C0C67C00000000\n03F3:00000606000E06060606060666663C00\n03F4:00007CC6C6C6FEC6C6C6C67C00000000\n03F5:00000000003E60C0FCC0603E00000000\n03F6:0000000000F80C067E060CF800000000\n0400:301800FEC0C0C0F8C0C0C0FE00000000\n0401:6C6C00FEC0C0C0F8C0C0C0FE00000000\n0402:0000FC30303E33333333333600000000\n0403:183000FEC0C0C0C0C0C0C0C000000000\n0404:00007CC6C0C0F8C0C0C0C67C00000000\n0405:00007CC6C0C07C0606C6C67C00000000\n0406:00003C18181818181818183C00000000\n0407:6666003C181818181818183C00000000\n0408:00001E0C0C0C0C0C0CCCCC7800000000\n0409:00003878D8DEDBDBDBDBDB9E00000000\n040A:0000D8D8D8DEFBDBDBDBDBDE00000000\n040B:0000FC30303E33333333333300000000\n040C:1830C6C6CCD8F0F0D8CCC6C600000000\n040D:3018C6C6C6CEDEF6E6C6C6C600000000\n040E:6C38C6C6C6C6C67E0606067C00000000\n040F:0000C6C6C6C6C6C6C6C6C6FE38380000\n0410:00007CC6C6C6C6FEC6C6C6C600000000\n0411:0000FCC0C0FCC6C6C6C6C6FC00000000\n0412:0000FCC6C6C6FCC6C6C6C6FC00000000\n0413:0000FEC0C0C0C0C0C0C0C0C000000000\n0414:00003E6666666666666666FFC3000000\n0415:0000FEC0C0C0F8C0C0C0C0FE00000000\n0416:0000DBDBDB7E3C7EDBDBDBDB00000000\n0417:00007CC6C6063C0606C6C67C00000000\n0418:0000C6C6C6CEDEF6E6C6C6C600000000\n0419:6C38C6C6C6CEDEF6E6C6C6C600000000\n041A:0000C6C6CCD8F0F0D8CCC6C600000000\n041B:00001E3666666666666666C600000000\n041C:000081C3E7FFDBC3C3C3C3C300000000\n041D:0000C6C6C6C6FEC6C6C6C6C600000000\n041E:00007CC6C6C6C6C6C6C6C67C00000000\n041F:0000FEC6C6C6C6C6C6C6C6C600000000\n0420:0000FCC6C6C6C6FCC0C0C0C000000000\n0421:00007CC6C6C0C0C0C0C6C67C00000000\n0422:0000FF18181818181818181800000000\n0423:0000C6C6C6C6C67E0606067C00000000\n0424:00187EDBDBDBDBDBDBDBDB7E18000000\n0425:0000C6C66C6C38386C6CC6C600000000\n0426:0000C6C6C6C6C6C6C6C6C67F03030000\n0427:0000C6C6C6C6C67E0606060600000000\n0428:0000DBDBDBDBDBDBDBDBDB7F00000000\n0429:0000D6D6D6D6D6D6D6D6D67F03030000\n042A:0000E060607E63636363637E00000000\n042B:0000C3C3C3F3DBDBDBDBDBF300000000\n042C:00006060607E63636363637E00000000\n042D:00007CC606063E060606C67C00000000\n042E:0000CEDBDBDBDBFBDBDBDBCE00000000\n042F:00007EC6C6C6C67E1E3666C600000000\n0430:00000000007C067EC6C6C67E00000000\n0431:00007CC0C0FCC6C6C6C6C6FC00000000\n0432:000078CCCCC8FCC6C6C6C6FC00000000\n0433:0000000000FEC0C0C0C0C0C000000000\n0434:00000000007EC6C6C6C6C67E06067C00\n0435:00000000007CC6C6FEC0C07C00000000\n0436:0000000000DBDB7E3C7EDBDB00000000\n0437:00000000007CC6063C06C67C00000000\n0438:0000000000C6C6C6C6C6C67E00000000\n0439:00006C3800C6C6C6C6C6C67E00000000\n043A:0000000000C6CCD8F0D8CCC600000000\n043B:00000000003E6666666666C600000000\n043C:0000000000C3E7FFDBC3C3C300000000\n043D:0000000000C6C6C6FEC6C6C600000000\n043E:00000000007CC6C6C6C6C67C00000000\n043F:0000000000FEC6C6C6C6C6C600000000\n0440:0000000000FCC6C6C6C6C6FCC0C0C000\n0441:00000000007CC6C0C0C0C67C00000000\n0442:0000000000FF18181818181800000000\n0443:0000000000C6C6C6C6C6C67E06067C00\n0444:00000000187EDBDBDBDBDB7E18000000\n0445:0000000000C6C66C386CC6C600000000\n0446:0000000000C6C6C6C6C6C67F03030000\n0447:0000000000C6C6C67E06060600000000\n0448:0000000000DBDBDBDBDBDB7F00000000\n0449:0000000000D6D6D6D6D6D67F03030000\n044A:0000000000E0607C6666667C00000000\n044B:0000000000C3C3F3DBDBDBF300000000\n044C:000000000060607C6666667C00000000\n044D:00000000007CC6063E06C67C00000000\n044E:0000000000CEDBDBFBDBDBCE00000000\n044F:00000000007EC6C67E3666C600000000\n0450:00003018007CC6C6FEC0C07C00000000\n0451:00006C6C007CC6C6FEC0C07C00000000\n0452:000060F8607E63636363636303030E00\n0453:0000183000FEC0C0C0C0C0C000000000\n0454:00000000007CC6C0F8C0C67C00000000\n0455:00000000007EC0C07C0606FC00000000\n0456:00001818003818181818183C00000000\n0457:00006C6C003818181818183C00000000\n0458:00000606000E06060606060666663C00\n0459:000000000078D8DEDBDBDB9E00000000\n045A:0000000000D8D8DEFBDBDBDE00000000\n045B:000060F8607E63636363636300000000\n045C:0000183000C6CCD8F0D8CCC600000000\n045D:0000301800C6C6C6C6C6C67E00000000\n045E:00006C3800C6C6C6C6C6C67E06067C00\n045F:0000000000C6C6C6C6C6C6FE38380000\n0462:000060F8607E63636363637E00000000\n0463:00006060F860607C6666667C00000000\n046A:0000FFC366663C7EDBDBDBDB00000000\n046B:0000000000FF663C3C7EDBDB00000000\n0490:0606FEC0C0C0C0C0C0C0C0C000000000\n0491:0000000606FEC0C0C0C0C0C000000000\n0492:00007F606060FC606060606000000000\n0493:00000000007F6060FC60606000000000\n0494:0000FEC0C0C0C0FCC6C6C6C6060C0000\n0495:0000000000FEC0C0F8CCCCCC0C180000\n0496:0000D6D6D67C387CD6D6D6D703030000\n0497:0000000000D6D67C387CD6D703030000\n0498:00007CC6C6063C0606C6C67C30303000\n0499:00000000007CC6063C06C67C30303000\n049A:0000C6C6CCD8F0F0D8CCC6C703030000\n049B:0000000000C6CCD8F0D8CCC703030000\n049C:0000C6C6D6DCF8F8DCD6C6C600000000\n049D:0000000000C6D6DCF8DCD6C600000000\n04A0:0000E3E3666C78786C66636300000000\n04A1:0000000000E3666C786C666300000000\n04A2:0000C6C6C6C6FEC6C6C6C6C703030000\n04A3:0000000000C6C6C6FEC6C6C703030000\n04A4:0000CFCCCCCCFCCCCCCCCCCC00000000\n04A5:0000000000CFCCCCFCCCCCCC00000000\n04AA:00007CC6C6C0C0C0C0C6C67C30303000\n04AB:00000000007CC6C0C0C0C67C30303000\n04AE:0000C3C366663C181818181800000000\n04AF:0000000000C3C366663C3C1818181800\n04B0:0000C3C366663C187E18181800000000\n04B1:0000000000C3C366663C3C187E181800\n04B2:0000C6C66C6C38386C6CC6C703030000\n04B3:0000000000C6C66C386CC6C703030000\n04B6:0000C6C6C6C6C67E0606060703030000\n04B7:0000000000C6C6C67E06060703030000\n04B8:0000C6C6C6D6D67E1616060600000000\n04B9:0000000000C6D6D67E16060600000000\n04BA:0000C0C0C0C0FCC6C6C6C6C600000000\n04BB:0000000000C0C0FCC6C6C6C600000000\n04C0:00003C18181818181818183C00000000\n04C1:6C3800DBDBDB7E3C7EDBDBDB00000000\n04C2:00006C3800DBDB7E3C7EDBDB00000000\n04CF:00003818181818181818183C00000000\n04D0:6C38007CC6C6C6FEC6C6C6C600000000\n04D1:00006C38007C067EC6C6C67E00000000\n04D2:6C6C007CC6C6C6FEC6C6C6C600000000\n04D3:00006C6C007C067EC6C6C67E00000000\n04D4:00007FCCCCCCFFCCCCCCCCCF00000000\n04D5:0000000000761B7BDFD8D86E00000000\n04D6:6C3800FEC0C0C0F8C0C0C0FE00000000\n04D7:00006C38007CC6C6FEC0C07C00000000\n04D8:00007CC60606FEC6C6C6C67C00000000\n04D9:00000000007C0606FEC6C67C00000000\n04DA:6C6C007CC60606FEC6C6C67C00000000\n04DB:00006C6C007C0606FEC6C67C00000000\n04DC:666600DBDBDB7E3C7EDBDBDB00000000\n04DD:0000666600DBDB7E3C7EDBDB00000000\n04DE:6C6C007CC6C6063C06C6C67C00000000\n04DF:00006C6C007CC6063C06C67C00000000\n04E2:7C00C6C6C6CEDEF6E6C6C6C600000000\n04E3:0000007C00C6C6C6C6C6C67E00000000\n04E4:6C6C00C6C6C6CEDEF6E6C6C600000000\n04E5:00006C6C00C6C6C6C6C6C67E00000000\n04E6:6C6C007CC6C6C6C6C6C6C67C00000000\n04E7:00006C6C007CC6C6C6C6C67C00000000\n04E8:00007CC6C6C6FEC6C6C6C67C00000000\n04E9:00000000007CC6C6FEC6C67C00000000\n04EA:6C6C007CC6C6C6FEC6C6C67C00000000\n04EB:00006C6C007CC6C6FEC6C67C00000000\n04EC:6C6C007CC606063E0606C67C00000000\n04ED:00006C6C007CC6063E06C67C00000000\n04EE:7C00C6C6C6C6C67E0606067C00000000\n04EF:0000007C00C6C6C6C6C6C67E06067C00\n04F0:6C6C00C6C6C6C67E0606067C00000000\n04F1:00006C6C00C6C6C6C6C6C67E06067C00\n04F2:366C00C6C6C6C67E0606067C00000000\n04F3:0000366C00C6C6C6C6C6C67E06067C00\n04F4:6C6C00C6C6C6C67E0606060600000000\n04F5:00006C6C00C6C6C67E06060600000000\n04F8:6C6C00C3C3C3F3DBDBDBDBF300000000\n04F9:00006C6C00C3C3F3DBDBDBF300000000\n05D0:0000C6C666663C78CCCCC6C600000000\n05D1:0000FC0606060606060606FF00000000\n05D2:0000780C0C0C0C0C1E3663C300000000\n05D3:0000FF06060606060606060600000000\n05D4:0000FC0606C6C6C6C6C6C6C600000000\n05D5:00007018181818181818181800000000\n05D6:00007E0C181818181818181800000000\n05D7:0000FCC6C6C6C6C6C6C6C6C600000000\n05D8:0000CCCEC6C6C6C6C6C6C67C00000000\n05D9:00007018181818000000000000000000\n05DA:0000FC06060606060606060606060600\n05DB:0000FC0606060606060606FC00000000\n05DC:C0C0FE060606060C1830303000000000\n05DD:0000FCC6C6C6C6C6C6C6C6FE00000000\n05DE:0000DE73636363636363636700000000\n05DF:0000F018181818181818181800000000\n05E0:0000780C0C0C0C0C0C0C0C7C00000000\n05E1:0000FE63636363636363633E00000000\n05E2:0000C6C6C6666636361C38E000000000\n05E3:00007CC6C6C666060606060606060600\n05E4:00007CC6C6C66606060606FC00000000\n05E5:0000636333361C181818181818181800\n05E6:0000C6C6666C383018180CFC00000000\n05E7:0000FE0606C6C6CCD8D8D8D8C0C0C000\n05E8:0000FC06060606060606060600000000\n05E9:0000DBDBDBDBDBF3E3C3C6FC00000000\n05EA:0000FE6363636363636363C300000000\n1E0C:0000F8CCC6C6C6C6C6C6CCF800303000\n1E0D:00000606067EC6C6C6C6C67E00181800\n1E34:0000C6C6CCD8F0F0D8CCC6C6007C0000\n1E35:0000C0C0C0C6CCD8F0D8CCC6007C0000\n1E36:0000C0C0C0C0C0C0C0C0C0FE00181800\n1E37:00003818181818181818183C00181800\n1E40:181881C3E7FFDBC3C3C3C3C300000000\n1E41:0000181800FEDBDBDBDBDBDB00000000\n1E42:000081C3E7FFDBC3C3C3C3C300181800\n1E43:0000000000FEDBDBDBDBDBDB00181800\n1E44:1818C6C6C6E6F6DECEC6C6C600000000\n1E45:0000303000FCC6C6C6C6C6C600000000\n1E46:0000C6C6C6E6F6DECEC6C6C600181800\n1E47:0000000000FCC6C6C6C6C6C600181800\n1E6C:0000FF18181818181818181800181800\n1E6D:0000303030FC30303030301E000C0C00\n1EB8:0000FEC0C0C0F8C0C0C0C0FE00181800\n1EB9:00000000007CC6C6FEC0C07C00181800\n1EBC:76DC00FEC0C0C0F8C0C0C0FE00000000\n1EBD:000076DC007CC6C6FEC0C07C00000000\n1ECA:00003C18181818181818183C00181800\n1ECB:00001818003818181818183C00181800\n1ECC:00007CC6C6C6C6C6C6C6C67C00181800\n1ECD:00000000007CC6C6C6C6C67C00181800\n1EE4:0000C6C6C6C6C6C6C6C6C67C00181800\n1EE5:0000000000C6C6C6C6C6C67E00181800\n1EF8:76DC00C3C366663C1818181800000000\n1EF9:000076DC00C6C6C6C6C6C67E06067C00\n2000:00000000000000000000000000000000\n2001:00000000000000000000000000000000\n2002:00000000000000000000000000000000\n2003:00000000000000000000000000000000\n2004:00000000000000000000000000000000\n2005:00000000000000000000000000000000\n2006:00000000000000000000000000000000\n2007:00000000000000000000000000000000\n2008:00000000000000000000000000000000\n2009:00000000000000000000000000000000\n200A:00000000000000000000000000000000\n200B:00000000000000000000000000000000\n200C:00000000000000000000000000000000\n200D:00000000000000000000000000000000\n200E:00000000000000000000000000000000\n200F:00000000000000000000000000000000\n2010:000000000000007C0000000000000000\n2011:000000000000007C0000000000000000\n2012:00000000000000FE0000000000000000\n2013:00000000000000FE0000000000000000\n2014:00000000000000FF0000000000000000\n2015:00000000000000FF0000000000000000\n2016:00006C6C6C6C6C6C6C6C6C6C00000000\n2017:00000000000000000000000000FE00FE\n2018:00183030000000000000000000000000\n2019:00181830000000000000000000000000\n201A:00000000000000000000181830000000\n201B:00303018000000000000000000000000\n201C:0066CCCC000000000000000000000000\n201D:00333366000000000000000000000000\n201E:000000000000000000006666CC000000\n201F:00CCCC66000000000000000000000000\n2020:000018187E1818181818181800000000\n2021:000018187E181818187E181800000000\n2022:000000000000183C3C18000000000000\n2026:00000000000000000000DBDB00000000\n2030:0000ECACF8183030607FD5DF00000000\n2032:00181818180000000000000000000000\n2033:00666666660000000000000000000000\n2039:00000000000C18306030180C00000000\n203A:00000000006030180C18306000000000\n203C:00006666666666666600666600000000\n203E:FE000000000000000000000000000000\n2070:00386C6C6C6C38000000000000000000\n2071:1800381818183C000000000000000000\n2074:000C1C347E0C0C000000000000000000\n2075:007860780C0C78000000000000000000\n2076:003860786C6C38000000000000000000\n2077:007C0C18183030000000000000000000\n2078:00386C386C6C38000000000000000000\n2079:00386C6C3C0C38000000000000000000\n207A:000018187E1818000000000000000000\n207B:000000007C0000000000000000000000\n207C:0000007C007C00000000000000000000\n207D:00183030303018000000000000000000\n207E:00301818181830000000000000000000\n207F:0000786C6C6C6C000000000000000000\n2080:00000000000000386C6C6C6C38000000\n2081:0000000000000018381818183C000000\n2082:00000000000000386C0C18307C000000\n2083:00000000000000780C380C0C78000000\n2084:000000000000000C1C347E0C0C000000\n2085:000000000000007860780C0C78000000\n2086:000000000000003860786C6C38000000\n2087:000000000000007C0C18183030000000\n2088:00000000000000386C386C6C38000000\n2089:00000000000000386C6C3C0C38000000\n208A:000000000000000018187E1818000000\n208B:000000000000000000007C0000000000\n208C:0000000000000000007C007C00000000\n208D:00000000000000183030303018000000\n208E:00000000000000301818181830000000\n2090:0000000000000000380C3C6C3C000000\n2091:0000000000000000386C7C603C000000\n2092:0000000000000000386C6C6C38000000\n2093:0000000000000000663C183C66000000\n2094:0000000000000000780C7C6C38000000\n2095:0000000000006060786C6C6C6C000000\n2096:0000000000006060666C786C66000000\n2097:0000000000003818181818183C000000\n2098:0000000000000000FCD6D6D6D6000000\n209A:0000000000000000786C6C6C78606000\n20A7:0000F8CCCCCCFAC6CFC6C6C300000000\n20AA:0000F28A8AAAAAAAAAA2A2BC00000000\n20AC:0000001E3360FC60FC60331E00000000\n20AE:0000FF18181E781E7818181800000000\n2102:00003C52525050505052523C00000000\n210E:0000C0C0C0FCC6C6C6C6C6C600000000\n210F:000060F8607E63636363636300000000\n2115:0000424262526A564A46424200000000\n2116:0000969696D0F0F0B096909600000000\n211A:00003C525252525252525A3C06000000\n211D:0000F8A4A4A4A4B8A8B4AAE600000000\n2122:0000FB55555100000000000000000000\n2124:00007E02060A14285060407E00000000\n2126:00007CC6C6C6C6C6C66C6CEE00000000\n2135:0000666633333E7CCCCCC66600000000\n2190:00000000002060FEFE60200000000000\n2191:0000183C7E1818181818181800000000\n2192:0000000000080CFEFE0C080000000000\n2193:0000181818181818187E3C1800000000\n2194:00000000002466FFFF66240000000000\n2195:0000183C7E181818187E3C1800000000\n21A4:00000000002262FEFE62220000000000\n21A6:0000000000888CFEFE8C880000000000\n21A8:0000183C7E1818187E3C187E00000000\n21B2:0000060606062666FEFE602000000000\n21B3:0000C0C0C0C0C8CCFEFE0C0800000000\n21B5:0000000006062666FEFE602000000000\n21BB:000000F83868CBC3C3663C0000000000\n21CB:0000002060FEFE00FEFE0C0800000000\n21CC:000000080CFEFE00FEFE602000000000\n21D0:00000000103E7EE07E3E100000000000\n21D1:000010387CEE6C6C6C6C6C6C00000000\n21D2:0000000010F8FC0EFCF8100000000000\n21D3:00006C6C6C6C6C6CEE7C381000000000\n21D4:00000000247EFFC3FF7E240000000000\n21D5:000010387CEE6C6CEE7C381000000000\n2200:0000C3C3C37E6666243C181800000000\n2203:000000FE060606FE060606FE00000000\n2204:00000CFE1E1636FE366666FEC0000000\n2205:000003067ECFDBDBF37E60C000000000\n2206:000018183C3C666666C3C3FF00000000\n2207:0000FFC3C36666663C3C181800000000\n2208:0000003E60C0C0FEC0C0603E00000000\n2209:0000063E6CCCD8FED8F0707E60000000\n220A:000000003E60C0FEC0603E0000000000\n220B:000000F80C0606FE06060CF800000000\n220C:0000C0F86C6636FE361E1CFC0C000000\n220D:00000000F80C06FE060CF80000000000\n2212:00000000000000FE0000000000000000\n2213:00000000007E0018187E181800000000\n2214:0000000018180018187E181800000000\n2215:0000000002060C183060C08000000000\n2216:0000000080C06030180C060200000000\n2219:00000000000038383800000000000000\n221A:000E0C0C0C0CCCCCCC6C3C1C00000000\n221E:000000000076DBDBDB6E000000000000\n221F:00000000C0C0C0C0C0FE000000000000\n2225:00006C6C6C6C6C6C6C6C6C6C00000000\n2227:0000000018183C3C6666C3C300000000\n2228:00000000C3C366663C3C181800000000\n2229:000000007CC6C6C6C6C6C6C600000000\n222A:00000000C6C6C6C6C6C6C67C00000000\n2248:000000000076DC0076DC000000000000\n2260:0000000006FE1830FEC0000000000000\n2261:00000000FE0000FE0000FE0000000000\n2264:0000000C18306030180C007E00000000\n2265:00000030180C060C1830007E00000000\n226A:000000091B366CD86C361B0900000000\n226B:00000090D86C361B366CD89000000000\n2282:000000007EC0C0C0C0C07E0000000000\n2283:00000000FC0606060606FC0000000000\n2286:0000007EC0C0C0C0C07E00FE00000000\n2287:000000FC0606060606FC00FE00000000\n22A5:0000000018181818181818FF00000000\n22C2:00007CC6C6C6C6C6C6C6C6C600000000\n22C3:0000C6C6C6C6C6C6C6C6C67C00000000\n2300:000003067ECFDBDBF37E60C000000000\n2302:00000000183C66C3C3C3C3FF00000000\n2308:00003C30303030303030303000000000\n2309:00003C0C0C0C0C0C0C0C0C0C00000000\n230A:00003030303030303030303C00000000\n230B:00000C0C0C0C0C0C0C0C0C3C00000000\n2310:0000000000FEC0C0C000000000000000\n2319:0000000000C0C0C0FE00000000000000\n2320:00000E1B1B1818181818181818181818\n2321:181818181818181818D8D87000000000\n239B:060C1818303030606060606060606060\n239C:60606060606060606060606060606060\n239D:60606060606060606030303018180C06\n239E:603018180C0C0C060606060606060606\n239F:06060606060606060606060606060606\n23A0:0606060606060606060C0C0C18183060\n23A1:7E606060606060606060606060606060\n23A2:60606060606060606060606060606060\n23A3:6060606060606060606060606060607E\n23A4:7E060606060606060606060606060606\n23A5:06060606060606060606060606060606\n23A6:0606060606060606060606060606067E\n23A7:0F183030303030303030303030303030\n23A8:30303030303030E0E030303030303030\n23A9:3030303030303030303030303030180F\n23AB:F0180C0C0C0C0C0C0C0C0C0C0C0C0C0C\n23AC:0C0C0C0C0C0C0C07070C0C0C0C0C0C0C\n23AD:0C0C0C0C0C0C0C0C0C0C0C0C0C0C18F0\n23AE:18181818181818181818181818181818\n23AF:00000000000000FFFF00000000000000\n23BA:FFFF0000000000000000000000000000\n23BB:00000000FFFF00000000000000000000\n23BC:00000000000000000000FFFF00000000\n23BD:0000000000000000000000000000FFFF\n23D0:18181818181818181818181818181818\n2409:00CCCCFCCCCCCC003F0C0C0C0C0C0000\n240A:00C0C0C0C0C0F8003F303C3030300000\n240B:00CCCCCCCC7830003F0C0C0C0C0C0000\n240C:00FCC0F0C0C0C0003F303C3030300000\n240D:0078CCC0C0CC78003E33333E36330000\n2424:00CCECFCDCCCCC0030303030303F0000\n2500:00000000000000FFFF00000000000000\n2501:000000000000FFFFFF00000000000000\n2502:18181818181818181818181818181818\n2503:38383838383838383838383838383838\n2508:00000000000000AAAA00000000000000\n2509:000000000000AAAAAA00000000000000\n250A:18181800181818001818180018181800\n250B:38383800383838003838380038383800\n250C:000000000000001F1F18181818181818\n250D:0000000000001F1F1F18181818181818\n250E:000000000000003F3F38383838383838\n250F:0000000000003F3F3F38383838383838\n2510:00000000000000F8F818181818181818\n2511:000000000000F8F8F818181818181818\n2512:00000000000000F8F838383838383838\n2513:000000000000F8F8F838383838383838\n2514:181818181818181F1F00000000000000\n2515:1818181818181F1F1F00000000000000\n2516:383838383838383F3F00000000000000\n2517:3838383838383F3F3F00000000000000\n2518:18181818181818F8F800000000000000\n2519:181818181818F8F8F800000000000000\n251A:38383838383838F8F800000000000000\n251B:383838383838F8F8F800000000000000\n251C:181818181818181F1F18181818181818\n251D:1818181818181F1F1F18181818181818\n251E:383838383838383F3F18181818181818\n251F:181818181818183F3F38383838383838\n2520:383838383838383F3F38383838383838\n2521:3838383838383F3F3F18181818181818\n2522:1818181818183F3F3F38383838383838\n2523:3838383838383F3F3F38383838383838\n2524:18181818181818F8F818181818181818\n2525:181818181818F8F8F818181818181818\n2526:38383838383838F8F818181818181818\n2527:18181818181818F8F838383838383838\n2528:38383838383838F8F838383838383838\n2529:383838383838F8F8F818181818181818\n252A:181818181818F8F8F838383838383838\n252B:383838383838F8F8F838383838383838\n252C:00000000000000FFFF18181818181818\n252D:000000000000F8FFFF18181818181818\n252E:0000000000001FFFFF18181818181818\n252F:000000000000FFFFFF18181818181818\n2530:00000000000000FFFF38383838383838\n2531:000000000000F8FFFF38383838383838\n2532:0000000000003FFFFF38383838383838\n2533:000000000000FFFFFF38383838383838\n2534:18181818181818FFFF00000000000000\n2535:181818181818F8FFFF00000000000000\n2536:1818181818181FFFFF00000000000000\n2537:181818181818FFFFFF00000000000000\n2538:38383838383838FFFF00000000000000\n2539:383838383838F8FFFF00000000000000\n253A:3838383838383FFFFF00000000000000\n253B:383838383838FFFFFF00000000000000\n253C:18181818181818FFFF18181818181818\n253D:181818181818F8FFFF18181818181818\n253E:1818181818181FFFFF18181818181818\n253F:181818181818FFFFFF18181818181818\n2540:38383838383838FFFF18181818181818\n2541:18181818181818FFFF38383838383838\n2542:38383838383838FFFF38383838383838\n2543:383838383838F8FFFF18181818181818\n2544:3838383838383FFFFF18181818181818\n2545:181818181818F8FFFF38383838383838\n2546:1818181818181FFFFF38383838383838\n2547:383838383838FFFFFF18181818181818\n2548:181818181818FFFFFF38383838383838\n2549:383838383838F8FFFF38383838383838\n254A:3838383838383FFFFF38383838383838\n254B:383838383838FFFFFF38383838383838\n2550:0000000000FFFF00FFFF000000000000\n2551:6C6C6C6C6C6C6C6C6C6C6C6C6C6C6C6C\n2552:00000000001F1F181F1F181818181818\n2553:000000000000007F7F6C6C6C6C6C6C6C\n2554:00000000007F7F606F6F6C6C6C6C6C6C\n2555:0000000000F8F818F8F8181818181818\n2556:00000000000000FCFC6C6C6C6C6C6C6C\n2557:0000000000FCFC0CECEC6C6C6C6C6C6C\n2558:18181818181F1F181F1F000000000000\n2559:6C6C6C6C6C6C6C7F7F00000000000000\n255A:6C6C6C6C6C6F6F607F7F000000000000\n255B:1818181818F8F818F8F8000000000000\n255C:6C6C6C6C6C6C6CFCFC00000000000000\n255D:6C6C6C6C6CECEC0CFCFC000000000000\n255E:18181818181F1F181F1F181818181818\n255F:6C6C6C6C6C6C6C6F6F6C6C6C6C6C6C6C\n2560:6C6C6C6C6C6F6F606F6F6C6C6C6C6C6C\n2561:1818181818F8F818F8F8181818181818\n2562:6C6C6C6C6C6C6CECEC6C6C6C6C6C6C6C\n2563:6C6C6C6C6CECEC0CECEC6C6C6C6C6C6C\n2564:0000000000FFFF00FFFF181818181818\n2565:00000000000000FFFF6C6C6C6C6C6C6C\n2566:0000000000FFFF00EFEF6C6C6C6C6C6C\n2567:1818181818FFFF00FFFF000000000000\n2568:6C6C6C6C6C6C6CFFFF00000000000000\n2569:6C6C6C6C6CEFEF00FFFF000000000000\n256A:1818181818FFFF18FFFF181818181818\n256B:6C6C6C6C6C6C6CFFFF6C6C6C6C6C6C6C\n256C:6C6C6C6C6CEFEF00EFEF6C6C6C6C6C6C\n256D:00000000000000070F1C181818181818\n256E:00000000000000E0F038181818181818\n256F:18181818181838F0E000000000000000\n2570:1818181818181C0F0700000000000000\n2571:0101030206040C08181030206040C080\n2572:80C0406020301018080C040602030101\n2573:81C1436226341C18181C34266243C181\n2574:00000000000000F8F800000000000000\n2575:18181818181818181800000000000000\n2576:000000000000001F1F00000000000000\n2577:00000000000000181818181818181818\n2578:000000000000F8F8F800000000000000\n2579:38383838383838383800000000000000\n257A:0000000000001F1F1F00000000000000\n257B:00000000000000383838383838383838\n257C:0000000000001FFFFF00000000000000\n257D:18181818181818383838383838383838\n257E:000000000000F8FFFF00000000000000\n257F:38383838383838383818181818181818\n2580:FFFFFFFFFFFFFFFF0000000000000000\n2581:0000000000000000000000000000FFFF\n2582:000000000000000000000000FFFFFFFF\n2583:00000000000000000000FFFFFFFFFFFF\n2584:0000000000000000FFFFFFFFFFFFFFFF\n2585:000000000000FFFFFFFFFFFFFFFFFFFF\n2586:00000000FFFFFFFFFFFFFFFFFFFFFFFF\n2587:0000FFFFFFFFFFFFFFFFFFFFFFFFFFFF\n2588:FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF\n2589:FEFEFEFEFEFEFEFEFEFEFEFEFEFEFEFE\n258A:FCFCFCFCFCFCFCFCFCFCFCFCFCFCFCFC\n258B:F8F8F8F8F8F8F8F8F8F8F8F8F8F8F8F8\n258C:F0F0F0F0F0F0F0F0F0F0F0F0F0F0F0F0\n258D:E0E0E0E0E0E0E0E0E0E0E0E0E0E0E0E0\n258E:C0C0C0C0C0C0C0C0C0C0C0C0C0C0C0C0\n258F:80808080808080808080808080808080\n2590:0F0F0F0F0F0F0F0F0F0F0F0F0F0F0F0F\n2591:88228822882288228822882288228822\n2592:AA55AA55AA55AA55AA55AA55AA55AA55\n2593:EEBBEEBBEEBBEEBBEEBBEEBBEEBBEEBB\n2596:0000000000000000F0F0F0F0F0F0F0F0\n2597:00000000000000000F0F0F0F0F0F0F0F\n2598:F0F0F0F0F0F0F0F00000000000000000\n2599:F0F0F0F0F0F0F0F0FFFFFFFFFFFFFFFF\n259A:F0F0F0F0F0F0F0F00F0F0F0F0F0F0F0F\n259B:FFFFFFFFFFFFFFFFF0F0F0F0F0F0F0F0\n259C:FFFFFFFFFFFFFFFF0F0F0F0F0F0F0F0F\n259D:0F0F0F0F0F0F0F0F0000000000000000\n259E:0F0F0F0F0F0F0F0FF0F0F0F0F0F0F0F0\n259F:0F0F0F0F0F0F0F0FFFFFFFFFFFFFFFFF\n25A0:00000000007C7C7C7C7C7C0000000000\n25AC:0000000000000000FEFEFEFE00000000\n25AE:0000FEFEFEFEFEFEFEFEFEFE00000000\n25B2:0000000018183C3C7E7EFFFF00000000\n25B6:00000000C0F0FCFFFFFCF0C000000000\n25BA:00000000C0F0FCFFFFFCF0C000000000\n25BC:00000000FFFF7E7E3C3C181800000000\n25C0:00000000030F3FFFFF3F0F0300000000\n25C4:00000000030F3FFFFF3F0F0300000000\n25C6:00000000183C7EFF7E3C180000000000\n25CA:00000000183C66C3663C180000000000\n25CB:00000000003C664242663C0000000000\n25CF:00000000003C7E7E7E7E3C0000000000\n25D8:FFFFFFFFFFFFE7C3C3E7FFFFFFFFFFFF\n25D9:FFFFFFFFFFC399BDBD99C3FFFFFFFFFF\n263A:00007E81A58181BD9981817E00000000\n263B:00007EFFDBFFFFC3E7FFFF7E00000000\n263C:00000018DB7E3CE73C7EDB1800000000\n2640:00003C666666663C187E181800000000\n2642:00003E0E1A3278CCCCCCCC7800000000\n2660:000018183C7EFFFF7E18183C00000000\n2663:0000183C3C185AFFFF5A183C00000000\n2665:0000000066FFFFFFFF7E3C1800000000\n2666:00000000183C7EFF7E3C180000000000\n266A:00003F333F3030303030F0E000000000\n266B:00007F637F636363636367E6C0000000\n2713:000003030606CCCC7878303000000000\n2714:000007070E0EDCFC7878303000000000\n2717:00000CCC7838383C6660C0C000000000\n2718:00000EEE7C3C3C3E7773E0E000000000\n27E8:00000C0C1818303018180C0C00000000\n27E9:0000303018180C0C1818303000000000\n27EA:000036366C6CD8D86C6C363600000000\n27EB:0000D8D86C6C36366C6CD8D800000000\n2800:00000000000000000000000000000000\n2801:00606000000000000000000000000000\n2802:00000000006060000000000000000000\n2803:00606000006060000000000000000000\n2804:00000000000000000060600000000000\n2805:00606000000000000060600000000000\n2806:00000000006060000060600000000000\n2807:00606000006060000060600000000000\n2808:00060600000000000000000000000000\n2809:00666600000000000000000000000000\n280A:00060600006060000000000000000000\n280B:00666600006060000000000000000000\n280C:00060600000000000060600000000000\n280D:00666600000000000060600000000000\n280E:00060600006060000060600000000000\n280F:00666600006060000060600000000000\n2810:00000000000606000000000000000000\n2811:00606000000606000000000000000000\n2812:00000000006666000000000000000000\n2813:00606000006666000000000000000000\n2814:00000000000606000060600000000000\n2815:00606000000606000060600000000000\n2816:00000000006666000060600000000000\n2817:00606000006666000060600000000000\n2818:00060600000606000000000000000000\n2819:00666600000606000000000000000000\n281A:00060600006666000000000000000000\n281B:00666600006666000000000000000000\n281C:00060600000606000060600000000000\n281D:00666600000606000060600000000000\n281E:00060600006666000060600000000000\n281F:00666600006666000060600000000000\n2820:00000000000000000006060000000000\n2821:00606000000000000006060000000000\n2822:00000000006060000006060000000000\n2823:00606000006060000006060000000000\n2824:00000000000000000066660000000000\n2825:00606000000000000066660000000000\n2826:00000000006060000066660000000000\n2827:00606000006060000066660000000000\n2828:00060600000000000006060000000000\n2829:00666600000000000006060000000000\n282A:00060600006060000006060000000000\n282B:00666600006060000006060000000000\n282C:00060600000000000066660000000000\n282D:00666600000000000066660000000000\n282E:00060600006060000066660000000000\n282F:00666600006060000066660000000000\n2830:00000000000606000006060000000000\n2831:00606000000606000006060000000000\n2832:00000000006666000006060000000000\n2833:00606000006666000006060000000000\n2834:00000000000606000066660000000000\n2835:00606000000606000066660000000000\n2836:00000000006666000066660000000000\n2837:00606000006666000066660000000000\n2838:00060600000606000006060000000000\n2839:00666600000606000006060000000000\n283A:00060600006666000006060000000000\n283B:00666600006666000006060000000000\n283C:00060600000606000066660000000000\n283D:00666600000606000066660000000000\n283E:00060600006666000066660000000000\n283F:00666600006666000066660000000000\n2840:00000000000000000000000000606000\n2841:00606000000000000000000000606000\n2842:00000000006060000000000000606000\n2843:00606000006060000000000000606000\n2844:00000000000000000060600000606000\n2845:00606000000000000060600000606000\n2846:00000000006060000060600000606000\n2847:00606000006060000060600000606000\n2848:00060600000000000000000000606000\n2849:00666600000000000000000000606000\n284A:00060600006060000000000000606000\n284B:00666600006060000000000000606000\n284C:00060600000000000060600000606000\n284D:00666600000000000060600000606000\n284E:00060600006060000060600000606000\n284F:00666600006060000060600000606000\n2850:00000000000606000000000000606000\n2851:00606000000606000000000000606000\n2852:00000000006666000000000000606000\n2853:00606000006666000000000000606000\n2854:00000000000606000060600000606000\n2855:00606000000606000060600000606000\n2856:00000000006666000060600000606000\n2857:00606000006666000060600000606000\n2858:00060600000606000000000000606000\n2859:00666600000606000000000000606000\n285A:00060600006666000000000000606000\n285B:00666600006666000000000000606000\n285C:00060600000606000060600000606000\n285D:00666600000606000060600000606000\n285E:00060600006666000060600000606000\n285F:00666600006666000060600000606000\n2860:00000000000000000006060000606000\n2861:00606000000000000006060000606000\n2862:00000000006060000006060000606000\n2863:00606000006060000006060000606000\n2864:00000000000000000066660000606000\n2865:00606000000000000066660000606000\n2866:00000000006060000066660000606000\n2867:00606000006060000066660000606000\n2868:00060600000000000006060000606000\n2869:00666600000000000006060000606000\n286A:00060600006060000006060000606000\n286B:00666600006060000006060000606000\n286C:00060600000000000066660000606000\n286D:00666600000000000066660000606000\n286E:00060600006060000066660000606000\n286F:00666600006060000066660000606000\n2870:00000000000606000006060000606000\n2871:00606000000606000006060000606000\n2872:00000000006666000006060000606000\n2873:00606000006666000006060000606000\n2874:00000000000606000066660000606000\n2875:00606000000606000066660000606000\n2876:00000000006666000066660000606000\n2877:00606000006666000066660000606000\n2878:00060600000606000006060000606000\n2879:00666600000606000006060000606000\n287A:00060600006666000006060000606000\n287B:00666600006666000006060000606000\n287C:00060600000606000066660000606000\n287D:00666600000606000066660000606000\n287E:00060600006666000066660000606000\n287F:00666600006666000066660000606000\n2880:00000000000000000000000000060600\n2881:00606000000000000000000000060600\n2882:00000000006060000000000000060600\n2883:00606000006060000000000000060600\n2884:00000000000000000060600000060600\n2885:00606000000000000060600000060600\n2886:00000000006060000060600000060600\n2887:00606000006060000060600000060600\n2888:00060600000000000000000000060600\n2889:00666600000000000000000000060600\n288A:00060600006060000000000000060600\n288B:00666600006060000000000000060600\n288C:00060600000000000060600000060600\n288D:00666600000000000060600000060600\n288E:00060600006060000060600000060600\n288F:00666600006060000060600000060600\n2890:00000000000606000000000000060600\n2891:00606000000606000000000000060600\n2892:00000000006666000000000000060600\n2893:00606000006666000000000000060600\n2894:00000000000606000060600000060600\n2895:00606000000606000060600000060600\n2896:00000000006666000060600000060600\n2897:00606000006666000060600000060600\n2898:00060600000606000000000000060600\n2899:00666600000606000000000000060600\n289A:00060600006666000000000000060600\n289B:00666600006666000000000000060600\n289C:00060600000606000060600000060600\n289D:00666600000606000060600000060600\n289E:00060600006666000060600000060600\n289F:00666600006666000060600000060600\n28A0:00000000000000000006060000060600\n28A1:00606000000000000006060000060600\n28A2:00000000006060000006060000060600\n28A3:00606000006060000006060000060600\n28A4:00000000000000000066660000060600\n28A5:00606000000000000066660000060600\n28A6:00000000006060000066660000060600\n28A7:00606000006060000066660000060600\n28A8:00060600000000000006060000060600\n28A9:00666600000000000006060000060600\n28AA:00060600006060000006060000060600\n28AB:00666600006060000006060000060600\n28AC:00060600000000000066660000060600\n28AD:00666600000000000066660000060600\n28AE:00060600006060000066660000060600\n28AF:00666600006060000066660000060600\n28B0:00000000000606000006060000060600\n28B1:00606000000606000006060000060600\n28B2:00000000006666000006060000060600\n28B3:00606000006666000006060000060600\n28B4:00000000000606000066660000060600\n28B5:00606000000606000066660000060600\n28B6:00000000006666000066660000060600\n28B7:00606000006666000066660000060600\n28B8:00060600000606000006060000060600\n28B9:00666600000606000006060000060600\n28BA:00060600006666000006060000060600\n28BB:00666600006666000006060000060600\n28BC:00060600000606000066660000060600\n28BD:00666600000606000066660000060600\n28BE:00060600006666000066660000060600\n28BF:00666600006666000066660000060600\n28C0:00000000000000000000000000666600\n28C1:00606000000000000000000000666600\n28C2:00000000006060000000000000666600\n28C3:00606000006060000000000000666600\n28C4:00000000000000000060600000666600\n28C5:00606000000000000060600000666600\n28C6:00000000006060000060600000666600\n28C7:00606000006060000060600000666600\n28C8:00060600000000000000000000666600\n28C9:00666600000000000000000000666600\n28CA:00060600006060000000000000666600\n28CB:00666600006060000000000000666600\n28CC:00060600000000000060600000666600\n28CD:00666600000000000060600000666600\n28CE:00060600006060000060600000666600\n28CF:00666600006060000060600000666600\n28D0:00000000000606000000000000666600\n28D1:00606000000606000000000000666600\n28D2:00000000006666000000000000666600\n28D3:00606000006666000000000000666600\n28D4:00000000000606000060600000666600\n28D5:00606000000606000060600000666600\n28D6:00000000006666000060600000666600\n28D7:00606000006666000060600000666600\n28D8:00060600000606000000000000666600\n28D9:00666600000606000000000000666600\n28DA:00060600006666000000000000666600\n28DB:00666600006666000000000000666600\n28DC:00060600000606000060600000666600\n28DD:00666600000606000060600000666600\n28DE:00060600006666000060600000666600\n28DF:00666600006666000060600000666600\n28E0:00000000000000000006060000666600\n28E1:00606000000000000006060000666600\n28E2:00000000006060000006060000666600\n28E3:00606000006060000006060000666600\n28E4:00000000000000000066660000666600\n28E5:00606000000000000066660000666600\n28E6:00000000006060000066660000666600\n28E7:00606000006060000066660000666600\n28E8:00060600000000000006060000666600\n28E9:00666600000000000006060000666600\n28EA:00060600006060000006060000666600\n28EB:00666600006060000006060000666600\n28EC:00060600000000000066660000666600\n28ED:00666600000000000066660000666600\n28EE:00060600006060000066660000666600\n28EF:00666600006060000066660000666600\n28F0:00000000000606000006060000666600\n28F1:00606000000606000006060000666600\n28F2:00000000006666000006060000666600\n28F3:00606000006666000006060000666600\n28F4:00000000000606000066660000666600\n28F5:00606000000606000066660000666600\n28F6:00000000006666000066660000666600\n28F7:00606000006666000066660000666600\n28F8:00060600000606000006060000666600\n28F9:00666600000606000006060000666600\n28FA:00060600006666000006060000666600\n28FB:00666600006666000006060000666600\n28FC:00060600000606000066660000666600\n28FD:00666600000606000066660000666600\n28FE:00060600006666000066660000666600\n28FF:00666600006666000066660000666600\n2E2C:0000000000C6C6000000C6C600000000\nE0A0:C0C0CCDEFFCCCCCC983060C0C0C0C0C0\nE0A1:00C0C0C0C0C0FC00333B3F3733330000\nE0A2:003C66666666FFFFE7C3E7FFFFFF0000\nE0B0:80C0E0F0F8FCFEFFFFFEFCF8F0E0C080\nE0B1:80C06030180C060303060C183060C080\nE0B2:0103070F1F3F7FFFFF7F3F1F0F070301\nE0B3:0103060C183060C0C06030180C060301\nF6BE:00000000000E06060606060666663C00\nFFFD:0000FEC6C6C6C6C6C6C6C6FE00000000\n"
  },
  {
    "path": "EFI_DEBUG/EFI/OC/Resources/Font/TerminusCore.hex",
    "content": "0000:0000EEC600C6C6C600C6C6EE00000000\n0020:00000000000000000000000000000000\n0021:00001818181818181800181800000000\n0022:00666666000000000000000000000000\n0023:00006C6C6CFE6C6CFE6C6C6C00000000\n0024:0018187EDBD8D87E1B1BDB7E18180000\n0025:000066D66C0C181830366B6600000000\n0026:0000386C6C3876DCCCCCDC7600000000\n0027:00181818000000000000000000000000\n0028:00000C18303030303030180C00000000\n0029:000030180C0C0C0C0C0C183000000000\n002A:00000000006C38FE386C000000000000\n002B:000000000018187E1818000000000000\n002C:00000000000000000000181830000000\n002D:00000000000000FE0000000000000000\n002E:00000000000000000000181800000000\n002F:000006060C0C18183030606000000000\n0030:00007CC6C6CEDEF6E6C6C67C00000000\n0031:00001838781818181818187E00000000\n0032:00007CC6C6060C183060C0FE00000000\n0033:00007CC6C6063C0606C6C67C00000000\n0034:0000060E1E3666C6FE06060600000000\n0035:0000FEC0C0C0FC060606C67C00000000\n0036:00003C60C0C0FCC6C6C6C67C00000000\n0037:0000FE06060C0C181830303000000000\n0038:00007CC6C6C67CC6C6C6C67C00000000\n0039:00007CC6C6C6C67E06060C7800000000\n003A:00000000001818000000181800000000\n003B:00000000001818000000181830000000\n003C:000000060C18306030180C0600000000\n003D:0000000000FE0000FE00000000000000\n003E:0000006030180C060C18306000000000\n003F:00007CC6C6C60C181800181800000000\n0040:00003E63CFDBDBDBDBCE603E00000000\n0041:00007CC6C6C6C6FEC6C6C6C600000000\n0042:0000FCC6C6C6FCC6C6C6C6FC00000000\n0043:00007CC6C6C0C0C0C0C6C67C00000000\n0044:0000F8CCC6C6C6C6C6C6CCF800000000\n0045:0000FEC0C0C0F8C0C0C0C0FE00000000\n0046:0000FEC0C0C0F8C0C0C0C0C000000000\n0047:00007CC6C6C0C0DEC6C6C67C00000000\n0048:0000C6C6C6C6FEC6C6C6C6C600000000\n0049:00003C18181818181818183C00000000\n004A:00001E0C0C0C0C0C0CCCCC7800000000\n004B:0000C6CCD8F0E0E0F0D8CCC600000000\n004C:0000C0C0C0C0C0C0C0C0C0FE00000000\n004D:0000C6C6EEFED6D6C6C6C6C600000000\n004E:0000C6C6C6E6F6DECEC6C6C600000000\n004F:00007CC6C6C6C6C6C6C6C67C00000000\n0050:0000FCC6C6C6C6FCC0C0C0C000000000\n0051:00007CC6C6C6C6C6C6C6DE7C06000000\n0052:0000FCC6C6C6C6FCF8CCC6C600000000\n0053:00007CC6C0C07C060606C67C00000000\n0054:00007E18181818181818181800000000\n0055:0000C6C6C6C6C6C6C6C6C67C00000000\n0056:0000C6C6C6C6C66C6C38381000000000\n0057:0000C6C6C6C6D6D6FEEE6C6C00000000\n0058:0000C6C66C6C38386C6CC6C600000000\n0059:0000C3C366663C181818181800000000\n005A:0000FE06060C183060C0C0FE00000000\n005B:00003C30303030303030303C00000000\n005C:00006060303018180C0C060600000000\n005D:00003C0C0C0C0C0C0C0C0C3C00000000\n005E:00183C66000000000000000000000000\n005F:00000000000000000000000000FE0000\n0060:30180000000000000000000000000000\n0061:00000000007C067EC6C6C67E00000000\n0062:0000C0C0C0FCC6C6C6C6C6FC00000000\n0063:00000000007CC6C0C0C0C67C00000000\n0064:00000606067EC6C6C6C6C67E00000000\n0065:00000000007CC6C6FEC0C07C00000000\n0066:00001E3030FC30303030303000000000\n0067:00000000007EC6C6C6C6C67E06067C00\n0068:0000C0C0C0FCC6C6C6C6C6C600000000\n0069:00003030007030303030307800000000\n006A:00000606000E06060606060666663C00\n006B:0000C0C0C0C6CCD8F0D8CCC600000000\n006C:00003818181818181818183C00000000\n006D:0000000000FCD6D6D6D6D6D600000000\n006E:0000000000FCC6C6C6C6C6C600000000\n006F:00000000007CC6C6C6C6C67C00000000\n0070:0000000000FCC6C6C6C6C6FCC0C0C000\n0071:00000000007EC6C6C6C6C67E06060600\n0072:0000000000DCE6C0C0C0C0C000000000\n0073:00000000007CC2C07C06867C00000000\n0074:0000303030FC30303030301E00000000\n0075:0000000000C6C6C6C6C6C67E00000000\n0076:0000000000C6C6C66C6C383800000000\n0077:0000000000C6C6D6D6D6D67C00000000\n0078:0000000000C6C66C386CC6C600000000\n0079:0000000000C6C6C6C6C6C67E06067C00\n007A:0000000000FE0C183060C0FE00000000\n007B:00001C30303060303030301C00000000\n007C:00001818181818181818181800000000\n007D:0000701818180C181818187000000000\n007E:0073DBCE000000000000000000000000\n00A0:00000000000000000000000000000000\n00A1:00001818001818181818181800000000\n00A2:00000018187EDBD8D8D8DB7E18180000\n00A3:0000386C6060F860606066FE00000000\n00A4:00000000663C6666663C660000000000\n00A5:0000C3C3663C187E187E181800000000\n00A6:00001818181800001818181800000000\n00A7:003C6660386C6666361C06663C000000\n00A8:6C6C0000000000000000000000000000\n00A9:0000007E8199A5A1A599817E00000000\n00AA:003C063E663E007E0000000000000000\n00AB:00000000001B366CD86C361B00000000\n00AC:0000000000FE06060600000000000000\n00AD:000000000000007C0000000000000000\n00AE:0000007E81B9A5B9A9A5817E00000000\n00AF:7C000000000000000000000000000000\n00B0:00386C6C380000000000000000000000\n00B1:000000000018187E1818007E00000000\n00B2:00386C0C18307C000000000000000000\n00B3:00780C380C0C78000000000000000000\n00B4:18300000000000000000000000000000\n00B5:0000000000C6C6C6C6C6CEF6C0C0C000\n00B6:00007FDBDBDBDB7B1B1B1B1B00000000\n00B7:00000000000000181800000000000000\n00B8:00000000000000000000000030306000\n00B9:0018381818183C000000000000000000\n00BA:003C6666663C007E0000000000000000\n00BB:0000000000D86C361B366CD800000000\n00BC:0060E062666C183066CE9A3E06060000\n00BD:0060E062666C183060CE9B060C1F0000\n00BE:00E0306236EC183066CE9A3E06060000\n00BF:0000303000303060C6C6C67C00000000\n00C0:3018007CC6C6C6FEC6C6C6C600000000\n00C1:1830007CC6C6C6FEC6C6C6C600000000\n00C2:386C007CC6C6C6FEC6C6C6C600000000\n00C3:76DC007CC6C6C6FEC6C6C6C600000000\n00C4:6C6C007CC6C6C6FEC6C6C6C600000000\n00C5:386C387CC6C6C6FEC6C6C6C600000000\n00C6:00007FCCCCCCFFCCCCCCCCCF00000000\n00C7:00007CC6C6C0C0C0C0C6C67C30306000\n00C8:301800FEC0C0C0F8C0C0C0FE00000000\n00C9:183000FEC0C0C0F8C0C0C0FE00000000\n00CA:386C00FEC0C0C0F8C0C0C0FE00000000\n00CB:6C6C00FEC0C0C0F8C0C0C0FE00000000\n00CC:3018003C181818181818183C00000000\n00CD:0C18003C181818181818183C00000000\n00CE:386C003C181818181818183C00000000\n00CF:6666003C181818181818183C00000000\n00D0:00007C666363FB636363667C00000000\n00D1:76DC00C6C6E6F6DECEC6C6C600000000\n00D2:3018007CC6C6C6C6C6C6C67C00000000\n00D3:1830007CC6C6C6C6C6C6C67C00000000\n00D4:386C007CC6C6C6C6C6C6C67C00000000\n00D5:76DC007CC6C6C6C6C6C6C67C00000000\n00D6:6C6C007CC6C6C6C6C6C6C67C00000000\n00D7:0000000000C66C38386CC60000000000\n00D8:00007CC7C6CEDEF6E6C6C67C00000000\n00D9:3018C6C6C6C6C6C6C6C6C67C00000000\n00DA:1830C6C6C6C6C6C6C6C6C67C00000000\n00DB:386C00C6C6C6C6C6C6C6C67C00000000\n00DC:6C6C00C6C6C6C6C6C6C6C67C00000000\n00DD:0C18C3C366663C181818181800000000\n00DE:0000C0C0FCC6C6C6C6FCC0C000000000\n00DF:000078CCCCC8FCC6C6C6E6DC00000000\n00E0:00003018007C067EC6C6C67E00000000\n00E1:00001830007C067EC6C6C67E00000000\n00E2:0000386C007C067EC6C6C67E00000000\n00E3:000076DC007C067EC6C6C67E00000000\n00E4:00006C6C007C067EC6C6C67E00000000\n00E5:0000386C387C067EC6C6C67E00000000\n00E6:0000000000761B7BDFD8D86E00000000\n00E7:00000000007CC6C0C0C0C67C30306000\n00E8:00003018007CC6C6FEC0C07C00000000\n00E9:00001830007CC6C6FEC0C07C00000000\n00EA:0000386C007CC6C6FEC0C07C00000000\n00EB:00006C6C007CC6C6FEC0C07C00000000\n00EC:00003018003818181818183C00000000\n00ED:00000C18003818181818183C00000000\n00EE:0000386C003818181818183C00000000\n00EF:00006C6C003818181818183C00000000\n00F0:00006830587CC6C6C6C6C67C00000000\n00F1:000076DC00FCC6C6C6C6C6C600000000\n00F2:00003018007CC6C6C6C6C67C00000000\n00F3:00001830007CC6C6C6C6C67C00000000\n00F4:0000386C007CC6C6C6C6C67C00000000\n00F5:000076DC007CC6C6C6C6C67C00000000\n00F6:00006C6C007CC6C6C6C6C67C00000000\n00F7:000000001818007E0018180000000000\n00F8:00000000003D676E7E76E6BC00000000\n00F9:0000301800C6C6C6C6C6C67E00000000\n00FA:0000183000C6C6C6C6C6C67E00000000\n00FB:0000386C00C6C6C6C6C6C67E00000000\n00FC:00006C6C00C6C6C6C6C6C67E00000000\n00FD:0000183000C6C6C6C6C6C67E06067C00\n00FE:0000C0C0C0FCC6C6C6C6C6FCC0C0C000\n00FF:00006C6C00C6C6C6C6C6C67E06067C00\n0100:7C007CC6C6C6C6FEC6C6C6C600000000\n0101:0000007C007C067EC6C6C67E00000000\n0102:6C38007CC6C6C6FEC6C6C6C600000000\n0103:00006C38007C067EC6C6C67E00000000\n0104:00007CC6C6C6C6FEC6C6C6C6060C0700\n0105:00000000007C067EC6C6C67E060C0700\n0106:1830007CC6C6C0C0C0C6C67C00000000\n0107:00001830007CC6C0C0C0C67C00000000\n0108:386C007CC6C6C0C0C0C6C67C00000000\n0109:0000386C007CC6C0C0C0C67C00000000\n010A:1818007CC6C6C0C0C0C6C67C00000000\n010B:00001818007CC6C0C0C0C67C00000000\n010C:6C38007CC6C6C0C0C0C6C67C00000000\n010D:00006C38007CC6C0C0C0C67C00000000\n010E:6C3800F8CCC6C6C6C6C6CCF800000000\n010F:6C380606067EC6C6C6C6C67E00000000\n0110:00007C666363FB636363667C00000000\n0111:0000061F067EC6C6C6C6C67E00000000\n0112:7C00FEC0C0C0F8C0C0C0C0FE00000000\n0113:0000007C007CC6C6FEC0C07C00000000\n0114:6C3800FEC0C0C0F8C0C0C0FE00000000\n0115:00006C38007CC6C6FEC0C07C00000000\n0116:181800FEC0C0C0F8C0C0C0FE00000000\n0117:00001818007CC6C6FEC0C07C00000000\n0118:0000FEC0C0C0F8C0C0C0C0FE060C0700\n0119:00000000007CC6C6FEC0C07C18301C00\n011A:6C3800FEC0C0C0F8C0C0C0FE00000000\n011B:00006C38007CC6C6FEC0C07C00000000\n011C:386C007CC6C0C0DEC6C6C67C00000000\n011D:0000386C007EC6C6C6C6C67E06067C00\n011E:6C38007CC6C0C0DEC6C6C67C00000000\n011F:00006C38007EC6C6C6C6C67E06067C00\n0120:1818007CC6C0C0DEC6C6C67C00000000\n0121:00001818007EC6C6C6C6C67E06067C00\n0122:00007CC6C6C0C0DEC6C6C67C00303060\n0123:000C1818007EC6C6C6C6C67E06067C00\n0124:386C00C6C6C6C6FEC6C6C6C600000000\n0125:1C36C0C0C0FCC6C6C6C6C6C600000000\n0126:000066FF66667E666666666600000000\n0127:000060F8607E63636363636300000000\n0128:76DC003C181818181818183C00000000\n0129:000076DC003818181818183C00000000\n012A:7E003C18181818181818183C00000000\n012B:0000007C003818181818183C00000000\n012C:6C38003C181818181818183C00000000\n012D:00006C38003818181818183C00000000\n012E:00003C18181818181818183C18301C00\n012F:00001818003818181818183C18301C00\n0130:1818003C181818181818183C00000000\n0131:00000000003818181818183C00000000\n0132:0000CFC6C6C6C6C6C6F6F6DC00000000\n0133:0000C6C600C6C6C6C6C6C6C636361C00\n0134:1C36001E0C0C0C0C0CCCCC7800000000\n0135:00000E1B000E06060606060666663C00\n0136:0000C6C6CCD8F0F0D8CCC6C600303060\n0137:0000C0C0C0C6CCD8F0D8CCC600303060\n0138:0000000000C6CCD8F0D8CCC600000000\n0139:60C000C0C0C0C0C0C0C0C0FE00000000\n013A:0C180038181818181818183C00000000\n013B:0000C0C0C0C0C0C0C0C0C0FE00303060\n013C:00003818181818181818183C00181830\n013D:6C38C0C0C0C0C0C0C0C0C0FE00000000\n013E:6C380038181818181818183C00000000\n013F:0000C0C0C0C0CCCCC0C0C0FE00000000\n0140:0000381818181B1B1818183C00000000\n0141:00006060606070E06060607F00000000\n0142:0000381818181C381818183C00000000\n0143:1830C6C6C6E6F6DECEC6C6C600000000\n0144:0000183000FCC6C6C6C6C6C600000000\n0145:0000C6C6C6E6F6DECEC6C6C600303060\n0146:0000000000FCC6C6C6C6C6C600303060\n0147:6C38C6C6C6E6F6DECEC6C6C600000000\n0148:00006C3800FCC6C6C6C6C6C600000000\n0149:006060C000FCC6C6C6C6C6C600000000\n014A:0000C6C6C6E6F6DECEC6C6C606061C00\n014B:0000000000FCC6C6C6C6C6C606061C00\n014C:7C007CC6C6C6C6C6C6C6C67C00000000\n014D:0000007C007CC6C6C6C6C67C00000000\n014E:6C38007CC6C6C6C6C6C6C67C00000000\n014F:00006C38007CC6C6C6C6C67C00000000\n0150:366C007CC6C6C6C6C6C6C67C00000000\n0151:0000366C007CC6C6C6C6C67C00000000\n0152:00007FCCCCCCCFCCCCCCCC7F00000000\n0153:00000000007EDBDBDFD8D87E00000000\n0154:183000FCC6C6C6FCF8CCC6C600000000\n0155:0000183000DCE6C0C0C0C0C000000000\n0156:0000FCC6C6C6C6FCF8CCC6C600303060\n0157:00000000006E736060606060006060C0\n0158:6C3800FCC6C6C6FCF8CCC6C600000000\n0159:00006C3800DCE6C0C0C0C0C000000000\n015A:1830007CC6C0C07C0606C67C00000000\n015B:00000C18007CC2C07C06867C00000000\n015C:386C007CC6C0C07C0606C67C00000000\n015D:0000386C007CC2C07C06867C00000000\n015E:00007CC6C0C07C060606C67C30306000\n015F:00000000007CC2C07C06867C30306000\n0160:6C38007CC6C0C07C0606C67C00000000\n0161:00006C38007CC2C07C06867C00000000\n0162:00007E1818181818181818180C0C1800\n0163:0000303030FC30303030301E0C0C1800\n0164:6C38007E181818181818181800000000\n0165:6C38003030FC30303030301E00000000\n0166:00007E1818187E181818181800000000\n0167:0000303030FC30783030301E00000000\n0168:76DC00C6C6C6C6C6C6C6C67C00000000\n0169:000076DC00C6C6C6C6C6C67E00000000\n016A:7C00C6C6C6C6C6C6C6C6C67C00000000\n016B:0000007C00C6C6C6C6C6C67E00000000\n016C:6C38C6C6C6C6C6C6C6C6C67C00000000\n016D:00006C3800C6C6C6C6C6C67E00000000\n016E:386C38C6C6C6C6C6C6C6C67C00000000\n016F:0000386C38C6C6C6C6C6C67E00000000\n0170:366C00C6C6C6C6C6C6C6C67C00000000\n0171:0000366C00C6C6C6C6C6C67E00000000\n0172:0000C6C6C6C6C6C6C6C6C67C18301C00\n0173:0000000000C6C6C6C6C6C67E060C0700\n0174:386C00C6C6C6D6D6FEEE6C6C00000000\n0175:0000386C00C6C6D6D6D6D67C00000000\n0176:386C00C3C366663C1818181800000000\n0177:0000386C00C6C6C6C6C6C67E06067C00\n0178:666600C3C366663C1818181800000000\n0179:183000FE060C183060C0C0FE00000000\n017A:0000183000FE0C183060C0FE00000000\n017B:181800FE060C183060C0C0FE00000000\n017C:0000181800FE0C183060C0FE00000000\n017D:6C3800FE060C183060C0C0FE00000000\n017E:00006C3800FE0C183060C0FE00000000\n017F:00001E30303030303030303000000000\n0186:00007CC6C606060606C6C67C00000000\n018E:0000FE0606063E06060606FE00000000\n018F:00007CC60606FEC6C6C6C67C00000000\n0190:00007CC6C6C078C0C0C6C67C00000000\n0192:00000E1B18187E181818181818D87000\n019D:0000636363737B6F676363636060C000\n019E:0000000000FCC6C6C6C6C6C606060600\n01B5:0000FE060C18FE3060C0C0FE00000000\n01B6:0000000000FE0C18FC3060FE00000000\n01B7:0000FE060C183C0606C6C67C00000000\n01CD:6C38007CC6C6C6FEC6C6C6C600000000\n01CE:00006C38007C067EC6C6C67E00000000\n01CF:6C38003C181818181818183C00000000\n01D0:00006C38003818181818183C00000000\n01D1:6C38007CC6C6C6C6C6C6C67C00000000\n01D2:00006C38007CC6C6C6C6C67C00000000\n01D3:6C38C6C6C6C6C6C6C6C6C67C00000000\n01D4:00006C3800C6C6C6C6C6C67E00000000\n01E2:7E007FCCCCCCFFCCCCCCCCCF00000000\n01E3:0000007E00761B7BDFD8D86E00000000\n01E4:00007CC6C6C0C0DEC6DFC67C00000000\n01E5:00000000007EC6C6DFC6C67E06067C00\n01E6:6C38007CC6C0C0DEC6C6C67C00000000\n01E7:00006C38007EC6C6C6C6C67E06067C00\n01E8:6C38C6C6CCD8F0F0D8CCC6C600000000\n01E9:6C38C0C0C0C6CCD8F0D8CCC600000000\n01EA:00007CC6C6C6C6C6C6C6C67C18301C00\n01EB:00000000007CC6C6C6C6C67C18301C00\n01EC:7C007CC6C6C6C6C6C6C6C67C18301C00\n01ED:0000007C007CC6C6C6C6C67C18301C00\n01EE:6C3800FE0C183C0606C6C67C00000000\n01EF:00006C3800FE060C183C0606C6C67C00\n01F0:00001B0E000E06060606060666663C00\n01F4:1830007CC6C0C0DEC6C6C67C00000000\n01F5:00000C18007EC6C6C6C6C67E06067C00\n01FC:0C18007FCCCCCCFFCCCCCCCF00000000\n01FD:00000C1800761B7BDFD8D86E00000000\n01FE:1830007CC7C6CEDEF6E6C67C00000000\n01FF:00001830003D676E7E76E6BC00000000\n0218:00007CC6C0C07C0606C6C67C00303060\n0219:00000000007CC2C07C06867C00303060\n021A:00007E18181818181818181800181830\n021B:0000303030FC30303030301E000C0C18\n0232:7E00C3C366663C181818181800000000\n0233:0000007C00C6C6C6C6C6C67E06067C00\n0237:00000000000E06060606060666663C00\n0254:00000000007CC6060606C67C00000000\n0258:00000000007CC6C6FE06067C00000000\n0259:00000000007C0606FEC6C67C00000000\n025B:00000000007CC6C078C0C67C00000000\n0272:00000000007E6363636363636060C000\n0292:0000000000FE060C183C0606C6C67C00\n02BB:18303000000000000000000000000000\n02BC:18183000000000000000000000000000\n02BD:30301800000000000000000000000000\n02C6:386C0000000000000000000000000000\n02C7:6C380000000000000000000000000000\n02D8:6C380000000000000000000000000000\n02D9:18180000000000000000000000000000\n02DB:00000000000000000000000018301C00\n02DC:76DC0000000000000000000000000000\n02DD:366C0000000000000000000000000000\n0300:30180000000000000000000000000000\n0301:18300000000000000000000000000000\n0302:386C0000000000000000000000000000\n0303:76DC0000000000000000000000000000\n0304:7C000000000000000000000000000000\n0305:FE000000000000000000000000000000\n0306:6C380000000000000000000000000000\n0307:18180000000000000000000000000000\n0308:6C6C0000000000000000000000000000\n030A:386C3800000000000000000000000000\n030B:366C0000000000000000000000000000\n030C:6C380000000000000000000000000000\n0329:00000000000000000000000000181800\n0384:60C00000000000000000000000000000\n0385:1830006C000000000000000000000000\n0386:60C07CC6C6C6C6FEC6C6C6C600000000\n0387:00000000001818000000000000000000\n0388:60C000FEC0C0C0F8C0C0C0FE00000000\n0389:60C000C6C6C6C6FEC6C6C6C600000000\n038A:60C03C18181818181818183C00000000\n038C:60C07CC6C6C6C6C6C6C6C67C00000000\n038E:60C000C3C366663C1818181800000000\n038F:60C07CC6C6C6C6C6C66C6CEE00000000\n0390:1830D8D8007030303030301C00000000\n0391:00007CC6C6C6C6FEC6C6C6C600000000\n0392:0000FCC6C6C6FCC6C6C6C6FC00000000\n0393:0000FEC0C0C0C0C0C0C0C0C000000000\n0394:000018183C3C666666C3C3FF00000000\n0395:0000FEC0C0C0F8C0C0C0C0FE00000000\n0396:0000FE06060C183060C0C0FE00000000\n0397:0000C6C6C6C6FEC6C6C6C6C600000000\n0398:00007CC6C6C6D6D6C6C6C67C00000000\n0399:00003C18181818181818183C00000000\n039A:0000C6C6CCD8F0F0D8CCC6C600000000\n039B:000018183C3C666666C3C3C300000000\n039C:0000C6C6EEFED6D6C6C6C6C600000000\n039D:0000C6C6C6E6F6DECEC6C6C600000000\n039E:0000FE0000007C00000000FE00000000\n039F:00007CC6C6C6C6C6C6C6C67C00000000\n03A0:0000FEC6C6C6C6C6C6C6C6C600000000\n03A1:0000FCC6C6C6C6FCC0C0C0C000000000\n03A3:0000FEC0603018183060C0FE00000000\n03A4:0000FF18181818181818181800000000\n03A5:0000C3C366663C181818181800000000\n03A6:0000187EDBDBDBDBDBDB7E1800000000\n03A7:0000C6C66C6C38386C6CC6C600000000\n03A8:0000DBDBDBDBDBDBDB7E181800000000\n03A9:00007CC6C6C6C6C6C66C6CEE00000000\n03AA:6666003C181818181818183C00000000\n03AB:666600C3C366663C1818181800000000\n03AC:00001830007BCECCCCCCCE7B00000000\n03AD:00001830007CC6C078C0C67C00000000\n03AE:0000183000FCC6C6C6C6C6C606060600\n03AF:00001830007030303030301C00000000\n03B0:1830006C00C6C6C6C6C6C67C00000000\n03B1:00000000007BCECCCCCCCE7B00000000\n03B2:000078CCCCC8FCC6C6C6C6FCC0C0C000\n03B3:0000000000C3C366663C3C1818181800\n03B4:00007E30187CC6C6C6C6C67C00000000\n03B5:00000000007CC6C078C0C67C00000000\n03B6:0000FE0C183060C0C0C0C07C06060C00\n03B7:0000000000FCC6C6C6C6C6C606060600\n03B8:00003C6666667E666666663C00000000\n03B9:00000000007030303030301C00000000\n03BA:0000000000C6CCD8F0D8CCC600000000\n03BB:0000303018183C3C6666C3C300000000\n03BC:0000000000C6C6C6C6C6CEF6C0C0C000\n03BD:0000000000C6C6C66C6C383800000000\n03BE:00007EC0C0C07CC0C0C0C07C06060C00\n03BF:00000000007CC6C6C6C6C67C00000000\n03C0:0000000000FEC6C6C6C6C6C600000000\n03C1:00000000007CC6C6C6C6C6FCC0C0C000\n03C2:00000000007CC6C0C0C0C07C06060C00\n03C3:00000000003F66666666663C00000000\n03C4:0000000000FF18181818180E00000000\n03C5:0000000000C6C6C6C6C6C67C00000000\n03C6:00000000004EDBDBDBDBDB7E18181800\n03C7:0000000000C6C66C6C38386C6CC6C600\n03C8:0000000000DBDBDBDBDBDB7E18181800\n03C9:000000000066C3DBDBDBFF6600000000\n03CA:0000D8D8007030303030301C00000000\n03CB:00006C6C00C6C6C6C6C6C67C00000000\n03CC:00001830007CC6C6C6C6C67C00000000\n03CD:0000183000C6C6C6C6C6C67C00000000\n03CE:00000C180066C3DBDBDBFF6600000000\n03D1:00003C6666663F06E666663C00000000\n03D5:00000000187EDBDBDBDBDB7E18000000\n03F0:0000000000E3361C18386CC700000000\n03F1:00000000007CC6C6C6C6C6FCC0C07C00\n03F2:00000000007CC6C0C0C0C67C00000000\n03F3:00000606000E06060606060666663C00\n03F4:00007CC6C6C6FEC6C6C6C67C00000000\n03F5:00000000003E60C0FCC0603E00000000\n03F6:0000000000F80C067E060CF800000000\n0400:301800FEC0C0C0F8C0C0C0FE00000000\n0401:6C6C00FEC0C0C0F8C0C0C0FE00000000\n0402:0000FC30303E33333333333600000000\n0403:183000FEC0C0C0C0C0C0C0C000000000\n0404:00007CC6C0C0F8C0C0C0C67C00000000\n0405:00007CC6C0C07C0606C6C67C00000000\n0406:00003C18181818181818183C00000000\n0407:6666003C181818181818183C00000000\n0408:00001E0C0C0C0C0C0CCCCC7800000000\n0409:00003878D8DEDBDBDBDBDB9E00000000\n040A:0000D8D8D8DEFBDBDBDBDBDE00000000\n040B:0000FC30303E33333333333300000000\n040C:1830C6C6CCD8F0F0D8CCC6C600000000\n040D:3018C6C6C6CEDEF6E6C6C6C600000000\n040E:6C38C6C6C6C6C67E0606067C00000000\n040F:0000C6C6C6C6C6C6C6C6C6FE38380000\n0410:00007CC6C6C6C6FEC6C6C6C600000000\n0411:0000FCC0C0FCC6C6C6C6C6FC00000000\n0412:0000FCC6C6C6FCC6C6C6C6FC00000000\n0413:0000FEC0C0C0C0C0C0C0C0C000000000\n0414:00003E6666666666666666FFC3000000\n0415:0000FEC0C0C0F8C0C0C0C0FE00000000\n0416:0000DBDBDB7E3C7EDBDBDBDB00000000\n0417:00007CC6C6063C0606C6C67C00000000\n0418:0000C6C6C6CEDEF6E6C6C6C600000000\n0419:6C38C6C6C6CEDEF6E6C6C6C600000000\n041A:0000C6C6CCD8F0F0D8CCC6C600000000\n041B:00001E3666666666666666C600000000\n041C:000081C3E7FFDBC3C3C3C3C300000000\n041D:0000C6C6C6C6FEC6C6C6C6C600000000\n041E:00007CC6C6C6C6C6C6C6C67C00000000\n041F:0000FEC6C6C6C6C6C6C6C6C600000000\n0420:0000FCC6C6C6C6FCC0C0C0C000000000\n0421:00007CC6C6C0C0C0C0C6C67C00000000\n0422:0000FF18181818181818181800000000\n0423:0000C6C6C6C6C67E0606067C00000000\n0424:00187EDBDBDBDBDBDBDBDB7E18000000\n0425:0000C6C66C6C38386C6CC6C600000000\n0426:0000C6C6C6C6C6C6C6C6C67F03030000\n0427:0000C6C6C6C6C67E0606060600000000\n0428:0000DBDBDBDBDBDBDBDBDB7F00000000\n0429:0000D6D6D6D6D6D6D6D6D67F03030000\n042A:0000E060607E63636363637E00000000\n042B:0000C3C3C3F3DBDBDBDBDBF300000000\n042C:00006060607E63636363637E00000000\n042D:00007CC606063E060606C67C00000000\n042E:0000CEDBDBDBDBFBDBDBDBCE00000000\n042F:00007EC6C6C6C67E1E3666C600000000\n0430:00000000007C067EC6C6C67E00000000\n0431:00007CC0C0FCC6C6C6C6C6FC00000000\n0432:000078CCCCC8FCC6C6C6C6FC00000000\n0433:0000000000FEC0C0C0C0C0C000000000\n0434:00000000007EC6C6C6C6C67E06067C00\n0435:00000000007CC6C6FEC0C07C00000000\n0436:0000000000DBDB7E3C7EDBDB00000000\n0437:00000000007CC6063C06C67C00000000\n0438:0000000000C6C6C6C6C6C67E00000000\n0439:00006C3800C6C6C6C6C6C67E00000000\n043A:0000000000C6CCD8F0D8CCC600000000\n043B:00000000003E6666666666C600000000\n043C:0000000000C3E7FFDBC3C3C300000000\n043D:0000000000C6C6C6FEC6C6C600000000\n043E:00000000007CC6C6C6C6C67C00000000\n043F:0000000000FEC6C6C6C6C6C600000000\n0440:0000000000FCC6C6C6C6C6FCC0C0C000\n0441:00000000007CC6C0C0C0C67C00000000\n0442:0000000000FF18181818181800000000\n0443:0000000000C6C6C6C6C6C67E06067C00\n0444:00000000187EDBDBDBDBDB7E18000000\n0445:0000000000C6C66C386CC6C600000000\n0446:0000000000C6C6C6C6C6C67F03030000\n0447:0000000000C6C6C67E06060600000000\n0448:0000000000DBDBDBDBDBDB7F00000000\n0449:0000000000D6D6D6D6D6D67F03030000\n044A:0000000000E0607C6666667C00000000\n044B:0000000000C3C3F3DBDBDBF300000000\n044C:000000000060607C6666667C00000000\n044D:00000000007CC6063E06C67C00000000\n044E:0000000000CEDBDBFBDBDBCE00000000\n044F:00000000007EC6C67E3666C600000000\n0450:00003018007CC6C6FEC0C07C00000000\n0451:00006C6C007CC6C6FEC0C07C00000000\n0452:000060F8607E63636363636303030E00\n0453:0000183000FEC0C0C0C0C0C000000000\n0454:00000000007CC6C0F8C0C67C00000000\n0455:00000000007EC0C07C0606FC00000000\n0456:00001818003818181818183C00000000\n0457:00006C6C003818181818183C00000000\n0458:00000606000E06060606060666663C00\n0459:000000000078D8DEDBDBDB9E00000000\n045A:0000000000D8D8DEFBDBDBDE00000000\n045B:000060F8607E63636363636300000000\n045C:0000183000C6CCD8F0D8CCC600000000\n045D:0000301800C6C6C6C6C6C67E00000000\n045E:00006C3800C6C6C6C6C6C67E06067C00\n045F:0000000000C6C6C6C6C6C6FE38380000\n0462:000060F8607E63636363637E00000000\n0463:00006060F860607C6666667C00000000\n046A:0000FFC366663C7EDBDBDBDB00000000\n046B:0000000000FF663C3C7EDBDB00000000\n0490:0606FEC0C0C0C0C0C0C0C0C000000000\n0491:0000000606FEC0C0C0C0C0C000000000\n0492:00007F606060FC606060606000000000\n0493:00000000007F6060FC60606000000000\n0494:0000FEC0C0C0C0FCC6C6C6C6060C0000\n0495:0000000000FEC0C0F8CCCCCC0C180000\n0496:0000D6D6D67C387CD6D6D6D703030000\n0497:0000000000D6D67C387CD6D703030000\n0498:00007CC6C6063C0606C6C67C30303000\n0499:00000000007CC6063C06C67C30303000\n049A:0000C6C6CCD8F0F0D8CCC6C703030000\n049B:0000000000C6CCD8F0D8CCC703030000\n049C:0000C6C6D6DCF8F8DCD6C6C600000000\n049D:0000000000C6D6DCF8DCD6C600000000\n04A0:0000E3E3666C78786C66636300000000\n04A1:0000000000E3666C786C666300000000\n04A2:0000C6C6C6C6FEC6C6C6C6C703030000\n04A3:0000000000C6C6C6FEC6C6C703030000\n04A4:0000CFCCCCCCFCCCCCCCCCCC00000000\n04A5:0000000000CFCCCCFCCCCCCC00000000\n04AA:00007CC6C6C0C0C0C0C6C67C30303000\n04AB:00000000007CC6C0C0C0C67C30303000\n04AE:0000C3C366663C181818181800000000\n04AF:0000000000C3C366663C3C1818181800\n04B0:0000C3C366663C187E18181800000000\n04B1:0000000000C3C366663C3C187E181800\n04B2:0000C6C66C6C38386C6CC6C703030000\n04B3:0000000000C6C66C386CC6C703030000\n04B6:0000C6C6C6C6C67E0606060703030000\n04B7:0000000000C6C6C67E06060703030000\n04B8:0000C6C6C6D6D67E1616060600000000\n04B9:0000000000C6D6D67E16060600000000\n04BA:0000C0C0C0C0FCC6C6C6C6C600000000\n04BB:0000000000C0C0FCC6C6C6C600000000\n04C0:00003C18181818181818183C00000000\n04C1:6C3800DBDBDB7E3C7EDBDBDB00000000\n04C2:00006C3800DBDB7E3C7EDBDB00000000\n04CF:00003818181818181818183C00000000\n04D0:6C38007CC6C6C6FEC6C6C6C600000000\n04D1:00006C38007C067EC6C6C67E00000000\n04D2:6C6C007CC6C6C6FEC6C6C6C600000000\n04D3:00006C6C007C067EC6C6C67E00000000\n04D4:00007FCCCCCCFFCCCCCCCCCF00000000\n04D5:0000000000761B7BDFD8D86E00000000\n04D6:6C3800FEC0C0C0F8C0C0C0FE00000000\n04D7:00006C38007CC6C6FEC0C07C00000000\n04D8:00007CC60606FEC6C6C6C67C00000000\n04D9:00000000007C0606FEC6C67C00000000\n04DA:6C6C007CC60606FEC6C6C67C00000000\n04DB:00006C6C007C0606FEC6C67C00000000\n04DC:666600DBDBDB7E3C7EDBDBDB00000000\n04DD:0000666600DBDB7E3C7EDBDB00000000\n04DE:6C6C007CC6C6063C06C6C67C00000000\n04DF:00006C6C007CC6063C06C67C00000000\n04E2:7C00C6C6C6CEDEF6E6C6C6C600000000\n04E3:0000007C00C6C6C6C6C6C67E00000000\n04E4:6C6C00C6C6C6CEDEF6E6C6C600000000\n04E5:00006C6C00C6C6C6C6C6C67E00000000\n04E6:6C6C007CC6C6C6C6C6C6C67C00000000\n04E7:00006C6C007CC6C6C6C6C67C00000000\n04E8:00007CC6C6C6FEC6C6C6C67C00000000\n04E9:00000000007CC6C6FEC6C67C00000000\n04EA:6C6C007CC6C6C6FEC6C6C67C00000000\n04EB:00006C6C007CC6C6FEC6C67C00000000\n04EC:6C6C007CC606063E0606C67C00000000\n04ED:00006C6C007CC6063E06C67C00000000\n04EE:7C00C6C6C6C6C67E0606067C00000000\n04EF:0000007C00C6C6C6C6C6C67E06067C00\n04F0:6C6C00C6C6C6C67E0606067C00000000\n04F1:00006C6C00C6C6C6C6C6C67E06067C00\n04F2:366C00C6C6C6C67E0606067C00000000\n04F3:0000366C00C6C6C6C6C6C67E06067C00\n04F4:6C6C00C6C6C6C67E0606060600000000\n04F5:00006C6C00C6C6C67E06060600000000\n04F8:6C6C00C3C3C3F3DBDBDBDBF300000000\n04F9:00006C6C00C3C3F3DBDBDBF300000000\n05D0:0000C6C666663C78CCCCC6C600000000\n05D1:0000FC0606060606060606FF00000000\n05D2:0000780C0C0C0C0C1E3663C300000000\n05D3:0000FF06060606060606060600000000\n05D4:0000FC0606C6C6C6C6C6C6C600000000\n05D5:00007018181818181818181800000000\n05D6:00007E0C181818181818181800000000\n05D7:0000FCC6C6C6C6C6C6C6C6C600000000\n05D8:0000CCCEC6C6C6C6C6C6C67C00000000\n05D9:00007018181818000000000000000000\n05DA:0000FC06060606060606060606060600\n05DB:0000FC0606060606060606FC00000000\n05DC:C0C0FE060606060C1830303000000000\n05DD:0000FCC6C6C6C6C6C6C6C6FE00000000\n05DE:0000DE73636363636363636700000000\n05DF:0000F018181818181818181800000000\n05E0:0000780C0C0C0C0C0C0C0C7C00000000\n05E1:0000FE63636363636363633E00000000\n05E2:0000C6C6C6666636361C38E000000000\n05E3:00007CC6C6C666060606060606060600\n05E4:00007CC6C6C66606060606FC00000000\n05E5:0000636333361C181818181818181800\n05E6:0000C6C6666C383018180CFC00000000\n05E7:0000FE0606C6C6CCD8D8D8D8C0C0C000\n05E8:0000FC06060606060606060600000000\n05E9:0000DBDBDBDBDBF3E3C3C6FC00000000\n05EA:0000FE6363636363636363C300000000\n1E0C:0000F8CCC6C6C6C6C6C6CCF800303000\n1E0D:00000606067EC6C6C6C6C67E00181800\n1E34:0000C6C6CCD8F0F0D8CCC6C6007C0000\n1E35:0000C0C0C0C6CCD8F0D8CCC6007C0000\n1E36:0000C0C0C0C0C0C0C0C0C0FE00181800\n1E37:00003818181818181818183C00181800\n1E40:1818C3C3E7FFDBDBC3C3C3C300000000\n1E41:0000181800FEDBDBDBDBDBDB00000000\n1E42:0000C3C3E7FFDBDBC3C3C3C300181800\n1E43:0000000000FEDBDBDBDBDBDB00181800\n1E44:1818C6C6C6E6F6DECEC6C6C600000000\n1E45:0000303000FCC6C6C6C6C6C600000000\n1E46:0000C6C6C6E6F6DECEC6C6C600181800\n1E47:0000000000FCC6C6C6C6C6C600181800\n1E6C:0000FF18181818181818181800181800\n1E6D:0000303030FC30303030301E000C0C00\n1EB8:0000FEC0C0C0F8C0C0C0C0FE00181800\n1EB9:00000000007CC6C6FEC0C07C00181800\n1EBC:76DC00FEC0C0C0F8C0C0C0FE00000000\n1EBD:000076DC007CC6C6FEC0C07C00000000\n1ECA:00003C18181818181818183C00181800\n1ECB:00001818003818181818183C00181800\n1ECC:00007CC6C6C6C6C6C6C6C67C00181800\n1ECD:00000000007CC6C6C6C6C67C00181800\n1EE4:0000C6C6C6C6C6C6C6C6C67C00181800\n1EE5:0000000000C6C6C6C6C6C67E00181800\n1EF8:76DC00C3C366663C1818181800000000\n1EF9:000076DC00C6C6C6C6C6C67E06067C00\n2000:00000000000000000000000000000000\n2001:00000000000000000000000000000000\n2002:00000000000000000000000000000000\n2003:00000000000000000000000000000000\n2004:00000000000000000000000000000000\n2005:00000000000000000000000000000000\n2006:00000000000000000000000000000000\n2007:00000000000000000000000000000000\n2008:00000000000000000000000000000000\n2009:00000000000000000000000000000000\n200A:00000000000000000000000000000000\n200B:00000000000000000000000000000000\n200C:00000000000000000000000000000000\n200D:00000000000000000000000000000000\n200E:00000000000000000000000000000000\n200F:00000000000000000000000000000000\n2010:000000000000007C0000000000000000\n2011:000000000000007C0000000000000000\n2012:00000000000000FE0000000000000000\n2013:00000000000000FE0000000000000000\n2014:00000000000000FF0000000000000000\n2015:00000000000000FF0000000000000000\n2016:00006C6C6C6C6C6C6C6C6C6C00000000\n2017:00000000000000000000000000FE00FE\n2018:00183030000000000000000000000000\n2019:00181830000000000000000000000000\n201A:00000000000000000000181830000000\n201B:00303018000000000000000000000000\n201C:0066CCCC000000000000000000000000\n201D:00333366000000000000000000000000\n201E:000000000000000000006666CC000000\n201F:00CCCC66000000000000000000000000\n2020:000018187E1818181818181800000000\n2021:000018187E181818187E181800000000\n2022:000000000000183C3C18000000000000\n2026:00000000000000000000DBDB00000000\n2030:0000ECACF8183030607FD5DF00000000\n2032:00181818180000000000000000000000\n2033:00666666660000000000000000000000\n2039:00000000000C18306030180C00000000\n203A:00000000006030180C18306000000000\n203C:00006666666666666600666600000000\n203E:FE000000000000000000000000000000\n2070:00386C6C6C6C38000000000000000000\n2071:1800381818183C000000000000000000\n2074:000C1C347E0C0C000000000000000000\n2075:007860780C0C78000000000000000000\n2076:003860786C6C38000000000000000000\n2077:007C0C18183030000000000000000000\n2078:00386C386C6C38000000000000000000\n2079:00386C6C3C0C38000000000000000000\n207A:000018187E1818000000000000000000\n207B:000000007C0000000000000000000000\n207C:0000007C007C00000000000000000000\n207D:00183030303018000000000000000000\n207E:00301818181830000000000000000000\n207F:0000786C6C6C6C000000000000000000\n2080:00000000000000386C6C6C6C38000000\n2081:0000000000000018381818183C000000\n2082:00000000000000386C0C18307C000000\n2083:00000000000000780C380C0C78000000\n2084:000000000000000C1C347E0C0C000000\n2085:000000000000007860780C0C78000000\n2086:000000000000003860786C6C38000000\n2087:000000000000007C0C18183030000000\n2088:00000000000000386C386C6C38000000\n2089:00000000000000386C6C3C0C38000000\n208A:000000000000000018187E1818000000\n208B:000000000000000000007C0000000000\n208C:0000000000000000007C007C00000000\n208D:00000000000000183030303018000000\n208E:00000000000000301818181830000000\n2090:0000000000000000380C3C6C3C000000\n2091:0000000000000000386C7C603C000000\n2092:0000000000000000386C6C6C38000000\n2093:0000000000000000663C183C66000000\n2094:0000000000000000780C7C6C38000000\n2095:0000000000006060786C6C6C6C000000\n2096:0000000000006060666C786C66000000\n2097:0000000000003818181818183C000000\n2098:0000000000000000FCD6D6D6D6000000\n209A:0000000000000000786C6C6C78606000\n20A7:0000F8CCCCCCFAC6CFC6C6C300000000\n20AA:0000F28A8AAAAAAAAAA2A2BC00000000\n20AC:0000001E3360FC60FC60331E00000000\n20AE:0000FF18181E781E7818181800000000\n2102:00003C52525050505052523C00000000\n210E:0000C0C0C0FCC6C6C6C6C6C600000000\n210F:000060F8607E63636363636300000000\n2115:0000424262526A564A46424200000000\n2116:0000969696D0F0F0B096909600000000\n211A:00003C525252525252525A3C06000000\n211D:0000F8A4A4A4A4B8A8B4AAE600000000\n2122:0000FB55555100000000000000000000\n2124:00007E02060A14285060407E00000000\n2126:00007CC6C6C6C6C6C66C6CEE00000000\n2135:0000666633333E7CCCCCC66600000000\n2190:00000000002060FEFE60200000000000\n2191:0000183C7E1818181818181800000000\n2192:0000000000080CFEFE0C080000000000\n2193:0000181818181818187E3C1800000000\n2194:00000000002466FFFF66240000000000\n2195:0000183C7E181818187E3C1800000000\n21A4:00000000002262FEFE62220000000000\n21A6:0000000000888CFEFE8C880000000000\n21A8:0000183C7E1818187E3C187E00000000\n21B2:0000060606062666FEFE602000000000\n21B3:0000C0C0C0C0C8CCFEFE0C0800000000\n21B5:0000000006062666FEFE602000000000\n21BB:000000F83868CBC3C3663C0000000000\n21CB:0000002060FEFE00FEFE0C0800000000\n21CC:000000080CFEFE00FEFE602000000000\n21D0:00000000103E7EE07E3E100000000000\n21D1:000010387CEE6C6C6C6C6C6C00000000\n21D2:0000000010F8FC0EFCF8100000000000\n21D3:00006C6C6C6C6C6CEE7C381000000000\n21D4:00000000247EFFC3FF7E240000000000\n21D5:000010387CEE6C6CEE7C381000000000\n2200:0000C3C3C37E6666243C181800000000\n2203:000000FE060606FE060606FE00000000\n2204:00000CFE1E1636FE366666FEC0000000\n2205:000003067ECFDBDBF37E60C000000000\n2206:000018183C3C666666C3C3FF00000000\n2207:0000FFC3C36666663C3C181800000000\n2208:0000003E60C0C0FEC0C0603E00000000\n2209:0000063E6CCCD8FED8F0707E60000000\n220A:000000003E60C0FEC0603E0000000000\n220B:000000F80C0606FE06060CF800000000\n220C:0000C0F86C6636FE361E1CFC0C000000\n220D:00000000F80C06FE060CF80000000000\n2212:00000000000000FE0000000000000000\n2213:00000000007E0018187E181800000000\n2214:0000000018180018187E181800000000\n2215:0000000002060C183060C08000000000\n2216:0000000080C06030180C060200000000\n2219:00000000000038383800000000000000\n221A:000E0C0C0C0CCCCCCC6C3C1C00000000\n221E:000000000076DBDBDB6E000000000000\n221F:00000000C0C0C0C0C0FE000000000000\n2225:00006C6C6C6C6C6C6C6C6C6C00000000\n2227:0000000018183C3C6666C3C300000000\n2228:00000000C3C366663C3C181800000000\n2229:000000007CC6C6C6C6C6C6C600000000\n222A:00000000C6C6C6C6C6C6C67C00000000\n2248:000000000076DC0076DC000000000000\n2260:0000000006FE1830FEC0000000000000\n2261:00000000FE0000FE0000FE0000000000\n2264:0000000C18306030180C007E00000000\n2265:00000030180C060C1830007E00000000\n226A:000000091B366CD86C361B0900000000\n226B:00000090D86C361B366CD89000000000\n2282:000000007EC0C0C0C0C07E0000000000\n2283:00000000FC0606060606FC0000000000\n2286:0000007EC0C0C0C0C07E00FE00000000\n2287:000000FC0606060606FC00FE00000000\n22A5:0000000018181818181818FF00000000\n22C2:00007CC6C6C6C6C6C6C6C6C600000000\n22C3:0000C6C6C6C6C6C6C6C6C67C00000000\n2300:000003067ECFDBDBF37E60C000000000\n2302:00000000183C66C3C3C3C3FF00000000\n2308:00003C30303030303030303000000000\n2309:00003C0C0C0C0C0C0C0C0C0C00000000\n230A:00003030303030303030303C00000000\n230B:00000C0C0C0C0C0C0C0C0C3C00000000\n2310:0000000000FEC0C0C000000000000000\n2319:0000000000C0C0C0FE00000000000000\n2320:00000E1B1B1818181818181818181818\n2321:181818181818181818D8D87000000000\n239B:060C1818303030606060606060606060\n239C:60606060606060606060606060606060\n239D:60606060606060606030303018180C06\n239E:603018180C0C0C060606060606060606\n239F:06060606060606060606060606060606\n23A0:0606060606060606060C0C0C18183060\n23A1:7E606060606060606060606060606060\n23A2:60606060606060606060606060606060\n23A3:6060606060606060606060606060607E\n23A4:7E060606060606060606060606060606\n23A5:06060606060606060606060606060606\n23A6:0606060606060606060606060606067E\n23A7:0F183030303030303030303030303030\n23A8:30303030303030E0E030303030303030\n23A9:3030303030303030303030303030180F\n23AB:F0180C0C0C0C0C0C0C0C0C0C0C0C0C0C\n23AC:0C0C0C0C0C0C0C07070C0C0C0C0C0C0C\n23AD:0C0C0C0C0C0C0C0C0C0C0C0C0C0C18F0\n23AE:18181818181818181818181818181818\n23AF:00000000000000FFFF00000000000000\n23BA:FFFF0000000000000000000000000000\n23BB:00000000FFFF00000000000000000000\n23BC:00000000000000000000FFFF00000000\n23BD:0000000000000000000000000000FFFF\n23D0:18181818181818181818181818181818\n2409:00CCCCFCCCCCCC003F0C0C0C0C0C0000\n240A:00C0C0C0C0C0F8003F303C3030300000\n240B:00CCCCCCCC7830003F0C0C0C0C0C0000\n240C:00FCC0F0C0C0C0003F303C3030300000\n240D:0078CCC0C0CC78003E33333E36330000\n2424:00CCECFCDCCCCC0030303030303F0000\n2500:00000000000000FFFF00000000000000\n2501:000000000000FFFFFF00000000000000\n2502:18181818181818181818181818181818\n2503:38383838383838383838383838383838\n2508:00000000000000AAAA00000000000000\n2509:000000000000AAAAAA00000000000000\n250A:18181800181818001818180018181800\n250B:38383800383838003838380038383800\n250C:000000000000001F1F18181818181818\n250D:0000000000001F1F1F18181818181818\n250E:000000000000003F3F38383838383838\n250F:0000000000003F3F3F38383838383838\n2510:00000000000000F8F818181818181818\n2511:000000000000F8F8F818181818181818\n2512:00000000000000F8F838383838383838\n2513:000000000000F8F8F838383838383838\n2514:181818181818181F1F00000000000000\n2515:1818181818181F1F1F00000000000000\n2516:383838383838383F3F00000000000000\n2517:3838383838383F3F3F00000000000000\n2518:18181818181818F8F800000000000000\n2519:181818181818F8F8F800000000000000\n251A:38383838383838F8F800000000000000\n251B:383838383838F8F8F800000000000000\n251C:181818181818181F1F18181818181818\n251D:1818181818181F1F1F18181818181818\n251E:383838383838383F3F18181818181818\n251F:181818181818183F3F38383838383838\n2520:383838383838383F3F38383838383838\n2521:3838383838383F3F3F18181818181818\n2522:1818181818183F3F3F38383838383838\n2523:3838383838383F3F3F38383838383838\n2524:18181818181818F8F818181818181818\n2525:181818181818F8F8F818181818181818\n2526:38383838383838F8F818181818181818\n2527:18181818181818F8F838383838383838\n2528:38383838383838F8F838383838383838\n2529:383838383838F8F8F818181818181818\n252A:181818181818F8F8F838383838383838\n252B:383838383838F8F8F838383838383838\n252C:00000000000000FFFF18181818181818\n252D:000000000000F8FFFF18181818181818\n252E:0000000000001FFFFF18181818181818\n252F:000000000000FFFFFF18181818181818\n2530:00000000000000FFFF38383838383838\n2531:000000000000F8FFFF38383838383838\n2532:0000000000003FFFFF38383838383838\n2533:000000000000FFFFFF38383838383838\n2534:18181818181818FFFF00000000000000\n2535:181818181818F8FFFF00000000000000\n2536:1818181818181FFFFF00000000000000\n2537:181818181818FFFFFF00000000000000\n2538:38383838383838FFFF00000000000000\n2539:383838383838F8FFFF00000000000000\n253A:3838383838383FFFFF00000000000000\n253B:383838383838FFFFFF00000000000000\n253C:18181818181818FFFF18181818181818\n253D:181818181818F8FFFF18181818181818\n253E:1818181818181FFFFF18181818181818\n253F:181818181818FFFFFF18181818181818\n2540:38383838383838FFFF18181818181818\n2541:18181818181818FFFF38383838383838\n2542:38383838383838FFFF38383838383838\n2543:383838383838F8FFFF18181818181818\n2544:3838383838383FFFFF18181818181818\n2545:181818181818F8FFFF38383838383838\n2546:1818181818181FFFFF38383838383838\n2547:383838383838FFFFFF18181818181818\n2548:181818181818FFFFFF38383838383838\n2549:383838383838F8FFFF38383838383838\n254A:3838383838383FFFFF38383838383838\n254B:383838383838FFFFFF38383838383838\n2550:0000000000FFFF00FFFF000000000000\n2551:6C6C6C6C6C6C6C6C6C6C6C6C6C6C6C6C\n2552:00000000001F1F181F1F181818181818\n2553:000000000000007F7F6C6C6C6C6C6C6C\n2554:00000000007F7F606F6F6C6C6C6C6C6C\n2555:0000000000F8F818F8F8181818181818\n2556:00000000000000FCFC6C6C6C6C6C6C6C\n2557:0000000000FCFC0CECEC6C6C6C6C6C6C\n2558:18181818181F1F181F1F000000000000\n2559:6C6C6C6C6C6C6C7F7F00000000000000\n255A:6C6C6C6C6C6F6F607F7F000000000000\n255B:1818181818F8F818F8F8000000000000\n255C:6C6C6C6C6C6C6CFCFC00000000000000\n255D:6C6C6C6C6CECEC0CFCFC000000000000\n255E:18181818181F1F181F1F181818181818\n255F:6C6C6C6C6C6C6C6F6F6C6C6C6C6C6C6C\n2560:6C6C6C6C6C6F6F606F6F6C6C6C6C6C6C\n2561:1818181818F8F818F8F8181818181818\n2562:6C6C6C6C6C6C6CECEC6C6C6C6C6C6C6C\n2563:6C6C6C6C6CECEC0CECEC6C6C6C6C6C6C\n2564:0000000000FFFF00FFFF181818181818\n2565:00000000000000FFFF6C6C6C6C6C6C6C\n2566:0000000000FFFF00EFEF6C6C6C6C6C6C\n2567:1818181818FFFF00FFFF000000000000\n2568:6C6C6C6C6C6C6CFFFF00000000000000\n2569:6C6C6C6C6CEFEF00FFFF000000000000\n256A:1818181818FFFF18FFFF181818181818\n256B:6C6C6C6C6C6C6CFFFF6C6C6C6C6C6C6C\n256C:6C6C6C6C6CEFEF00EFEF6C6C6C6C6C6C\n256D:00000000000000070F1C181818181818\n256E:00000000000000E0F038181818181818\n256F:18181818181838F0E000000000000000\n2570:1818181818181C0F0700000000000000\n2571:0101030206040C08181030206040C080\n2572:80C0406020301018080C040602030101\n2573:81C1436226341C18181C34266243C181\n2574:00000000000000F8F800000000000000\n2575:18181818181818181800000000000000\n2576:000000000000001F1F00000000000000\n2577:00000000000000181818181818181818\n2578:000000000000F8F8F800000000000000\n2579:38383838383838383800000000000000\n257A:0000000000001F1F1F00000000000000\n257B:00000000000000383838383838383838\n257C:0000000000001FFFFF00000000000000\n257D:18181818181818383838383838383838\n257E:000000000000F8FFFF00000000000000\n257F:38383838383838383818181818181818\n2580:FFFFFFFFFFFFFFFF0000000000000000\n2581:0000000000000000000000000000FFFF\n2582:000000000000000000000000FFFFFFFF\n2583:00000000000000000000FFFFFFFFFFFF\n2584:0000000000000000FFFFFFFFFFFFFFFF\n2585:000000000000FFFFFFFFFFFFFFFFFFFF\n2586:00000000FFFFFFFFFFFFFFFFFFFFFFFF\n2587:0000FFFFFFFFFFFFFFFFFFFFFFFFFFFF\n2588:FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF\n2589:FEFEFEFEFEFEFEFEFEFEFEFEFEFEFEFE\n258A:FCFCFCFCFCFCFCFCFCFCFCFCFCFCFCFC\n258B:F8F8F8F8F8F8F8F8F8F8F8F8F8F8F8F8\n258C:F0F0F0F0F0F0F0F0F0F0F0F0F0F0F0F0\n258D:E0E0E0E0E0E0E0E0E0E0E0E0E0E0E0E0\n258E:C0C0C0C0C0C0C0C0C0C0C0C0C0C0C0C0\n258F:80808080808080808080808080808080\n2590:0F0F0F0F0F0F0F0F0F0F0F0F0F0F0F0F\n2591:88228822882288228822882288228822\n2592:AA55AA55AA55AA55AA55AA55AA55AA55\n2593:EEBBEEBBEEBBEEBBEEBBEEBBEEBBEEBB\n2596:0000000000000000F0F0F0F0F0F0F0F0\n2597:00000000000000000F0F0F0F0F0F0F0F\n2598:F0F0F0F0F0F0F0F00000000000000000\n2599:F0F0F0F0F0F0F0F0FFFFFFFFFFFFFFFF\n259A:F0F0F0F0F0F0F0F00F0F0F0F0F0F0F0F\n259B:FFFFFFFFFFFFFFFFF0F0F0F0F0F0F0F0\n259C:FFFFFFFFFFFFFFFF0F0F0F0F0F0F0F0F\n259D:0F0F0F0F0F0F0F0F0000000000000000\n259E:0F0F0F0F0F0F0F0FF0F0F0F0F0F0F0F0\n259F:0F0F0F0F0F0F0F0FFFFFFFFFFFFFFFFF\n25A0:00000000007C7C7C7C7C7C0000000000\n25AC:0000000000000000FEFEFEFE00000000\n25AE:0000FEFEFEFEFEFEFEFEFEFE00000000\n25B2:0000000018183C3C7E7EFFFF00000000\n25B6:00000000C0F0FCFFFFFCF0C000000000\n25BA:00000000C0F0FCFFFFFCF0C000000000\n25BC:00000000FFFF7E7E3C3C181800000000\n25C0:00000000030F3FFFFF3F0F0300000000\n25C4:00000000030F3FFFFF3F0F0300000000\n25C6:00000000183C7EFF7E3C180000000000\n25CA:00000000183C66C3663C180000000000\n25CB:00000000003C664242663C0000000000\n25CF:00000000003C7E7E7E7E3C0000000000\n25D8:FFFFFFFFFFFFE7C3C3E7FFFFFFFFFFFF\n25D9:FFFFFFFFFFC399BDBD99C3FFFFFFFFFF\n263A:00007E81A58181BD9981817E00000000\n263B:00007EFFDBFFFFC3E7FFFF7E00000000\n263C:00000018DB7E3CE73C7EDB1800000000\n2640:00003C666666663C187E181800000000\n2642:00003E0E1A3278CCCCCCCC7800000000\n2660:000018183C7EFFFF7E18183C00000000\n2663:0000183C3C185AFFFF5A183C00000000\n2665:0000000066FFFFFFFF7E3C1800000000\n2666:00000000183C7EFF7E3C180000000000\n266A:00003F333F3030303030F0E000000000\n266B:00007F637F636363636367E6C0000000\n2713:000003030606CCCC7878303000000000\n2714:000007070E0EDCFC7878303000000000\n2717:00000CCC7838383C6660C0C000000000\n2718:00000EEE7C3C3C3E7773E0E000000000\n27E8:00000C0C1818303018180C0C00000000\n27E9:0000303018180C0C1818303000000000\n27EA:000036366C6CD8D86C6C363600000000\n27EB:0000D8D86C6C36366C6CD8D800000000\n2800:00000000000000000000000000000000\n2801:00606000000000000000000000000000\n2802:00000000006060000000000000000000\n2803:00606000006060000000000000000000\n2804:00000000000000000060600000000000\n2805:00606000000000000060600000000000\n2806:00000000006060000060600000000000\n2807:00606000006060000060600000000000\n2808:00060600000000000000000000000000\n2809:00666600000000000000000000000000\n280A:00060600006060000000000000000000\n280B:00666600006060000000000000000000\n280C:00060600000000000060600000000000\n280D:00666600000000000060600000000000\n280E:00060600006060000060600000000000\n280F:00666600006060000060600000000000\n2810:00000000000606000000000000000000\n2811:00606000000606000000000000000000\n2812:00000000006666000000000000000000\n2813:00606000006666000000000000000000\n2814:00000000000606000060600000000000\n2815:00606000000606000060600000000000\n2816:00000000006666000060600000000000\n2817:00606000006666000060600000000000\n2818:00060600000606000000000000000000\n2819:00666600000606000000000000000000\n281A:00060600006666000000000000000000\n281B:00666600006666000000000000000000\n281C:00060600000606000060600000000000\n281D:00666600000606000060600000000000\n281E:00060600006666000060600000000000\n281F:00666600006666000060600000000000\n2820:00000000000000000006060000000000\n2821:00606000000000000006060000000000\n2822:00000000006060000006060000000000\n2823:00606000006060000006060000000000\n2824:00000000000000000066660000000000\n2825:00606000000000000066660000000000\n2826:00000000006060000066660000000000\n2827:00606000006060000066660000000000\n2828:00060600000000000006060000000000\n2829:00666600000000000006060000000000\n282A:00060600006060000006060000000000\n282B:00666600006060000006060000000000\n282C:00060600000000000066660000000000\n282D:00666600000000000066660000000000\n282E:00060600006060000066660000000000\n282F:00666600006060000066660000000000\n2830:00000000000606000006060000000000\n2831:00606000000606000006060000000000\n2832:00000000006666000006060000000000\n2833:00606000006666000006060000000000\n2834:00000000000606000066660000000000\n2835:00606000000606000066660000000000\n2836:00000000006666000066660000000000\n2837:00606000006666000066660000000000\n2838:00060600000606000006060000000000\n2839:00666600000606000006060000000000\n283A:00060600006666000006060000000000\n283B:00666600006666000006060000000000\n283C:00060600000606000066660000000000\n283D:00666600000606000066660000000000\n283E:00060600006666000066660000000000\n283F:00666600006666000066660000000000\n2840:00000000000000000000000000606000\n2841:00606000000000000000000000606000\n2842:00000000006060000000000000606000\n2843:00606000006060000000000000606000\n2844:00000000000000000060600000606000\n2845:00606000000000000060600000606000\n2846:00000000006060000060600000606000\n2847:00606000006060000060600000606000\n2848:00060600000000000000000000606000\n2849:00666600000000000000000000606000\n284A:00060600006060000000000000606000\n284B:00666600006060000000000000606000\n284C:00060600000000000060600000606000\n284D:00666600000000000060600000606000\n284E:00060600006060000060600000606000\n284F:00666600006060000060600000606000\n2850:00000000000606000000000000606000\n2851:00606000000606000000000000606000\n2852:00000000006666000000000000606000\n2853:00606000006666000000000000606000\n2854:00000000000606000060600000606000\n2855:00606000000606000060600000606000\n2856:00000000006666000060600000606000\n2857:00606000006666000060600000606000\n2858:00060600000606000000000000606000\n2859:00666600000606000000000000606000\n285A:00060600006666000000000000606000\n285B:00666600006666000000000000606000\n285C:00060600000606000060600000606000\n285D:00666600000606000060600000606000\n285E:00060600006666000060600000606000\n285F:00666600006666000060600000606000\n2860:00000000000000000006060000606000\n2861:00606000000000000006060000606000\n2862:00000000006060000006060000606000\n2863:00606000006060000006060000606000\n2864:00000000000000000066660000606000\n2865:00606000000000000066660000606000\n2866:00000000006060000066660000606000\n2867:00606000006060000066660000606000\n2868:00060600000000000006060000606000\n2869:00666600000000000006060000606000\n286A:00060600006060000006060000606000\n286B:00666600006060000006060000606000\n286C:00060600000000000066660000606000\n286D:00666600000000000066660000606000\n286E:00060600006060000066660000606000\n286F:00666600006060000066660000606000\n2870:00000000000606000006060000606000\n2871:00606000000606000006060000606000\n2872:00000000006666000006060000606000\n2873:00606000006666000006060000606000\n2874:00000000000606000066660000606000\n2875:00606000000606000066660000606000\n2876:00000000006666000066660000606000\n2877:00606000006666000066660000606000\n2878:00060600000606000006060000606000\n2879:00666600000606000006060000606000\n287A:00060600006666000006060000606000\n287B:00666600006666000006060000606000\n287C:00060600000606000066660000606000\n287D:00666600000606000066660000606000\n287E:00060600006666000066660000606000\n287F:00666600006666000066660000606000\n2880:00000000000000000000000000060600\n2881:00606000000000000000000000060600\n2882:00000000006060000000000000060600\n2883:00606000006060000000000000060600\n2884:00000000000000000060600000060600\n2885:00606000000000000060600000060600\n2886:00000000006060000060600000060600\n2887:00606000006060000060600000060600\n2888:00060600000000000000000000060600\n2889:00666600000000000000000000060600\n288A:00060600006060000000000000060600\n288B:00666600006060000000000000060600\n288C:00060600000000000060600000060600\n288D:00666600000000000060600000060600\n288E:00060600006060000060600000060600\n288F:00666600006060000060600000060600\n2890:00000000000606000000000000060600\n2891:00606000000606000000000000060600\n2892:00000000006666000000000000060600\n2893:00606000006666000000000000060600\n2894:00000000000606000060600000060600\n2895:00606000000606000060600000060600\n2896:00000000006666000060600000060600\n2897:00606000006666000060600000060600\n2898:00060600000606000000000000060600\n2899:00666600000606000000000000060600\n289A:00060600006666000000000000060600\n289B:00666600006666000000000000060600\n289C:00060600000606000060600000060600\n289D:00666600000606000060600000060600\n289E:00060600006666000060600000060600\n289F:00666600006666000060600000060600\n28A0:00000000000000000006060000060600\n28A1:00606000000000000006060000060600\n28A2:00000000006060000006060000060600\n28A3:00606000006060000006060000060600\n28A4:00000000000000000066660000060600\n28A5:00606000000000000066660000060600\n28A6:00000000006060000066660000060600\n28A7:00606000006060000066660000060600\n28A8:00060600000000000006060000060600\n28A9:00666600000000000006060000060600\n28AA:00060600006060000006060000060600\n28AB:00666600006060000006060000060600\n28AC:00060600000000000066660000060600\n28AD:00666600000000000066660000060600\n28AE:00060600006060000066660000060600\n28AF:00666600006060000066660000060600\n28B0:00000000000606000006060000060600\n28B1:00606000000606000006060000060600\n28B2:00000000006666000006060000060600\n28B3:00606000006666000006060000060600\n28B4:00000000000606000066660000060600\n28B5:00606000000606000066660000060600\n28B6:00000000006666000066660000060600\n28B7:00606000006666000066660000060600\n28B8:00060600000606000006060000060600\n28B9:00666600000606000006060000060600\n28BA:00060600006666000006060000060600\n28BB:00666600006666000006060000060600\n28BC:00060600000606000066660000060600\n28BD:00666600000606000066660000060600\n28BE:00060600006666000066660000060600\n28BF:00666600006666000066660000060600\n28C0:00000000000000000000000000666600\n28C1:00606000000000000000000000666600\n28C2:00000000006060000000000000666600\n28C3:00606000006060000000000000666600\n28C4:00000000000000000060600000666600\n28C5:00606000000000000060600000666600\n28C6:00000000006060000060600000666600\n28C7:00606000006060000060600000666600\n28C8:00060600000000000000000000666600\n28C9:00666600000000000000000000666600\n28CA:00060600006060000000000000666600\n28CB:00666600006060000000000000666600\n28CC:00060600000000000060600000666600\n28CD:00666600000000000060600000666600\n28CE:00060600006060000060600000666600\n28CF:00666600006060000060600000666600\n28D0:00000000000606000000000000666600\n28D1:00606000000606000000000000666600\n28D2:00000000006666000000000000666600\n28D3:00606000006666000000000000666600\n28D4:00000000000606000060600000666600\n28D5:00606000000606000060600000666600\n28D6:00000000006666000060600000666600\n28D7:00606000006666000060600000666600\n28D8:00060600000606000000000000666600\n28D9:00666600000606000000000000666600\n28DA:00060600006666000000000000666600\n28DB:00666600006666000000000000666600\n28DC:00060600000606000060600000666600\n28DD:00666600000606000060600000666600\n28DE:00060600006666000060600000666600\n28DF:00666600006666000060600000666600\n28E0:00000000000000000006060000666600\n28E1:00606000000000000006060000666600\n28E2:00000000006060000006060000666600\n28E3:00606000006060000006060000666600\n28E4:00000000000000000066660000666600\n28E5:00606000000000000066660000666600\n28E6:00000000006060000066660000666600\n28E7:00606000006060000066660000666600\n28E8:00060600000000000006060000666600\n28E9:00666600000000000006060000666600\n28EA:00060600006060000006060000666600\n28EB:00666600006060000006060000666600\n28EC:00060600000000000066660000666600\n28ED:00666600000000000066660000666600\n28EE:00060600006060000066660000666600\n28EF:00666600006060000066660000666600\n28F0:00000000000606000006060000666600\n28F1:00606000000606000006060000666600\n28F2:00000000006666000006060000666600\n28F3:00606000006666000006060000666600\n28F4:00000000000606000066660000666600\n28F5:00606000000606000066660000666600\n28F6:00000000006666000066660000666600\n28F7:00606000006666000066660000666600\n28F8:00060600000606000006060000666600\n28F9:00666600000606000006060000666600\n28FA:00060600006666000006060000666600\n28FB:00666600006666000006060000666600\n28FC:00060600000606000066660000666600\n28FD:00666600000606000066660000666600\n28FE:00060600006666000066660000666600\n28FF:00666600006666000066660000666600\n2E2C:0000000000C6C6000000C6C600000000\nE0A0:C0C0CCDEFFCCCCCC983060C0C0C0C0C0\nE0A1:00C0C0C0C0C0FC00333B3F3733330000\nE0A2:003C66666666FFFFE7C3E7FFFFFF0000\nE0B0:80C0E0F0F8FCFEFFFFFEFCF8F0E0C080\nE0B1:80C06030180C060303060C183060C080\nE0B2:0103070F1F3F7FFFFF7F3F1F0F070301\nE0B3:0103060C183060C0C06030180C060301\nF6BE:00000000000E06060606060666663C00\nFFFD:0000FEC6C6C6C6C6C6C6C6FE00000000\n"
  },
  {
    "path": "EFI_DEBUG/EFI/OC/config.plist",
    "content": "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<!DOCTYPE plist PUBLIC \"-//Apple//DTD PLIST 1.0//EN\" \"http://www.apple.com/DTDs/PropertyList-1.0.dtd\">\n<plist version=\"1.0\">\n<dict>\n\t<key>#WARNING - 1</key>\n\t<string>This is just a sample. Do NOT try loading it.</string>\n\t<key>#WARNING - 2</key>\n\t<string>Ensure you understand EVERY field before booting.</string>\n\t<key>#WARNING - 3</key>\n\t<string>In most cases recommended to use Sample.plist</string>\n\t<key>#WARNING - 4</key>\n\t<string>Use SampleCustom.plist only for special cases.</string>\n\t<key>ACPI</key>\n\t<dict>\n\t\t<key>Add</key>\n\t\t<array>\n\t\t\t<dict>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>SSDT-EC.aml</string>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<true/>\n\t\t\t\t<key>Path</key>\n\t\t\t\t<string>SSDT-EC.aml</string>\n\t\t\t</dict>\n\t\t\t<dict>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>SSDT-USBX.aml</string>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<true/>\n\t\t\t\t<key>Path</key>\n\t\t\t\t<string>SSDT-USBX.aml</string>\n\t\t\t</dict>\n\t\t</array>\n\t\t<key>Delete</key>\n\t\t<array>\n\t\t\t<dict>\n\t\t\t\t<key>All</key>\n\t\t\t\t<false/>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>Delete CpuPm</string>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<false/>\n\t\t\t\t<key>OemTableId</key>\n\t\t\t\t<data>Q3B1UG0AAAA=</data>\n\t\t\t\t<key>TableLength</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t\t<key>TableSignature</key>\n\t\t\t\t<data>U1NEVA==</data>\n\t\t\t</dict>\n\t\t\t<dict>\n\t\t\t\t<key>All</key>\n\t\t\t\t<false/>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>Delete Cpu0Ist</string>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<false/>\n\t\t\t\t<key>OemTableId</key>\n\t\t\t\t<data>Q3B1MElzdAA=</data>\n\t\t\t\t<key>TableLength</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t\t<key>TableSignature</key>\n\t\t\t\t<data>U1NEVA==</data>\n\t\t\t</dict>\n\t\t</array>\n\t\t<key>Patch</key>\n\t\t<array>\n\t\t\t<dict>\n\t\t\t\t<key>Base</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>BaseSkip</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>Replace one byte sequence with another</string>\n\t\t\t\t<key>Count</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<false/>\n\t\t\t\t<key>Find</key>\n\t\t\t\t<data>ESIzRA==</data>\n\t\t\t\t<key>Limit</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t\t<key>Mask</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>OemTableId</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>Replace</key>\n\t\t\t\t<data>RDMiEQ==</data>\n\t\t\t\t<key>ReplaceMask</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>Skip</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t\t<key>TableLength</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t\t<key>TableSignature</key>\n\t\t\t\t<data></data>\n\t\t\t</dict>\n\t\t\t<dict>\n\t\t\t\t<key>Base</key>\n\t\t\t\t<string>\\_SB.PCI0.LPCB.HPET</string>\n\t\t\t\t<key>BaseSkip</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>HPET _CRS to XCRS</string>\n\t\t\t\t<key>Count</key>\n\t\t\t\t<integer>1</integer>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<false/>\n\t\t\t\t<key>Find</key>\n\t\t\t\t<data>X0NSUw==</data>\n\t\t\t\t<key>Limit</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t\t<key>Mask</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>OemTableId</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>Replace</key>\n\t\t\t\t<data>WENSUw==</data>\n\t\t\t\t<key>ReplaceMask</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>Skip</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t\t<key>TableLength</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t\t<key>TableSignature</key>\n\t\t\t\t<data></data>\n\t\t\t</dict>\n\t\t</array>\n\t\t<key>Quirks</key>\n\t\t<dict>\n\t\t\t<key>FadtEnableReset</key>\n\t\t\t<false/>\n\t\t\t<key>NormalizeHeaders</key>\n\t\t\t<false/>\n\t\t\t<key>RebaseRegions</key>\n\t\t\t<false/>\n\t\t\t<key>ResetHwSig</key>\n\t\t\t<false/>\n\t\t\t<key>ResetLogoStatus</key>\n\t\t\t<false/>\n\t\t\t<key>SyncTableIds</key>\n\t\t\t<false/>\n\t\t</dict>\n\t</dict>\n\t<key>Booter</key>\n\t<dict>\n\t\t<key>MmioWhitelist</key>\n\t\t<array>\n\t\t\t<dict>\n\t\t\t\t<key>Address</key>\n\t\t\t\t<integer>4275159040</integer>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>Haswell: SB_RCBA is a 0x4 page memory region, containing SPI_BASE at 0x3800 (SPI_BASE_ADDRESS)</string>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<false/>\n\t\t\t</dict>\n\t\t\t<dict>\n\t\t\t\t<key>Address</key>\n\t\t\t\t<integer>4278190080</integer>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>Generic: PCI root is a 0x1000 page memory region used by some types of firmware</string>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<false/>\n\t\t\t</dict>\n\t\t</array>\n\t\t<key>Patch</key>\n\t\t<array>\n\t\t\t<dict>\n\t\t\t\t<key>Arch</key>\n\t\t\t\t<string>Any</string>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>macOS to hacOS</string>\n\t\t\t\t<key>Count</key>\n\t\t\t\t<integer>1</integer>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<false/>\n\t\t\t\t<key>Find</key>\n\t\t\t\t<data>bWFjT1M=</data>\n\t\t\t\t<key>Identifier</key>\n\t\t\t\t<string>Apple</string>\n\t\t\t\t<key>Limit</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t\t<key>Mask</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>Replace</key>\n\t\t\t\t<data>aGFjT1M=</data>\n\t\t\t\t<key>ReplaceMask</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>Skip</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t</dict>\n\t\t</array>\n\t\t<key>Quirks</key>\n\t\t<dict>\n\t\t\t<key>AllowRelocationBlock</key>\n\t\t\t<false/>\n\t\t\t<key>AvoidRuntimeDefrag</key>\n\t\t\t<true/>\n\t\t\t<key>ClearTaskSwitchBit</key>\n\t\t\t<false/>\n\t\t\t<key>DevirtualiseMmio</key>\n\t\t\t<false/>\n\t\t\t<key>DisableSingleUser</key>\n\t\t\t<false/>\n\t\t\t<key>DisableVariableWrite</key>\n\t\t\t<false/>\n\t\t\t<key>DiscardHibernateMap</key>\n\t\t\t<false/>\n\t\t\t<key>EnableSafeModeSlide</key>\n\t\t\t<false/>\n\t\t\t<key>EnableWriteUnprotector</key>\n\t\t\t<true/>\n\t\t\t<key>FixupAppleEfiImages</key>\n\t\t\t<false/>\n\t\t\t<key>ForceBooterSignature</key>\n\t\t\t<false/>\n\t\t\t<key>ForceExitBootServices</key>\n\t\t\t<false/>\n\t\t\t<key>ProtectMemoryRegions</key>\n\t\t\t<false/>\n\t\t\t<key>ProtectSecureBoot</key>\n\t\t\t<false/>\n\t\t\t<key>ProtectUefiServices</key>\n\t\t\t<false/>\n\t\t\t<key>ProvideCustomSlide</key>\n\t\t\t<false/>\n\t\t\t<key>ProvideMaxSlide</key>\n\t\t\t<integer>0</integer>\n\t\t\t<key>RebuildAppleMemoryMap</key>\n\t\t\t<false/>\n\t\t\t<key>ResizeAppleGpuBars</key>\n\t\t\t<integer>0</integer>\n\t\t\t<key>SetupVirtualMap</key>\n\t\t\t<false/>\n\t\t\t<key>SignalAppleOS</key>\n\t\t\t<false/>\n\t\t\t<key>SyncRuntimePermissions</key>\n\t\t\t<false/>\n\t\t</dict>\n\t</dict>\n\t<key>DeviceProperties</key>\n\t<dict>\n\t\t<key>Add</key>\n\t\t<dict>\n\t\t\t<key>PciRoot(0x0)/Pci(0x2,0x0)</key>\n\t\t\t<dict>\n\t\t\t\t<key>AAPL,ig-platform-id</key>\n\t\t\t\t<data></data>\n\t\t\t</dict>\n\t\t\t<key>PciRoot(0x0)/Pci(0x1b,0x0)</key>\n\t\t\t<dict>\n\t\t\t\t<key>layout-id</key>\n\t\t\t\t<data>AQAAAA==</data>\n\t\t\t</dict>\n\t\t\t<key>PciRoot(0x0)/Pci(0x1E,0x0)/Pci(0x1,0x0)/Pci(0x12,0x0)</key>\n\t\t\t<dict>\n\t\t\t\t<key>built-in</key>\n\t\t\t\t<data>AQ==</data>\n\t\t\t</dict>\n\t\t\t<key>PciRoot(0x0)/Pci(0x1E,0x0)/Pci(0x1,0x0)/Pci(0x7,0x0)</key>\n\t\t\t<dict>\n\t\t\t\t<key>built-in</key>\n\t\t\t\t<data>AQ==</data>\n\t\t\t</dict>\n\t\t\t<key>PciRoot(0x0)/Pci(0x12,0x0)</key>\n\t\t\t<dict>\n\t\t\t\t<key>built-in</key>\n\t\t\t\t<data>AQ==</data>\n\t\t\t</dict>\n\t\t\t<key>PciRoot(0x0)/Pci(0x13,0x0)</key>\n\t\t\t<dict>\n\t\t\t\t<key>built-in</key>\n\t\t\t\t<data>AQ==</data>\n\t\t\t</dict>\n\t\t\t<key>PciRoot(0x0)/Pci(0x1E,0x0)/Pci(0x1,0x0)/Pci(0x13,0x0)</key>\n\t\t\t<dict>\n\t\t\t\t<key>built-in</key>\n\t\t\t\t<data>AQ==</data>\n\t\t\t</dict>\n\t\t</dict>\n\t\t<key>Delete</key>\n\t\t<dict/>\n\t</dict>\n\t<key>Kernel</key>\n\t<dict>\n\t\t<key>Add</key>\n\t\t<array>\n\t\t\t<dict>\n\t\t\t\t<key>Arch</key>\n\t\t\t\t<string>Any</string>\n\t\t\t\t<key>BundlePath</key>\n\t\t\t\t<string>Lilu.kext</string>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>Lilu.kext</string>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<true/>\n\t\t\t\t<key>ExecutablePath</key>\n\t\t\t\t<string>Contents/MacOS/Lilu</string>\n\t\t\t\t<key>MaxKernel</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>MinKernel</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>PlistPath</key>\n\t\t\t\t<string>Contents/Info.plist</string>\n\t\t\t</dict>\n\t\t\t<dict>\n\t\t\t\t<key>Arch</key>\n\t\t\t\t<string>Any</string>\n\t\t\t\t<key>BundlePath</key>\n\t\t\t\t<string>VirtualSMC.kext</string>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>VirtualSMC.kext</string>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<true/>\n\t\t\t\t<key>ExecutablePath</key>\n\t\t\t\t<string>Contents/MacOS/VirtualSMC</string>\n\t\t\t\t<key>MaxKernel</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>MinKernel</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>PlistPath</key>\n\t\t\t\t<string>Contents/Info.plist</string>\n\t\t\t</dict>\n\t\t\t<dict>\n\t\t\t\t<key>Arch</key>\n\t\t\t\t<string>Any</string>\n\t\t\t\t<key>BundlePath</key>\n\t\t\t\t<string>WhateverGreen.kext</string>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>WhateverGreen.kext</string>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<true/>\n\t\t\t\t<key>ExecutablePath</key>\n\t\t\t\t<string>Contents/MacOS/WhateverGreen</string>\n\t\t\t\t<key>MaxKernel</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>MinKernel</key>\n\t\t\t\t<string>10.0.0</string>\n\t\t\t\t<key>PlistPath</key>\n\t\t\t\t<string>Contents/Info.plist</string>\n\t\t\t</dict>\n\t\t\t<dict>\n\t\t\t\t<key>Arch</key>\n\t\t\t\t<string>Any</string>\n\t\t\t\t<key>BundlePath</key>\n\t\t\t\t<string>VoodooPS2Controller.kext</string>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>Acidanthera VoodooPS2Controller.kext</string>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<true/>\n\t\t\t\t<key>ExecutablePath</key>\n\t\t\t\t<string>Contents/MacOS/VoodooPS2Controller</string>\n\t\t\t\t<key>MaxKernel</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>MinKernel</key>\n\t\t\t\t<string>15.0.0</string>\n\t\t\t\t<key>PlistPath</key>\n\t\t\t\t<string>Contents/Info.plist</string>\n\t\t\t</dict>\n\t\t\t<dict>\n\t\t\t\t<key>Arch</key>\n\t\t\t\t<string>Any</string>\n\t\t\t\t<key>BundlePath</key>\n\t\t\t\t<string>VoodooPS2Controller.kext/Contents/PlugIns/VoodooPS2Keyboard.kext</string>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>Acidanthera VoodooPS2Keyboard.kext</string>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<true/>\n\t\t\t\t<key>ExecutablePath</key>\n\t\t\t\t<string>Contents/MacOS/VoodooPS2Keyboard</string>\n\t\t\t\t<key>MaxKernel</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>MinKernel</key>\n\t\t\t\t<string>15.0.0</string>\n\t\t\t\t<key>PlistPath</key>\n\t\t\t\t<string>Contents/Info.plist</string>\n\t\t\t</dict>\n\t\t\t<dict>\n\t\t\t\t<key>Arch</key>\n\t\t\t\t<string>Any</string>\n\t\t\t\t<key>BundlePath</key>\n\t\t\t\t<string>AppleMCEReporterDisabler.kext</string>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>Fix kernel panic MacPro SMBIOS</string>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<true/>\n\t\t\t\t<key>ExecutablePath</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>MaxKernel</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>MinKernel</key>\n\t\t\t\t<string>21.0.0</string>\n\t\t\t\t<key>PlistPath</key>\n\t\t\t\t<string>Contents/Info.plist</string>\n\t\t\t</dict>\n\t\t</array>\n\t\t<key>Block</key>\n\t\t<array>\n\t\t\t<dict>\n\t\t\t\t<key>Arch</key>\n\t\t\t\t<string>Any</string>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<false/>\n\t\t\t\t<key>Identifier</key>\n\t\t\t\t<string>com.apple.driver.AppleTyMCEDriver</string>\n\t\t\t\t<key>MaxKernel</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>MinKernel</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>Strategy</key>\n\t\t\t\t<string>Disable</string>\n\t\t\t</dict>\n\t\t\t<dict>\n\t\t\t\t<key>Arch</key>\n\t\t\t\t<string>x86_64</string>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<false/>\n\t\t\t\t<key>Identifier</key>\n\t\t\t\t<string>com.apple.iokit.IOSkywalkFamily</string>\n\t\t\t\t<key>MaxKernel</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>MinKernel</key>\n\t\t\t\t<string>23.0.0</string>\n\t\t\t\t<key>Strategy</key>\n\t\t\t\t<string>Exclude</string>\n\t\t\t</dict>\n\t\t</array>\n\t\t<key>Emulate</key>\n\t\t<dict>\n\t\t\t<key>Cpuid1Data</key>\n\t\t\t<data></data>\n\t\t\t<key>Cpuid1Mask</key>\n\t\t\t<data></data>\n\t\t\t<key>DummyPowerManagement</key>\n\t\t\t<true/>\n\t\t\t<key>MaxKernel</key>\n\t\t\t<string></string>\n\t\t\t<key>MinKernel</key>\n\t\t\t<string></string>\n\t\t</dict>\n\t\t<key>Force</key>\n\t\t<array>\n\t\t\t<dict>\n\t\t\t\t<key>Arch</key>\n\t\t\t\t<string>Any</string>\n\t\t\t\t<key>BundlePath</key>\n\t\t\t\t<string>System/Library/Extensions/IONetworkingFamily.kext</string>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<false/>\n\t\t\t\t<key>ExecutablePath</key>\n\t\t\t\t<string>Contents/MacOS/IONetworkingFamily</string>\n\t\t\t\t<key>Identifier</key>\n\t\t\t\t<string>com.apple.iokit.IONetworkingFamily</string>\n\t\t\t\t<key>MaxKernel</key>\n\t\t\t\t<string>13.99.99</string>\n\t\t\t\t<key>MinKernel</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>PlistPath</key>\n\t\t\t\t<string>Contents/Info.plist</string>\n\t\t\t</dict>\n\t\t</array>\n\t\t<key>Patch</key>\n\t\t<array>\n\t\t\t<dict>\n\t\t\t\t<key>Arch</key>\n\t\t\t\t<string>Any</string>\n\t\t\t\t<key>Base</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>Enable TRIM/discard on QEMU SATA SSD - 10.7+</string>\n\t\t\t\t<key>Count</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<true/>\n\t\t\t\t<key>Find</key>\n\t\t\t\t<data>AEFQUExFIFNTRAA=</data>\n\t\t\t\t<key>Identifier</key>\n\t\t\t\t<string>com.apple.iokit.IOAHCIBlockStorage</string>\n\t\t\t\t<key>Limit</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t\t<key>Mask</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>MaxKernel</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>MinKernel</key>\n\t\t\t\t<string>11.0.0</string>\n\t\t\t\t<key>Replace</key>\n\t\t\t\t<data>AAAAAAAAAAAAAAA=</data>\n\t\t\t\t<key>ReplaceMask</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>Skip</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t</dict>\n\t\t\t<dict>\n\t\t\t\t<key>Arch</key>\n\t\t\t\t<string>Any</string>\n\t\t\t\t<key>Base</key>\n\t\t\t\t<string>__ZN8AppleRTC18setupDateTimeAlarmEPK11RTCDateTime</string>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>Disable RTC wake scheduling</string>\n\t\t\t\t<key>Count</key>\n\t\t\t\t<integer>1</integer>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<false/>\n\t\t\t\t<key>Find</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>Identifier</key>\n\t\t\t\t<string>com.apple.driver.AppleRTC</string>\n\t\t\t\t<key>Limit</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t\t<key>Mask</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>MaxKernel</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>MinKernel</key>\n\t\t\t\t<string>19.0.0</string>\n\t\t\t\t<key>Replace</key>\n\t\t\t\t<data>ww==</data>\n\t\t\t\t<key>ReplaceMask</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>Skip</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t</dict>\n\t\t\t<dict>\n\t\t\t\t<key>Arch</key>\n\t\t\t\t<string>Any</string>\n\t\t\t\t<key>Base</key>\n\t\t\t\t<string>_AcpiOsVprintf</string>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>Disable ACPI logging</string>\n\t\t\t\t<key>Count</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<false/>\n\t\t\t\t<key>Find</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>Identifier</key>\n\t\t\t\t<string>com.apple.driver.AppleACPIPlatform</string>\n\t\t\t\t<key>Limit</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t\t<key>Mask</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>MaxKernel</key>\n\t\t\t\t<string>18.5.0</string>\n\t\t\t\t<key>MinKernel</key>\n\t\t\t\t<string>18.5.0</string>\n\t\t\t\t<key>Replace</key>\n\t\t\t\t<data>ww==</data>\n\t\t\t\t<key>ReplaceMask</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>Skip</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t</dict>\n\t\t\t<dict>\n\t\t\t\t<key>Arch</key>\n\t\t\t\t<string>x86_64</string>\n\t\t\t\t<key>Base</key>\n\t\t\t\t<string>__ZN11BCM5701Enet14getAdapterInfoEv</string>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>Broadcom BCM57785 patch</string>\n\t\t\t\t<key>Count</key>\n\t\t\t\t<integer>1</integer>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<false/>\n\t\t\t\t<key>Find</key>\n\t\t\t\t<data>6AAA//9miYMABQAA</data>\n\t\t\t\t<key>Identifier</key>\n\t\t\t\t<string>com.apple.iokit.AppleBCM5701Ethernet</string>\n\t\t\t\t<key>Limit</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t\t<key>Mask</key>\n\t\t\t\t<data>/wAA////////////</data>\n\t\t\t\t<key>MaxKernel</key>\n\t\t\t\t<string>19.9.9</string>\n\t\t\t\t<key>MinKernel</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>Replace</key>\n\t\t\t\t<data>uLQWAABmiYMABQAA</data>\n\t\t\t\t<key>ReplaceMask</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>Skip</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t</dict>\n\t\t\t<dict>\n\t\t\t\t<key>Arch</key>\n\t\t\t\t<string>x86_64</string>\n\t\t\t\t<key>Base</key>\n\t\t\t\t<string>__ZN24IOBluetoothHCIController5startEP9IOService</string>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>Disable Bluetooth entirely</string>\n\t\t\t\t<key>Count</key>\n\t\t\t\t<integer>1</integer>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<false/>\n\t\t\t\t<key>Find</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>Identifier</key>\n\t\t\t\t<string>com.apple.iokit.IOBluetoothFamily</string>\n\t\t\t\t<key>Limit</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t\t<key>Mask</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>MaxKernel</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>MinKernel</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>Replace</key>\n\t\t\t\t<data>ww==</data>\n\t\t\t\t<key>ReplaceMask</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>Skip</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t</dict>\n\t\t\t<dict>\n\t\t\t\t<key>Arch</key>\n\t\t\t\t<string>x86_64</string>\n\t\t\t\t<key>Base</key>\n\t\t\t\t<string>_panic</string>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>Send panic string to serial port</string>\n\t\t\t\t<key>Count</key>\n\t\t\t\t<integer>1</integer>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<false/>\n\t\t\t\t<key>Find</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>Identifier</key>\n\t\t\t\t<string>kernel</string>\n\t\t\t\t<key>Limit</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t\t<key>Mask</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>MaxKernel</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>MinKernel</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>Replace</key>\n\t\t\t\t<data>MfaKD4TJdQT/xrEKZrr9A+yoIHT7Zrr4A4jI7kj/x4X2dN/r/g==</data>\n\t\t\t\t<key>ReplaceMask</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>Skip</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t</dict>\n\t\t\t<dict>\n\t\t\t\t<key>Arch</key>\n\t\t\t\t<string>x86_64</string>\n\t\t\t\t<key>Base</key>\n\t\t\t\t<string>_kernel_debug_string_early</string>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>Send early prints to serial port</string>\n\t\t\t\t<key>Count</key>\n\t\t\t\t<integer>1</integer>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<false/>\n\t\t\t\t<key>Find</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>Identifier</key>\n\t\t\t\t<string>kernel</string>\n\t\t\t\t<key>Limit</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t\t<key>Mask</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>MaxKernel</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>MinKernel</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>Replace</key>\n\t\t\t\t<data>MfaKD4TJdQT/xrEKZrr9A+yoIHT7Zrr4A4jI7kj/x4X2dN/D</data>\n\t\t\t\t<key>ReplaceMask</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>Skip</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t</dict>\n\t\t\t<dict>\n\t\t\t\t<key>Arch</key>\n\t\t\t\t<string>Any</string>\n\t\t\t\t<key>Base</key>\n\t\t\t\t<string>_disable_serial_output</string>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>Enable early serial output on RELEASE kernel</string>\n\t\t\t\t<key>Count</key>\n\t\t\t\t<integer>1</integer>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<false/>\n\t\t\t\t<key>Find</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>Identifier</key>\n\t\t\t\t<string>kernel</string>\n\t\t\t\t<key>Limit</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t\t<key>Mask</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>MaxKernel</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>MinKernel</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>Replace</key>\n\t\t\t\t<data>AA==</data>\n\t\t\t\t<key>ReplaceMask</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>Skip</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t</dict>\n\t\t\t<dict>\n\t\t\t\t<key>Arch</key>\n\t\t\t\t<string>Any</string>\n\t\t\t\t<key>Base</key>\n\t\t\t\t<string>_vstart</string>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>Print K and dead loop</string>\n\t\t\t\t<key>Count</key>\n\t\t\t\t<integer>1</integer>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<false/>\n\t\t\t\t<key>Find</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>Identifier</key>\n\t\t\t\t<string>kernel</string>\n\t\t\t\t<key>Limit</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t\t<key>Mask</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>MaxKernel</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>MinKernel</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>Replace</key>\n\t\t\t\t<data>sUtmuv0D7KggdPtmuvgDiMjusQpmuv0D7KggdPtmuvgDiMju6/4=</data>\n\t\t\t\t<key>ReplaceMask</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>Skip</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t</dict>\n\t\t\t<dict>\n\t\t\t\t<key>Arch</key>\n\t\t\t\t<string>Any</string>\n\t\t\t\t<key>Base</key>\n\t\t\t\t<string>_vstart</string>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>Early reboot</string>\n\t\t\t\t<key>Count</key>\n\t\t\t\t<integer>1</integer>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<false/>\n\t\t\t\t<key>Find</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>Identifier</key>\n\t\t\t\t<string>kernel</string>\n\t\t\t\t<key>Limit</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t\t<key>Mask</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>MaxKernel</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>MinKernel</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>Replace</key>\n\t\t\t\t<data>McCwBrr5DAAA7uv+</data>\n\t\t\t\t<key>ReplaceMask</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>Skip</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t</dict>\n\t\t\t<dict>\n\t\t\t\t<key>Arch</key>\n\t\t\t\t<string>x86_64</string>\n\t\t\t\t<key>Base</key>\n\t\t\t\t<string>_early_random</string>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>SurPlus v1 - PART 1 of 2 - Patch read_erandom (inlined in _early_random)</string>\n\t\t\t\t<key>Count</key>\n\t\t\t\t<integer>1</integer>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<false/>\n\t\t\t\t<key>Find</key>\n\t\t\t\t<data>AHQjSIs=</data>\n\t\t\t\t<key>Identifier</key>\n\t\t\t\t<string>kernel</string>\n\t\t\t\t<key>Limit</key>\n\t\t\t\t<integer>800</integer>\n\t\t\t\t<key>Mask</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>MaxKernel</key>\n\t\t\t\t<string>21.1.0</string>\n\t\t\t\t<key>MinKernel</key>\n\t\t\t\t<string>20.4.0</string>\n\t\t\t\t<key>Replace</key>\n\t\t\t\t<data>AOsjSIs=</data>\n\t\t\t\t<key>ReplaceMask</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>Skip</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t</dict>\n\t\t\t<dict>\n\t\t\t\t<key>Arch</key>\n\t\t\t\t<string>x86_64</string>\n\t\t\t\t<key>Base</key>\n\t\t\t\t<string>_register_and_init_prng</string>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>SurPlus v1 - PART 2 of 2 - Patch register_and_init_prng</string>\n\t\t\t\t<key>Count</key>\n\t\t\t\t<integer>1</integer>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<false/>\n\t\t\t\t<key>Find</key>\n\t\t\t\t<data>ukgBAAAx9g==</data>\n\t\t\t\t<key>Identifier</key>\n\t\t\t\t<string>kernel</string>\n\t\t\t\t<key>Limit</key>\n\t\t\t\t<integer>256</integer>\n\t\t\t\t<key>Mask</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>MaxKernel</key>\n\t\t\t\t<string>21.1.0</string>\n\t\t\t\t<key>MinKernel</key>\n\t\t\t\t<string>20.4.0</string>\n\t\t\t\t<key>Replace</key>\n\t\t\t\t<data>ukgBAADrBQ==</data>\n\t\t\t\t<key>ReplaceMask</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>Skip</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t</dict>\n\t\t</array>\n\t\t<key>Quirks</key>\n\t\t<dict>\n\t\t\t<key>AppleCpuPmCfgLock</key>\n\t\t\t<false/>\n\t\t\t<key>AppleXcpmCfgLock</key>\n\t\t\t<false/>\n\t\t\t<key>AppleXcpmExtraMsrs</key>\n\t\t\t<false/>\n\t\t\t<key>AppleXcpmForceBoost</key>\n\t\t\t<false/>\n\t\t\t<key>CustomPciSerialDevice</key>\n\t\t\t<false/>\n\t\t\t<key>CustomSMBIOSGuid</key>\n\t\t\t<false/>\n\t\t\t<key>DisableIoMapper</key>\n\t\t\t<false/>\n\t\t\t<key>DisableIoMapperMapping</key>\n\t\t\t<false/>\n\t\t\t<key>DisableLinkeditJettison</key>\n\t\t\t<true/>\n\t\t\t<key>DisableRtcChecksum</key>\n\t\t\t<false/>\n\t\t\t<key>ExtendBTFeatureFlags</key>\n\t\t\t<false/>\n\t\t\t<key>ExternalDiskIcons</key>\n\t\t\t<false/>\n\t\t\t<key>ForceAquantiaEthernet</key>\n\t\t\t<false/>\n\t\t\t<key>ForceSecureBootScheme</key>\n\t\t\t<true/>\n\t\t\t<key>IncreasePciBarSize</key>\n\t\t\t<false/>\n\t\t\t<key>LapicKernelPanic</key>\n\t\t\t<false/>\n\t\t\t<key>LegacyCommpage</key>\n\t\t\t<false/>\n\t\t\t<key>PanicNoKextDump</key>\n\t\t\t<true/>\n\t\t\t<key>PowerTimeoutKernelPanic</key>\n\t\t\t<true/>\n\t\t\t<key>ProvideCurrentCpuInfo</key>\n\t\t\t<true/>\n\t\t\t<key>SetApfsTrimTimeout</key>\n\t\t\t<integer>-1</integer>\n\t\t\t<key>ThirdPartyDrives</key>\n\t\t\t<false/>\n\t\t\t<key>XhciPortLimit</key>\n\t\t\t<false/>\n\t\t</dict>\n\t\t<key>Scheme</key>\n\t\t<dict>\n\t\t\t<key>CustomKernel</key>\n\t\t\t<false/>\n\t\t\t<key>FuzzyMatch</key>\n\t\t\t<true/>\n\t\t\t<key>KernelArch</key>\n\t\t\t<string>Auto</string>\n\t\t\t<key>KernelCache</key>\n\t\t\t<string>Auto</string>\n\t\t</dict>\n\t</dict>\n\t<key>Misc</key>\n\t<dict>\n\t\t<key>BlessOverride</key>\n\t\t<array/>\n\t\t<key>Boot</key>\n\t\t<dict>\n\t\t\t<key>ConsoleAttributes</key>\n\t\t\t<integer>0</integer>\n\t\t\t<key>HibernateMode</key>\n\t\t\t<string>None</string>\n\t\t\t<key>HibernateSkipsPicker</key>\n\t\t\t<false/>\n\t\t\t<key>HideAuxiliary</key>\n\t\t\t<false/>\n\t\t\t<key>InstanceIdentifier</key>\n\t\t\t<string></string>\n\t\t\t<key>LauncherOption</key>\n\t\t\t<string>Disabled</string>\n\t\t\t<key>LauncherPath</key>\n\t\t\t<string>Default</string>\n\t\t\t<key>PickerAttributes</key>\n\t\t\t<integer>17</integer>\n\t\t\t<key>PickerAudioAssist</key>\n\t\t\t<false/>\n\t\t\t<key>PickerMode</key>\n\t\t\t<string>External</string>\n\t\t\t<key>PickerVariant</key>\n\t\t\t<string>Auto</string>\n\t\t\t<key>PollAppleHotKeys</key>\n\t\t\t<true/>\n\t\t\t<key>ShowPicker</key>\n\t\t\t<true/>\n\t\t\t<key>TakeoffDelay</key>\n\t\t\t<integer>0</integer>\n\t\t\t<key>Timeout</key>\n\t\t\t<integer>5</integer>\n\t\t</dict>\n\t\t<key>Debug</key>\n\t\t<dict>\n\t\t\t<key>AppleDebug</key>\n\t\t\t<true/>\n\t\t\t<key>ApplePanic</key>\n\t\t\t<true/>\n\t\t\t<key>DisableWatchDog</key>\n\t\t\t<true/>\n\t\t\t<key>DisplayDelay</key>\n\t\t\t<integer>0</integer>\n\t\t\t<key>DisplayLevel</key>\n\t\t\t<integer>2147483714</integer>\n\t\t\t<key>LogModules</key>\n\t\t\t<string>*</string>\n\t\t\t<key>SysReport</key>\n\t\t\t<false/>\n\t\t\t<key>Target</key>\n\t\t\t<integer>67</integer>\n\t\t</dict>\n\t\t<key>Entries</key>\n\t\t<array>\n\t\t\t<dict>\n\t\t\t\t<key>Arguments</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>Auxiliary</key>\n\t\t\t\t<false/>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>Not signed for security reasons</string>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<false/>\n\t\t\t\t<key>Flavour</key>\n\t\t\t\t<string>Auto</string>\n\t\t\t\t<key>Name</key>\n\t\t\t\t<string>CustomOS</string>\n\t\t\t\t<key>Path</key>\n\t\t\t\t<string>PciRoot(0x0)/Pci(0x1,0x1)/Pci(0x0,0x0)/NVMe(0x1,11-22-33-44-55-66-77-88)/HD(1,GPT,00000000-0000-0000-0000-000000000000,0x800,0x64000)/\\EFI\\BOOT\\BOOTX64.EFI</string>\n\t\t\t\t<key>TextMode</key>\n\t\t\t\t<false/>\n\t\t\t</dict>\n\t\t</array>\n\t\t<key>Security</key>\n\t\t<dict>\n\t\t\t<key>AllowSetDefault</key>\n\t\t\t<true/>\n\t\t\t<key>ApECID</key>\n\t\t\t<integer>0</integer>\n\t\t\t<key>AuthRestart</key>\n\t\t\t<false/>\n\t\t\t<key>BlacklistAppleUpdate</key>\n\t\t\t<true/>\n\t\t\t<key>DmgLoading</key>\n\t\t\t<string>Signed</string>\n\t\t\t<key>EnablePassword</key>\n\t\t\t<false/>\n\t\t\t<key>ExposeSensitiveData</key>\n\t\t\t<integer>6</integer>\n\t\t\t<key>HaltLevel</key>\n\t\t\t<integer>2147483648</integer>\n\t\t\t<key>PasswordHash</key>\n\t\t\t<data></data>\n\t\t\t<key>PasswordSalt</key>\n\t\t\t<data></data>\n\t\t\t<key>ScanPolicy</key>\n\t\t\t<integer>0</integer>\n\t\t\t<key>SecureBootModel</key>\n\t\t\t<string>Disabled</string>\n\t\t\t<key>Vault</key>\n\t\t\t<string>Optional</string>\n\t\t</dict>\n\t\t<key>Serial</key>\n\t\t<dict>\n\t\t\t<key>Init</key>\n\t\t\t<false/>\n\t\t\t<key>Override</key>\n\t\t\t<false/>\n\t\t</dict>\n\t\t<key>Tools</key>\n\t\t<array>\n\t\t\t<dict>\n\t\t\t\t<key>Arguments</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>Auxiliary</key>\n\t\t\t\t<true/>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>OpenShell.efi</string>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<true/>\n\t\t\t\t<key>Flavour</key>\n\t\t\t\t<string>OpenShell:UEFIShell:Shell</string>\n\t\t\t\t<key>FullNvramAccess</key>\n\t\t\t\t<false/>\n\t\t\t\t<key>Name</key>\n\t\t\t\t<string>OpenShell.efi</string>\n\t\t\t\t<key>Path</key>\n\t\t\t\t<string>OpenShell.efi</string>\n\t\t\t\t<key>RealPath</key>\n\t\t\t\t<false/>\n\t\t\t\t<key>TextMode</key>\n\t\t\t\t<false/>\n\t\t\t</dict>\n\t\t</array>\n\t</dict>\n\t<key>NVRAM</key>\n\t<dict>\n\t\t<key>Add</key>\n\t\t<dict>\n\t\t\t<key>4D1EDE05-38C7-4A6A-9CC6-4BCCA8B38C14</key>\n\t\t\t<dict>\n\t\t\t\t<key>DefaultBackgroundColor</key>\n\t\t\t\t<data>AAAAAA==</data>\n\t\t\t</dict>\n\t\t\t<key>4D1FDA02-38C7-4A6A-9CC6-4BCCA8B30102</key>\n\t\t\t<dict>\n\t\t\t\t<key>rtc-blacklist</key>\n\t\t\t\t<data></data>\n\t\t\t</dict>\n\t\t\t<key>7C436110-AB2A-4BBB-A880-FE41995C9F82</key>\n\t\t\t<dict>\n\t\t\t\t<key>#INFO (prev-lang:kbd)</key>\n\t\t\t\t<string>en:252 (ABC), set 656e3a323532</string>\n\t\t\t\t<key>ForceDisplayRotationInEFI</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t\t<key>SystemAudioVolume</key>\n\t\t\t\t<data>Rg==</data>\n\t\t\t\t<key>boot-args</key>\n\t\t\t\t<string>-v keepsyms=1 debug=0x100</string>\n\t\t\t\t<key>csr-active-config</key>\n\t\t\t\t<data>AAAAAA==</data>\n\t\t\t\t<key>prev-lang:kbd</key>\n\t\t\t\t<data>ZW4tVVM6MA==</data>\n\t\t\t\t<key>run-efi-updater</key>\n\t\t\t\t<string>No</string>\n\t\t\t</dict>\n\t\t</dict>\n\t\t<key>Delete</key>\n\t\t<dict>\n\t\t\t<key>4D1EDE05-38C7-4A6A-9CC6-4BCCA8B38C14</key>\n\t\t\t<array>\n\t\t\t\t<string>DefaultBackgroundColor</string>\n\t\t\t</array>\n\t\t\t<key>4D1FDA02-38C7-4A6A-9CC6-4BCCA8B30102</key>\n\t\t\t<array>\n\t\t\t\t<string>rtc-blacklist</string>\n\t\t\t</array>\n\t\t\t<key>7C436110-AB2A-4BBB-A880-FE41995C9F82</key>\n\t\t\t<array>\n\t\t\t\t<string>boot-args</string>\n\t\t\t\t<string>ForceDisplayRotationInEFI</string>\n\t\t\t</array>\n\t\t</dict>\n\t\t<key>LegacyOverwrite</key>\n\t\t<false/>\n\t\t<key>LegacySchema</key>\n\t\t<dict>\n\t\t\t<key>7C436110-AB2A-4BBB-A880-FE41995C9F82</key>\n\t\t\t<array>\n\t\t\t\t<string>EFILoginHiDPI</string>\n\t\t\t\t<string>EFIBluetoothDelay</string>\n\t\t\t\t<string>LocationServicesEnabled</string>\n\t\t\t\t<string>SystemAudioVolume</string>\n\t\t\t\t<string>SystemAudioVolumeDB</string>\n\t\t\t\t<string>SystemAudioVolumeSaved</string>\n\t\t\t\t<string>bluetoothActiveControllerInfo</string>\n\t\t\t\t<string>bluetoothInternalControllerInfo</string>\n\t\t\t\t<string>flagstate</string>\n\t\t\t\t<string>fmm-computer-name</string>\n\t\t\t\t<string>fmm-mobileme-token-FMM</string>\n\t\t\t\t<string>fmm-mobileme-token-FMM-BridgeHasAccount</string>\n\t\t\t\t<string>nvda_drv</string>\n\t\t\t\t<string>prev-lang:kbd</string>\n\t\t\t\t<string>backlight-level</string>\n\t\t\t\t<string>BootCampHD</string>\n\t\t\t</array>\n\t\t\t<key>8BE4DF61-93CA-11D2-AA0D-00E098032B8C</key>\n\t\t\t<array>\n\t\t\t\t<string>Boot0080</string>\n\t\t\t\t<string>Boot0081</string>\n\t\t\t\t<string>Boot0082</string>\n\t\t\t\t<string>BootNext</string>\n\t\t\t\t<string>BootOrder</string>\n\t\t\t</array>\n\t\t</dict>\n\t\t<key>WriteFlash</key>\n\t\t<true/>\n\t</dict>\n\t<key>PlatformInfo</key>\n\t<dict>\n\t\t<key>Automatic</key>\n\t\t<true/>\n\t\t<key>CustomMemory</key>\n\t\t<false/>\n\t\t<key>Generic</key>\n\t\t<dict>\n\t\t\t<key>AdviseFeatures</key>\n\t\t\t<false/>\n\t\t\t<key>MLB</key>\n\t\t\t<string>M0000000000000001</string>\n\t\t\t<key>MaxBIOSVersion</key>\n\t\t\t<false/>\n\t\t\t<key>ProcessorType</key>\n\t\t\t<integer>0</integer>\n\t\t\t<key>ROM</key>\n\t\t\t<data>ESIzRFVm</data>\n\t\t\t<key>SpoofVendor</key>\n\t\t\t<true/>\n\t\t\t<key>SystemMemoryStatus</key>\n\t\t\t<string>Auto</string>\n\t\t\t<key>SystemProductName</key>\n\t\t\t<string>iMac19,1</string>\n\t\t\t<key>SystemSerialNumber</key>\n\t\t\t<string>W00000000001</string>\n\t\t\t<key>SystemUUID</key>\n\t\t\t<string>00000000-0000-0000-0000-000000000000</string>\n\t\t</dict>\n\t\t<key>UpdateDataHub</key>\n\t\t<true/>\n\t\t<key>UpdateNVRAM</key>\n\t\t<true/>\n\t\t<key>UpdateSMBIOS</key>\n\t\t<true/>\n\t\t<key>UpdateSMBIOSMode</key>\n\t\t<string>Create</string>\n\t\t<key>UseRawUuidEncoding</key>\n\t\t<false/>\n\t</dict>\n\t<key>UEFI</key>\n\t<dict>\n\t\t<key>APFS</key>\n\t\t<dict>\n\t\t\t<key>EnableJumpstart</key>\n\t\t\t<true/>\n\t\t\t<key>GlobalConnect</key>\n\t\t\t<false/>\n\t\t\t<key>HideVerbose</key>\n\t\t\t<true/>\n\t\t\t<key>JumpstartHotPlug</key>\n\t\t\t<false/>\n\t\t\t<key>MinDate</key>\n\t\t\t<integer>-1</integer>\n\t\t\t<key>MinVersion</key>\n\t\t\t<integer>-1</integer>\n\t\t</dict>\n\t\t<key>AppleInput</key>\n\t\t<dict>\n\t\t\t<key>AppleEvent</key>\n\t\t\t<string>Builtin</string>\n\t\t\t<key>CustomDelays</key>\n\t\t\t<false/>\n\t\t\t<key>GraphicsInputMirroring</key>\n\t\t\t<true/>\n\t\t\t<key>KeyInitialDelay</key>\n\t\t\t<integer>50</integer>\n\t\t\t<key>KeySubsequentDelay</key>\n\t\t\t<integer>5</integer>\n\t\t\t<key>PointerDwellClickTimeout</key>\n\t\t\t<integer>0</integer>\n\t\t\t<key>PointerDwellDoubleClickTimeout</key>\n\t\t\t<integer>0</integer>\n\t\t\t<key>PointerDwellRadius</key>\n\t\t\t<integer>0</integer>\n\t\t\t<key>PointerPollMask</key>\n\t\t\t<integer>-1</integer>\n\t\t\t<key>PointerPollMax</key>\n\t\t\t<integer>80</integer>\n\t\t\t<key>PointerPollMin</key>\n\t\t\t<integer>10</integer>\n\t\t\t<key>PointerSpeedDiv</key>\n\t\t\t<integer>1</integer>\n\t\t\t<key>PointerSpeedMul</key>\n\t\t\t<integer>1</integer>\n\t\t</dict>\n\t\t<key>Audio</key>\n\t\t<dict>\n\t\t\t<key>AudioCodec</key>\n\t\t\t<integer>0</integer>\n\t\t\t<key>AudioDevice</key>\n\t\t\t<string>PciRoot(0x0)/Pci(0x1b,0x0)</string>\n\t\t\t<key>AudioOutMask</key>\n\t\t\t<integer>1</integer>\n\t\t\t<key>AudioSupport</key>\n\t\t\t<false/>\n\t\t\t<key>DisconnectHda</key>\n\t\t\t<false/>\n\t\t\t<key>MaximumGain</key>\n\t\t\t<integer>-15</integer>\n\t\t\t<key>MinimumAssistGain</key>\n\t\t\t<integer>-30</integer>\n\t\t\t<key>MinimumAudibleGain</key>\n\t\t\t<integer>-55</integer>\n\t\t\t<key>PlayChime</key>\n\t\t\t<string>Auto</string>\n\t\t\t<key>ResetTrafficClass</key>\n\t\t\t<false/>\n\t\t\t<key>SetupDelay</key>\n\t\t\t<integer>0</integer>\n\t\t</dict>\n\t\t<key>ConnectDrivers</key>\n\t\t<true/>\n\t\t<key>Drivers</key>\n\t\t<array>\n\t\t\t<dict>\n\t\t\t\t<key>Arguments</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>OpenCanopy.efi</string>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<true/>\n\t\t\t\t<key>LoadEarly</key>\n\t\t\t\t<false/>\n\t\t\t\t<key>Path</key>\n\t\t\t\t<string>OpenCanopy.efi</string>\n\t\t\t</dict>\n\t\t\t<dict>\n\t\t\t\t<key>Arguments</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>OpenHfsPlus.efi</string>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<true/>\n\t\t\t\t<key>LoadEarly</key>\n\t\t\t\t<false/>\n\t\t\t\t<key>Path</key>\n\t\t\t\t<string>OpenHfsPlus.efi</string>\n\t\t\t</dict>\n\t\t\t<dict>\n\t\t\t\t<key>Arguments</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>OpenRuntime.efi</string>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<true/>\n\t\t\t\t<key>LoadEarly</key>\n\t\t\t\t<false/>\n\t\t\t\t<key>Path</key>\n\t\t\t\t<string>OpenRuntime.efi</string>\n\t\t\t</dict>\n\t\t\t<dict>\n\t\t\t\t<key>Arguments</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>ResetNvramEntry.efi</string>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<true/>\n\t\t\t\t<key>LoadEarly</key>\n\t\t\t\t<false/>\n\t\t\t\t<key>Path</key>\n\t\t\t\t<string>ResetNvramEntry.efi</string>\n\t\t\t</dict>\n\t\t\t<dict>\n\t\t\t\t<key>Arguments</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>ToggleSipEntry.efi</string>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<true/>\n\t\t\t\t<key>LoadEarly</key>\n\t\t\t\t<false/>\n\t\t\t\t<key>Path</key>\n\t\t\t\t<string>ToggleSipEntry.efi</string>\n\t\t\t</dict>\n\t\t</array>\n\t\t<key>Input</key>\n\t\t<dict>\n\t\t\t<key>KeyFiltering</key>\n\t\t\t<false/>\n\t\t\t<key>KeyForgetThreshold</key>\n\t\t\t<integer>5</integer>\n\t\t\t<key>KeySupport</key>\n\t\t\t<true/>\n\t\t\t<key>KeySupportMode</key>\n\t\t\t<string>Auto</string>\n\t\t\t<key>KeySwap</key>\n\t\t\t<false/>\n\t\t\t<key>PointerSupport</key>\n\t\t\t<false/>\n\t\t\t<key>PointerSupportMode</key>\n\t\t\t<string>ASUS</string>\n\t\t\t<key>TimerResolution</key>\n\t\t\t<integer>50000</integer>\n\t\t</dict>\n\t\t<key>Output</key>\n\t\t<dict>\n\t\t\t<key>ClearScreenOnModeSwitch</key>\n\t\t\t<false/>\n\t\t\t<key>ConsoleFont</key>\n\t\t\t<string></string>\n\t\t\t<key>ConsoleMode</key>\n\t\t\t<string></string>\n\t\t\t<key>DirectGopRendering</key>\n\t\t\t<false/>\n\t\t\t<key>ForceResolution</key>\n\t\t\t<false/>\n\t\t\t<key>GopBurstMode</key>\n\t\t\t<false/>\n\t\t\t<key>GopPassThrough</key>\n\t\t\t<string>Disabled</string>\n\t\t\t<key>IgnoreTextInGraphics</key>\n\t\t\t<false/>\n\t\t\t<key>InitialMode</key>\n\t\t\t<string>Auto</string>\n\t\t\t<key>ProvideConsoleGop</key>\n\t\t\t<true/>\n\t\t\t<key>ReconnectGraphicsOnConnect</key>\n\t\t\t<false/>\n\t\t\t<key>ReconnectOnResChange</key>\n\t\t\t<false/>\n\t\t\t<key>ReplaceTabWithSpace</key>\n\t\t\t<false/>\n\t\t\t<key>Resolution</key>\n\t\t\t<string></string>\n\t\t\t<key>SanitiseClearScreen</key>\n\t\t\t<false/>\n\t\t\t<key>TextRenderer</key>\n\t\t\t<string>BuiltinGraphics</string>\n\t\t\t<key>UIScale</key>\n\t\t\t<integer>0</integer>\n\t\t\t<key>UgaPassThrough</key>\n\t\t\t<false/>\n\t\t</dict>\n\t\t<key>ProtocolOverrides</key>\n\t\t<dict>\n\t\t\t<key>AppleAudio</key>\n\t\t\t<false/>\n\t\t\t<key>AppleBootPolicy</key>\n\t\t\t<false/>\n\t\t\t<key>AppleDebugLog</key>\n\t\t\t<false/>\n\t\t\t<key>AppleEg2Info</key>\n\t\t\t<false/>\n\t\t\t<key>AppleFramebufferInfo</key>\n\t\t\t<false/>\n\t\t\t<key>AppleImageConversion</key>\n\t\t\t<false/>\n\t\t\t<key>AppleImg4Verification</key>\n\t\t\t<false/>\n\t\t\t<key>AppleKeyMap</key>\n\t\t\t<false/>\n\t\t\t<key>AppleRtcRam</key>\n\t\t\t<false/>\n\t\t\t<key>AppleSecureBoot</key>\n\t\t\t<false/>\n\t\t\t<key>AppleSmcIo</key>\n\t\t\t<false/>\n\t\t\t<key>AppleUserInterfaceTheme</key>\n\t\t\t<false/>\n\t\t\t<key>DataHub</key>\n\t\t\t<false/>\n\t\t\t<key>DeviceProperties</key>\n\t\t\t<false/>\n\t\t\t<key>FirmwareVolume</key>\n\t\t\t<true/>\n\t\t\t<key>HashServices</key>\n\t\t\t<false/>\n\t\t\t<key>OSInfo</key>\n\t\t\t<false/>\n\t\t\t<key>PciIo</key>\n\t\t\t<false/>\n\t\t\t<key>UnicodeCollation</key>\n\t\t\t<false/>\n\t\t</dict>\n\t\t<key>Quirks</key>\n\t\t<dict>\n\t\t\t<key>ActivateHpetSupport</key>\n\t\t\t<false/>\n\t\t\t<key>DisableSecurityPolicy</key>\n\t\t\t<false/>\n\t\t\t<key>EnableVectorAcceleration</key>\n\t\t\t<true/>\n\t\t\t<key>EnableVmx</key>\n\t\t\t<false/>\n\t\t\t<key>ExitBootServicesDelay</key>\n\t\t\t<integer>0</integer>\n\t\t\t<key>ForceOcWriteFlash</key>\n\t\t\t<false/>\n\t\t\t<key>ForgeUefiSupport</key>\n\t\t\t<false/>\n\t\t\t<key>IgnoreInvalidFlexRatio</key>\n\t\t\t<false/>\n\t\t\t<key>ReleaseUsbOwnership</key>\n\t\t\t<false/>\n\t\t\t<key>ReloadOptionRoms</key>\n\t\t\t<false/>\n\t\t\t<key>RequestBootVarRouting</key>\n\t\t\t<true/>\n\t\t\t<key>ResizeGpuBars</key>\n\t\t\t<integer>-1</integer>\n\t\t\t<key>ResizeUsePciRbIo</key>\n\t\t\t<false/>\n\t\t\t<key>ShimRetainProtocol</key>\n\t\t\t<false/>\n\t\t\t<key>TscSyncTimeout</key>\n\t\t\t<integer>0</integer>\n\t\t\t<key>UnblockFsConnect</key>\n\t\t\t<false/>\n\t\t</dict>\n\t\t<key>ReservedMemory</key>\n\t\t<array>\n\t\t\t<dict>\n\t\t\t\t<key>Address</key>\n\t\t\t\t<integer>268435456</integer>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>HD3000: IGPU memory corruption errata</string>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<false/>\n\t\t\t\t<key>Size</key>\n\t\t\t\t<integer>268435456</integer>\n\t\t\t\t<key>Type</key>\n\t\t\t\t<string>Reserved</string>\n\t\t\t</dict>\n\t\t\t<dict>\n\t\t\t\t<key>Address</key>\n\t\t\t\t<integer>569344</integer>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>Fix black screen on wake from hibernation for Lenovo Thinkpad T490</string>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<false/>\n\t\t\t\t<key>Size</key>\n\t\t\t\t<integer>4096</integer>\n\t\t\t\t<key>Type</key>\n\t\t\t\t<string>RuntimeCode</string>\n\t\t\t</dict>\n\t\t</array>\n\t\t<key>Unload</key>\n\t\t<array/>\n\t</dict>\n</dict>\n</plist>\n"
  },
  {
    "path": "EFI_RELEASE/EFI/BOOT/.contentFlavour",
    "content": "OpenCore"
  },
  {
    "path": "EFI_RELEASE/EFI/BOOT/.contentVisibility",
    "content": "Disabled"
  },
  {
    "path": "EFI_RELEASE/EFI/OC/.contentFlavour",
    "content": "OpenCore"
  },
  {
    "path": "EFI_RELEASE/EFI/OC/.contentVisibility",
    "content": "Disabled"
  },
  {
    "path": "EFI_RELEASE/EFI/OC/Kexts/AppleMCEReporterDisabler.kext/Contents/Info.plist",
    "content": "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<!DOCTYPE plist PUBLIC \"-//Apple//DTD PLIST 1.0//EN\" \"http://www.apple.com/DTDs/PropertyList-1.0.dtd\">\n<plist version=\"1.0\">\n<dict>\n\t<key>CFBundleDevelopmentRegion</key>\n\t<string>English</string>\n\t<key>CFBundleGetInfoString</key>\n\t<string>AppleIntelMCEReporter Disabler 1.0, © 2019 by XLNC. All rights reserved.</string>\n\t<key>CFBundleIdentifier</key>\n\t<string>org.xlnc.disabler.MCEReporter</string>\n\t<key>CFBundleInfoDictionaryVersion</key>\n\t<string>6.0</string>\n\t<key>CFBundleName</key>\n\t<string>DisableAppleIntelMCEReporter</string>\n\t<key>CFBundlePackageType</key>\n\t<string>KEXT</string>\n\t<key>CFBundleVersion</key>\n\t<string>1.2</string>\n\t<key>IOKitPersonalities</key>\n\t<dict>\n\t\t<key>DisableMCEInterruptController</key>\n\t\t<dict>\n\t\t\t<key>CFBundleIdentifier</key>\n\t\t\t<string>com.apple.driver.AppleIntelMCEReporter</string>\n\t\t\t<key>IOClass</key>\n\t\t\t<string>IOService</string>\n\t\t\t<key>IOMatchCategory</key>\n\t\t\t<string>AppleIntelMCEInterruptController</string>\n\t\t\t<key>IOProbeScore</key>\n\t\t\t<integer>5000</integer>\n\t\t\t<key>IOPropertyMatch</key>\n\t\t\t<array>\n\t\t\t\t<dict>\n\t\t\t\t\t<key>board-id</key>\n\t\t\t\t\t<string>Mac-F60DEB81FF30ACF6</string>\n\t\t\t\t</dict>\n\t\t\t\t<dict>\n\t\t\t\t\t<key>board-id</key>\n\t\t\t\t\t<string>Mac-7BA5B2D9E42DDD94</string>\n\t\t\t\t</dict>\n\t\t\t\t<dict>\n\t\t\t\t\t<key>board-id</key>\n\t\t\t\t\t<string>Mac-27AD2F918AE68F61</string>\n\t\t\t\t</dict>\n\t\t\t</array>\n\t\t\t<key>IOProviderClass</key>\n\t\t\t<string>IOPlatformExpertDevice</string>\n\t\t</dict>\n\t\t<key>DisableMCEReporter</key>\n\t\t<dict>\n\t\t\t<key>CFBundleIdentifier</key>\n\t\t\t<string>com.apple.driver.AppleIntelMCEReporter</string>\n\t\t\t<key>IOClass</key>\n\t\t\t<string>IOService</string>\n\t\t\t<key>IOMatchCategory</key>\n\t\t\t<string>AppleIntelMCEReporter</string>\n\t\t\t<key>IOProbeScore</key>\n\t\t\t<integer>5000</integer>\n\t\t\t<key>IOProviderClass</key>\n\t\t\t<string>AppleIntelMCEInterruptNub</string>\n\t\t</dict>\n\t</dict>\n\t<key>OSBundleRequired</key>\n\t<string>Root</string>\n</dict>\n</plist>\n"
  },
  {
    "path": "EFI_RELEASE/EFI/OC/Kexts/Lilu.kext/Contents/Info.plist",
    "content": "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<!DOCTYPE plist PUBLIC \"-//Apple//DTD PLIST 1.0//EN\" \"http://www.apple.com/DTDs/PropertyList-1.0.dtd\">\n<plist version=\"1.0\">\n<dict>\n\t<key>BuildMachineOSBuild</key>\n\t<string>23H626</string>\n\t<key>CFBundleDevelopmentRegion</key>\n\t<string>en</string>\n\t<key>CFBundleExecutable</key>\n\t<string>Lilu</string>\n\t<key>CFBundleIdentifier</key>\n\t<string>as.vit9696.Lilu</string>\n\t<key>CFBundleInfoDictionaryVersion</key>\n\t<string>6.0</string>\n\t<key>CFBundleName</key>\n\t<string>Lilu</string>\n\t<key>CFBundlePackageType</key>\n\t<string>KEXT</string>\n\t<key>CFBundleShortVersionString</key>\n\t<string>1.7.1</string>\n\t<key>CFBundleSignature</key>\n\t<string>????</string>\n\t<key>CFBundleSupportedPlatforms</key>\n\t<array>\n\t\t<string>MacOSX</string>\n\t</array>\n\t<key>CFBundleVersion</key>\n\t<string>1.7.1</string>\n\t<key>DTCompiler</key>\n\t<string>com.apple.compilers.llvm.clang.1_0</string>\n\t<key>DTPlatformBuild</key>\n\t<string></string>\n\t<key>DTPlatformName</key>\n\t<string>macosx</string>\n\t<key>DTPlatformVersion</key>\n\t<string>14.2</string>\n\t<key>DTSDKBuild</key>\n\t<string>23C53</string>\n\t<key>DTSDKName</key>\n\t<string>macosx14.2</string>\n\t<key>DTXcode</key>\n\t<string>1520</string>\n\t<key>DTXcodeBuild</key>\n\t<string>15C500b</string>\n\t<key>IOKitPersonalities</key>\n\t<dict>\n\t\t<key>as.vit9696.Lilu</key>\n\t\t<dict>\n\t\t\t<key>CFBundleIdentifier</key>\n\t\t\t<string>as.vit9696.Lilu</string>\n\t\t\t<key>IOClass</key>\n\t\t\t<string>Lilu</string>\n\t\t\t<key>IOMatchCategory</key>\n\t\t\t<string>Lilu</string>\n\t\t\t<key>IOProviderClass</key>\n\t\t\t<string>IOResources</string>\n\t\t\t<key>IOResourceMatch</key>\n\t\t\t<string>IOBSD</string>\n\t\t</dict>\n\t</dict>\n\t<key>LSMinimumSystemVersion</key>\n\t<string>10.6</string>\n\t<key>NSHumanReadableCopyright</key>\n\t<string>Copyright © 2016-2020 vit9696. All rights reserved.</string>\n\t<key>OSBundleCompatibleVersion</key>\n\t<string>1.2.0</string>\n\t<key>OSBundleLibraries</key>\n\t<dict>\n\t\t<key>com.apple.kernel.6.0</key>\n\t\t<string>7.9.9</string>\n\t\t<key>com.apple.kpi.bsd</key>\n\t\t<string>8.0.0</string>\n\t\t<key>com.apple.kpi.iokit</key>\n\t\t<string>8.0.0</string>\n\t\t<key>com.apple.kpi.libkern</key>\n\t\t<string>8.0.0</string>\n\t\t<key>com.apple.kpi.mach</key>\n\t\t<string>8.0.0</string>\n\t\t<key>com.apple.kpi.unsupported</key>\n\t\t<string>8.0.0</string>\n\t</dict>\n\t<key>OSBundleLibraries_x86_64</key>\n\t<dict>\n\t\t<key>com.apple.kpi.bsd</key>\n\t\t<string>10.0.0</string>\n\t\t<key>com.apple.kpi.dsep</key>\n\t\t<string>10.0.0</string>\n\t\t<key>com.apple.kpi.iokit</key>\n\t\t<string>10.0.0</string>\n\t\t<key>com.apple.kpi.libkern</key>\n\t\t<string>10.0.0</string>\n\t\t<key>com.apple.kpi.mach</key>\n\t\t<string>10.0.0</string>\n\t\t<key>com.apple.kpi.unsupported</key>\n\t\t<string>10.0.0</string>\n\t</dict>\n\t<key>OSBundleRequired</key>\n\t<string>Root</string>\n</dict>\n</plist>\n"
  },
  {
    "path": "EFI_RELEASE/EFI/OC/Kexts/VirtualSMC.kext/Contents/Info.plist",
    "content": "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<!DOCTYPE plist PUBLIC \"-//Apple//DTD PLIST 1.0//EN\" \"http://www.apple.com/DTDs/PropertyList-1.0.dtd\">\n<plist version=\"1.0\">\n<dict>\n\t<key>BuildMachineOSBuild</key>\n\t<string>23H626</string>\n\t<key>CFBundleDevelopmentRegion</key>\n\t<string>en</string>\n\t<key>CFBundleExecutable</key>\n\t<string>VirtualSMC</string>\n\t<key>CFBundleIdentifier</key>\n\t<string>as.vit9696.VirtualSMC</string>\n\t<key>CFBundleInfoDictionaryVersion</key>\n\t<string>6.0</string>\n\t<key>CFBundleName</key>\n\t<string>VirtualSMC</string>\n\t<key>CFBundlePackageType</key>\n\t<string>KEXT</string>\n\t<key>CFBundleShortVersionString</key>\n\t<string>1.3.7</string>\n\t<key>CFBundleSignature</key>\n\t<string>????</string>\n\t<key>CFBundleSupportedPlatforms</key>\n\t<array>\n\t\t<string>MacOSX</string>\n\t</array>\n\t<key>CFBundleVersion</key>\n\t<string>1.3.7</string>\n\t<key>DTCompiler</key>\n\t<string>com.apple.compilers.llvm.clang.1_0</string>\n\t<key>DTPlatformBuild</key>\n\t<string></string>\n\t<key>DTPlatformName</key>\n\t<string>macosx</string>\n\t<key>DTPlatformVersion</key>\n\t<string>14.2</string>\n\t<key>DTSDKBuild</key>\n\t<string>23C53</string>\n\t<key>DTSDKName</key>\n\t<string>macosx14.2</string>\n\t<key>DTXcode</key>\n\t<string>1520</string>\n\t<key>DTXcodeBuild</key>\n\t<string>15C500b</string>\n\t<key>IOKitPersonalities</key>\n\t<dict>\n\t\t<key>as.vit9696.VirtualSMC</key>\n\t\t<dict>\n\t\t\t<key>CFBundleIdentifier</key>\n\t\t\t<string>as.vit9696.VirtualSMC</string>\n\t\t\t<key>IOClass</key>\n\t\t\t<string>VirtualSMC</string>\n\t\t\t<key>IODeviceMemory</key>\n\t\t\t<array>\n\t\t\t\t<array>\n\t\t\t\t\t<dict>\n\t\t\t\t\t\t<key>address</key>\n\t\t\t\t\t\t<integer>768</integer>\n\t\t\t\t\t\t<key>length</key>\n\t\t\t\t\t\t<integer>32</integer>\n\t\t\t\t\t</dict>\n\t\t\t\t</array>\n\t\t\t\t<array>\n\t\t\t\t\t<dict>\n\t\t\t\t\t\t<key>address</key>\n\t\t\t\t\t\t<integer>4277141504</integer>\n\t\t\t\t\t\t<key>length</key>\n\t\t\t\t\t\t<integer>65536</integer>\n\t\t\t\t\t</dict>\n\t\t\t\t</array>\n\t\t\t</array>\n\t\t\t<key>IOInterruptControllers</key>\n\t\t\t<array>\n\t\t\t\t<string>io-apic-0</string>\n\t\t\t</array>\n\t\t\t<key>IOInterruptSpecifiers</key>\n\t\t\t<array>\n\t\t\t\t<data>\n\t\t\t\tBgAAAAAAAAA=\n\t\t\t\t</data>\n\t\t\t</array>\n\t\t\t<key>IOMatchCategory</key>\n\t\t\t<string>IOACPIPlatformDevice</string>\n\t\t\t<key>IOName</key>\n\t\t\t<string>SMC</string>\n\t\t\t<key>IOProbeScore</key>\n\t\t\t<integer>60000</integer>\n\t\t\t<key>IOProviderClass</key>\n\t\t\t<string>AppleACPIPlatformExpert</string>\n\t\t\t<key>Keystore</key>\n\t\t\t<dict>\n\t\t\t\t<key>Generic</key>\n\t\t\t\t<array>\n\t\t\t\t\t<dict>\n\t\t\t\t\t\t<key>attr</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tiA==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t\t<key>comment</key>\n\t\t\t\t\t\t<string>Total fan number, this should be put to a plugin</string>\n\t\t\t\t\t\t<key>name</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tRk51bQ==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t\t<key>type</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tdWk4IA==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t\t<key>value</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tAA==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t</dict>\n\t\t\t\t\t<dict>\n\t\t\t\t\t\t<key>attr</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tgA==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t\t<key>comment</key>\n\t\t\t\t\t\t<string>CPU plimit</string>\n\t\t\t\t\t\t<key>name</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tTVNUYw==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t\t<key>type</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tdWk4IA==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t\t<key>value</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tAA==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t</dict>\n\t\t\t\t\t<dict>\n\t\t\t\t\t\t<key>attr</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tgA==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t\t<key>comment</key>\n\t\t\t\t\t\t<string>FAN plimit (supposedly)</string>\n\t\t\t\t\t\t<key>name</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tTVNUZg==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t\t<key>type</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tdWk4IA==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t\t<key>value</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tAA==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t</dict>\n\t\t\t\t\t<dict>\n\t\t\t\t\t\t<key>attr</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tgA==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t\t<key>comment</key>\n\t\t\t\t\t\t<string>Memory plimit</string>\n\t\t\t\t\t\t<key>name</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tTVNUbQ==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t\t<key>type</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tdWk4IA==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t\t<key>value</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tAA==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t</dict>\n\t\t\t\t\t<dict>\n\t\t\t\t\t\t<key>attr</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tgA==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t\t<key>comment</key>\n\t\t\t\t\t\t<string>This should be 1 on laptops, and is overriden by sensors</string>\n\t\t\t\t\t\t<key>name</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tQkFUUA==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t\t<key>type</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tZmxhZw==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t\t<key>value</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tAA==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t</dict>\n\t\t\t\t\t<dict>\n\t\t\t\t\t\t<key>attr</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tgA==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t\t<key>comment</key>\n\t\t\t\t\t\t<string>Only MacPros have custom illumination controllers</string>\n\t\t\t\t\t\t<key>name</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tTHNOTQ==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t\t<key>type</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tdWk4IA==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t\t<key>value</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tAA==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t</dict>\n\t\t\t\t</array>\n\t\t\t\t<key>GenericDesktopV1</key>\n\t\t\t\t<array/>\n\t\t\t\t<key>GenericDesktopV2</key>\n\t\t\t\t<array/>\n\t\t\t\t<key>GenericLaptopV1</key>\n\t\t\t\t<array/>\n\t\t\t\t<key>GenericLaptopV2</key>\n\t\t\t\t<array/>\n\t\t\t\t<key>GenericV1</key>\n\t\t\t\t<array>\n\t\t\t\t\t<dict>\n\t\t\t\t\t\t<key>attr</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tgA==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t\t<key>comment</key>\n\t\t\t\t\t\t<string>GPU plimit</string>\n\t\t\t\t\t\t<key>name</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tTVNUZw==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t\t<key>type</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tdWk4IA==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t\t<key>value</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tAA==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t</dict>\n\t\t\t\t</array>\n\t\t\t\t<key>GenericV2</key>\n\t\t\t\t<array>\n\t\t\t\t\t<dict>\n\t\t\t\t\t\t<key>attr</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tgA==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t\t<key>comment</key>\n\t\t\t\t\t\t<string>E plimit (???)</string>\n\t\t\t\t\t\t<key>name</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tTVNUZQ==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t\t<key>type</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tdWk4IA==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t\t<key>value</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tAA==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t</dict>\n\t\t\t\t\t<dict>\n\t\t\t\t\t\t<key>attr</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tgA==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t\t<key>comment</key>\n\t\t\t\t\t\t<string>I plimit (???)</string>\n\t\t\t\t\t\t<key>name</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tTVNUaQ==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t\t<key>type</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tdWk4IA==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t\t<key>value</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tAA==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t</dict>\n\t\t\t\t\t<dict>\n\t\t\t\t\t\t<key>attr</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tgA==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t\t<key>comment</key>\n\t\t\t\t\t\t<string>J plimit (???)</string>\n\t\t\t\t\t\t<key>name</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tTVNUag==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t\t<key>type</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tdWk4IA==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t\t<key>value</key>\n\t\t\t\t\t\t<data>\n\t\t\t\t\t\tAA==\n\t\t\t\t\t\t</data>\n\t\t\t\t\t</dict>\n\t\t\t\t</array>\n\t\t\t</dict>\n\t\t\t<key>ModelInfo</key>\n\t\t\t<dict>\n\t\t\t\t<key>GenericV1</key>\n\t\t\t\t<dict>\n\t\t\t\t\t<key>branch</key>\n\t\t\t\t\t<data>\n\t\t\t\t\tajUyAAAAAAA=\n\t\t\t\t\t</data>\n\t\t\t\t\t<key>hwname</key>\n\t\t\t\t\t<data>\n\t\t\t\t\tc21jLXBpa2V0b24A\n\t\t\t\t\t</data>\n\t\t\t\t\t<key>platform</key>\n\t\t\t\t\t<data>\n\t\t\t\t\tajUyAAAAAAA=\n\t\t\t\t\t</data>\n\t\t\t\t\t<key>rev</key>\n\t\t\t\t\t<data>\n\t\t\t\t\tAXQPAAAE\n\t\t\t\t\t</data>\n\t\t\t\t\t<key>revfb</key>\n\t\t\t\t\t<data>\n\t\t\t\t\tAXQPAAAE\n\t\t\t\t\t</data>\n\t\t\t\t\t<key>revfu</key>\n\t\t\t\t\t<data>\n\t\t\t\t\tAXQPAAAE\n\t\t\t\t\t</data>\n\t\t\t\t</dict>\n\t\t\t\t<key>GenericV2</key>\n\t\t\t\t<dict>\n\t\t\t\t\t<key>branch</key>\n\t\t\t\t\t<data>\n\t\t\t\t\tajUyAAAAAAA=\n\t\t\t\t\t</data>\n\t\t\t\t\t<key>hwname</key>\n\t\t\t\t\t<data>\n\t\t\t\t\tc21jLWh1cm9ucml2ZXIA\n\t\t\t\t\t</data>\n\t\t\t\t\t<key>platform</key>\n\t\t\t\t\t<data>\n\t\t\t\t\tajUyAAAAAAA=\n\t\t\t\t\t</data>\n\t\t\t\t\t<key>rev</key>\n\t\t\t\t\t<data>\n\t\t\t\t\tAigPAAAH\n\t\t\t\t\t</data>\n\t\t\t\t\t<key>revfb</key>\n\t\t\t\t\t<data>\n\t\t\t\t\tAigPAAAH\n\t\t\t\t\t</data>\n\t\t\t\t\t<key>revfu</key>\n\t\t\t\t\t<data>\n\t\t\t\t\tAigPAAAH\n\t\t\t\t\t</data>\n\t\t\t\t</dict>\n\t\t\t\t<key>GenericV3</key>\n\t\t\t\t<dict>\n\t\t\t\t\t<key>hwname</key>\n\t\t\t\t\t<data>\n\t\t\t\t\tc21jLWh1cm9ucml2ZXIA\n\t\t\t\t\t</data>\n\t\t\t\t\t<key>platform</key>\n\t\t\t\t\t<data>\n\t\t\t\t\tajUyAAAAAAA=\n\t\t\t\t\t</data>\n\t\t\t\t</dict>\n\t\t\t</dict>\n\t\t\t<key>_STA</key>\n\t\t\t<integer>11</integer>\n\t\t\t<key>name</key>\n\t\t\t<data>\n\t\t\tQVBQMDAwMQA=\n\t\t\t</data>\n\t\t</dict>\n\t</dict>\n\t<key>LSMinimumSystemVersion</key>\n\t<string>10.6</string>\n\t<key>NSHumanReadableCopyright</key>\n\t<string>Copyright © 2017 vit9696. All rights reserved.</string>\n\t<key>OSBundleCompatibleVersion</key>\n\t<string>1.0</string>\n\t<key>OSBundleLibraries</key>\n\t<dict>\n\t\t<key>as.vit9696.Lilu</key>\n\t\t<string>1.2.0</string>\n\t\t<key>com.apple.iokit.IOACPIFamily</key>\n\t\t<string>1.0.0d1</string>\n\t\t<key>com.apple.kernel.6.0</key>\n\t\t<string>7.9.9</string>\n\t\t<key>com.apple.kpi.bsd</key>\n\t\t<string>8.0.0</string>\n\t\t<key>com.apple.kpi.iokit</key>\n\t\t<string>8.0.0</string>\n\t\t<key>com.apple.kpi.libkern</key>\n\t\t<string>8.0.0</string>\n\t\t<key>com.apple.kpi.mach</key>\n\t\t<string>8.0.0</string>\n\t\t<key>com.apple.kpi.unsupported</key>\n\t\t<string>8.0.0</string>\n\t</dict>\n\t<key>OSBundleLibraries_x86_64</key>\n\t<dict>\n\t\t<key>as.vit9696.Lilu</key>\n\t\t<string>1.2.0</string>\n\t\t<key>com.apple.iokit.IOACPIFamily</key>\n\t\t<string>1.0.0d1</string>\n\t\t<key>com.apple.kpi.bsd</key>\n\t\t<string>10.0.0</string>\n\t\t<key>com.apple.kpi.iokit</key>\n\t\t<string>10.0.0</string>\n\t\t<key>com.apple.kpi.libkern</key>\n\t\t<string>10.0.0</string>\n\t\t<key>com.apple.kpi.mach</key>\n\t\t<string>10.0.0</string>\n\t\t<key>com.apple.kpi.unsupported</key>\n\t\t<string>10.0.0</string>\n\t</dict>\n\t<key>OSBundleRequired</key>\n\t<string>Root</string>\n</dict>\n</plist>\n"
  },
  {
    "path": "EFI_RELEASE/EFI/OC/Kexts/VoodooPS2Controller.kext/Contents/Info.plist",
    "content": "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<!DOCTYPE plist PUBLIC \"-//Apple//DTD PLIST 1.0//EN\" \"http://www.apple.com/DTDs/PropertyList-1.0.dtd\">\n<plist version=\"1.0\">\n<dict>\n\t<key>BuildMachineOSBuild</key>\n\t<string>23H222</string>\n\t<key>CFBundleExecutable</key>\n\t<string>VoodooPS2Controller</string>\n\t<key>CFBundleGetInfoString</key>\n\t<string>2.3.7, Copyright Apple Computer, Inc. 2000-2003, David Elliot 2007, RehabMan 2012-2013</string>\n\t<key>CFBundleIdentifier</key>\n\t<string>as.acidanthera.voodoo.driver.PS2Controller</string>\n\t<key>CFBundleInfoDictionaryVersion</key>\n\t<string>6.0</string>\n\t<key>CFBundleName</key>\n\t<string>Voodoo PS/2 Controller</string>\n\t<key>CFBundlePackageType</key>\n\t<string>KEXT</string>\n\t<key>CFBundleShortVersionString</key>\n\t<string>2.3.7</string>\n\t<key>CFBundleSignature</key>\n\t<string>????</string>\n\t<key>CFBundleSupportedPlatforms</key>\n\t<array>\n\t\t<string>MacOSX</string>\n\t</array>\n\t<key>CFBundleVersion</key>\n\t<string>2.3.7</string>\n\t<key>DTCompiler</key>\n\t<string>com.apple.compilers.llvm.clang.1_0</string>\n\t<key>DTPlatformBuild</key>\n\t<string></string>\n\t<key>DTPlatformName</key>\n\t<string>macosx</string>\n\t<key>DTPlatformVersion</key>\n\t<string>14.2</string>\n\t<key>DTSDKBuild</key>\n\t<string>23C53</string>\n\t<key>DTSDKName</key>\n\t<string>macosx14.2</string>\n\t<key>DTXcode</key>\n\t<string>1520</string>\n\t<key>DTXcodeBuild</key>\n\t<string>15C500b</string>\n\t<key>IOKitPersonalities</key>\n\t<dict>\n\t\t<key>ACPI PS/2 Nub</key>\n\t\t<dict>\n\t\t\t<key>CFBundleIdentifier</key>\n\t\t\t<string>as.acidanthera.voodoo.driver.PS2Controller</string>\n\t\t\t<key>FindMouseDelay</key>\n\t\t\t<integer>100</integer>\n\t\t\t<key>IOClass</key>\n\t\t\t<string>AppleACPIPS2Nub</string>\n\t\t\t<key>IONameMatch</key>\n\t\t\t<array>\n\t\t\t\t<string>PNP0303</string>\n\t\t\t\t<string>PNP030B</string>\n\t\t\t\t<string>PNP0320</string>\n\t\t\t</array>\n\t\t\t<key>IOProviderClass</key>\n\t\t\t<string>IOACPIPlatformDevice</string>\n\t\t\t<key>MouseNameMatch</key>\n\t\t\t<array>\n\t\t\t\t<string>PNP0F03</string>\n\t\t\t\t<string>PNP0F0B</string>\n\t\t\t\t<string>PNP0F0E</string>\n\t\t\t\t<string>PNP0F13</string>\n\t\t\t</array>\n\t\t</dict>\n\t\t<key>ApplePS2Controller</key>\n\t\t<dict>\n\t\t\t<key>CFBundleIdentifier</key>\n\t\t\t<string>as.acidanthera.voodoo.driver.PS2Controller</string>\n\t\t\t<key>IOClass</key>\n\t\t\t<string>ApplePS2Controller</string>\n\t\t\t<key>IONameMatch</key>\n\t\t\t<string>ps2controller</string>\n\t\t\t<key>IOProviderClass</key>\n\t\t\t<string>IOPlatformDevice</string>\n\t\t\t<key>Platform Profile</key>\n\t\t\t<dict>\n\t\t\t\t<key>Default</key>\n\t\t\t\t<dict>\n\t\t\t\t\t<key>MouseWakeFirst</key>\n\t\t\t\t\t<false/>\n\t\t\t\t\t<key>WakeDelay</key>\n\t\t\t\t\t<integer>10</integer>\n\t\t\t\t</dict>\n\t\t\t\t<key>HPQOEM</key>\n\t\t\t\t<dict>\n\t\t\t\t\t<key>1411</key>\n\t\t\t\t\t<string>ProBook</string>\n\t\t\t\t\t<key>1619</key>\n\t\t\t\t\t<string>ProBook</string>\n\t\t\t\t\t<key>161C</key>\n\t\t\t\t\t<string>ProBook</string>\n\t\t\t\t\t<key>164F</key>\n\t\t\t\t\t<string>ProBook</string>\n\t\t\t\t\t<key>167C</key>\n\t\t\t\t\t<string>ProBook</string>\n\t\t\t\t\t<key>167E</key>\n\t\t\t\t\t<string>ProBook</string>\n\t\t\t\t\t<key>1680</key>\n\t\t\t\t\t<string>ProBook</string>\n\t\t\t\t\t<key>179B</key>\n\t\t\t\t\t<string>ProBook</string>\n\t\t\t\t\t<key>179C</key>\n\t\t\t\t\t<string>ProBook</string>\n\t\t\t\t\t<key>17A9</key>\n\t\t\t\t\t<string>ProBook</string>\n\t\t\t\t\t<key>17F0</key>\n\t\t\t\t\t<string>ProBook</string>\n\t\t\t\t\t<key>17F3</key>\n\t\t\t\t\t<string>ProBook</string>\n\t\t\t\t\t<key>17F6</key>\n\t\t\t\t\t<string>ProBook</string>\n\t\t\t\t\t<key>1942</key>\n\t\t\t\t\t<string>ProBook</string>\n\t\t\t\t\t<key>1949</key>\n\t\t\t\t\t<string>ProBook</string>\n\t\t\t\t\t<key>198F</key>\n\t\t\t\t\t<string>ProBook</string>\n\t\t\t\t\t<key>ProBook</key>\n\t\t\t\t\t<dict>\n\t\t\t\t\t\t<key>WakeDelay</key>\n\t\t\t\t\t\t<integer>0</integer>\n\t\t\t\t\t</dict>\n\t\t\t\t\t<key>ProBook-102</key>\n\t\t\t\t\t<string>ProBook</string>\n\t\t\t\t\t<key>ProBook-87</key>\n\t\t\t\t\t<string>ProBook</string>\n\t\t\t\t</dict>\n\t\t\t</dict>\n\t\t\t<key>RM,deliverNotifications</key>\n\t\t\t<true/>\n\t\t</dict>\n\t</dict>\n\t<key>LSMinimumSystemVersion</key>\n\t<string>10.10</string>\n\t<key>OSBundleCompatibleVersion</key>\n\t<string>2.3.7</string>\n\t<key>OSBundleLibraries</key>\n\t<dict>\n\t\t<key>com.apple.iokit.IOACPIFamily</key>\n\t\t<string>1.0.0d1</string>\n\t\t<key>com.apple.kpi.bsd</key>\n\t\t<string>8.0.0</string>\n\t\t<key>com.apple.kpi.iokit</key>\n\t\t<string>8.0.0</string>\n\t\t<key>com.apple.kpi.libkern</key>\n\t\t<string>8.0.0</string>\n\t\t<key>com.apple.kpi.mach</key>\n\t\t<string>8.0.0</string>\n\t\t<key>com.apple.kpi.unsupported</key>\n\t\t<string>8.0.0</string>\n\t</dict>\n\t<key>OSBundleRequired</key>\n\t<string>Console</string>\n</dict>\n</plist>\n"
  },
  {
    "path": "EFI_RELEASE/EFI/OC/Kexts/VoodooPS2Controller.kext/Contents/PlugIns/VoodooPS2Keyboard.kext/Contents/Info.plist",
    "content": "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<!DOCTYPE plist PUBLIC \"-//Apple//DTD PLIST 1.0//EN\" \"http://www.apple.com/DTDs/PropertyList-1.0.dtd\">\n<plist version=\"1.0\">\n<dict>\n\t<key>BuildMachineOSBuild</key>\n\t<string>23H222</string>\n\t<key>CFBundleExecutable</key>\n\t<string>VoodooPS2Keyboard</string>\n\t<key>CFBundleGetInfoString</key>\n\t<string>2.3.7, Copyright Apple Computer, Inc. 2000-2003, RehabMan 2012-2013</string>\n\t<key>CFBundleIdentifier</key>\n\t<string>as.acidanthera.voodoo.driver.PS2Keyboard</string>\n\t<key>CFBundleInfoDictionaryVersion</key>\n\t<string>6.0</string>\n\t<key>CFBundleName</key>\n\t<string>Voodoo PS/2 Keyboard</string>\n\t<key>CFBundlePackageType</key>\n\t<string>KEXT</string>\n\t<key>CFBundleShortVersionString</key>\n\t<string>2.3.7</string>\n\t<key>CFBundleSignature</key>\n\t<string>????</string>\n\t<key>CFBundleSupportedPlatforms</key>\n\t<array>\n\t\t<string>MacOSX</string>\n\t</array>\n\t<key>CFBundleVersion</key>\n\t<string>2.3.7</string>\n\t<key>DTCompiler</key>\n\t<string>com.apple.compilers.llvm.clang.1_0</string>\n\t<key>DTPlatformBuild</key>\n\t<string></string>\n\t<key>DTPlatformName</key>\n\t<string>macosx</string>\n\t<key>DTPlatformVersion</key>\n\t<string>14.2</string>\n\t<key>DTSDKBuild</key>\n\t<string>23C53</string>\n\t<key>DTSDKName</key>\n\t<string>macosx14.2</string>\n\t<key>DTXcode</key>\n\t<string>1520</string>\n\t<key>DTXcodeBuild</key>\n\t<string>15C500b</string>\n\t<key>IOKitPersonalities</key>\n\t<dict>\n\t\t<key>ApplePS2Keyboard</key>\n\t\t<dict>\n\t\t\t<key>CFBundleIdentifier</key>\n\t\t\t<string>as.acidanthera.voodoo.driver.PS2Keyboard</string>\n\t\t\t<key>IOClass</key>\n\t\t\t<string>ApplePS2Keyboard</string>\n\t\t\t<key>IOProviderClass</key>\n\t\t\t<string>ApplePS2KeyboardDevice</string>\n\t\t\t<key>Platform Profile</key>\n\t\t\t<dict>\n\t\t\t\t<key>DELL</key>\n\t\t\t\t<dict>\n\t\t\t\t\t<key>Dell-Keys</key>\n\t\t\t\t\t<dict>\n\t\t\t\t\t\t<key>Breakless PS2</key>\n\t\t\t\t\t\t<array>\n\t\t\t\t\t\t\t<string>e005</string>\n\t\t\t\t\t\t\t<string>e006</string>\n\t\t\t\t\t\t</array>\n\t\t\t\t\t\t<key>Function Keys Special</key>\n\t\t\t\t\t\t<array>\n\t\t\t\t\t\t\t<string>;The following 12 items map Fn+fkeys to fkeys</string>\n\t\t\t\t\t\t\t<string>e020=3b</string>\n\t\t\t\t\t\t\t<string>e02e=3c</string>\n\t\t\t\t\t\t\t<string>e030=3d</string>\n\t\t\t\t\t\t\t<string>e022=3e</string>\n\t\t\t\t\t\t\t<string>;Fn+f5 macro</string>\n\t\t\t\t\t\t\t<string>;Fn+f6 macro</string>\n\t\t\t\t\t\t\t<string>;Fn+f7 macro</string>\n\t\t\t\t\t\t\t<string>;Fn+f8 macro</string>\n\t\t\t\t\t\t\t<string>;Fn+f9 macro</string>\n\t\t\t\t\t\t\t<string>;Fn+f10 no code</string>\n\t\t\t\t\t\t\t<string>e005=57</string>\n\t\t\t\t\t\t\t<string>e006=58</string>\n\t\t\t\t\t\t\t<string>;The following 12 items map fkeys to Fn+fkeys</string>\n\t\t\t\t\t\t\t<string>3b=e020</string>\n\t\t\t\t\t\t\t<string>3c=e02e</string>\n\t\t\t\t\t\t\t<string>3d=e030</string>\n\t\t\t\t\t\t\t<string>3e=e022</string>\n\t\t\t\t\t\t\t<string>;Fn+f5 macro</string>\n\t\t\t\t\t\t\t<string>;Fn+f6 macro</string>\n\t\t\t\t\t\t\t<string>;Fn+f7 macro</string>\n\t\t\t\t\t\t\t<string>;Fn+f8 macro</string>\n\t\t\t\t\t\t\t<string>;Fn+f9 macro</string>\n\t\t\t\t\t\t\t<string>;Fn+f10 no code</string>\n\t\t\t\t\t\t\t<string>57=e005</string>\n\t\t\t\t\t\t\t<string>58=e006</string>\n\t\t\t\t\t\t</array>\n\t\t\t\t\t\t<key>Function Keys Standard</key>\n\t\t\t\t\t\t<array>\n\t\t\t\t\t\t\t<string>;The following 12 items map Fn+fkeys to Fn+fkeys</string>\n\t\t\t\t\t\t\t<string>e020=e020</string>\n\t\t\t\t\t\t\t<string>e02e=e02e</string>\n\t\t\t\t\t\t\t<string>e030=e030</string>\n\t\t\t\t\t\t\t<string>e022=e022</string>\n\t\t\t\t\t\t\t<string>;Fn+f5 macro</string>\n\t\t\t\t\t\t\t<string>;Fn+f6 macro</string>\n\t\t\t\t\t\t\t<string>;Fn+f7 macro</string>\n\t\t\t\t\t\t\t<string>;Fn+f8 macro</string>\n\t\t\t\t\t\t\t<string>;Fn+f9 macro</string>\n\t\t\t\t\t\t\t<string>;Fn+f10 no code</string>\n\t\t\t\t\t\t\t<string>e005=e005</string>\n\t\t\t\t\t\t\t<string>e006=e006</string>\n\t\t\t\t\t\t\t<string>;The following 12 items map fkeys to fkeys</string>\n\t\t\t\t\t\t\t<string>3b=3b</string>\n\t\t\t\t\t\t\t<string>3c=3c</string>\n\t\t\t\t\t\t\t<string>3d=3d</string>\n\t\t\t\t\t\t\t<string>3e=3e</string>\n\t\t\t\t\t\t\t<string>3f=3f</string>\n\t\t\t\t\t\t\t<string>40=40</string>\n\t\t\t\t\t\t\t<string>41=41</string>\n\t\t\t\t\t\t\t<string>42=42</string>\n\t\t\t\t\t\t\t<string>43=43</string>\n\t\t\t\t\t\t\t<string>44=44</string>\n\t\t\t\t\t\t\t<string>57=57</string>\n\t\t\t\t\t\t\t<string>58=58</string>\n\t\t\t\t\t\t</array>\n\t\t\t\t\t</dict>\n\t\t\t\t\t<key>HSW-LPT</key>\n\t\t\t\t\t<string>Dell-Keys</string>\n\t\t\t\t\t<key>SNB-CPT</key>\n\t\t\t\t\t<dict>\n\t\t\t\t\t\t<key>ActionSwipeDown</key>\n\t\t\t\t\t\t<string>63 d, 63 u</string>\n\t\t\t\t\t\t<key>ActionSwipeUp</key>\n\t\t\t\t\t\t<string>61 d, 61 u</string>\n\t\t\t\t\t\t<key>Breakless PS2</key>\n\t\t\t\t\t\t<array>\n\t\t\t\t\t\t\t<string>e01e;Touchpad Fn+f3 is breakless</string>\n\t\t\t\t\t\t\t<string>e06e;REVIEW: temporary for case that macro inversion does not work...</string>\n\t\t\t\t\t\t</array>\n\t\t\t\t\t\t<key>Custom ADB Map</key>\n\t\t\t\t\t\t<array>\n\t\t\t\t\t\t\t<string>e009=83;Dell Support to Launchpad</string>\n\t\t\t\t\t\t\t<string>e0f1=71;Call brightens up w RKA1 for special mode (was =90)</string>\n\t\t\t\t\t\t\t<string>e0f2=6b;Call brightens down w RKA2 for special mode (was =91)</string>\n\t\t\t\t\t\t\t<string>e06e=70;Map vidmirror key for special mode default is adb90</string>\n\t\t\t\t\t\t</array>\n\t\t\t\t\t\t<key>Custom PS2 Map</key>\n\t\t\t\t\t\t<array>\n\t\t\t\t\t\t\t<string>e01e=e037;Map tp disable to Fn+f3</string>\n\t\t\t\t\t\t\t<string>e037=e01e;Prevent PrntScr from triggering tp disable</string>\n\t\t\t\t\t\t</array>\n\t\t\t\t\t\t<key>Function Keys Special</key>\n\t\t\t\t\t\t<array>\n\t\t\t\t\t\t\t<string>;The following 12 items map Fn+fkeys to fkeys</string>\n\t\t\t\t\t\t\t<string>e06e=3b</string>\n\t\t\t\t\t\t\t<string>e008=3c</string>\n\t\t\t\t\t\t\t<string>e01e=3d</string>\n\t\t\t\t\t\t\t<string>e005=3e</string>\n\t\t\t\t\t\t\t<string>e006=3f</string>\n\t\t\t\t\t\t\t<string>e00c=40</string>\n\t\t\t\t\t\t\t<string>;Fn+f7 no dedicated macro</string>\n\t\t\t\t\t\t\t<string>e010=42</string>\n\t\t\t\t\t\t\t<string>e022=43</string>\n\t\t\t\t\t\t\t<string>e019=44</string>\n\t\t\t\t\t\t\t<string>e02e=57</string>\n\t\t\t\t\t\t\t<string>e030=58</string>\n\t\t\t\t\t\t\t<string>;The following 12 items map fkeys to Fn+fkeys</string>\n\t\t\t\t\t\t\t<string>3b=e06e;Map vidmirror key to f1</string>\n\t\t\t\t\t\t\t<string>3c=e0f0;Map radio toggle action from EC query to f2</string>\n\t\t\t\t\t\t\t<string>3d=e037;Map touchpad toggle button to f3</string>\n\t\t\t\t\t\t\t<string>3e=e0f2;Map acpi RKA2 to f4 brightness down</string>\n\t\t\t\t\t\t\t<string>3f=e0f1;Map acpi RKA1 to f5 brightness up</string>\n\t\t\t\t\t\t\t<string>40=e0f3;Map acpi RKA3 to f6 keyboard backlight</string>\n\t\t\t\t\t\t\t<string>;Fn+f7 no macro</string>\n\t\t\t\t\t\t\t<string>42=e010</string>\n\t\t\t\t\t\t\t<string>43=e022</string>\n\t\t\t\t\t\t\t<string>44=e019</string>\n\t\t\t\t\t\t\t<string>57=e02e</string>\n\t\t\t\t\t\t\t<string>58=e030</string>\n\t\t\t\t\t\t</array>\n\t\t\t\t\t\t<key>Function Keys Standard</key>\n\t\t\t\t\t\t<array>\n\t\t\t\t\t\t\t<string>;The following 12 items map Fn+fkeys to Fn+fkeys</string>\n\t\t\t\t\t\t\t<string>e06e=e06e;Fn+f1 macro translated</string>\n\t\t\t\t\t\t\t<string>e008=e008;Fn+f2 regular scancode and EC query call q8c</string>\n\t\t\t\t\t\t\t<string>e01e=e037;Fn+f3 regular scancode and EC controls LED</string>\n\t\t\t\t\t\t\t<string>e005=e005;Fn+f4 no ps2scancode and EC query call q81</string>\n\t\t\t\t\t\t\t<string>e006=e006;Fn+f5 no ps2scancode and EC query call q80</string>\n\t\t\t\t\t\t\t<string>e00c=e00c;Fn+f6 no ps2scancode and EC query call q8a</string>\n\t\t\t\t\t\t\t<string>;Fn+f7 no macro just regular f key</string>\n\t\t\t\t\t\t\t<string>e010=e010; Fn+f8 regular scancode</string>\n\t\t\t\t\t\t\t<string>e022=e022; Fn+f9 regular scancode</string>\n\t\t\t\t\t\t\t<string>e019=e019;Fn+f10 regular scancode</string>\n\t\t\t\t\t\t\t<string>e02e=e02e;Fn+f11 regular scancode</string>\n\t\t\t\t\t\t\t<string>e030=e030;Fn+f12 regular scancode</string>\n\t\t\t\t\t\t\t<string>;Fn+f13 is mute dedicated button that always produces e020 regardless of Fn</string>\n\t\t\t\t\t\t\t<string>;The following 12 items map fkeys to fkeys</string>\n\t\t\t\t\t\t\t<string>3b=3b</string>\n\t\t\t\t\t\t\t<string>3c=3c</string>\n\t\t\t\t\t\t\t<string>3d=3d</string>\n\t\t\t\t\t\t\t<string>3e=3e</string>\n\t\t\t\t\t\t\t<string>3f=3f</string>\n\t\t\t\t\t\t\t<string>40=40</string>\n\t\t\t\t\t\t\t<string>41=41</string>\n\t\t\t\t\t\t\t<string>42=42</string>\n\t\t\t\t\t\t\t<string>43=43</string>\n\t\t\t\t\t\t\t<string>44=44</string>\n\t\t\t\t\t\t\t<string>57=57</string>\n\t\t\t\t\t\t\t<string>58=58</string>\n\t\t\t\t\t\t</array>\n\t\t\t\t\t\t<key>Macro Inversion</key>\n\t\t\t\t\t\t<array>\n\t\t\t\t\t\t\t<string>;This section maps ps2 codes (packet format) received quickly (macros) into fake ps2 codes (packet format)</string>\n\t\t\t\t\t\t\t<string>;Fn+F1</string>\n\t\t\t\t\t\t\t<data>\n\t\t\t\t\t\t\t//8CbgAAAAACWwEZ\n\t\t\t\t\t\t\t</data>\n\t\t\t\t\t\t\t<data>\n\t\t\t\t\t\t\t//8C7gAAAAAC2wGZ\n\t\t\t\t\t\t\t</data>\n\t\t\t\t\t\t\t<data>\n\t\t\t\t\t\t\t//8C7gAAAAABmQLb\n\t\t\t\t\t\t\t</data>\n\t\t\t\t\t\t</array>\n\t\t\t\t\t\t<key>MaximumMacroTime</key>\n\t\t\t\t\t\t<integer>35000000</integer>\n\t\t\t\t\t\t<key>Note-Author</key>\n\t\t\t\t\t\t<string>TimeWalker aka TimeWalker75a</string>\n\t\t\t\t\t\t<key>Note-Comment</key>\n\t\t\t\t\t\t<string>Keyboard Profile for DELL SandyBridge SecureCore Tiano based laptops (Vostro 3450 &amp; 3750, Inspiron N4110, XPS L502x &amp; L702x &amp; L511z)</string>\n\t\t\t\t\t</dict>\n\t\t\t\t\t<key>WN09</key>\n\t\t\t\t\t<dict>\n\t\t\t\t\t\t<key>Breakless PS2</key>\n\t\t\t\t\t\t<array>\n\t\t\t\t\t\t\t<string>e01b</string>\n\t\t\t\t\t\t\t<string>e008</string>\n\t\t\t\t\t\t\t<string>e01e</string>\n\t\t\t\t\t\t\t<string>e005</string>\n\t\t\t\t\t\t\t<string>e06e</string>\n\t\t\t\t\t\t\t<string>e006</string>\n\t\t\t\t\t\t</array>\n\t\t\t\t\t\t<key>Custom ADB Map</key>\n\t\t\t\t\t\t<array>\n\t\t\t\t\t\t\t<string>e01b=70</string>\n\t\t\t\t\t\t\t<string>e06e=83</string>\n\t\t\t\t\t\t</array>\n\t\t\t\t\t\t<key>Custom PS2 Map</key>\n\t\t\t\t\t\t<array>\n\t\t\t\t\t\t\t<string>56=2b</string>\n\t\t\t\t\t\t\t<string>29=56</string>\n\t\t\t\t\t\t\t<string>2b=29</string>\n\t\t\t\t\t\t\t<string>e01e=e037</string>\n\t\t\t\t\t\t\t<string>e037=e01e</string>\n\t\t\t\t\t\t</array>\n\t\t\t\t\t</dict>\n\t\t\t\t\t<key>WN09a</key>\n\t\t\t\t\t<dict>\n\t\t\t\t\t\t<key>Breakless PS2</key>\n\t\t\t\t\t\t<array>\n\t\t\t\t\t\t\t<string>e01b</string>\n\t\t\t\t\t\t\t<string>e008</string>\n\t\t\t\t\t\t\t<string>e01e</string>\n\t\t\t\t\t\t\t<string>e005</string>\n\t\t\t\t\t\t\t<string>e06e</string>\n\t\t\t\t\t\t\t<string>e006</string>\n\t\t\t\t\t\t</array>\n\t\t\t\t\t\t<key>Custom ADB Map</key>\n\t\t\t\t\t\t<array>\n\t\t\t\t\t\t\t<string>e01b=70</string>\n\t\t\t\t\t\t\t<string>e06e=83</string>\n\t\t\t\t\t\t</array>\n\t\t\t\t\t\t<key>Custom PS2 Map</key>\n\t\t\t\t\t\t<array>\n\t\t\t\t\t\t\t<string>e01e=e037</string>\n\t\t\t\t\t\t\t<string>e037=e01e</string>\n\t\t\t\t\t\t</array>\n\t\t\t\t\t</dict>\n\t\t\t\t</dict>\n\t\t\t\t<key>Default</key>\n\t\t\t\t<dict>\n\t\t\t\t\t<key>Breakless PS2</key>\n\t\t\t\t\t<array>\n\t\t\t\t\t\t<string>;Items must be strings in the form of breaklessscan (in hex)</string>\n\t\t\t\t\t</array>\n\t\t\t\t\t<key>Custom ADB Map</key>\n\t\t\t\t\t<array>\n\t\t\t\t\t\t<string>;Items must be strings in the form of scanfrom=adbto (in hex)</string>\n\t\t\t\t\t</array>\n\t\t\t\t\t<key>Custom PS2 Map</key>\n\t\t\t\t\t<array>\n\t\t\t\t\t\t<string>;Items must be strings in the form of scanfrom=scanto (in hex)</string>\n\t\t\t\t\t\t<string>e027=0;disable discrete fnkeys toggle</string>\n\t\t\t\t\t\t<string>e028=0;disable discrete trackpad toggle</string>\n\t\t\t\t\t</array>\n\t\t\t\t\t<key>HIDF12EjectDelay</key>\n\t\t\t\t\t<integer>250</integer>\n\t\t\t\t\t<key>LogScanCodes</key>\n\t\t\t\t\t<integer>0</integer>\n\t\t\t\t\t<key>Make Application key into Apple Fn key</key>\n\t\t\t\t\t<false/>\n\t\t\t\t\t<key>Make Application key into right windows</key>\n\t\t\t\t\t<true/>\n\t\t\t\t\t<key>Make right modifier keys into Hangul and Hanja</key>\n\t\t\t\t\t<false/>\n\t\t\t\t\t<key>SleepPressTime</key>\n\t\t\t\t\t<integer>0</integer>\n\t\t\t\t\t<key>Swap capslock and left control</key>\n\t\t\t\t\t<false/>\n\t\t\t\t\t<key>Swap command and option</key>\n\t\t\t\t\t<false/>\n\t\t\t\t\t<key>Use ISO layout keyboard</key>\n\t\t\t\t\t<false/>\n\t\t\t\t\t<key>alt_handler_id</key>\n\t\t\t\t\t<integer>3</integer>\n\t\t\t\t</dict>\n\t\t\t\t<key>HPQOEM</key>\n\t\t\t\t<dict>\n\t\t\t\t\t<key>1411</key>\n\t\t\t\t\t<string>ProBook-102;ProBook 4520s</string>\n\t\t\t\t\t<key>1619</key>\n\t\t\t\t\t<string>ProBook-87;ProBook 6560b</string>\n\t\t\t\t\t<key>161C</key>\n\t\t\t\t\t<string>ProBook-87;ProBook 8460p</string>\n\t\t\t\t\t<key>164F</key>\n\t\t\t\t\t<string>ProBook-87;ProBook 5330m</string>\n\t\t\t\t\t<key>167C</key>\n\t\t\t\t\t<string>ProBook-102;ProBook 4530s</string>\n\t\t\t\t\t<key>167E</key>\n\t\t\t\t\t<string>ProBook-102;ProBook 4330s</string>\n\t\t\t\t\t<key>1680</key>\n\t\t\t\t\t<string>ProBook-102;ProBook 4230s</string>\n\t\t\t\t\t<key>179B</key>\n\t\t\t\t\t<string>ProBook-87;ProBook 6470b</string>\n\t\t\t\t\t<key>179C</key>\n\t\t\t\t\t<string>ProBook-87;ProBook 6470b</string>\n\t\t\t\t\t<key>17A9</key>\n\t\t\t\t\t<string>ProBook-87;ProBook 8570b</string>\n\t\t\t\t\t<key>17F0</key>\n\t\t\t\t\t<string>ProBook-102;ProBook 4340s</string>\n\t\t\t\t\t<key>17F3</key>\n\t\t\t\t\t<string>ProBook-102;ProBook 4440s</string>\n\t\t\t\t\t<key>17F6</key>\n\t\t\t\t\t<string>ProBook-102;ProBook 4540s</string>\n\t\t\t\t\t<key>1942</key>\n\t\t\t\t\t<string>ProBook-87;ProBook 450s G1</string>\n\t\t\t\t\t<key>1949</key>\n\t\t\t\t\t<string>ProBook-87;ProBook 450s G1</string>\n\t\t\t\t\t<key>1962</key>\n\t\t\t\t\t<string>Haswell-Envy;HP Envy 15-j063cl</string>\n\t\t\t\t\t<key>1963</key>\n\t\t\t\t\t<string>Haswell-Envy;HP Envy 15-j063cl</string>\n\t\t\t\t\t<key>1965</key>\n\t\t\t\t\t<string>Haswell-Envy;HP Envy 17t-j100</string>\n\t\t\t\t\t<key>1966</key>\n\t\t\t\t\t<string>Haswell-Envy;HP Envy 17t-j000</string>\n\t\t\t\t\t<key>198F</key>\n\t\t\t\t\t<string>ProBook-87;ProBook 450s G0</string>\n\t\t\t\t\t<key>Haswell-Envy</key>\n\t\t\t\t\t<dict>\n\t\t\t\t\t\t<key>Custom ADB Map</key>\n\t\t\t\t\t\t<array>\n\t\t\t\t\t\t\t<string>e019=42;next</string>\n\t\t\t\t\t\t\t<string>e010=4d;previous</string>\n\t\t\t\t\t\t</array>\n\t\t\t\t\t\t<key>Custom PS2 Map</key>\n\t\t\t\t\t\t<array>\n\t\t\t\t\t\t\t<string>e045=e037</string>\n\t\t\t\t\t\t\t<string>e0ab=0;bogus Fn+F2/F3</string>\n\t\t\t\t\t\t</array>\n\t\t\t\t\t</dict>\n\t\t\t\t\t<key>ProBook-102</key>\n\t\t\t\t\t<dict>\n\t\t\t\t\t\t<key>Custom PS2 Map</key>\n\t\t\t\t\t\t<array>\n\t\t\t\t\t\t\t<string>e005=0</string>\n\t\t\t\t\t\t</array>\n\t\t\t\t\t\t<key>Function Keys Special</key>\n\t\t\t\t\t\t<array>\n\t\t\t\t\t\t\t<string>;The following 12 items map Fn+fkeys to fkeys</string>\n\t\t\t\t\t\t\t<string>e05f=3b</string>\n\t\t\t\t\t\t\t<string>e012=3c</string>\n\t\t\t\t\t\t\t<string>e017=3d</string>\n\t\t\t\t\t\t\t<string>e06e=3e</string>\n\t\t\t\t\t\t\t<string>e00a=3f</string>\n\t\t\t\t\t\t\t<string>e009=40</string>\n\t\t\t\t\t\t\t<string>e020=41</string>\n\t\t\t\t\t\t\t<string>e02e=42</string>\n\t\t\t\t\t\t\t<string>e030=43</string>\n\t\t\t\t\t\t\t<string>e010=44</string>\n\t\t\t\t\t\t\t<string>e022=57</string>\n\t\t\t\t\t\t\t<string>e019=58</string>\n\t\t\t\t\t\t\t<string>;The following 12 items map fkeys to Fn+fkeys</string>\n\t\t\t\t\t\t\t<string>3b=e05f</string>\n\t\t\t\t\t\t\t<string>3c=e012</string>\n\t\t\t\t\t\t\t<string>3d=e017</string>\n\t\t\t\t\t\t\t<string>3e=e06e</string>\n\t\t\t\t\t\t\t<string>3f=e00a</string>\n\t\t\t\t\t\t\t<string>40=e009</string>\n\t\t\t\t\t\t\t<string>41=e020</string>\n\t\t\t\t\t\t\t<string>42=e02e</string>\n\t\t\t\t\t\t\t<string>43=e030</string>\n\t\t\t\t\t\t\t<string>44=e010</string>\n\t\t\t\t\t\t\t<string>57=e022</string>\n\t\t\t\t\t\t\t<string>58=e019</string>\n\t\t\t\t\t\t</array>\n\t\t\t\t\t\t<key>Function Keys Standard</key>\n\t\t\t\t\t\t<array>\n\t\t\t\t\t\t\t<string>;The following 12 items map Fn+fkeys to Fn+fkeys</string>\n\t\t\t\t\t\t\t<string>e05f=e05f</string>\n\t\t\t\t\t\t\t<string>e012=e012</string>\n\t\t\t\t\t\t\t<string>e017=e017</string>\n\t\t\t\t\t\t\t<string>e06e=e06e</string>\n\t\t\t\t\t\t\t<string>e00a=e00a</string>\n\t\t\t\t\t\t\t<string>e009=e009</string>\n\t\t\t\t\t\t\t<string>e020=e020</string>\n\t\t\t\t\t\t\t<string>e02e=e02e</string>\n\t\t\t\t\t\t\t<string>e030=e030</string>\n\t\t\t\t\t\t\t<string>e010=e010</string>\n\t\t\t\t\t\t\t<string>e022=e022</string>\n\t\t\t\t\t\t\t<string>e019=e019</string>\n\t\t\t\t\t\t\t<string>;The following 12 items map fkeys to fkeys</string>\n\t\t\t\t\t\t\t<string>3b=3b</string>\n\t\t\t\t\t\t\t<string>3c=3c</string>\n\t\t\t\t\t\t\t<string>3d=3d</string>\n\t\t\t\t\t\t\t<string>3e=3e</string>\n\t\t\t\t\t\t\t<string>3f=3f</string>\n\t\t\t\t\t\t\t<string>40=40</string>\n\t\t\t\t\t\t\t<string>41=41</string>\n\t\t\t\t\t\t\t<string>42=42</string>\n\t\t\t\t\t\t\t<string>43=43</string>\n\t\t\t\t\t\t\t<string>44=44</string>\n\t\t\t\t\t\t\t<string>57=57</string>\n\t\t\t\t\t\t\t<string>58=58</string>\n\t\t\t\t\t\t</array>\n\t\t\t\t\t\t<key>SleepPressTime</key>\n\t\t\t\t\t\t<integer>3000</integer>\n\t\t\t\t\t</dict>\n\t\t\t\t\t<key>ProBook-87</key>\n\t\t\t\t\t<dict>\n\t\t\t\t\t\t<key>Custom ADB Map</key>\n\t\t\t\t\t\t<array>\n\t\t\t\t\t\t\t<string>46=4d;scroll =&gt; Previous-track</string>\n\t\t\t\t\t\t\t<string>e045=34;pause =&gt; Play-Pause</string>\n\t\t\t\t\t\t\t<string>e052=42;insert =&gt; Next-track</string>\n\t\t\t\t\t\t\t<string>e046=92;break =&gt; Eject</string>\n\t\t\t\t\t\t</array>\n\t\t\t\t\t\t<key>Custom PS2 Map</key>\n\t\t\t\t\t\t<array>\n\t\t\t\t\t\t\t<string>e005=0</string>\n\t\t\t\t\t\t</array>\n\t\t\t\t\t\t<key>Function Keys Special</key>\n\t\t\t\t\t\t<array>\n\t\t\t\t\t\t\t<string>;The following 8 items map Fn+fkeys to fkeys</string>\n\t\t\t\t\t\t\t<string>e05f=3d</string>\n\t\t\t\t\t\t\t<string>e06e=3e</string>\n\t\t\t\t\t\t\t<string>e02e=40</string>\n\t\t\t\t\t\t\t<string>e030=41</string>\n\t\t\t\t\t\t\t<string>e009=42</string>\n\t\t\t\t\t\t\t<string>e012=43</string>\n\t\t\t\t\t\t\t<string>e017=44</string>\n\t\t\t\t\t\t\t<string>e033=57</string>\n\t\t\t\t\t\t\t<string>;The following 8 items map fkeys to Fn+fkeys</string>\n\t\t\t\t\t\t\t<string>3d=e05f</string>\n\t\t\t\t\t\t\t<string>3e=e06e</string>\n\t\t\t\t\t\t\t<string>40=e02e</string>\n\t\t\t\t\t\t\t<string>41=e030</string>\n\t\t\t\t\t\t\t<string>42=e037</string>\n\t\t\t\t\t\t\t<string>43=e012</string>\n\t\t\t\t\t\t\t<string>44=e017</string>\n\t\t\t\t\t\t</array>\n\t\t\t\t\t\t<key>Function Keys Standard</key>\n\t\t\t\t\t\t<array>\n\t\t\t\t\t\t\t<string>;The following 8 items map Fn+fkeys to Fn+fkeys</string>\n\t\t\t\t\t\t\t<string>e05f=e05f</string>\n\t\t\t\t\t\t\t<string>e06e=e06e</string>\n\t\t\t\t\t\t\t<string>e02e=e02e</string>\n\t\t\t\t\t\t\t<string>e030=e030</string>\n\t\t\t\t\t\t\t<string>e009=e009</string>\n\t\t\t\t\t\t\t<string>e012=e012</string>\n\t\t\t\t\t\t\t<string>e017=e017</string>\n\t\t\t\t\t\t\t<string>e033=e033</string>\n\t\t\t\t\t\t\t<string>;The following 8 items map fkeys to fkeys</string>\n\t\t\t\t\t\t\t<string>3d=3d</string>\n\t\t\t\t\t\t\t<string>3e=3e</string>\n\t\t\t\t\t\t\t<string>40=40</string>\n\t\t\t\t\t\t\t<string>41=41</string>\n\t\t\t\t\t\t\t<string>42=42</string>\n\t\t\t\t\t\t\t<string>43=43</string>\n\t\t\t\t\t\t\t<string>44=44</string>\n\t\t\t\t\t\t</array>\n\t\t\t\t\t\t<key>SleepPressTime</key>\n\t\t\t\t\t\t<integer>3000</integer>\n\t\t\t\t\t</dict>\n\t\t\t\t</dict>\n\t\t\t\t<key>Intel</key>\n\t\t\t\t<dict>\n\t\t\t\t\t<key>CALPELLA</key>\n\t\t\t\t\t<string>SamsungKeys</string>\n\t\t\t\t\t<key>SamsungKeys</key>\n\t\t\t\t\t<dict>\n\t\t\t\t\t\t<key>Breakless PS2</key>\n\t\t\t\t\t\t<array>\n\t\t\t\t\t\t\t<string>e003</string>\n\t\t\t\t\t\t\t<string>e002</string>\n\t\t\t\t\t\t\t<string>e004</string>\n\t\t\t\t\t\t\t<string>e020</string>\n\t\t\t\t\t\t\t<string>;e031</string>\n\t\t\t\t\t\t\t<string>e033</string>\n\t\t\t\t\t\t\t<string>e006</string>\n\t\t\t\t\t\t\t<string>e077</string>\n\t\t\t\t\t\t\t<string>e079</string>\n\t\t\t\t\t\t\t<string>e008</string>\n\t\t\t\t\t\t\t<string>e009</string>\n\t\t\t\t\t\t</array>\n\t\t\t\t\t\t<key>Custom ADB Map</key>\n\t\t\t\t\t\t<array>\n\t\t\t\t\t\t\t<string>e002=70</string>\n\t\t\t\t\t\t\t<string>e006=80</string>\n\t\t\t\t\t\t\t<string>e008=71 (was =90)</string>\n\t\t\t\t\t\t\t<string>e009=6b (was =91)</string>\n\t\t\t\t\t\t</array>\n\t\t\t\t\t\t<key>Function Keys Special</key>\n\t\t\t\t\t\t<array>\n\t\t\t\t\t\t\t<string>;The following 12 items map Fn+fkeys to fkeys</string>\n\t\t\t\t\t\t\t<string>;fn+f1 no code</string>\n\t\t\t\t\t\t\t<string>e003=3c</string>\n\t\t\t\t\t\t\t<string>;fn+f3 weird code</string>\n\t\t\t\t\t\t\t<string>e002=3e</string>\n\t\t\t\t\t\t\t<string>e004=3f</string>\n\t\t\t\t\t\t\t<string>e020=40</string>\n\t\t\t\t\t\t\t<string>e031=41</string>\n\t\t\t\t\t\t\t<string>e033=42</string>\n\t\t\t\t\t\t\t<string>e006=43</string>\n\t\t\t\t\t\t\t<string>;fn+f10 weird code</string>\n\t\t\t\t\t\t\t<string>;fn+f11 no code</string>\n\t\t\t\t\t\t\t<string>;fn+f12 scrolllock</string>\n\t\t\t\t\t\t\t<string>;The following 12 items map fkeys to Fn+fkeys</string>\n\t\t\t\t\t\t\t<string>;fn+f1 no code</string>\n\t\t\t\t\t\t\t<string>3c=e003</string>\n\t\t\t\t\t\t\t<string>;fn+f3 weird code</string>\n\t\t\t\t\t\t\t<string>3e=e002</string>\n\t\t\t\t\t\t\t<string>3f=e004</string>\n\t\t\t\t\t\t\t<string>40=e020</string>\n\t\t\t\t\t\t\t<string>41=e031</string>\n\t\t\t\t\t\t\t<string>42=e033</string>\n\t\t\t\t\t\t\t<string>43=e006</string>\n\t\t\t\t\t\t\t<string>;fn+f10 weird code</string>\n\t\t\t\t\t\t\t<string>;fn+f11 no code</string>\n\t\t\t\t\t\t\t<string>;fn+f12 scrolllock</string>\n\t\t\t\t\t\t</array>\n\t\t\t\t\t\t<key>Function Keys Standard</key>\n\t\t\t\t\t\t<array>\n\t\t\t\t\t\t\t<string>;The following 12 items map Fn+fkeys to Fn+fkeys</string>\n\t\t\t\t\t\t\t<string>;fn+f1 no code</string>\n\t\t\t\t\t\t\t<string>e003=e003</string>\n\t\t\t\t\t\t\t<string>;fn+f3 weird code</string>\n\t\t\t\t\t\t\t<string>e002=e002</string>\n\t\t\t\t\t\t\t<string>e004=e004</string>\n\t\t\t\t\t\t\t<string>e020=e020</string>\n\t\t\t\t\t\t\t<string>e031=e031</string>\n\t\t\t\t\t\t\t<string>e033=e033</string>\n\t\t\t\t\t\t\t<string>e006=e006</string>\n\t\t\t\t\t\t\t<string>;fn+f10 weird code</string>\n\t\t\t\t\t\t\t<string>;fn+f11 no code</string>\n\t\t\t\t\t\t\t<string>;fn+f12 scrolllock</string>\n\t\t\t\t\t\t\t<string>;The following 12 items map fkeys to fkeys</string>\n\t\t\t\t\t\t\t<string>3b=3b</string>\n\t\t\t\t\t\t\t<string>3c=3c</string>\n\t\t\t\t\t\t\t<string>3d=3d</string>\n\t\t\t\t\t\t\t<string>3e=3e</string>\n\t\t\t\t\t\t\t<string>3f=3f</string>\n\t\t\t\t\t\t\t<string>40=40</string>\n\t\t\t\t\t\t\t<string>41=41</string>\n\t\t\t\t\t\t\t<string>42=42</string>\n\t\t\t\t\t\t\t<string>43=43</string>\n\t\t\t\t\t\t\t<string>44=44</string>\n\t\t\t\t\t\t\t<string>57=57</string>\n\t\t\t\t\t\t\t<string>58=58</string>\n\t\t\t\t\t\t</array>\n\t\t\t\t\t</dict>\n\t\t\t\t</dict>\n\t\t\t\t<key>SECCSD</key>\n\t\t\t\t<dict>\n\t\t\t\t\t<key>LH43STAR</key>\n\t\t\t\t\t<string>SamsungKeys</string>\n\t\t\t\t\t<key>SamsungKeys</key>\n\t\t\t\t\t<dict>\n\t\t\t\t\t\t<key>Breakless PS2</key>\n\t\t\t\t\t\t<array>\n\t\t\t\t\t\t\t<string>e020</string>\n\t\t\t\t\t\t\t<string>e02e</string>\n\t\t\t\t\t\t\t<string>e030</string>\n\t\t\t\t\t\t</array>\n\t\t\t\t\t</dict>\n\t\t\t\t</dict>\n\t\t\t</dict>\n\t\t</dict>\n\t</dict>\n\t<key>LSMinimumSystemVersion</key>\n\t<string>10.10</string>\n\t<key>OSBundleLibraries</key>\n\t<dict>\n\t\t<key>as.acidanthera.voodoo.driver.PS2Controller</key>\n\t\t<string>2.3.7</string>\n\t\t<key>com.apple.iokit.IOHIDFamily</key>\n\t\t<string>1.0.0b1</string>\n\t\t<key>com.apple.kpi.bsd</key>\n\t\t<string>8.0.0</string>\n\t\t<key>com.apple.kpi.iokit</key>\n\t\t<string>8.0.0</string>\n\t\t<key>com.apple.kpi.libkern</key>\n\t\t<string>8.0.0</string>\n\t\t<key>com.apple.kpi.mach</key>\n\t\t<string>8.0.0</string>\n\t\t<key>com.apple.kpi.unsupported</key>\n\t\t<string>8.0.0</string>\n\t</dict>\n\t<key>OSBundleRequired</key>\n\t<string>Console</string>\n</dict>\n</plist>\n"
  },
  {
    "path": "EFI_RELEASE/EFI/OC/Kexts/WhateverGreen.kext/Contents/Info.plist",
    "content": "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<!DOCTYPE plist PUBLIC \"-//Apple//DTD PLIST 1.0//EN\" \"http://www.apple.com/DTDs/PropertyList-1.0.dtd\">\n<plist version=\"1.0\">\n<dict>\n\t<key>BuildMachineOSBuild</key>\n\t<string>23H626</string>\n\t<key>CFBundleDevelopmentRegion</key>\n\t<string>en</string>\n\t<key>CFBundleExecutable</key>\n\t<string>WhateverGreen</string>\n\t<key>CFBundleIdentifier</key>\n\t<string>as.vit9696.WhateverGreen</string>\n\t<key>CFBundleInfoDictionaryVersion</key>\n\t<string>6.0</string>\n\t<key>CFBundleName</key>\n\t<string>WhateverGreen</string>\n\t<key>CFBundlePackageType</key>\n\t<string>KEXT</string>\n\t<key>CFBundleShortVersionString</key>\n\t<string>1.7.0</string>\n\t<key>CFBundleSignature</key>\n\t<string>????</string>\n\t<key>CFBundleSupportedPlatforms</key>\n\t<array>\n\t\t<string>MacOSX</string>\n\t</array>\n\t<key>CFBundleVersion</key>\n\t<string>1.7.0</string>\n\t<key>DTCompiler</key>\n\t<string>com.apple.compilers.llvm.clang.1_0</string>\n\t<key>DTPlatformBuild</key>\n\t<string></string>\n\t<key>DTPlatformName</key>\n\t<string>macosx</string>\n\t<key>DTPlatformVersion</key>\n\t<string>14.2</string>\n\t<key>DTSDKBuild</key>\n\t<string>23C53</string>\n\t<key>DTSDKName</key>\n\t<string>macosx14.2</string>\n\t<key>DTXcode</key>\n\t<string>1520</string>\n\t<key>DTXcodeBuild</key>\n\t<string>15C500b</string>\n\t<key>IOKitPersonalities</key>\n\t<dict>\n\t\t<key>NVHDAEnabler</key>\n\t\t<dict>\n\t\t\t<key>CFBundleIdentifier</key>\n\t\t\t<string>as.vit9696.WhateverGreen</string>\n\t\t\t<key>IOClass</key>\n\t\t\t<string>NVHDAEnabler</string>\n\t\t\t<key>IOMatchCategory</key>\n\t\t\t<string>IOFramebuffer</string>\n\t\t\t<key>IOPCIClassMatch</key>\n\t\t\t<string>0x03000000&amp;0xff000000</string>\n\t\t\t<key>IOPCIMatch</key>\n\t\t\t<string>0x000010de&amp;0x0000ffff</string>\n\t\t\t<key>IOProbeScore</key>\n\t\t\t<integer>300000</integer>\n\t\t\t<key>IOProviderClass</key>\n\t\t\t<string>IOPCIDevice</string>\n\t\t</dict>\n\t\t<key>as.vit9696.WhateverGreen</key>\n\t\t<dict>\n\t\t\t<key>CFBundleIdentifier</key>\n\t\t\t<string>as.vit9696.WhateverGreen</string>\n\t\t\t<key>IOClass</key>\n\t\t\t<string>WhateverGreen</string>\n\t\t\t<key>IOMatchCategory</key>\n\t\t\t<string>WhateverGreen</string>\n\t\t\t<key>IOProviderClass</key>\n\t\t\t<string>IOResources</string>\n\t\t\t<key>IOResourceMatch</key>\n\t\t\t<string>IOKit</string>\n\t\t</dict>\n\t</dict>\n\t<key>LSMinimumSystemVersion</key>\n\t<string>10.6</string>\n\t<key>NSHumanReadableCopyright</key>\n\t<string>Copyright © 2018 vit9696. All rights reserved.</string>\n\t<key>OSBundleCompatibleVersion</key>\n\t<string>1.0</string>\n\t<key>OSBundleLibraries</key>\n\t<dict>\n\t\t<key>as.vit9696.Lilu</key>\n\t\t<string>1.2.0</string>\n\t\t<key>com.apple.iokit.IOPCIFamily</key>\n\t\t<string>1.0.0b1</string>\n\t\t<key>com.apple.kpi.bsd</key>\n\t\t<string>10.0.0</string>\n\t\t<key>com.apple.kpi.dsep</key>\n\t\t<string>10.0.0</string>\n\t\t<key>com.apple.kpi.iokit</key>\n\t\t<string>10.0.0</string>\n\t\t<key>com.apple.kpi.libkern</key>\n\t\t<string>10.0.0</string>\n\t\t<key>com.apple.kpi.mach</key>\n\t\t<string>10.0.0</string>\n\t\t<key>com.apple.kpi.unsupported</key>\n\t\t<string>10.0.0</string>\n\t</dict>\n\t<key>OSBundleRequired</key>\n\t<string>Root</string>\n</dict>\n</plist>\n"
  },
  {
    "path": "EFI_RELEASE/EFI/OC/Resources/Font/Terminus.hex",
    "content": "0000:0000EEC600C6C6C600C6C6EE00000000\n0020:00000000000000000000000000000000\n0021:00001818181818181800181800000000\n0022:00666666000000000000000000000000\n0023:00006C6C6CFE6C6CFE6C6C6C00000000\n0024:0018187EDBD8D87E1B1BDB7E18180000\n0025:000066D66C0C181830366B6600000000\n0026:0000386C6C3876DCCCCCDC7600000000\n0027:00181818000000000000000000000000\n0028:00000C18303030303030180C00000000\n0029:000030180C0C0C0C0C0C183000000000\n002A:00000000006C38FE386C000000000000\n002B:000000000018187E1818000000000000\n002C:00000000000000000000181830000000\n002D:00000000000000FE0000000000000000\n002E:00000000000000000000181800000000\n002F:000006060C0C18183030606000000000\n0030:00007CC6C6CEDEF6E6C6C67C00000000\n0031:00001838781818181818187E00000000\n0032:00007CC6C6060C183060C0FE00000000\n0033:00007CC6C6063C0606C6C67C00000000\n0034:0000060E1E3666C6FE06060600000000\n0035:0000FEC0C0C0FC060606C67C00000000\n0036:00003C60C0C0FCC6C6C6C67C00000000\n0037:0000FE06060C0C181830303000000000\n0038:00007CC6C6C67CC6C6C6C67C00000000\n0039:00007CC6C6C6C67E06060C7800000000\n003A:00000000001818000000181800000000\n003B:00000000001818000000181830000000\n003C:000000060C18306030180C0600000000\n003D:0000000000FE0000FE00000000000000\n003E:0000006030180C060C18306000000000\n003F:00007CC6C6C60C181800181800000000\n0040:00007EC3CFDBDBDBDBCFC07F00000000\n0041:00007CC6C6C6C6FEC6C6C6C600000000\n0042:0000FCC6C6C6FCC6C6C6C6FC00000000\n0043:00007CC6C6C0C0C0C0C6C67C00000000\n0044:0000F8CCC6C6C6C6C6C6CCF800000000\n0045:0000FEC0C0C0F8C0C0C0C0FE00000000\n0046:0000FEC0C0C0F8C0C0C0C0C000000000\n0047:00007CC6C6C0C0DEC6C6C67C00000000\n0048:0000C6C6C6C6FEC6C6C6C6C600000000\n0049:00003C18181818181818183C00000000\n004A:00001E0C0C0C0C0C0CCCCC7800000000\n004B:0000C6C6CCD8F0F0D8CCC6C600000000\n004C:0000C0C0C0C0C0C0C0C0C0FE00000000\n004D:000081C3E7FFDBC3C3C3C3C300000000\n004E:0000C6C6C6E6F6DECEC6C6C600000000\n004F:00007CC6C6C6C6C6C6C6C67C00000000\n0050:0000FCC6C6C6C6FCC0C0C0C000000000\n0051:00007CC6C6C6C6C6C6C6DE7C06000000\n0052:0000FCC6C6C6C6FCF0D8CCC600000000\n0053:00007CC6C0C07C0606C6C67C00000000\n0054:0000FF18181818181818181800000000\n0055:0000C6C6C6C6C6C6C6C6C67C00000000\n0056:0000C6C6C6C6C66C6C6C383800000000\n0057:0000C3C3C3C3C3DBFFE7C38100000000\n0058:0000C6C66C6C38386C6CC6C600000000\n0059:0000C3C366663C181818181800000000\n005A:0000FE06060C183060C0C0FE00000000\n005B:00003C30303030303030303C00000000\n005C:00006060303018180C0C060600000000\n005D:00003C0C0C0C0C0C0C0C0C3C00000000\n005E:00183C66000000000000000000000000\n005F:00000000000000000000000000FE0000\n0060:30180000000000000000000000000000\n0061:00000000007C067EC6C6C67E00000000\n0062:0000C0C0C0FCC6C6C6C6C6FC00000000\n0063:00000000007CC6C0C0C0C67C00000000\n0064:00000606067EC6C6C6C6C67E00000000\n0065:00000000007CC6C6FEC0C07C00000000\n0066:00001E3030FC30303030303000000000\n0067:00000000007EC6C6C6C6C67E06067C00\n0068:0000C0C0C0FCC6C6C6C6C6C600000000\n0069:00001818003818181818183C00000000\n006A:00000606000E06060606060666663C00\n006B:0000C0C0C0C6CCD8F0D8CCC600000000\n006C:00003818181818181818183C00000000\n006D:0000000000FEDBDBDBDBDBDB00000000\n006E:0000000000FCC6C6C6C6C6C600000000\n006F:00000000007CC6C6C6C6C67C00000000\n0070:0000000000FCC6C6C6C6C6FCC0C0C000\n0071:00000000007EC6C6C6C6C67E06060600\n0072:0000000000DEF0E0C0C0C0C000000000\n0073:00000000007EC0C07C0606FC00000000\n0074:0000303030FC30303030301E00000000\n0075:0000000000C6C6C6C6C6C67E00000000\n0076:0000000000C6C6C66C6C383800000000\n0077:0000000000C3C3DBDBDBDB7E00000000\n0078:0000000000C6C66C386CC6C600000000\n0079:0000000000C6C6C6C6C6C67E06067C00\n007A:0000000000FE0C183060C0FE00000000\n007B:00001C30303060303030301C00000000\n007C:00001818181818181818181800000000\n007D:0000701818180C181818187000000000\n007E:0073DBCE000000000000000000000000\n00A0:00000000000000000000000000000000\n00A1:00001818001818181818181800000000\n00A2:00000018187EDBD8D8D8DB7E18180000\n00A3:0000386C6060F860606066FE00000000\n00A4:00000000663C6666663C660000000000\n00A5:0000C3C3663C187E187E181800000000\n00A6:00001818181800001818181800000000\n00A7:003C6660386C6666361C06663C000000\n00A8:6C6C0000000000000000000000000000\n00A9:0000007E8199A5A1A599817E00000000\n00AA:003C063E663E007E0000000000000000\n00AB:00000000001B366CD86C361B00000000\n00AC:0000000000FE06060600000000000000\n00AD:000000000000007C0000000000000000\n00AE:0000007E81B9A5B9A9A5817E00000000\n00AF:7C000000000000000000000000000000\n00B0:00386C6C380000000000000000000000\n00B1:000000000018187E1818007E00000000\n00B2:00386C0C18307C000000000000000000\n00B3:00780C380C0C78000000000000000000\n00B4:18300000000000000000000000000000\n00B5:0000000000C6C6C6C6C6CEF6C0C0C000\n00B6:00007FDBDBDBDB7B1B1B1B1B00000000\n00B7:00000000000000181800000000000000\n00B8:00000000000000000000000030306000\n00B9:0018381818183C000000000000000000\n00BA:003C6666663C007E0000000000000000\n00BB:0000000000D86C361B366CD800000000\n00BC:0060E062666C183066CE9A3E06060000\n00BD:0060E062666C183060CE9B060C1F0000\n00BE:00E0306236EC183066CE9A3E06060000\n00BF:0000303000303060C6C6C67C00000000\n00C0:3018007CC6C6C6FEC6C6C6C600000000\n00C1:1830007CC6C6C6FEC6C6C6C600000000\n00C2:386C007CC6C6C6FEC6C6C6C600000000\n00C3:76DC007CC6C6C6FEC6C6C6C600000000\n00C4:6C6C007CC6C6C6FEC6C6C6C600000000\n00C5:386C387CC6C6C6FEC6C6C6C600000000\n00C6:00007FCCCCCCFFCCCCCCCCCF00000000\n00C7:00007CC6C6C0C0C0C0C6C67C30306000\n00C8:301800FEC0C0C0F8C0C0C0FE00000000\n00C9:183000FEC0C0C0F8C0C0C0FE00000000\n00CA:386C00FEC0C0C0F8C0C0C0FE00000000\n00CB:6C6C00FEC0C0C0F8C0C0C0FE00000000\n00CC:3018003C181818181818183C00000000\n00CD:0C18003C181818181818183C00000000\n00CE:386C003C181818181818183C00000000\n00CF:6666003C181818181818183C00000000\n00D0:00007C666363FB636363667C00000000\n00D1:76DC00C6C6E6F6DECEC6C6C600000000\n00D2:3018007CC6C6C6C6C6C6C67C00000000\n00D3:1830007CC6C6C6C6C6C6C67C00000000\n00D4:386C007CC6C6C6C6C6C6C67C00000000\n00D5:76DC007CC6C6C6C6C6C6C67C00000000\n00D6:6C6C007CC6C6C6C6C6C6C67C00000000\n00D7:0000000000C66C38386CC60000000000\n00D8:00007CC7C6CEDEF6E6C6C67C00000000\n00D9:3018C6C6C6C6C6C6C6C6C67C00000000\n00DA:1830C6C6C6C6C6C6C6C6C67C00000000\n00DB:386C00C6C6C6C6C6C6C6C67C00000000\n00DC:6C6C00C6C6C6C6C6C6C6C67C00000000\n00DD:0C18C3C366663C181818181800000000\n00DE:0000C0C0FCC6C6C6C6FCC0C000000000\n00DF:000078CCCCC8FCC6C6C6E6DC00000000\n00E0:00003018007C067EC6C6C67E00000000\n00E1:00001830007C067EC6C6C67E00000000\n00E2:0000386C007C067EC6C6C67E00000000\n00E3:000076DC007C067EC6C6C67E00000000\n00E4:00006C6C007C067EC6C6C67E00000000\n00E5:0000386C387C067EC6C6C67E00000000\n00E6:0000000000761B7BDFD8D86E00000000\n00E7:00000000007CC6C0C0C0C67C30306000\n00E8:00003018007CC6C6FEC0C07C00000000\n00E9:00001830007CC6C6FEC0C07C00000000\n00EA:0000386C007CC6C6FEC0C07C00000000\n00EB:00006C6C007CC6C6FEC0C07C00000000\n00EC:00003018003818181818183C00000000\n00ED:00000C18003818181818183C00000000\n00EE:0000386C003818181818183C00000000\n00EF:00006C6C003818181818183C00000000\n00F0:00006830587CC6C6C6C6C67C00000000\n00F1:000076DC00FCC6C6C6C6C6C600000000\n00F2:00003018007CC6C6C6C6C67C00000000\n00F3:00001830007CC6C6C6C6C67C00000000\n00F4:0000386C007CC6C6C6C6C67C00000000\n00F5:000076DC007CC6C6C6C6C67C00000000\n00F6:00006C6C007CC6C6C6C6C67C00000000\n00F7:000000001818007E0018180000000000\n00F8:00000000003D676E7E76E6BC00000000\n00F9:0000301800C6C6C6C6C6C67E00000000\n00FA:0000183000C6C6C6C6C6C67E00000000\n00FB:0000386C00C6C6C6C6C6C67E00000000\n00FC:00006C6C00C6C6C6C6C6C67E00000000\n00FD:0000183000C6C6C6C6C6C67E06067C00\n00FE:0000C0C0C0FCC6C6C6C6C6FCC0C0C000\n00FF:00006C6C00C6C6C6C6C6C67E06067C00\n0100:7C007CC6C6C6C6FEC6C6C6C600000000\n0101:0000007C007C067EC6C6C67E00000000\n0102:6C38007CC6C6C6FEC6C6C6C600000000\n0103:00006C38007C067EC6C6C67E00000000\n0104:00007CC6C6C6C6FEC6C6C6C6060C0700\n0105:00000000007C067EC6C6C67E060C0700\n0106:1830007CC6C6C0C0C0C6C67C00000000\n0107:00001830007CC6C0C0C0C67C00000000\n0108:386C007CC6C6C0C0C0C6C67C00000000\n0109:0000386C007CC6C0C0C0C67C00000000\n010A:1818007CC6C6C0C0C0C6C67C00000000\n010B:00001818007CC6C0C0C0C67C00000000\n010C:6C38007CC6C6C0C0C0C6C67C00000000\n010D:00006C38007CC6C0C0C0C67C00000000\n010E:6C3800F8CCC6C6C6C6C6CCF800000000\n010F:6C380606067EC6C6C6C6C67E00000000\n0110:00007C666363FB636363667C00000000\n0111:0000061F067EC6C6C6C6C67E00000000\n0112:7C00FEC0C0C0F8C0C0C0C0FE00000000\n0113:0000007C007CC6C6FEC0C07C00000000\n0114:6C3800FEC0C0C0F8C0C0C0FE00000000\n0115:00006C38007CC6C6FEC0C07C00000000\n0116:181800FEC0C0C0F8C0C0C0FE00000000\n0117:00001818007CC6C6FEC0C07C00000000\n0118:0000FEC0C0C0F8C0C0C0C0FE060C0700\n0119:00000000007CC6C6FEC0C07C18301C00\n011A:6C3800FEC0C0C0F8C0C0C0FE00000000\n011B:00006C38007CC6C6FEC0C07C00000000\n011C:386C007CC6C0C0DEC6C6C67C00000000\n011D:0000386C007EC6C6C6C6C67E06067C00\n011E:6C38007CC6C0C0DEC6C6C67C00000000\n011F:00006C38007EC6C6C6C6C67E06067C00\n0120:1818007CC6C0C0DEC6C6C67C00000000\n0121:00001818007EC6C6C6C6C67E06067C00\n0122:00007CC6C6C0C0DEC6C6C67C00303060\n0123:000C1818007EC6C6C6C6C67E06067C00\n0124:386C00C6C6C6C6FEC6C6C6C600000000\n0125:1C36C0C0C0FCC6C6C6C6C6C600000000\n0126:000066FF66667E666666666600000000\n0127:000060F8607E63636363636300000000\n0128:76DC003C181818181818183C00000000\n0129:000076DC003818181818183C00000000\n012A:7E003C18181818181818183C00000000\n012B:0000007C003818181818183C00000000\n012C:6C38003C181818181818183C00000000\n012D:00006C38003818181818183C00000000\n012E:00003C18181818181818183C18301C00\n012F:00001818003818181818183C18301C00\n0130:1818003C181818181818183C00000000\n0131:00000000003818181818183C00000000\n0132:0000CFC6C6C6C6C6C6F6F6DC00000000\n0133:0000C6C600C6C6C6C6C6C6C636361C00\n0134:1C36001E0C0C0C0C0CCCCC7800000000\n0135:00000E1B000E06060606060666663C00\n0136:0000C6C6CCD8F0F0D8CCC6C600303060\n0137:0000C0C0C0C6CCD8F0D8CCC600303060\n0138:0000000000C6CCD8F0D8CCC600000000\n0139:60C000C0C0C0C0C0C0C0C0FE00000000\n013A:0C180038181818181818183C00000000\n013B:0000C0C0C0C0C0C0C0C0C0FE00303060\n013C:00003818181818181818183C00181830\n013D:6C38C0C0C0C0C0C0C0C0C0FE00000000\n013E:6C380038181818181818183C00000000\n013F:0000C0C0C0C0CCCCC0C0C0FE00000000\n0140:0000381818181B1B1818183C00000000\n0141:00006060606070E06060607F00000000\n0142:0000381818181C381818183C00000000\n0143:1830C6C6C6E6F6DECEC6C6C600000000\n0144:0000183000FCC6C6C6C6C6C600000000\n0145:0000C6C6C6E6F6DECEC6C6C600303060\n0146:0000000000FCC6C6C6C6C6C600303060\n0147:6C38C6C6C6E6F6DECEC6C6C600000000\n0148:00006C3800FCC6C6C6C6C6C600000000\n0149:006060C000FCC6C6C6C6C6C600000000\n014A:0000C6C6C6E6F6DECEC6C6C606061C00\n014B:0000000000FCC6C6C6C6C6C606061C00\n014C:7C007CC6C6C6C6C6C6C6C67C00000000\n014D:0000007C007CC6C6C6C6C67C00000000\n014E:6C38007CC6C6C6C6C6C6C67C00000000\n014F:00006C38007CC6C6C6C6C67C00000000\n0150:366C007CC6C6C6C6C6C6C67C00000000\n0151:0000366C007CC6C6C6C6C67C00000000\n0152:00007FCCCCCCCFCCCCCCCC7F00000000\n0153:00000000007EDBDBDFD8D87E00000000\n0154:183000FCC6C6C6FCF0D8CCC600000000\n0155:0000183000DEF0E0C0C0C0C000000000\n0156:0000FCC6C6C6C6FCF0D8CCC600303060\n0157:00000000006F787060606060006060C0\n0158:6C3800FCC6C6C6FCF0D8CCC600000000\n0159:00006C3800DEF0E0C0C0C0C000000000\n015A:1830007CC6C0C07C0606C67C00000000\n015B:00000C18007EC0C07C0606FC00000000\n015C:386C007CC6C0C07C0606C67C00000000\n015D:0000386C007EC0C07C0606FC00000000\n015E:00007CC6C0C07C0606C6C67C30306000\n015F:00000000007EC0C07C0606FC30306000\n0160:6C38007CC6C0C07C0606C67C00000000\n0161:00006C38007EC0C07C0606FC00000000\n0162:0000FF1818181818181818180C0C1800\n0163:0000303030FC30303030301E0C0C1800\n0164:6C3800FF181818181818181800000000\n0165:6C38003030FC30303030301E00000000\n0166:0000FF1818187E181818181800000000\n0167:0000303030FC30783030301E00000000\n0168:76DC00C6C6C6C6C6C6C6C67C00000000\n0169:000076DC00C6C6C6C6C6C67E00000000\n016A:7C00C6C6C6C6C6C6C6C6C67C00000000\n016B:0000007C00C6C6C6C6C6C67E00000000\n016C:6C38C6C6C6C6C6C6C6C6C67C00000000\n016D:00006C3800C6C6C6C6C6C67E00000000\n016E:386C38C6C6C6C6C6C6C6C67C00000000\n016F:0000386C38C6C6C6C6C6C67E00000000\n0170:366C00C6C6C6C6C6C6C6C67C00000000\n0171:0000366C00C6C6C6C6C6C67E00000000\n0172:0000C6C6C6C6C6C6C6C6C67C18301C00\n0173:0000000000C6C6C6C6C6C67E060C0700\n0174:386C00C3C3C3C3DBFFE7C38100000000\n0175:0000386C00C3C3DBDBDBDB7E00000000\n0176:386C00C3C366663C1818181800000000\n0177:0000386C00C6C6C6C6C6C67E06067C00\n0178:666600C3C366663C1818181800000000\n0179:183000FE060C183060C0C0FE00000000\n017A:0000183000FE0C183060C0FE00000000\n017B:181800FE060C183060C0C0FE00000000\n017C:0000181800FE0C183060C0FE00000000\n017D:6C3800FE060C183060C0C0FE00000000\n017E:00006C3800FE0C183060C0FE00000000\n017F:00001E30303030303030303000000000\n0186:00007CC6C606060606C6C67C00000000\n018E:0000FE0606063E06060606FE00000000\n018F:00007CC60606FEC6C6C6C67C00000000\n0190:00007CC6C6C078C0C0C6C67C00000000\n0192:00000E1B18187E181818181818D87000\n019D:0000636363737B6F676363636060C000\n019E:0000000000FCC6C6C6C6C6C606060600\n01B5:0000FE060C18FE3060C0C0FE00000000\n01B6:0000000000FE0C18FC3060FE00000000\n01B7:0000FE060C183C0606C6C67C00000000\n01CD:6C38007CC6C6C6FEC6C6C6C600000000\n01CE:00006C38007C067EC6C6C67E00000000\n01CF:6C38003C181818181818183C00000000\n01D0:00006C38003818181818183C00000000\n01D1:6C38007CC6C6C6C6C6C6C67C00000000\n01D2:00006C38007CC6C6C6C6C67C00000000\n01D3:6C38C6C6C6C6C6C6C6C6C67C00000000\n01D4:00006C3800C6C6C6C6C6C67E00000000\n01E2:7E007FCCCCCCFFCCCCCCCCCF00000000\n01E3:0000007E00761B7BDFD8D86E00000000\n01E4:00007CC6C6C0C0DEC6DFC67C00000000\n01E5:00000000007EC6C6DFC6C67E06067C00\n01E6:6C38007CC6C0C0DEC6C6C67C00000000\n01E7:00006C38007EC6C6C6C6C67E06067C00\n01E8:6C38C6C6CCD8F0F0D8CCC6C600000000\n01E9:6C38C0C0C0C6CCD8F0D8CCC600000000\n01EA:00007CC6C6C6C6C6C6C6C67C18301C00\n01EB:00000000007CC6C6C6C6C67C18301C00\n01EC:7C007CC6C6C6C6C6C6C6C67C18301C00\n01ED:0000007C007CC6C6C6C6C67C18301C00\n01EE:6C3800FE0C183C0606C6C67C00000000\n01EF:00006C3800FE060C183C0606C6C67C00\n01F0:00001B0E000E06060606060666663C00\n01F4:1830007CC6C0C0DEC6C6C67C00000000\n01F5:00000C18007EC6C6C6C6C67E06067C00\n01FC:0C18007FCCCCCCFFCCCCCCCF00000000\n01FD:00000C1800761B7BDFD8D86E00000000\n01FE:1830007CC7C6CEDEF6E6C67C00000000\n01FF:00001830003D676E7E76E6BC00000000\n0218:00007CC6C0C07C0606C6C67C00303060\n0219:00000000007EC0C07C0606FC00303060\n021A:0000FF18181818181818181800181830\n021B:0000303030FC30303030301E000C0C18\n0232:7E00C3C366663C181818181800000000\n0233:0000007C00C6C6C6C6C6C67E06067C00\n0237:00000000000E06060606060666663C00\n0254:00000000007CC6060606C67C00000000\n0258:00000000007CC6C6FE06067C00000000\n0259:00000000007C0606FEC6C67C00000000\n025B:00000000007CC6C078C0C67C00000000\n0272:00000000007E6363636363636060C000\n0292:0000000000FE060C183C0606C6C67C00\n02BB:18303000000000000000000000000000\n02BC:18183000000000000000000000000000\n02BD:30301800000000000000000000000000\n02C6:386C0000000000000000000000000000\n02C7:6C380000000000000000000000000000\n02D8:6C380000000000000000000000000000\n02D9:18180000000000000000000000000000\n02DB:00000000000000000000000018301C00\n02DC:76DC0000000000000000000000000000\n02DD:366C0000000000000000000000000000\n0300:30180000000000000000000000000000\n0301:18300000000000000000000000000000\n0302:386C0000000000000000000000000000\n0303:76DC0000000000000000000000000000\n0304:7C000000000000000000000000000000\n0305:FE000000000000000000000000000000\n0306:6C380000000000000000000000000000\n0307:18180000000000000000000000000000\n0308:6C6C0000000000000000000000000000\n030A:386C3800000000000000000000000000\n030B:366C0000000000000000000000000000\n030C:6C380000000000000000000000000000\n0329:00000000000000000000000000181800\n0384:60C00000000000000000000000000000\n0385:1830006C000000000000000000000000\n0386:60C07CC6C6C6C6FEC6C6C6C600000000\n0387:00000000001818000000000000000000\n0388:60C000FEC0C0C0F8C0C0C0FE00000000\n0389:60C000C6C6C6C6FEC6C6C6C600000000\n038A:60C03C18181818181818183C00000000\n038C:60C07CC6C6C6C6C6C6C6C67C00000000\n038E:60C000C3C366663C1818181800000000\n038F:60C07CC6C6C6C6C6C66C6CEE00000000\n0390:1830D8D8007030303030301C00000000\n0391:00007CC6C6C6C6FEC6C6C6C600000000\n0392:0000FCC6C6C6FCC6C6C6C6FC00000000\n0393:0000FEC0C0C0C0C0C0C0C0C000000000\n0394:000018183C3C666666C3C3FF00000000\n0395:0000FEC0C0C0F8C0C0C0C0FE00000000\n0396:0000FE06060C183060C0C0FE00000000\n0397:0000C6C6C6C6FEC6C6C6C6C600000000\n0398:00007CC6C6C6D6D6C6C6C67C00000000\n0399:00003C18181818181818183C00000000\n039A:0000C6C6CCD8F0F0D8CCC6C600000000\n039B:000018183C3C666666C3C3C300000000\n039C:000081C3E7FFDBC3C3C3C3C300000000\n039D:0000C6C6C6E6F6DECEC6C6C600000000\n039E:0000FE0000007C00000000FE00000000\n039F:00007CC6C6C6C6C6C6C6C67C00000000\n03A0:0000FEC6C6C6C6C6C6C6C6C600000000\n03A1:0000FCC6C6C6C6FCC0C0C0C000000000\n03A3:0000FEC0603018183060C0FE00000000\n03A4:0000FF18181818181818181800000000\n03A5:0000C3C366663C181818181800000000\n03A6:0000187EDBDBDBDBDBDB7E1800000000\n03A7:0000C6C66C6C38386C6CC6C600000000\n03A8:0000DBDBDBDBDBDBDB7E181800000000\n03A9:00007CC6C6C6C6C6C66C6CEE00000000\n03AA:6666003C181818181818183C00000000\n03AB:666600C3C366663C1818181800000000\n03AC:00001830007BCECCCCCCCE7B00000000\n03AD:00001830007CC6C078C0C67C00000000\n03AE:0000183000FCC6C6C6C6C6C606060600\n03AF:00001830007030303030301C00000000\n03B0:1830006C00C6C6C6C6C6C67C00000000\n03B1:00000000007BCECCCCCCCE7B00000000\n03B2:000078CCCCC8FCC6C6C6C6FCC0C0C000\n03B3:0000000000C3C366663C3C1818181800\n03B4:00007E30187CC6C6C6C6C67C00000000\n03B5:00000000007CC6C078C0C67C00000000\n03B6:0000FE0C183060C0C0C0C07C06060C00\n03B7:0000000000FCC6C6C6C6C6C606060600\n03B8:00003C6666667E666666663C00000000\n03B9:00000000007030303030301C00000000\n03BA:0000000000C6CCD8F0D8CCC600000000\n03BB:0000303018183C3C6666C3C300000000\n03BC:0000000000C6C6C6C6C6CEF6C0C0C000\n03BD:0000000000C6C6C66C6C383800000000\n03BE:00007EC0C0C07CC0C0C0C07C06060C00\n03BF:00000000007CC6C6C6C6C67C00000000\n03C0:0000000000FEC6C6C6C6C6C600000000\n03C1:00000000007CC6C6C6C6C6FCC0C0C000\n03C2:00000000007CC6C0C0C0C07C06060C00\n03C3:00000000003F66666666663C00000000\n03C4:0000000000FF18181818180E00000000\n03C5:0000000000C6C6C6C6C6C67C00000000\n03C6:00000000004EDBDBDBDBDB7E18181800\n03C7:0000000000C6C66C6C38386C6CC6C600\n03C8:0000000000DBDBDBDBDBDB7E18181800\n03C9:000000000066C3DBDBDBFF6600000000\n03CA:0000D8D8007030303030301C00000000\n03CB:00006C6C00C6C6C6C6C6C67C00000000\n03CC:00001830007CC6C6C6C6C67C00000000\n03CD:0000183000C6C6C6C6C6C67C00000000\n03CE:00000C180066C3DBDBDBFF6600000000\n03D1:00003C6666663F06E666663C00000000\n03D5:00000000187EDBDBDBDBDB7E18000000\n03F0:0000000000E3361C18386CC700000000\n03F1:00000000007CC6C6C6C6C6FCC0C07C00\n03F2:00000000007CC6C0C0C0C67C00000000\n03F3:00000606000E06060606060666663C00\n03F4:00007CC6C6C6FEC6C6C6C67C00000000\n03F5:00000000003E60C0FCC0603E00000000\n03F6:0000000000F80C067E060CF800000000\n0400:301800FEC0C0C0F8C0C0C0FE00000000\n0401:6C6C00FEC0C0C0F8C0C0C0FE00000000\n0402:0000FC30303E33333333333600000000\n0403:183000FEC0C0C0C0C0C0C0C000000000\n0404:00007CC6C0C0F8C0C0C0C67C00000000\n0405:00007CC6C0C07C0606C6C67C00000000\n0406:00003C18181818181818183C00000000\n0407:6666003C181818181818183C00000000\n0408:00001E0C0C0C0C0C0CCCCC7800000000\n0409:00003878D8DEDBDBDBDBDB9E00000000\n040A:0000D8D8D8DEFBDBDBDBDBDE00000000\n040B:0000FC30303E33333333333300000000\n040C:1830C6C6CCD8F0F0D8CCC6C600000000\n040D:3018C6C6C6CEDEF6E6C6C6C600000000\n040E:6C38C6C6C6C6C67E0606067C00000000\n040F:0000C6C6C6C6C6C6C6C6C6FE38380000\n0410:00007CC6C6C6C6FEC6C6C6C600000000\n0411:0000FCC0C0FCC6C6C6C6C6FC00000000\n0412:0000FCC6C6C6FCC6C6C6C6FC00000000\n0413:0000FEC0C0C0C0C0C0C0C0C000000000\n0414:00003E6666666666666666FFC3000000\n0415:0000FEC0C0C0F8C0C0C0C0FE00000000\n0416:0000DBDBDB7E3C7EDBDBDBDB00000000\n0417:00007CC6C6063C0606C6C67C00000000\n0418:0000C6C6C6CEDEF6E6C6C6C600000000\n0419:6C38C6C6C6CEDEF6E6C6C6C600000000\n041A:0000C6C6CCD8F0F0D8CCC6C600000000\n041B:00001E3666666666666666C600000000\n041C:000081C3E7FFDBC3C3C3C3C300000000\n041D:0000C6C6C6C6FEC6C6C6C6C600000000\n041E:00007CC6C6C6C6C6C6C6C67C00000000\n041F:0000FEC6C6C6C6C6C6C6C6C600000000\n0420:0000FCC6C6C6C6FCC0C0C0C000000000\n0421:00007CC6C6C0C0C0C0C6C67C00000000\n0422:0000FF18181818181818181800000000\n0423:0000C6C6C6C6C67E0606067C00000000\n0424:00187EDBDBDBDBDBDBDBDB7E18000000\n0425:0000C6C66C6C38386C6CC6C600000000\n0426:0000C6C6C6C6C6C6C6C6C67F03030000\n0427:0000C6C6C6C6C67E0606060600000000\n0428:0000DBDBDBDBDBDBDBDBDB7F00000000\n0429:0000D6D6D6D6D6D6D6D6D67F03030000\n042A:0000E060607E63636363637E00000000\n042B:0000C3C3C3F3DBDBDBDBDBF300000000\n042C:00006060607E63636363637E00000000\n042D:00007CC606063E060606C67C00000000\n042E:0000CEDBDBDBDBFBDBDBDBCE00000000\n042F:00007EC6C6C6C67E1E3666C600000000\n0430:00000000007C067EC6C6C67E00000000\n0431:00007CC0C0FCC6C6C6C6C6FC00000000\n0432:000078CCCCC8FCC6C6C6C6FC00000000\n0433:0000000000FEC0C0C0C0C0C000000000\n0434:00000000007EC6C6C6C6C67E06067C00\n0435:00000000007CC6C6FEC0C07C00000000\n0436:0000000000DBDB7E3C7EDBDB00000000\n0437:00000000007CC6063C06C67C00000000\n0438:0000000000C6C6C6C6C6C67E00000000\n0439:00006C3800C6C6C6C6C6C67E00000000\n043A:0000000000C6CCD8F0D8CCC600000000\n043B:00000000003E6666666666C600000000\n043C:0000000000C3E7FFDBC3C3C300000000\n043D:0000000000C6C6C6FEC6C6C600000000\n043E:00000000007CC6C6C6C6C67C00000000\n043F:0000000000FEC6C6C6C6C6C600000000\n0440:0000000000FCC6C6C6C6C6FCC0C0C000\n0441:00000000007CC6C0C0C0C67C00000000\n0442:0000000000FF18181818181800000000\n0443:0000000000C6C6C6C6C6C67E06067C00\n0444:00000000187EDBDBDBDBDB7E18000000\n0445:0000000000C6C66C386CC6C600000000\n0446:0000000000C6C6C6C6C6C67F03030000\n0447:0000000000C6C6C67E06060600000000\n0448:0000000000DBDBDBDBDBDB7F00000000\n0449:0000000000D6D6D6D6D6D67F03030000\n044A:0000000000E0607C6666667C00000000\n044B:0000000000C3C3F3DBDBDBF300000000\n044C:000000000060607C6666667C00000000\n044D:00000000007CC6063E06C67C00000000\n044E:0000000000CEDBDBFBDBDBCE00000000\n044F:00000000007EC6C67E3666C600000000\n0450:00003018007CC6C6FEC0C07C00000000\n0451:00006C6C007CC6C6FEC0C07C00000000\n0452:000060F8607E63636363636303030E00\n0453:0000183000FEC0C0C0C0C0C000000000\n0454:00000000007CC6C0F8C0C67C00000000\n0455:00000000007EC0C07C0606FC00000000\n0456:00001818003818181818183C00000000\n0457:00006C6C003818181818183C00000000\n0458:00000606000E06060606060666663C00\n0459:000000000078D8DEDBDBDB9E00000000\n045A:0000000000D8D8DEFBDBDBDE00000000\n045B:000060F8607E63636363636300000000\n045C:0000183000C6CCD8F0D8CCC600000000\n045D:0000301800C6C6C6C6C6C67E00000000\n045E:00006C3800C6C6C6C6C6C67E06067C00\n045F:0000000000C6C6C6C6C6C6FE38380000\n0462:000060F8607E63636363637E00000000\n0463:00006060F860607C6666667C00000000\n046A:0000FFC366663C7EDBDBDBDB00000000\n046B:0000000000FF663C3C7EDBDB00000000\n0490:0606FEC0C0C0C0C0C0C0C0C000000000\n0491:0000000606FEC0C0C0C0C0C000000000\n0492:00007F606060FC606060606000000000\n0493:00000000007F6060FC60606000000000\n0494:0000FEC0C0C0C0FCC6C6C6C6060C0000\n0495:0000000000FEC0C0F8CCCCCC0C180000\n0496:0000D6D6D67C387CD6D6D6D703030000\n0497:0000000000D6D67C387CD6D703030000\n0498:00007CC6C6063C0606C6C67C30303000\n0499:00000000007CC6063C06C67C30303000\n049A:0000C6C6CCD8F0F0D8CCC6C703030000\n049B:0000000000C6CCD8F0D8CCC703030000\n049C:0000C6C6D6DCF8F8DCD6C6C600000000\n049D:0000000000C6D6DCF8DCD6C600000000\n04A0:0000E3E3666C78786C66636300000000\n04A1:0000000000E3666C786C666300000000\n04A2:0000C6C6C6C6FEC6C6C6C6C703030000\n04A3:0000000000C6C6C6FEC6C6C703030000\n04A4:0000CFCCCCCCFCCCCCCCCCCC00000000\n04A5:0000000000CFCCCCFCCCCCCC00000000\n04AA:00007CC6C6C0C0C0C0C6C67C30303000\n04AB:00000000007CC6C0C0C0C67C30303000\n04AE:0000C3C366663C181818181800000000\n04AF:0000000000C3C366663C3C1818181800\n04B0:0000C3C366663C187E18181800000000\n04B1:0000000000C3C366663C3C187E181800\n04B2:0000C6C66C6C38386C6CC6C703030000\n04B3:0000000000C6C66C386CC6C703030000\n04B6:0000C6C6C6C6C67E0606060703030000\n04B7:0000000000C6C6C67E06060703030000\n04B8:0000C6C6C6D6D67E1616060600000000\n04B9:0000000000C6D6D67E16060600000000\n04BA:0000C0C0C0C0FCC6C6C6C6C600000000\n04BB:0000000000C0C0FCC6C6C6C600000000\n04C0:00003C18181818181818183C00000000\n04C1:6C3800DBDBDB7E3C7EDBDBDB00000000\n04C2:00006C3800DBDB7E3C7EDBDB00000000\n04CF:00003818181818181818183C00000000\n04D0:6C38007CC6C6C6FEC6C6C6C600000000\n04D1:00006C38007C067EC6C6C67E00000000\n04D2:6C6C007CC6C6C6FEC6C6C6C600000000\n04D3:00006C6C007C067EC6C6C67E00000000\n04D4:00007FCCCCCCFFCCCCCCCCCF00000000\n04D5:0000000000761B7BDFD8D86E00000000\n04D6:6C3800FEC0C0C0F8C0C0C0FE00000000\n04D7:00006C38007CC6C6FEC0C07C00000000\n04D8:00007CC60606FEC6C6C6C67C00000000\n04D9:00000000007C0606FEC6C67C00000000\n04DA:6C6C007CC60606FEC6C6C67C00000000\n04DB:00006C6C007C0606FEC6C67C00000000\n04DC:666600DBDBDB7E3C7EDBDBDB00000000\n04DD:0000666600DBDB7E3C7EDBDB00000000\n04DE:6C6C007CC6C6063C06C6C67C00000000\n04DF:00006C6C007CC6063C06C67C00000000\n04E2:7C00C6C6C6CEDEF6E6C6C6C600000000\n04E3:0000007C00C6C6C6C6C6C67E00000000\n04E4:6C6C00C6C6C6CEDEF6E6C6C600000000\n04E5:00006C6C00C6C6C6C6C6C67E00000000\n04E6:6C6C007CC6C6C6C6C6C6C67C00000000\n04E7:00006C6C007CC6C6C6C6C67C00000000\n04E8:00007CC6C6C6FEC6C6C6C67C00000000\n04E9:00000000007CC6C6FEC6C67C00000000\n04EA:6C6C007CC6C6C6FEC6C6C67C00000000\n04EB:00006C6C007CC6C6FEC6C67C00000000\n04EC:6C6C007CC606063E0606C67C00000000\n04ED:00006C6C007CC6063E06C67C00000000\n04EE:7C00C6C6C6C6C67E0606067C00000000\n04EF:0000007C00C6C6C6C6C6C67E06067C00\n04F0:6C6C00C6C6C6C67E0606067C00000000\n04F1:00006C6C00C6C6C6C6C6C67E06067C00\n04F2:366C00C6C6C6C67E0606067C00000000\n04F3:0000366C00C6C6C6C6C6C67E06067C00\n04F4:6C6C00C6C6C6C67E0606060600000000\n04F5:00006C6C00C6C6C67E06060600000000\n04F8:6C6C00C3C3C3F3DBDBDBDBF300000000\n04F9:00006C6C00C3C3F3DBDBDBF300000000\n05D0:0000C6C666663C78CCCCC6C600000000\n05D1:0000FC0606060606060606FF00000000\n05D2:0000780C0C0C0C0C1E3663C300000000\n05D3:0000FF06060606060606060600000000\n05D4:0000FC0606C6C6C6C6C6C6C600000000\n05D5:00007018181818181818181800000000\n05D6:00007E0C181818181818181800000000\n05D7:0000FCC6C6C6C6C6C6C6C6C600000000\n05D8:0000CCCEC6C6C6C6C6C6C67C00000000\n05D9:00007018181818000000000000000000\n05DA:0000FC06060606060606060606060600\n05DB:0000FC0606060606060606FC00000000\n05DC:C0C0FE060606060C1830303000000000\n05DD:0000FCC6C6C6C6C6C6C6C6FE00000000\n05DE:0000DE73636363636363636700000000\n05DF:0000F018181818181818181800000000\n05E0:0000780C0C0C0C0C0C0C0C7C00000000\n05E1:0000FE63636363636363633E00000000\n05E2:0000C6C6C6666636361C38E000000000\n05E3:00007CC6C6C666060606060606060600\n05E4:00007CC6C6C66606060606FC00000000\n05E5:0000636333361C181818181818181800\n05E6:0000C6C6666C383018180CFC00000000\n05E7:0000FE0606C6C6CCD8D8D8D8C0C0C000\n05E8:0000FC06060606060606060600000000\n05E9:0000DBDBDBDBDBF3E3C3C6FC00000000\n05EA:0000FE6363636363636363C300000000\n1E0C:0000F8CCC6C6C6C6C6C6CCF800303000\n1E0D:00000606067EC6C6C6C6C67E00181800\n1E34:0000C6C6CCD8F0F0D8CCC6C6007C0000\n1E35:0000C0C0C0C6CCD8F0D8CCC6007C0000\n1E36:0000C0C0C0C0C0C0C0C0C0FE00181800\n1E37:00003818181818181818183C00181800\n1E40:181881C3E7FFDBC3C3C3C3C300000000\n1E41:0000181800FEDBDBDBDBDBDB00000000\n1E42:000081C3E7FFDBC3C3C3C3C300181800\n1E43:0000000000FEDBDBDBDBDBDB00181800\n1E44:1818C6C6C6E6F6DECEC6C6C600000000\n1E45:0000303000FCC6C6C6C6C6C600000000\n1E46:0000C6C6C6E6F6DECEC6C6C600181800\n1E47:0000000000FCC6C6C6C6C6C600181800\n1E6C:0000FF18181818181818181800181800\n1E6D:0000303030FC30303030301E000C0C00\n1EB8:0000FEC0C0C0F8C0C0C0C0FE00181800\n1EB9:00000000007CC6C6FEC0C07C00181800\n1EBC:76DC00FEC0C0C0F8C0C0C0FE00000000\n1EBD:000076DC007CC6C6FEC0C07C00000000\n1ECA:00003C18181818181818183C00181800\n1ECB:00001818003818181818183C00181800\n1ECC:00007CC6C6C6C6C6C6C6C67C00181800\n1ECD:00000000007CC6C6C6C6C67C00181800\n1EE4:0000C6C6C6C6C6C6C6C6C67C00181800\n1EE5:0000000000C6C6C6C6C6C67E00181800\n1EF8:76DC00C3C366663C1818181800000000\n1EF9:000076DC00C6C6C6C6C6C67E06067C00\n2000:00000000000000000000000000000000\n2001:00000000000000000000000000000000\n2002:00000000000000000000000000000000\n2003:00000000000000000000000000000000\n2004:00000000000000000000000000000000\n2005:00000000000000000000000000000000\n2006:00000000000000000000000000000000\n2007:00000000000000000000000000000000\n2008:00000000000000000000000000000000\n2009:00000000000000000000000000000000\n200A:00000000000000000000000000000000\n200B:00000000000000000000000000000000\n200C:00000000000000000000000000000000\n200D:00000000000000000000000000000000\n200E:00000000000000000000000000000000\n200F:00000000000000000000000000000000\n2010:000000000000007C0000000000000000\n2011:000000000000007C0000000000000000\n2012:00000000000000FE0000000000000000\n2013:00000000000000FE0000000000000000\n2014:00000000000000FF0000000000000000\n2015:00000000000000FF0000000000000000\n2016:00006C6C6C6C6C6C6C6C6C6C00000000\n2017:00000000000000000000000000FE00FE\n2018:00183030000000000000000000000000\n2019:00181830000000000000000000000000\n201A:00000000000000000000181830000000\n201B:00303018000000000000000000000000\n201C:0066CCCC000000000000000000000000\n201D:00333366000000000000000000000000\n201E:000000000000000000006666CC000000\n201F:00CCCC66000000000000000000000000\n2020:000018187E1818181818181800000000\n2021:000018187E181818187E181800000000\n2022:000000000000183C3C18000000000000\n2026:00000000000000000000DBDB00000000\n2030:0000ECACF8183030607FD5DF00000000\n2032:00181818180000000000000000000000\n2033:00666666660000000000000000000000\n2039:00000000000C18306030180C00000000\n203A:00000000006030180C18306000000000\n203C:00006666666666666600666600000000\n203E:FE000000000000000000000000000000\n2070:00386C6C6C6C38000000000000000000\n2071:1800381818183C000000000000000000\n2074:000C1C347E0C0C000000000000000000\n2075:007860780C0C78000000000000000000\n2076:003860786C6C38000000000000000000\n2077:007C0C18183030000000000000000000\n2078:00386C386C6C38000000000000000000\n2079:00386C6C3C0C38000000000000000000\n207A:000018187E1818000000000000000000\n207B:000000007C0000000000000000000000\n207C:0000007C007C00000000000000000000\n207D:00183030303018000000000000000000\n207E:00301818181830000000000000000000\n207F:0000786C6C6C6C000000000000000000\n2080:00000000000000386C6C6C6C38000000\n2081:0000000000000018381818183C000000\n2082:00000000000000386C0C18307C000000\n2083:00000000000000780C380C0C78000000\n2084:000000000000000C1C347E0C0C000000\n2085:000000000000007860780C0C78000000\n2086:000000000000003860786C6C38000000\n2087:000000000000007C0C18183030000000\n2088:00000000000000386C386C6C38000000\n2089:00000000000000386C6C3C0C38000000\n208A:000000000000000018187E1818000000\n208B:000000000000000000007C0000000000\n208C:0000000000000000007C007C00000000\n208D:00000000000000183030303018000000\n208E:00000000000000301818181830000000\n2090:0000000000000000380C3C6C3C000000\n2091:0000000000000000386C7C603C000000\n2092:0000000000000000386C6C6C38000000\n2093:0000000000000000663C183C66000000\n2094:0000000000000000780C7C6C38000000\n2095:0000000000006060786C6C6C6C000000\n2096:0000000000006060666C786C66000000\n2097:0000000000003818181818183C000000\n2098:0000000000000000FCD6D6D6D6000000\n209A:0000000000000000786C6C6C78606000\n20A7:0000F8CCCCCCFAC6CFC6C6C300000000\n20AA:0000F28A8AAAAAAAAAA2A2BC00000000\n20AC:0000001E3360FC60FC60331E00000000\n20AE:0000FF18181E781E7818181800000000\n2102:00003C52525050505052523C00000000\n210E:0000C0C0C0FCC6C6C6C6C6C600000000\n210F:000060F8607E63636363636300000000\n2115:0000424262526A564A46424200000000\n2116:0000969696D0F0F0B096909600000000\n211A:00003C525252525252525A3C06000000\n211D:0000F8A4A4A4A4B8A8B4AAE600000000\n2122:0000FB55555100000000000000000000\n2124:00007E02060A14285060407E00000000\n2126:00007CC6C6C6C6C6C66C6CEE00000000\n2135:0000666633333E7CCCCCC66600000000\n2190:00000000002060FEFE60200000000000\n2191:0000183C7E1818181818181800000000\n2192:0000000000080CFEFE0C080000000000\n2193:0000181818181818187E3C1800000000\n2194:00000000002466FFFF66240000000000\n2195:0000183C7E181818187E3C1800000000\n21A4:00000000002262FEFE62220000000000\n21A6:0000000000888CFEFE8C880000000000\n21A8:0000183C7E1818187E3C187E00000000\n21B2:0000060606062666FEFE602000000000\n21B3:0000C0C0C0C0C8CCFEFE0C0800000000\n21B5:0000000006062666FEFE602000000000\n21BB:000000F83868CBC3C3663C0000000000\n21CB:0000002060FEFE00FEFE0C0800000000\n21CC:000000080CFEFE00FEFE602000000000\n21D0:00000000103E7EE07E3E100000000000\n21D1:000010387CEE6C6C6C6C6C6C00000000\n21D2:0000000010F8FC0EFCF8100000000000\n21D3:00006C6C6C6C6C6CEE7C381000000000\n21D4:00000000247EFFC3FF7E240000000000\n21D5:000010387CEE6C6CEE7C381000000000\n2200:0000C3C3C37E6666243C181800000000\n2203:000000FE060606FE060606FE00000000\n2204:00000CFE1E1636FE366666FEC0000000\n2205:000003067ECFDBDBF37E60C000000000\n2206:000018183C3C666666C3C3FF00000000\n2207:0000FFC3C36666663C3C181800000000\n2208:0000003E60C0C0FEC0C0603E00000000\n2209:0000063E6CCCD8FED8F0707E60000000\n220A:000000003E60C0FEC0603E0000000000\n220B:000000F80C0606FE06060CF800000000\n220C:0000C0F86C6636FE361E1CFC0C000000\n220D:00000000F80C06FE060CF80000000000\n2212:00000000000000FE0000000000000000\n2213:00000000007E0018187E181800000000\n2214:0000000018180018187E181800000000\n2215:0000000002060C183060C08000000000\n2216:0000000080C06030180C060200000000\n2219:00000000000038383800000000000000\n221A:000E0C0C0C0CCCCCCC6C3C1C00000000\n221E:000000000076DBDBDB6E000000000000\n221F:00000000C0C0C0C0C0FE000000000000\n2225:00006C6C6C6C6C6C6C6C6C6C00000000\n2227:0000000018183C3C6666C3C300000000\n2228:00000000C3C366663C3C181800000000\n2229:000000007CC6C6C6C6C6C6C600000000\n222A:00000000C6C6C6C6C6C6C67C00000000\n2248:000000000076DC0076DC000000000000\n2260:0000000006FE1830FEC0000000000000\n2261:00000000FE0000FE0000FE0000000000\n2264:0000000C18306030180C007E00000000\n2265:00000030180C060C1830007E00000000\n226A:000000091B366CD86C361B0900000000\n226B:00000090D86C361B366CD89000000000\n2282:000000007EC0C0C0C0C07E0000000000\n2283:00000000FC0606060606FC0000000000\n2286:0000007EC0C0C0C0C07E00FE00000000\n2287:000000FC0606060606FC00FE00000000\n22A5:0000000018181818181818FF00000000\n22C2:00007CC6C6C6C6C6C6C6C6C600000000\n22C3:0000C6C6C6C6C6C6C6C6C67C00000000\n2300:000003067ECFDBDBF37E60C000000000\n2302:00000000183C66C3C3C3C3FF00000000\n2308:00003C30303030303030303000000000\n2309:00003C0C0C0C0C0C0C0C0C0C00000000\n230A:00003030303030303030303C00000000\n230B:00000C0C0C0C0C0C0C0C0C3C00000000\n2310:0000000000FEC0C0C000000000000000\n2319:0000000000C0C0C0FE00000000000000\n2320:00000E1B1B1818181818181818181818\n2321:181818181818181818D8D87000000000\n239B:060C1818303030606060606060606060\n239C:60606060606060606060606060606060\n239D:60606060606060606030303018180C06\n239E:603018180C0C0C060606060606060606\n239F:06060606060606060606060606060606\n23A0:0606060606060606060C0C0C18183060\n23A1:7E606060606060606060606060606060\n23A2:60606060606060606060606060606060\n23A3:6060606060606060606060606060607E\n23A4:7E060606060606060606060606060606\n23A5:06060606060606060606060606060606\n23A6:0606060606060606060606060606067E\n23A7:0F183030303030303030303030303030\n23A8:30303030303030E0E030303030303030\n23A9:3030303030303030303030303030180F\n23AB:F0180C0C0C0C0C0C0C0C0C0C0C0C0C0C\n23AC:0C0C0C0C0C0C0C07070C0C0C0C0C0C0C\n23AD:0C0C0C0C0C0C0C0C0C0C0C0C0C0C18F0\n23AE:18181818181818181818181818181818\n23AF:00000000000000FFFF00000000000000\n23BA:FFFF0000000000000000000000000000\n23BB:00000000FFFF00000000000000000000\n23BC:00000000000000000000FFFF00000000\n23BD:0000000000000000000000000000FFFF\n23D0:18181818181818181818181818181818\n2409:00CCCCFCCCCCCC003F0C0C0C0C0C0000\n240A:00C0C0C0C0C0F8003F303C3030300000\n240B:00CCCCCCCC7830003F0C0C0C0C0C0000\n240C:00FCC0F0C0C0C0003F303C3030300000\n240D:0078CCC0C0CC78003E33333E36330000\n2424:00CCECFCDCCCCC0030303030303F0000\n2500:00000000000000FFFF00000000000000\n2501:000000000000FFFFFF00000000000000\n2502:18181818181818181818181818181818\n2503:38383838383838383838383838383838\n2508:00000000000000AAAA00000000000000\n2509:000000000000AAAAAA00000000000000\n250A:18181800181818001818180018181800\n250B:38383800383838003838380038383800\n250C:000000000000001F1F18181818181818\n250D:0000000000001F1F1F18181818181818\n250E:000000000000003F3F38383838383838\n250F:0000000000003F3F3F38383838383838\n2510:00000000000000F8F818181818181818\n2511:000000000000F8F8F818181818181818\n2512:00000000000000F8F838383838383838\n2513:000000000000F8F8F838383838383838\n2514:181818181818181F1F00000000000000\n2515:1818181818181F1F1F00000000000000\n2516:383838383838383F3F00000000000000\n2517:3838383838383F3F3F00000000000000\n2518:18181818181818F8F800000000000000\n2519:181818181818F8F8F800000000000000\n251A:38383838383838F8F800000000000000\n251B:383838383838F8F8F800000000000000\n251C:181818181818181F1F18181818181818\n251D:1818181818181F1F1F18181818181818\n251E:383838383838383F3F18181818181818\n251F:181818181818183F3F38383838383838\n2520:383838383838383F3F38383838383838\n2521:3838383838383F3F3F18181818181818\n2522:1818181818183F3F3F38383838383838\n2523:3838383838383F3F3F38383838383838\n2524:18181818181818F8F818181818181818\n2525:181818181818F8F8F818181818181818\n2526:38383838383838F8F818181818181818\n2527:18181818181818F8F838383838383838\n2528:38383838383838F8F838383838383838\n2529:383838383838F8F8F818181818181818\n252A:181818181818F8F8F838383838383838\n252B:383838383838F8F8F838383838383838\n252C:00000000000000FFFF18181818181818\n252D:000000000000F8FFFF18181818181818\n252E:0000000000001FFFFF18181818181818\n252F:000000000000FFFFFF18181818181818\n2530:00000000000000FFFF38383838383838\n2531:000000000000F8FFFF38383838383838\n2532:0000000000003FFFFF38383838383838\n2533:000000000000FFFFFF38383838383838\n2534:18181818181818FFFF00000000000000\n2535:181818181818F8FFFF00000000000000\n2536:1818181818181FFFFF00000000000000\n2537:181818181818FFFFFF00000000000000\n2538:38383838383838FFFF00000000000000\n2539:383838383838F8FFFF00000000000000\n253A:3838383838383FFFFF00000000000000\n253B:383838383838FFFFFF00000000000000\n253C:18181818181818FFFF18181818181818\n253D:181818181818F8FFFF18181818181818\n253E:1818181818181FFFFF18181818181818\n253F:181818181818FFFFFF18181818181818\n2540:38383838383838FFFF18181818181818\n2541:18181818181818FFFF38383838383838\n2542:38383838383838FFFF38383838383838\n2543:383838383838F8FFFF18181818181818\n2544:3838383838383FFFFF18181818181818\n2545:181818181818F8FFFF38383838383838\n2546:1818181818181FFFFF38383838383838\n2547:383838383838FFFFFF18181818181818\n2548:181818181818FFFFFF38383838383838\n2549:383838383838F8FFFF38383838383838\n254A:3838383838383FFFFF38383838383838\n254B:383838383838FFFFFF38383838383838\n2550:0000000000FFFF00FFFF000000000000\n2551:6C6C6C6C6C6C6C6C6C6C6C6C6C6C6C6C\n2552:00000000001F1F181F1F181818181818\n2553:000000000000007F7F6C6C6C6C6C6C6C\n2554:00000000007F7F606F6F6C6C6C6C6C6C\n2555:0000000000F8F818F8F8181818181818\n2556:00000000000000FCFC6C6C6C6C6C6C6C\n2557:0000000000FCFC0CECEC6C6C6C6C6C6C\n2558:18181818181F1F181F1F000000000000\n2559:6C6C6C6C6C6C6C7F7F00000000000000\n255A:6C6C6C6C6C6F6F607F7F000000000000\n255B:1818181818F8F818F8F8000000000000\n255C:6C6C6C6C6C6C6CFCFC00000000000000\n255D:6C6C6C6C6CECEC0CFCFC000000000000\n255E:18181818181F1F181F1F181818181818\n255F:6C6C6C6C6C6C6C6F6F6C6C6C6C6C6C6C\n2560:6C6C6C6C6C6F6F606F6F6C6C6C6C6C6C\n2561:1818181818F8F818F8F8181818181818\n2562:6C6C6C6C6C6C6CECEC6C6C6C6C6C6C6C\n2563:6C6C6C6C6CECEC0CECEC6C6C6C6C6C6C\n2564:0000000000FFFF00FFFF181818181818\n2565:00000000000000FFFF6C6C6C6C6C6C6C\n2566:0000000000FFFF00EFEF6C6C6C6C6C6C\n2567:1818181818FFFF00FFFF000000000000\n2568:6C6C6C6C6C6C6CFFFF00000000000000\n2569:6C6C6C6C6CEFEF00FFFF000000000000\n256A:1818181818FFFF18FFFF181818181818\n256B:6C6C6C6C6C6C6CFFFF6C6C6C6C6C6C6C\n256C:6C6C6C6C6CEFEF00EFEF6C6C6C6C6C6C\n256D:00000000000000070F1C181818181818\n256E:00000000000000E0F038181818181818\n256F:18181818181838F0E000000000000000\n2570:1818181818181C0F0700000000000000\n2571:0101030206040C08181030206040C080\n2572:80C0406020301018080C040602030101\n2573:81C1436226341C18181C34266243C181\n2574:00000000000000F8F800000000000000\n2575:18181818181818181800000000000000\n2576:000000000000001F1F00000000000000\n2577:00000000000000181818181818181818\n2578:000000000000F8F8F800000000000000\n2579:38383838383838383800000000000000\n257A:0000000000001F1F1F00000000000000\n257B:00000000000000383838383838383838\n257C:0000000000001FFFFF00000000000000\n257D:18181818181818383838383838383838\n257E:000000000000F8FFFF00000000000000\n257F:38383838383838383818181818181818\n2580:FFFFFFFFFFFFFFFF0000000000000000\n2581:0000000000000000000000000000FFFF\n2582:000000000000000000000000FFFFFFFF\n2583:00000000000000000000FFFFFFFFFFFF\n2584:0000000000000000FFFFFFFFFFFFFFFF\n2585:000000000000FFFFFFFFFFFFFFFFFFFF\n2586:00000000FFFFFFFFFFFFFFFFFFFFFFFF\n2587:0000FFFFFFFFFFFFFFFFFFFFFFFFFFFF\n2588:FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF\n2589:FEFEFEFEFEFEFEFEFEFEFEFEFEFEFEFE\n258A:FCFCFCFCFCFCFCFCFCFCFCFCFCFCFCFC\n258B:F8F8F8F8F8F8F8F8F8F8F8F8F8F8F8F8\n258C:F0F0F0F0F0F0F0F0F0F0F0F0F0F0F0F0\n258D:E0E0E0E0E0E0E0E0E0E0E0E0E0E0E0E0\n258E:C0C0C0C0C0C0C0C0C0C0C0C0C0C0C0C0\n258F:80808080808080808080808080808080\n2590:0F0F0F0F0F0F0F0F0F0F0F0F0F0F0F0F\n2591:88228822882288228822882288228822\n2592:AA55AA55AA55AA55AA55AA55AA55AA55\n2593:EEBBEEBBEEBBEEBBEEBBEEBBEEBBEEBB\n2596:0000000000000000F0F0F0F0F0F0F0F0\n2597:00000000000000000F0F0F0F0F0F0F0F\n2598:F0F0F0F0F0F0F0F00000000000000000\n2599:F0F0F0F0F0F0F0F0FFFFFFFFFFFFFFFF\n259A:F0F0F0F0F0F0F0F00F0F0F0F0F0F0F0F\n259B:FFFFFFFFFFFFFFFFF0F0F0F0F0F0F0F0\n259C:FFFFFFFFFFFFFFFF0F0F0F0F0F0F0F0F\n259D:0F0F0F0F0F0F0F0F0000000000000000\n259E:0F0F0F0F0F0F0F0FF0F0F0F0F0F0F0F0\n259F:0F0F0F0F0F0F0F0FFFFFFFFFFFFFFFFF\n25A0:00000000007C7C7C7C7C7C0000000000\n25AC:0000000000000000FEFEFEFE00000000\n25AE:0000FEFEFEFEFEFEFEFEFEFE00000000\n25B2:0000000018183C3C7E7EFFFF00000000\n25B6:00000000C0F0FCFFFFFCF0C000000000\n25BA:00000000C0F0FCFFFFFCF0C000000000\n25BC:00000000FFFF7E7E3C3C181800000000\n25C0:00000000030F3FFFFF3F0F0300000000\n25C4:00000000030F3FFFFF3F0F0300000000\n25C6:00000000183C7EFF7E3C180000000000\n25CA:00000000183C66C3663C180000000000\n25CB:00000000003C664242663C0000000000\n25CF:00000000003C7E7E7E7E3C0000000000\n25D8:FFFFFFFFFFFFE7C3C3E7FFFFFFFFFFFF\n25D9:FFFFFFFFFFC399BDBD99C3FFFFFFFFFF\n263A:00007E81A58181BD9981817E00000000\n263B:00007EFFDBFFFFC3E7FFFF7E00000000\n263C:00000018DB7E3CE73C7EDB1800000000\n2640:00003C666666663C187E181800000000\n2642:00003E0E1A3278CCCCCCCC7800000000\n2660:000018183C7EFFFF7E18183C00000000\n2663:0000183C3C185AFFFF5A183C00000000\n2665:0000000066FFFFFFFF7E3C1800000000\n2666:00000000183C7EFF7E3C180000000000\n266A:00003F333F3030303030F0E000000000\n266B:00007F637F636363636367E6C0000000\n2713:000003030606CCCC7878303000000000\n2714:000007070E0EDCFC7878303000000000\n2717:00000CCC7838383C6660C0C000000000\n2718:00000EEE7C3C3C3E7773E0E000000000\n27E8:00000C0C1818303018180C0C00000000\n27E9:0000303018180C0C1818303000000000\n27EA:000036366C6CD8D86C6C363600000000\n27EB:0000D8D86C6C36366C6CD8D800000000\n2800:00000000000000000000000000000000\n2801:00606000000000000000000000000000\n2802:00000000006060000000000000000000\n2803:00606000006060000000000000000000\n2804:00000000000000000060600000000000\n2805:00606000000000000060600000000000\n2806:00000000006060000060600000000000\n2807:00606000006060000060600000000000\n2808:00060600000000000000000000000000\n2809:00666600000000000000000000000000\n280A:00060600006060000000000000000000\n280B:00666600006060000000000000000000\n280C:00060600000000000060600000000000\n280D:00666600000000000060600000000000\n280E:00060600006060000060600000000000\n280F:00666600006060000060600000000000\n2810:00000000000606000000000000000000\n2811:00606000000606000000000000000000\n2812:00000000006666000000000000000000\n2813:00606000006666000000000000000000\n2814:00000000000606000060600000000000\n2815:00606000000606000060600000000000\n2816:00000000006666000060600000000000\n2817:00606000006666000060600000000000\n2818:00060600000606000000000000000000\n2819:00666600000606000000000000000000\n281A:00060600006666000000000000000000\n281B:00666600006666000000000000000000\n281C:00060600000606000060600000000000\n281D:00666600000606000060600000000000\n281E:00060600006666000060600000000000\n281F:00666600006666000060600000000000\n2820:00000000000000000006060000000000\n2821:00606000000000000006060000000000\n2822:00000000006060000006060000000000\n2823:00606000006060000006060000000000\n2824:00000000000000000066660000000000\n2825:00606000000000000066660000000000\n2826:00000000006060000066660000000000\n2827:00606000006060000066660000000000\n2828:00060600000000000006060000000000\n2829:00666600000000000006060000000000\n282A:00060600006060000006060000000000\n282B:00666600006060000006060000000000\n282C:00060600000000000066660000000000\n282D:00666600000000000066660000000000\n282E:00060600006060000066660000000000\n282F:00666600006060000066660000000000\n2830:00000000000606000006060000000000\n2831:00606000000606000006060000000000\n2832:00000000006666000006060000000000\n2833:00606000006666000006060000000000\n2834:00000000000606000066660000000000\n2835:00606000000606000066660000000000\n2836:00000000006666000066660000000000\n2837:00606000006666000066660000000000\n2838:00060600000606000006060000000000\n2839:00666600000606000006060000000000\n283A:00060600006666000006060000000000\n283B:00666600006666000006060000000000\n283C:00060600000606000066660000000000\n283D:00666600000606000066660000000000\n283E:00060600006666000066660000000000\n283F:00666600006666000066660000000000\n2840:00000000000000000000000000606000\n2841:00606000000000000000000000606000\n2842:00000000006060000000000000606000\n2843:00606000006060000000000000606000\n2844:00000000000000000060600000606000\n2845:00606000000000000060600000606000\n2846:00000000006060000060600000606000\n2847:00606000006060000060600000606000\n2848:00060600000000000000000000606000\n2849:00666600000000000000000000606000\n284A:00060600006060000000000000606000\n284B:00666600006060000000000000606000\n284C:00060600000000000060600000606000\n284D:00666600000000000060600000606000\n284E:00060600006060000060600000606000\n284F:00666600006060000060600000606000\n2850:00000000000606000000000000606000\n2851:00606000000606000000000000606000\n2852:00000000006666000000000000606000\n2853:00606000006666000000000000606000\n2854:00000000000606000060600000606000\n2855:00606000000606000060600000606000\n2856:00000000006666000060600000606000\n2857:00606000006666000060600000606000\n2858:00060600000606000000000000606000\n2859:00666600000606000000000000606000\n285A:00060600006666000000000000606000\n285B:00666600006666000000000000606000\n285C:00060600000606000060600000606000\n285D:00666600000606000060600000606000\n285E:00060600006666000060600000606000\n285F:00666600006666000060600000606000\n2860:00000000000000000006060000606000\n2861:00606000000000000006060000606000\n2862:00000000006060000006060000606000\n2863:00606000006060000006060000606000\n2864:00000000000000000066660000606000\n2865:00606000000000000066660000606000\n2866:00000000006060000066660000606000\n2867:00606000006060000066660000606000\n2868:00060600000000000006060000606000\n2869:00666600000000000006060000606000\n286A:00060600006060000006060000606000\n286B:00666600006060000006060000606000\n286C:00060600000000000066660000606000\n286D:00666600000000000066660000606000\n286E:00060600006060000066660000606000\n286F:00666600006060000066660000606000\n2870:00000000000606000006060000606000\n2871:00606000000606000006060000606000\n2872:00000000006666000006060000606000\n2873:00606000006666000006060000606000\n2874:00000000000606000066660000606000\n2875:00606000000606000066660000606000\n2876:00000000006666000066660000606000\n2877:00606000006666000066660000606000\n2878:00060600000606000006060000606000\n2879:00666600000606000006060000606000\n287A:00060600006666000006060000606000\n287B:00666600006666000006060000606000\n287C:00060600000606000066660000606000\n287D:00666600000606000066660000606000\n287E:00060600006666000066660000606000\n287F:00666600006666000066660000606000\n2880:00000000000000000000000000060600\n2881:00606000000000000000000000060600\n2882:00000000006060000000000000060600\n2883:00606000006060000000000000060600\n2884:00000000000000000060600000060600\n2885:00606000000000000060600000060600\n2886:00000000006060000060600000060600\n2887:00606000006060000060600000060600\n2888:00060600000000000000000000060600\n2889:00666600000000000000000000060600\n288A:00060600006060000000000000060600\n288B:00666600006060000000000000060600\n288C:00060600000000000060600000060600\n288D:00666600000000000060600000060600\n288E:00060600006060000060600000060600\n288F:00666600006060000060600000060600\n2890:00000000000606000000000000060600\n2891:00606000000606000000000000060600\n2892:00000000006666000000000000060600\n2893:00606000006666000000000000060600\n2894:00000000000606000060600000060600\n2895:00606000000606000060600000060600\n2896:00000000006666000060600000060600\n2897:00606000006666000060600000060600\n2898:00060600000606000000000000060600\n2899:00666600000606000000000000060600\n289A:00060600006666000000000000060600\n289B:00666600006666000000000000060600\n289C:00060600000606000060600000060600\n289D:00666600000606000060600000060600\n289E:00060600006666000060600000060600\n289F:00666600006666000060600000060600\n28A0:00000000000000000006060000060600\n28A1:00606000000000000006060000060600\n28A2:00000000006060000006060000060600\n28A3:00606000006060000006060000060600\n28A4:00000000000000000066660000060600\n28A5:00606000000000000066660000060600\n28A6:00000000006060000066660000060600\n28A7:00606000006060000066660000060600\n28A8:00060600000000000006060000060600\n28A9:00666600000000000006060000060600\n28AA:00060600006060000006060000060600\n28AB:00666600006060000006060000060600\n28AC:00060600000000000066660000060600\n28AD:00666600000000000066660000060600\n28AE:00060600006060000066660000060600\n28AF:00666600006060000066660000060600\n28B0:00000000000606000006060000060600\n28B1:00606000000606000006060000060600\n28B2:00000000006666000006060000060600\n28B3:00606000006666000006060000060600\n28B4:00000000000606000066660000060600\n28B5:00606000000606000066660000060600\n28B6:00000000006666000066660000060600\n28B7:00606000006666000066660000060600\n28B8:00060600000606000006060000060600\n28B9:00666600000606000006060000060600\n28BA:00060600006666000006060000060600\n28BB:00666600006666000006060000060600\n28BC:00060600000606000066660000060600\n28BD:00666600000606000066660000060600\n28BE:00060600006666000066660000060600\n28BF:00666600006666000066660000060600\n28C0:00000000000000000000000000666600\n28C1:00606000000000000000000000666600\n28C2:00000000006060000000000000666600\n28C3:00606000006060000000000000666600\n28C4:00000000000000000060600000666600\n28C5:00606000000000000060600000666600\n28C6:00000000006060000060600000666600\n28C7:00606000006060000060600000666600\n28C8:00060600000000000000000000666600\n28C9:00666600000000000000000000666600\n28CA:00060600006060000000000000666600\n28CB:00666600006060000000000000666600\n28CC:00060600000000000060600000666600\n28CD:00666600000000000060600000666600\n28CE:00060600006060000060600000666600\n28CF:00666600006060000060600000666600\n28D0:00000000000606000000000000666600\n28D1:00606000000606000000000000666600\n28D2:00000000006666000000000000666600\n28D3:00606000006666000000000000666600\n28D4:00000000000606000060600000666600\n28D5:00606000000606000060600000666600\n28D6:00000000006666000060600000666600\n28D7:00606000006666000060600000666600\n28D8:00060600000606000000000000666600\n28D9:00666600000606000000000000666600\n28DA:00060600006666000000000000666600\n28DB:00666600006666000000000000666600\n28DC:00060600000606000060600000666600\n28DD:00666600000606000060600000666600\n28DE:00060600006666000060600000666600\n28DF:00666600006666000060600000666600\n28E0:00000000000000000006060000666600\n28E1:00606000000000000006060000666600\n28E2:00000000006060000006060000666600\n28E3:00606000006060000006060000666600\n28E4:00000000000000000066660000666600\n28E5:00606000000000000066660000666600\n28E6:00000000006060000066660000666600\n28E7:00606000006060000066660000666600\n28E8:00060600000000000006060000666600\n28E9:00666600000000000006060000666600\n28EA:00060600006060000006060000666600\n28EB:00666600006060000006060000666600\n28EC:00060600000000000066660000666600\n28ED:00666600000000000066660000666600\n28EE:00060600006060000066660000666600\n28EF:00666600006060000066660000666600\n28F0:00000000000606000006060000666600\n28F1:00606000000606000006060000666600\n28F2:00000000006666000006060000666600\n28F3:00606000006666000006060000666600\n28F4:00000000000606000066660000666600\n28F5:00606000000606000066660000666600\n28F6:00000000006666000066660000666600\n28F7:00606000006666000066660000666600\n28F8:00060600000606000006060000666600\n28F9:00666600000606000006060000666600\n28FA:00060600006666000006060000666600\n28FB:00666600006666000006060000666600\n28FC:00060600000606000066660000666600\n28FD:00666600000606000066660000666600\n28FE:00060600006666000066660000666600\n28FF:00666600006666000066660000666600\n2E2C:0000000000C6C6000000C6C600000000\nE0A0:C0C0CCDEFFCCCCCC983060C0C0C0C0C0\nE0A1:00C0C0C0C0C0FC00333B3F3733330000\nE0A2:003C66666666FFFFE7C3E7FFFFFF0000\nE0B0:80C0E0F0F8FCFEFFFFFEFCF8F0E0C080\nE0B1:80C06030180C060303060C183060C080\nE0B2:0103070F1F3F7FFFFF7F3F1F0F070301\nE0B3:0103060C183060C0C06030180C060301\nF6BE:00000000000E06060606060666663C00\nFFFD:0000FEC6C6C6C6C6C6C6C6FE00000000\n"
  },
  {
    "path": "EFI_RELEASE/EFI/OC/Resources/Font/TerminusCore.hex",
    "content": "0000:0000EEC600C6C6C600C6C6EE00000000\n0020:00000000000000000000000000000000\n0021:00001818181818181800181800000000\n0022:00666666000000000000000000000000\n0023:00006C6C6CFE6C6CFE6C6C6C00000000\n0024:0018187EDBD8D87E1B1BDB7E18180000\n0025:000066D66C0C181830366B6600000000\n0026:0000386C6C3876DCCCCCDC7600000000\n0027:00181818000000000000000000000000\n0028:00000C18303030303030180C00000000\n0029:000030180C0C0C0C0C0C183000000000\n002A:00000000006C38FE386C000000000000\n002B:000000000018187E1818000000000000\n002C:00000000000000000000181830000000\n002D:00000000000000FE0000000000000000\n002E:00000000000000000000181800000000\n002F:000006060C0C18183030606000000000\n0030:00007CC6C6CEDEF6E6C6C67C00000000\n0031:00001838781818181818187E00000000\n0032:00007CC6C6060C183060C0FE00000000\n0033:00007CC6C6063C0606C6C67C00000000\n0034:0000060E1E3666C6FE06060600000000\n0035:0000FEC0C0C0FC060606C67C00000000\n0036:00003C60C0C0FCC6C6C6C67C00000000\n0037:0000FE06060C0C181830303000000000\n0038:00007CC6C6C67CC6C6C6C67C00000000\n0039:00007CC6C6C6C67E06060C7800000000\n003A:00000000001818000000181800000000\n003B:00000000001818000000181830000000\n003C:000000060C18306030180C0600000000\n003D:0000000000FE0000FE00000000000000\n003E:0000006030180C060C18306000000000\n003F:00007CC6C6C60C181800181800000000\n0040:00003E63CFDBDBDBDBCE603E00000000\n0041:00007CC6C6C6C6FEC6C6C6C600000000\n0042:0000FCC6C6C6FCC6C6C6C6FC00000000\n0043:00007CC6C6C0C0C0C0C6C67C00000000\n0044:0000F8CCC6C6C6C6C6C6CCF800000000\n0045:0000FEC0C0C0F8C0C0C0C0FE00000000\n0046:0000FEC0C0C0F8C0C0C0C0C000000000\n0047:00007CC6C6C0C0DEC6C6C67C00000000\n0048:0000C6C6C6C6FEC6C6C6C6C600000000\n0049:00003C18181818181818183C00000000\n004A:00001E0C0C0C0C0C0CCCCC7800000000\n004B:0000C6CCD8F0E0E0F0D8CCC600000000\n004C:0000C0C0C0C0C0C0C0C0C0FE00000000\n004D:0000C6C6EEFED6D6C6C6C6C600000000\n004E:0000C6C6C6E6F6DECEC6C6C600000000\n004F:00007CC6C6C6C6C6C6C6C67C00000000\n0050:0000FCC6C6C6C6FCC0C0C0C000000000\n0051:00007CC6C6C6C6C6C6C6DE7C06000000\n0052:0000FCC6C6C6C6FCF8CCC6C600000000\n0053:00007CC6C0C07C060606C67C00000000\n0054:00007E18181818181818181800000000\n0055:0000C6C6C6C6C6C6C6C6C67C00000000\n0056:0000C6C6C6C6C66C6C38381000000000\n0057:0000C6C6C6C6D6D6FEEE6C6C00000000\n0058:0000C6C66C6C38386C6CC6C600000000\n0059:0000C3C366663C181818181800000000\n005A:0000FE06060C183060C0C0FE00000000\n005B:00003C30303030303030303C00000000\n005C:00006060303018180C0C060600000000\n005D:00003C0C0C0C0C0C0C0C0C3C00000000\n005E:00183C66000000000000000000000000\n005F:00000000000000000000000000FE0000\n0060:30180000000000000000000000000000\n0061:00000000007C067EC6C6C67E00000000\n0062:0000C0C0C0FCC6C6C6C6C6FC00000000\n0063:00000000007CC6C0C0C0C67C00000000\n0064:00000606067EC6C6C6C6C67E00000000\n0065:00000000007CC6C6FEC0C07C00000000\n0066:00001E3030FC30303030303000000000\n0067:00000000007EC6C6C6C6C67E06067C00\n0068:0000C0C0C0FCC6C6C6C6C6C600000000\n0069:00003030007030303030307800000000\n006A:00000606000E06060606060666663C00\n006B:0000C0C0C0C6CCD8F0D8CCC600000000\n006C:00003818181818181818183C00000000\n006D:0000000000FCD6D6D6D6D6D600000000\n006E:0000000000FCC6C6C6C6C6C600000000\n006F:00000000007CC6C6C6C6C67C00000000\n0070:0000000000FCC6C6C6C6C6FCC0C0C000\n0071:00000000007EC6C6C6C6C67E06060600\n0072:0000000000DCE6C0C0C0C0C000000000\n0073:00000000007CC2C07C06867C00000000\n0074:0000303030FC30303030301E00000000\n0075:0000000000C6C6C6C6C6C67E00000000\n0076:0000000000C6C6C66C6C383800000000\n0077:0000000000C6C6D6D6D6D67C00000000\n0078:0000000000C6C66C386CC6C600000000\n0079:0000000000C6C6C6C6C6C67E06067C00\n007A:0000000000FE0C183060C0FE00000000\n007B:00001C30303060303030301C00000000\n007C:00001818181818181818181800000000\n007D:0000701818180C181818187000000000\n007E:0073DBCE000000000000000000000000\n00A0:00000000000000000000000000000000\n00A1:00001818001818181818181800000000\n00A2:00000018187EDBD8D8D8DB7E18180000\n00A3:0000386C6060F860606066FE00000000\n00A4:00000000663C6666663C660000000000\n00A5:0000C3C3663C187E187E181800000000\n00A6:00001818181800001818181800000000\n00A7:003C6660386C6666361C06663C000000\n00A8:6C6C0000000000000000000000000000\n00A9:0000007E8199A5A1A599817E00000000\n00AA:003C063E663E007E0000000000000000\n00AB:00000000001B366CD86C361B00000000\n00AC:0000000000FE06060600000000000000\n00AD:000000000000007C0000000000000000\n00AE:0000007E81B9A5B9A9A5817E00000000\n00AF:7C000000000000000000000000000000\n00B0:00386C6C380000000000000000000000\n00B1:000000000018187E1818007E00000000\n00B2:00386C0C18307C000000000000000000\n00B3:00780C380C0C78000000000000000000\n00B4:18300000000000000000000000000000\n00B5:0000000000C6C6C6C6C6CEF6C0C0C000\n00B6:00007FDBDBDBDB7B1B1B1B1B00000000\n00B7:00000000000000181800000000000000\n00B8:00000000000000000000000030306000\n00B9:0018381818183C000000000000000000\n00BA:003C6666663C007E0000000000000000\n00BB:0000000000D86C361B366CD800000000\n00BC:0060E062666C183066CE9A3E06060000\n00BD:0060E062666C183060CE9B060C1F0000\n00BE:00E0306236EC183066CE9A3E06060000\n00BF:0000303000303060C6C6C67C00000000\n00C0:3018007CC6C6C6FEC6C6C6C600000000\n00C1:1830007CC6C6C6FEC6C6C6C600000000\n00C2:386C007CC6C6C6FEC6C6C6C600000000\n00C3:76DC007CC6C6C6FEC6C6C6C600000000\n00C4:6C6C007CC6C6C6FEC6C6C6C600000000\n00C5:386C387CC6C6C6FEC6C6C6C600000000\n00C6:00007FCCCCCCFFCCCCCCCCCF00000000\n00C7:00007CC6C6C0C0C0C0C6C67C30306000\n00C8:301800FEC0C0C0F8C0C0C0FE00000000\n00C9:183000FEC0C0C0F8C0C0C0FE00000000\n00CA:386C00FEC0C0C0F8C0C0C0FE00000000\n00CB:6C6C00FEC0C0C0F8C0C0C0FE00000000\n00CC:3018003C181818181818183C00000000\n00CD:0C18003C181818181818183C00000000\n00CE:386C003C181818181818183C00000000\n00CF:6666003C181818181818183C00000000\n00D0:00007C666363FB636363667C00000000\n00D1:76DC00C6C6E6F6DECEC6C6C600000000\n00D2:3018007CC6C6C6C6C6C6C67C00000000\n00D3:1830007CC6C6C6C6C6C6C67C00000000\n00D4:386C007CC6C6C6C6C6C6C67C00000000\n00D5:76DC007CC6C6C6C6C6C6C67C00000000\n00D6:6C6C007CC6C6C6C6C6C6C67C00000000\n00D7:0000000000C66C38386CC60000000000\n00D8:00007CC7C6CEDEF6E6C6C67C00000000\n00D9:3018C6C6C6C6C6C6C6C6C67C00000000\n00DA:1830C6C6C6C6C6C6C6C6C67C00000000\n00DB:386C00C6C6C6C6C6C6C6C67C00000000\n00DC:6C6C00C6C6C6C6C6C6C6C67C00000000\n00DD:0C18C3C366663C181818181800000000\n00DE:0000C0C0FCC6C6C6C6FCC0C000000000\n00DF:000078CCCCC8FCC6C6C6E6DC00000000\n00E0:00003018007C067EC6C6C67E00000000\n00E1:00001830007C067EC6C6C67E00000000\n00E2:0000386C007C067EC6C6C67E00000000\n00E3:000076DC007C067EC6C6C67E00000000\n00E4:00006C6C007C067EC6C6C67E00000000\n00E5:0000386C387C067EC6C6C67E00000000\n00E6:0000000000761B7BDFD8D86E00000000\n00E7:00000000007CC6C0C0C0C67C30306000\n00E8:00003018007CC6C6FEC0C07C00000000\n00E9:00001830007CC6C6FEC0C07C00000000\n00EA:0000386C007CC6C6FEC0C07C00000000\n00EB:00006C6C007CC6C6FEC0C07C00000000\n00EC:00003018003818181818183C00000000\n00ED:00000C18003818181818183C00000000\n00EE:0000386C003818181818183C00000000\n00EF:00006C6C003818181818183C00000000\n00F0:00006830587CC6C6C6C6C67C00000000\n00F1:000076DC00FCC6C6C6C6C6C600000000\n00F2:00003018007CC6C6C6C6C67C00000000\n00F3:00001830007CC6C6C6C6C67C00000000\n00F4:0000386C007CC6C6C6C6C67C00000000\n00F5:000076DC007CC6C6C6C6C67C00000000\n00F6:00006C6C007CC6C6C6C6C67C00000000\n00F7:000000001818007E0018180000000000\n00F8:00000000003D676E7E76E6BC00000000\n00F9:0000301800C6C6C6C6C6C67E00000000\n00FA:0000183000C6C6C6C6C6C67E00000000\n00FB:0000386C00C6C6C6C6C6C67E00000000\n00FC:00006C6C00C6C6C6C6C6C67E00000000\n00FD:0000183000C6C6C6C6C6C67E06067C00\n00FE:0000C0C0C0FCC6C6C6C6C6FCC0C0C000\n00FF:00006C6C00C6C6C6C6C6C67E06067C00\n0100:7C007CC6C6C6C6FEC6C6C6C600000000\n0101:0000007C007C067EC6C6C67E00000000\n0102:6C38007CC6C6C6FEC6C6C6C600000000\n0103:00006C38007C067EC6C6C67E00000000\n0104:00007CC6C6C6C6FEC6C6C6C6060C0700\n0105:00000000007C067EC6C6C67E060C0700\n0106:1830007CC6C6C0C0C0C6C67C00000000\n0107:00001830007CC6C0C0C0C67C00000000\n0108:386C007CC6C6C0C0C0C6C67C00000000\n0109:0000386C007CC6C0C0C0C67C00000000\n010A:1818007CC6C6C0C0C0C6C67C00000000\n010B:00001818007CC6C0C0C0C67C00000000\n010C:6C38007CC6C6C0C0C0C6C67C00000000\n010D:00006C38007CC6C0C0C0C67C00000000\n010E:6C3800F8CCC6C6C6C6C6CCF800000000\n010F:6C380606067EC6C6C6C6C67E00000000\n0110:00007C666363FB636363667C00000000\n0111:0000061F067EC6C6C6C6C67E00000000\n0112:7C00FEC0C0C0F8C0C0C0C0FE00000000\n0113:0000007C007CC6C6FEC0C07C00000000\n0114:6C3800FEC0C0C0F8C0C0C0FE00000000\n0115:00006C38007CC6C6FEC0C07C00000000\n0116:181800FEC0C0C0F8C0C0C0FE00000000\n0117:00001818007CC6C6FEC0C07C00000000\n0118:0000FEC0C0C0F8C0C0C0C0FE060C0700\n0119:00000000007CC6C6FEC0C07C18301C00\n011A:6C3800FEC0C0C0F8C0C0C0FE00000000\n011B:00006C38007CC6C6FEC0C07C00000000\n011C:386C007CC6C0C0DEC6C6C67C00000000\n011D:0000386C007EC6C6C6C6C67E06067C00\n011E:6C38007CC6C0C0DEC6C6C67C00000000\n011F:00006C38007EC6C6C6C6C67E06067C00\n0120:1818007CC6C0C0DEC6C6C67C00000000\n0121:00001818007EC6C6C6C6C67E06067C00\n0122:00007CC6C6C0C0DEC6C6C67C00303060\n0123:000C1818007EC6C6C6C6C67E06067C00\n0124:386C00C6C6C6C6FEC6C6C6C600000000\n0125:1C36C0C0C0FCC6C6C6C6C6C600000000\n0126:000066FF66667E666666666600000000\n0127:000060F8607E63636363636300000000\n0128:76DC003C181818181818183C00000000\n0129:000076DC003818181818183C00000000\n012A:7E003C18181818181818183C00000000\n012B:0000007C003818181818183C00000000\n012C:6C38003C181818181818183C00000000\n012D:00006C38003818181818183C00000000\n012E:00003C18181818181818183C18301C00\n012F:00001818003818181818183C18301C00\n0130:1818003C181818181818183C00000000\n0131:00000000003818181818183C00000000\n0132:0000CFC6C6C6C6C6C6F6F6DC00000000\n0133:0000C6C600C6C6C6C6C6C6C636361C00\n0134:1C36001E0C0C0C0C0CCCCC7800000000\n0135:00000E1B000E06060606060666663C00\n0136:0000C6C6CCD8F0F0D8CCC6C600303060\n0137:0000C0C0C0C6CCD8F0D8CCC600303060\n0138:0000000000C6CCD8F0D8CCC600000000\n0139:60C000C0C0C0C0C0C0C0C0FE00000000\n013A:0C180038181818181818183C00000000\n013B:0000C0C0C0C0C0C0C0C0C0FE00303060\n013C:00003818181818181818183C00181830\n013D:6C38C0C0C0C0C0C0C0C0C0FE00000000\n013E:6C380038181818181818183C00000000\n013F:0000C0C0C0C0CCCCC0C0C0FE00000000\n0140:0000381818181B1B1818183C00000000\n0141:00006060606070E06060607F00000000\n0142:0000381818181C381818183C00000000\n0143:1830C6C6C6E6F6DECEC6C6C600000000\n0144:0000183000FCC6C6C6C6C6C600000000\n0145:0000C6C6C6E6F6DECEC6C6C600303060\n0146:0000000000FCC6C6C6C6C6C600303060\n0147:6C38C6C6C6E6F6DECEC6C6C600000000\n0148:00006C3800FCC6C6C6C6C6C600000000\n0149:006060C000FCC6C6C6C6C6C600000000\n014A:0000C6C6C6E6F6DECEC6C6C606061C00\n014B:0000000000FCC6C6C6C6C6C606061C00\n014C:7C007CC6C6C6C6C6C6C6C67C00000000\n014D:0000007C007CC6C6C6C6C67C00000000\n014E:6C38007CC6C6C6C6C6C6C67C00000000\n014F:00006C38007CC6C6C6C6C67C00000000\n0150:366C007CC6C6C6C6C6C6C67C00000000\n0151:0000366C007CC6C6C6C6C67C00000000\n0152:00007FCCCCCCCFCCCCCCCC7F00000000\n0153:00000000007EDBDBDFD8D87E00000000\n0154:183000FCC6C6C6FCF8CCC6C600000000\n0155:0000183000DCE6C0C0C0C0C000000000\n0156:0000FCC6C6C6C6FCF8CCC6C600303060\n0157:00000000006E736060606060006060C0\n0158:6C3800FCC6C6C6FCF8CCC6C600000000\n0159:00006C3800DCE6C0C0C0C0C000000000\n015A:1830007CC6C0C07C0606C67C00000000\n015B:00000C18007CC2C07C06867C00000000\n015C:386C007CC6C0C07C0606C67C00000000\n015D:0000386C007CC2C07C06867C00000000\n015E:00007CC6C0C07C060606C67C30306000\n015F:00000000007CC2C07C06867C30306000\n0160:6C38007CC6C0C07C0606C67C00000000\n0161:00006C38007CC2C07C06867C00000000\n0162:00007E1818181818181818180C0C1800\n0163:0000303030FC30303030301E0C0C1800\n0164:6C38007E181818181818181800000000\n0165:6C38003030FC30303030301E00000000\n0166:00007E1818187E181818181800000000\n0167:0000303030FC30783030301E00000000\n0168:76DC00C6C6C6C6C6C6C6C67C00000000\n0169:000076DC00C6C6C6C6C6C67E00000000\n016A:7C00C6C6C6C6C6C6C6C6C67C00000000\n016B:0000007C00C6C6C6C6C6C67E00000000\n016C:6C38C6C6C6C6C6C6C6C6C67C00000000\n016D:00006C3800C6C6C6C6C6C67E00000000\n016E:386C38C6C6C6C6C6C6C6C67C00000000\n016F:0000386C38C6C6C6C6C6C67E00000000\n0170:366C00C6C6C6C6C6C6C6C67C00000000\n0171:0000366C00C6C6C6C6C6C67E00000000\n0172:0000C6C6C6C6C6C6C6C6C67C18301C00\n0173:0000000000C6C6C6C6C6C67E060C0700\n0174:386C00C6C6C6D6D6FEEE6C6C00000000\n0175:0000386C00C6C6D6D6D6D67C00000000\n0176:386C00C3C366663C1818181800000000\n0177:0000386C00C6C6C6C6C6C67E06067C00\n0178:666600C3C366663C1818181800000000\n0179:183000FE060C183060C0C0FE00000000\n017A:0000183000FE0C183060C0FE00000000\n017B:181800FE060C183060C0C0FE00000000\n017C:0000181800FE0C183060C0FE00000000\n017D:6C3800FE060C183060C0C0FE00000000\n017E:00006C3800FE0C183060C0FE00000000\n017F:00001E30303030303030303000000000\n0186:00007CC6C606060606C6C67C00000000\n018E:0000FE0606063E06060606FE00000000\n018F:00007CC60606FEC6C6C6C67C00000000\n0190:00007CC6C6C078C0C0C6C67C00000000\n0192:00000E1B18187E181818181818D87000\n019D:0000636363737B6F676363636060C000\n019E:0000000000FCC6C6C6C6C6C606060600\n01B5:0000FE060C18FE3060C0C0FE00000000\n01B6:0000000000FE0C18FC3060FE00000000\n01B7:0000FE060C183C0606C6C67C00000000\n01CD:6C38007CC6C6C6FEC6C6C6C600000000\n01CE:00006C38007C067EC6C6C67E00000000\n01CF:6C38003C181818181818183C00000000\n01D0:00006C38003818181818183C00000000\n01D1:6C38007CC6C6C6C6C6C6C67C00000000\n01D2:00006C38007CC6C6C6C6C67C00000000\n01D3:6C38C6C6C6C6C6C6C6C6C67C00000000\n01D4:00006C3800C6C6C6C6C6C67E00000000\n01E2:7E007FCCCCCCFFCCCCCCCCCF00000000\n01E3:0000007E00761B7BDFD8D86E00000000\n01E4:00007CC6C6C0C0DEC6DFC67C00000000\n01E5:00000000007EC6C6DFC6C67E06067C00\n01E6:6C38007CC6C0C0DEC6C6C67C00000000\n01E7:00006C38007EC6C6C6C6C67E06067C00\n01E8:6C38C6C6CCD8F0F0D8CCC6C600000000\n01E9:6C38C0C0C0C6CCD8F0D8CCC600000000\n01EA:00007CC6C6C6C6C6C6C6C67C18301C00\n01EB:00000000007CC6C6C6C6C67C18301C00\n01EC:7C007CC6C6C6C6C6C6C6C67C18301C00\n01ED:0000007C007CC6C6C6C6C67C18301C00\n01EE:6C3800FE0C183C0606C6C67C00000000\n01EF:00006C3800FE060C183C0606C6C67C00\n01F0:00001B0E000E06060606060666663C00\n01F4:1830007CC6C0C0DEC6C6C67C00000000\n01F5:00000C18007EC6C6C6C6C67E06067C00\n01FC:0C18007FCCCCCCFFCCCCCCCF00000000\n01FD:00000C1800761B7BDFD8D86E00000000\n01FE:1830007CC7C6CEDEF6E6C67C00000000\n01FF:00001830003D676E7E76E6BC00000000\n0218:00007CC6C0C07C0606C6C67C00303060\n0219:00000000007CC2C07C06867C00303060\n021A:00007E18181818181818181800181830\n021B:0000303030FC30303030301E000C0C18\n0232:7E00C3C366663C181818181800000000\n0233:0000007C00C6C6C6C6C6C67E06067C00\n0237:00000000000E06060606060666663C00\n0254:00000000007CC6060606C67C00000000\n0258:00000000007CC6C6FE06067C00000000\n0259:00000000007C0606FEC6C67C00000000\n025B:00000000007CC6C078C0C67C00000000\n0272:00000000007E6363636363636060C000\n0292:0000000000FE060C183C0606C6C67C00\n02BB:18303000000000000000000000000000\n02BC:18183000000000000000000000000000\n02BD:30301800000000000000000000000000\n02C6:386C0000000000000000000000000000\n02C7:6C380000000000000000000000000000\n02D8:6C380000000000000000000000000000\n02D9:18180000000000000000000000000000\n02DB:00000000000000000000000018301C00\n02DC:76DC0000000000000000000000000000\n02DD:366C0000000000000000000000000000\n0300:30180000000000000000000000000000\n0301:18300000000000000000000000000000\n0302:386C0000000000000000000000000000\n0303:76DC0000000000000000000000000000\n0304:7C000000000000000000000000000000\n0305:FE000000000000000000000000000000\n0306:6C380000000000000000000000000000\n0307:18180000000000000000000000000000\n0308:6C6C0000000000000000000000000000\n030A:386C3800000000000000000000000000\n030B:366C0000000000000000000000000000\n030C:6C380000000000000000000000000000\n0329:00000000000000000000000000181800\n0384:60C00000000000000000000000000000\n0385:1830006C000000000000000000000000\n0386:60C07CC6C6C6C6FEC6C6C6C600000000\n0387:00000000001818000000000000000000\n0388:60C000FEC0C0C0F8C0C0C0FE00000000\n0389:60C000C6C6C6C6FEC6C6C6C600000000\n038A:60C03C18181818181818183C00000000\n038C:60C07CC6C6C6C6C6C6C6C67C00000000\n038E:60C000C3C366663C1818181800000000\n038F:60C07CC6C6C6C6C6C66C6CEE00000000\n0390:1830D8D8007030303030301C00000000\n0391:00007CC6C6C6C6FEC6C6C6C600000000\n0392:0000FCC6C6C6FCC6C6C6C6FC00000000\n0393:0000FEC0C0C0C0C0C0C0C0C000000000\n0394:000018183C3C666666C3C3FF00000000\n0395:0000FEC0C0C0F8C0C0C0C0FE00000000\n0396:0000FE06060C183060C0C0FE00000000\n0397:0000C6C6C6C6FEC6C6C6C6C600000000\n0398:00007CC6C6C6D6D6C6C6C67C00000000\n0399:00003C18181818181818183C00000000\n039A:0000C6C6CCD8F0F0D8CCC6C600000000\n039B:000018183C3C666666C3C3C300000000\n039C:0000C6C6EEFED6D6C6C6C6C600000000\n039D:0000C6C6C6E6F6DECEC6C6C600000000\n039E:0000FE0000007C00000000FE00000000\n039F:00007CC6C6C6C6C6C6C6C67C00000000\n03A0:0000FEC6C6C6C6C6C6C6C6C600000000\n03A1:0000FCC6C6C6C6FCC0C0C0C000000000\n03A3:0000FEC0603018183060C0FE00000000\n03A4:0000FF18181818181818181800000000\n03A5:0000C3C366663C181818181800000000\n03A6:0000187EDBDBDBDBDBDB7E1800000000\n03A7:0000C6C66C6C38386C6CC6C600000000\n03A8:0000DBDBDBDBDBDBDB7E181800000000\n03A9:00007CC6C6C6C6C6C66C6CEE00000000\n03AA:6666003C181818181818183C00000000\n03AB:666600C3C366663C1818181800000000\n03AC:00001830007BCECCCCCCCE7B00000000\n03AD:00001830007CC6C078C0C67C00000000\n03AE:0000183000FCC6C6C6C6C6C606060600\n03AF:00001830007030303030301C00000000\n03B0:1830006C00C6C6C6C6C6C67C00000000\n03B1:00000000007BCECCCCCCCE7B00000000\n03B2:000078CCCCC8FCC6C6C6C6FCC0C0C000\n03B3:0000000000C3C366663C3C1818181800\n03B4:00007E30187CC6C6C6C6C67C00000000\n03B5:00000000007CC6C078C0C67C00000000\n03B6:0000FE0C183060C0C0C0C07C06060C00\n03B7:0000000000FCC6C6C6C6C6C606060600\n03B8:00003C6666667E666666663C00000000\n03B9:00000000007030303030301C00000000\n03BA:0000000000C6CCD8F0D8CCC600000000\n03BB:0000303018183C3C6666C3C300000000\n03BC:0000000000C6C6C6C6C6CEF6C0C0C000\n03BD:0000000000C6C6C66C6C383800000000\n03BE:00007EC0C0C07CC0C0C0C07C06060C00\n03BF:00000000007CC6C6C6C6C67C00000000\n03C0:0000000000FEC6C6C6C6C6C600000000\n03C1:00000000007CC6C6C6C6C6FCC0C0C000\n03C2:00000000007CC6C0C0C0C07C06060C00\n03C3:00000000003F66666666663C00000000\n03C4:0000000000FF18181818180E00000000\n03C5:0000000000C6C6C6C6C6C67C00000000\n03C6:00000000004EDBDBDBDBDB7E18181800\n03C7:0000000000C6C66C6C38386C6CC6C600\n03C8:0000000000DBDBDBDBDBDB7E18181800\n03C9:000000000066C3DBDBDBFF6600000000\n03CA:0000D8D8007030303030301C00000000\n03CB:00006C6C00C6C6C6C6C6C67C00000000\n03CC:00001830007CC6C6C6C6C67C00000000\n03CD:0000183000C6C6C6C6C6C67C00000000\n03CE:00000C180066C3DBDBDBFF6600000000\n03D1:00003C6666663F06E666663C00000000\n03D5:00000000187EDBDBDBDBDB7E18000000\n03F0:0000000000E3361C18386CC700000000\n03F1:00000000007CC6C6C6C6C6FCC0C07C00\n03F2:00000000007CC6C0C0C0C67C00000000\n03F3:00000606000E06060606060666663C00\n03F4:00007CC6C6C6FEC6C6C6C67C00000000\n03F5:00000000003E60C0FCC0603E00000000\n03F6:0000000000F80C067E060CF800000000\n0400:301800FEC0C0C0F8C0C0C0FE00000000\n0401:6C6C00FEC0C0C0F8C0C0C0FE00000000\n0402:0000FC30303E33333333333600000000\n0403:183000FEC0C0C0C0C0C0C0C000000000\n0404:00007CC6C0C0F8C0C0C0C67C00000000\n0405:00007CC6C0C07C0606C6C67C00000000\n0406:00003C18181818181818183C00000000\n0407:6666003C181818181818183C00000000\n0408:00001E0C0C0C0C0C0CCCCC7800000000\n0409:00003878D8DEDBDBDBDBDB9E00000000\n040A:0000D8D8D8DEFBDBDBDBDBDE00000000\n040B:0000FC30303E33333333333300000000\n040C:1830C6C6CCD8F0F0D8CCC6C600000000\n040D:3018C6C6C6CEDEF6E6C6C6C600000000\n040E:6C38C6C6C6C6C67E0606067C00000000\n040F:0000C6C6C6C6C6C6C6C6C6FE38380000\n0410:00007CC6C6C6C6FEC6C6C6C600000000\n0411:0000FCC0C0FCC6C6C6C6C6FC00000000\n0412:0000FCC6C6C6FCC6C6C6C6FC00000000\n0413:0000FEC0C0C0C0C0C0C0C0C000000000\n0414:00003E6666666666666666FFC3000000\n0415:0000FEC0C0C0F8C0C0C0C0FE00000000\n0416:0000DBDBDB7E3C7EDBDBDBDB00000000\n0417:00007CC6C6063C0606C6C67C00000000\n0418:0000C6C6C6CEDEF6E6C6C6C600000000\n0419:6C38C6C6C6CEDEF6E6C6C6C600000000\n041A:0000C6C6CCD8F0F0D8CCC6C600000000\n041B:00001E3666666666666666C600000000\n041C:000081C3E7FFDBC3C3C3C3C300000000\n041D:0000C6C6C6C6FEC6C6C6C6C600000000\n041E:00007CC6C6C6C6C6C6C6C67C00000000\n041F:0000FEC6C6C6C6C6C6C6C6C600000000\n0420:0000FCC6C6C6C6FCC0C0C0C000000000\n0421:00007CC6C6C0C0C0C0C6C67C00000000\n0422:0000FF18181818181818181800000000\n0423:0000C6C6C6C6C67E0606067C00000000\n0424:00187EDBDBDBDBDBDBDBDB7E18000000\n0425:0000C6C66C6C38386C6CC6C600000000\n0426:0000C6C6C6C6C6C6C6C6C67F03030000\n0427:0000C6C6C6C6C67E0606060600000000\n0428:0000DBDBDBDBDBDBDBDBDB7F00000000\n0429:0000D6D6D6D6D6D6D6D6D67F03030000\n042A:0000E060607E63636363637E00000000\n042B:0000C3C3C3F3DBDBDBDBDBF300000000\n042C:00006060607E63636363637E00000000\n042D:00007CC606063E060606C67C00000000\n042E:0000CEDBDBDBDBFBDBDBDBCE00000000\n042F:00007EC6C6C6C67E1E3666C600000000\n0430:00000000007C067EC6C6C67E00000000\n0431:00007CC0C0FCC6C6C6C6C6FC00000000\n0432:000078CCCCC8FCC6C6C6C6FC00000000\n0433:0000000000FEC0C0C0C0C0C000000000\n0434:00000000007EC6C6C6C6C67E06067C00\n0435:00000000007CC6C6FEC0C07C00000000\n0436:0000000000DBDB7E3C7EDBDB00000000\n0437:00000000007CC6063C06C67C00000000\n0438:0000000000C6C6C6C6C6C67E00000000\n0439:00006C3800C6C6C6C6C6C67E00000000\n043A:0000000000C6CCD8F0D8CCC600000000\n043B:00000000003E6666666666C600000000\n043C:0000000000C3E7FFDBC3C3C300000000\n043D:0000000000C6C6C6FEC6C6C600000000\n043E:00000000007CC6C6C6C6C67C00000000\n043F:0000000000FEC6C6C6C6C6C600000000\n0440:0000000000FCC6C6C6C6C6FCC0C0C000\n0441:00000000007CC6C0C0C0C67C00000000\n0442:0000000000FF18181818181800000000\n0443:0000000000C6C6C6C6C6C67E06067C00\n0444:00000000187EDBDBDBDBDB7E18000000\n0445:0000000000C6C66C386CC6C600000000\n0446:0000000000C6C6C6C6C6C67F03030000\n0447:0000000000C6C6C67E06060600000000\n0448:0000000000DBDBDBDBDBDB7F00000000\n0449:0000000000D6D6D6D6D6D67F03030000\n044A:0000000000E0607C6666667C00000000\n044B:0000000000C3C3F3DBDBDBF300000000\n044C:000000000060607C6666667C00000000\n044D:00000000007CC6063E06C67C00000000\n044E:0000000000CEDBDBFBDBDBCE00000000\n044F:00000000007EC6C67E3666C600000000\n0450:00003018007CC6C6FEC0C07C00000000\n0451:00006C6C007CC6C6FEC0C07C00000000\n0452:000060F8607E63636363636303030E00\n0453:0000183000FEC0C0C0C0C0C000000000\n0454:00000000007CC6C0F8C0C67C00000000\n0455:00000000007EC0C07C0606FC00000000\n0456:00001818003818181818183C00000000\n0457:00006C6C003818181818183C00000000\n0458:00000606000E06060606060666663C00\n0459:000000000078D8DEDBDBDB9E00000000\n045A:0000000000D8D8DEFBDBDBDE00000000\n045B:000060F8607E63636363636300000000\n045C:0000183000C6CCD8F0D8CCC600000000\n045D:0000301800C6C6C6C6C6C67E00000000\n045E:00006C3800C6C6C6C6C6C67E06067C00\n045F:0000000000C6C6C6C6C6C6FE38380000\n0462:000060F8607E63636363637E00000000\n0463:00006060F860607C6666667C00000000\n046A:0000FFC366663C7EDBDBDBDB00000000\n046B:0000000000FF663C3C7EDBDB00000000\n0490:0606FEC0C0C0C0C0C0C0C0C000000000\n0491:0000000606FEC0C0C0C0C0C000000000\n0492:00007F606060FC606060606000000000\n0493:00000000007F6060FC60606000000000\n0494:0000FEC0C0C0C0FCC6C6C6C6060C0000\n0495:0000000000FEC0C0F8CCCCCC0C180000\n0496:0000D6D6D67C387CD6D6D6D703030000\n0497:0000000000D6D67C387CD6D703030000\n0498:00007CC6C6063C0606C6C67C30303000\n0499:00000000007CC6063C06C67C30303000\n049A:0000C6C6CCD8F0F0D8CCC6C703030000\n049B:0000000000C6CCD8F0D8CCC703030000\n049C:0000C6C6D6DCF8F8DCD6C6C600000000\n049D:0000000000C6D6DCF8DCD6C600000000\n04A0:0000E3E3666C78786C66636300000000\n04A1:0000000000E3666C786C666300000000\n04A2:0000C6C6C6C6FEC6C6C6C6C703030000\n04A3:0000000000C6C6C6FEC6C6C703030000\n04A4:0000CFCCCCCCFCCCCCCCCCCC00000000\n04A5:0000000000CFCCCCFCCCCCCC00000000\n04AA:00007CC6C6C0C0C0C0C6C67C30303000\n04AB:00000000007CC6C0C0C0C67C30303000\n04AE:0000C3C366663C181818181800000000\n04AF:0000000000C3C366663C3C1818181800\n04B0:0000C3C366663C187E18181800000000\n04B1:0000000000C3C366663C3C187E181800\n04B2:0000C6C66C6C38386C6CC6C703030000\n04B3:0000000000C6C66C386CC6C703030000\n04B6:0000C6C6C6C6C67E0606060703030000\n04B7:0000000000C6C6C67E06060703030000\n04B8:0000C6C6C6D6D67E1616060600000000\n04B9:0000000000C6D6D67E16060600000000\n04BA:0000C0C0C0C0FCC6C6C6C6C600000000\n04BB:0000000000C0C0FCC6C6C6C600000000\n04C0:00003C18181818181818183C00000000\n04C1:6C3800DBDBDB7E3C7EDBDBDB00000000\n04C2:00006C3800DBDB7E3C7EDBDB00000000\n04CF:00003818181818181818183C00000000\n04D0:6C38007CC6C6C6FEC6C6C6C600000000\n04D1:00006C38007C067EC6C6C67E00000000\n04D2:6C6C007CC6C6C6FEC6C6C6C600000000\n04D3:00006C6C007C067EC6C6C67E00000000\n04D4:00007FCCCCCCFFCCCCCCCCCF00000000\n04D5:0000000000761B7BDFD8D86E00000000\n04D6:6C3800FEC0C0C0F8C0C0C0FE00000000\n04D7:00006C38007CC6C6FEC0C07C00000000\n04D8:00007CC60606FEC6C6C6C67C00000000\n04D9:00000000007C0606FEC6C67C00000000\n04DA:6C6C007CC60606FEC6C6C67C00000000\n04DB:00006C6C007C0606FEC6C67C00000000\n04DC:666600DBDBDB7E3C7EDBDBDB00000000\n04DD:0000666600DBDB7E3C7EDBDB00000000\n04DE:6C6C007CC6C6063C06C6C67C00000000\n04DF:00006C6C007CC6063C06C67C00000000\n04E2:7C00C6C6C6CEDEF6E6C6C6C600000000\n04E3:0000007C00C6C6C6C6C6C67E00000000\n04E4:6C6C00C6C6C6CEDEF6E6C6C600000000\n04E5:00006C6C00C6C6C6C6C6C67E00000000\n04E6:6C6C007CC6C6C6C6C6C6C67C00000000\n04E7:00006C6C007CC6C6C6C6C67C00000000\n04E8:00007CC6C6C6FEC6C6C6C67C00000000\n04E9:00000000007CC6C6FEC6C67C00000000\n04EA:6C6C007CC6C6C6FEC6C6C67C00000000\n04EB:00006C6C007CC6C6FEC6C67C00000000\n04EC:6C6C007CC606063E0606C67C00000000\n04ED:00006C6C007CC6063E06C67C00000000\n04EE:7C00C6C6C6C6C67E0606067C00000000\n04EF:0000007C00C6C6C6C6C6C67E06067C00\n04F0:6C6C00C6C6C6C67E0606067C00000000\n04F1:00006C6C00C6C6C6C6C6C67E06067C00\n04F2:366C00C6C6C6C67E0606067C00000000\n04F3:0000366C00C6C6C6C6C6C67E06067C00\n04F4:6C6C00C6C6C6C67E0606060600000000\n04F5:00006C6C00C6C6C67E06060600000000\n04F8:6C6C00C3C3C3F3DBDBDBDBF300000000\n04F9:00006C6C00C3C3F3DBDBDBF300000000\n05D0:0000C6C666663C78CCCCC6C600000000\n05D1:0000FC0606060606060606FF00000000\n05D2:0000780C0C0C0C0C1E3663C300000000\n05D3:0000FF06060606060606060600000000\n05D4:0000FC0606C6C6C6C6C6C6C600000000\n05D5:00007018181818181818181800000000\n05D6:00007E0C181818181818181800000000\n05D7:0000FCC6C6C6C6C6C6C6C6C600000000\n05D8:0000CCCEC6C6C6C6C6C6C67C00000000\n05D9:00007018181818000000000000000000\n05DA:0000FC06060606060606060606060600\n05DB:0000FC0606060606060606FC00000000\n05DC:C0C0FE060606060C1830303000000000\n05DD:0000FCC6C6C6C6C6C6C6C6FE00000000\n05DE:0000DE73636363636363636700000000\n05DF:0000F018181818181818181800000000\n05E0:0000780C0C0C0C0C0C0C0C7C00000000\n05E1:0000FE63636363636363633E00000000\n05E2:0000C6C6C6666636361C38E000000000\n05E3:00007CC6C6C666060606060606060600\n05E4:00007CC6C6C66606060606FC00000000\n05E5:0000636333361C181818181818181800\n05E6:0000C6C6666C383018180CFC00000000\n05E7:0000FE0606C6C6CCD8D8D8D8C0C0C000\n05E8:0000FC06060606060606060600000000\n05E9:0000DBDBDBDBDBF3E3C3C6FC00000000\n05EA:0000FE6363636363636363C300000000\n1E0C:0000F8CCC6C6C6C6C6C6CCF800303000\n1E0D:00000606067EC6C6C6C6C67E00181800\n1E34:0000C6C6CCD8F0F0D8CCC6C6007C0000\n1E35:0000C0C0C0C6CCD8F0D8CCC6007C0000\n1E36:0000C0C0C0C0C0C0C0C0C0FE00181800\n1E37:00003818181818181818183C00181800\n1E40:1818C3C3E7FFDBDBC3C3C3C300000000\n1E41:0000181800FEDBDBDBDBDBDB00000000\n1E42:0000C3C3E7FFDBDBC3C3C3C300181800\n1E43:0000000000FEDBDBDBDBDBDB00181800\n1E44:1818C6C6C6E6F6DECEC6C6C600000000\n1E45:0000303000FCC6C6C6C6C6C600000000\n1E46:0000C6C6C6E6F6DECEC6C6C600181800\n1E47:0000000000FCC6C6C6C6C6C600181800\n1E6C:0000FF18181818181818181800181800\n1E6D:0000303030FC30303030301E000C0C00\n1EB8:0000FEC0C0C0F8C0C0C0C0FE00181800\n1EB9:00000000007CC6C6FEC0C07C00181800\n1EBC:76DC00FEC0C0C0F8C0C0C0FE00000000\n1EBD:000076DC007CC6C6FEC0C07C00000000\n1ECA:00003C18181818181818183C00181800\n1ECB:00001818003818181818183C00181800\n1ECC:00007CC6C6C6C6C6C6C6C67C00181800\n1ECD:00000000007CC6C6C6C6C67C00181800\n1EE4:0000C6C6C6C6C6C6C6C6C67C00181800\n1EE5:0000000000C6C6C6C6C6C67E00181800\n1EF8:76DC00C3C366663C1818181800000000\n1EF9:000076DC00C6C6C6C6C6C67E06067C00\n2000:00000000000000000000000000000000\n2001:00000000000000000000000000000000\n2002:00000000000000000000000000000000\n2003:00000000000000000000000000000000\n2004:00000000000000000000000000000000\n2005:00000000000000000000000000000000\n2006:00000000000000000000000000000000\n2007:00000000000000000000000000000000\n2008:00000000000000000000000000000000\n2009:00000000000000000000000000000000\n200A:00000000000000000000000000000000\n200B:00000000000000000000000000000000\n200C:00000000000000000000000000000000\n200D:00000000000000000000000000000000\n200E:00000000000000000000000000000000\n200F:00000000000000000000000000000000\n2010:000000000000007C0000000000000000\n2011:000000000000007C0000000000000000\n2012:00000000000000FE0000000000000000\n2013:00000000000000FE0000000000000000\n2014:00000000000000FF0000000000000000\n2015:00000000000000FF0000000000000000\n2016:00006C6C6C6C6C6C6C6C6C6C00000000\n2017:00000000000000000000000000FE00FE\n2018:00183030000000000000000000000000\n2019:00181830000000000000000000000000\n201A:00000000000000000000181830000000\n201B:00303018000000000000000000000000\n201C:0066CCCC000000000000000000000000\n201D:00333366000000000000000000000000\n201E:000000000000000000006666CC000000\n201F:00CCCC66000000000000000000000000\n2020:000018187E1818181818181800000000\n2021:000018187E181818187E181800000000\n2022:000000000000183C3C18000000000000\n2026:00000000000000000000DBDB00000000\n2030:0000ECACF8183030607FD5DF00000000\n2032:00181818180000000000000000000000\n2033:00666666660000000000000000000000\n2039:00000000000C18306030180C00000000\n203A:00000000006030180C18306000000000\n203C:00006666666666666600666600000000\n203E:FE000000000000000000000000000000\n2070:00386C6C6C6C38000000000000000000\n2071:1800381818183C000000000000000000\n2074:000C1C347E0C0C000000000000000000\n2075:007860780C0C78000000000000000000\n2076:003860786C6C38000000000000000000\n2077:007C0C18183030000000000000000000\n2078:00386C386C6C38000000000000000000\n2079:00386C6C3C0C38000000000000000000\n207A:000018187E1818000000000000000000\n207B:000000007C0000000000000000000000\n207C:0000007C007C00000000000000000000\n207D:00183030303018000000000000000000\n207E:00301818181830000000000000000000\n207F:0000786C6C6C6C000000000000000000\n2080:00000000000000386C6C6C6C38000000\n2081:0000000000000018381818183C000000\n2082:00000000000000386C0C18307C000000\n2083:00000000000000780C380C0C78000000\n2084:000000000000000C1C347E0C0C000000\n2085:000000000000007860780C0C78000000\n2086:000000000000003860786C6C38000000\n2087:000000000000007C0C18183030000000\n2088:00000000000000386C386C6C38000000\n2089:00000000000000386C6C3C0C38000000\n208A:000000000000000018187E1818000000\n208B:000000000000000000007C0000000000\n208C:0000000000000000007C007C00000000\n208D:00000000000000183030303018000000\n208E:00000000000000301818181830000000\n2090:0000000000000000380C3C6C3C000000\n2091:0000000000000000386C7C603C000000\n2092:0000000000000000386C6C6C38000000\n2093:0000000000000000663C183C66000000\n2094:0000000000000000780C7C6C38000000\n2095:0000000000006060786C6C6C6C000000\n2096:0000000000006060666C786C66000000\n2097:0000000000003818181818183C000000\n2098:0000000000000000FCD6D6D6D6000000\n209A:0000000000000000786C6C6C78606000\n20A7:0000F8CCCCCCFAC6CFC6C6C300000000\n20AA:0000F28A8AAAAAAAAAA2A2BC00000000\n20AC:0000001E3360FC60FC60331E00000000\n20AE:0000FF18181E781E7818181800000000\n2102:00003C52525050505052523C00000000\n210E:0000C0C0C0FCC6C6C6C6C6C600000000\n210F:000060F8607E63636363636300000000\n2115:0000424262526A564A46424200000000\n2116:0000969696D0F0F0B096909600000000\n211A:00003C525252525252525A3C06000000\n211D:0000F8A4A4A4A4B8A8B4AAE600000000\n2122:0000FB55555100000000000000000000\n2124:00007E02060A14285060407E00000000\n2126:00007CC6C6C6C6C6C66C6CEE00000000\n2135:0000666633333E7CCCCCC66600000000\n2190:00000000002060FEFE60200000000000\n2191:0000183C7E1818181818181800000000\n2192:0000000000080CFEFE0C080000000000\n2193:0000181818181818187E3C1800000000\n2194:00000000002466FFFF66240000000000\n2195:0000183C7E181818187E3C1800000000\n21A4:00000000002262FEFE62220000000000\n21A6:0000000000888CFEFE8C880000000000\n21A8:0000183C7E1818187E3C187E00000000\n21B2:0000060606062666FEFE602000000000\n21B3:0000C0C0C0C0C8CCFEFE0C0800000000\n21B5:0000000006062666FEFE602000000000\n21BB:000000F83868CBC3C3663C0000000000\n21CB:0000002060FEFE00FEFE0C0800000000\n21CC:000000080CFEFE00FEFE602000000000\n21D0:00000000103E7EE07E3E100000000000\n21D1:000010387CEE6C6C6C6C6C6C00000000\n21D2:0000000010F8FC0EFCF8100000000000\n21D3:00006C6C6C6C6C6CEE7C381000000000\n21D4:00000000247EFFC3FF7E240000000000\n21D5:000010387CEE6C6CEE7C381000000000\n2200:0000C3C3C37E6666243C181800000000\n2203:000000FE060606FE060606FE00000000\n2204:00000CFE1E1636FE366666FEC0000000\n2205:000003067ECFDBDBF37E60C000000000\n2206:000018183C3C666666C3C3FF00000000\n2207:0000FFC3C36666663C3C181800000000\n2208:0000003E60C0C0FEC0C0603E00000000\n2209:0000063E6CCCD8FED8F0707E60000000\n220A:000000003E60C0FEC0603E0000000000\n220B:000000F80C0606FE06060CF800000000\n220C:0000C0F86C6636FE361E1CFC0C000000\n220D:00000000F80C06FE060CF80000000000\n2212:00000000000000FE0000000000000000\n2213:00000000007E0018187E181800000000\n2214:0000000018180018187E181800000000\n2215:0000000002060C183060C08000000000\n2216:0000000080C06030180C060200000000\n2219:00000000000038383800000000000000\n221A:000E0C0C0C0CCCCCCC6C3C1C00000000\n221E:000000000076DBDBDB6E000000000000\n221F:00000000C0C0C0C0C0FE000000000000\n2225:00006C6C6C6C6C6C6C6C6C6C00000000\n2227:0000000018183C3C6666C3C300000000\n2228:00000000C3C366663C3C181800000000\n2229:000000007CC6C6C6C6C6C6C600000000\n222A:00000000C6C6C6C6C6C6C67C00000000\n2248:000000000076DC0076DC000000000000\n2260:0000000006FE1830FEC0000000000000\n2261:00000000FE0000FE0000FE0000000000\n2264:0000000C18306030180C007E00000000\n2265:00000030180C060C1830007E00000000\n226A:000000091B366CD86C361B0900000000\n226B:00000090D86C361B366CD89000000000\n2282:000000007EC0C0C0C0C07E0000000000\n2283:00000000FC0606060606FC0000000000\n2286:0000007EC0C0C0C0C07E00FE00000000\n2287:000000FC0606060606FC00FE00000000\n22A5:0000000018181818181818FF00000000\n22C2:00007CC6C6C6C6C6C6C6C6C600000000\n22C3:0000C6C6C6C6C6C6C6C6C67C00000000\n2300:000003067ECFDBDBF37E60C000000000\n2302:00000000183C66C3C3C3C3FF00000000\n2308:00003C30303030303030303000000000\n2309:00003C0C0C0C0C0C0C0C0C0C00000000\n230A:00003030303030303030303C00000000\n230B:00000C0C0C0C0C0C0C0C0C3C00000000\n2310:0000000000FEC0C0C000000000000000\n2319:0000000000C0C0C0FE00000000000000\n2320:00000E1B1B1818181818181818181818\n2321:181818181818181818D8D87000000000\n239B:060C1818303030606060606060606060\n239C:60606060606060606060606060606060\n239D:60606060606060606030303018180C06\n239E:603018180C0C0C060606060606060606\n239F:06060606060606060606060606060606\n23A0:0606060606060606060C0C0C18183060\n23A1:7E606060606060606060606060606060\n23A2:60606060606060606060606060606060\n23A3:6060606060606060606060606060607E\n23A4:7E060606060606060606060606060606\n23A5:06060606060606060606060606060606\n23A6:0606060606060606060606060606067E\n23A7:0F183030303030303030303030303030\n23A8:30303030303030E0E030303030303030\n23A9:3030303030303030303030303030180F\n23AB:F0180C0C0C0C0C0C0C0C0C0C0C0C0C0C\n23AC:0C0C0C0C0C0C0C07070C0C0C0C0C0C0C\n23AD:0C0C0C0C0C0C0C0C0C0C0C0C0C0C18F0\n23AE:18181818181818181818181818181818\n23AF:00000000000000FFFF00000000000000\n23BA:FFFF0000000000000000000000000000\n23BB:00000000FFFF00000000000000000000\n23BC:00000000000000000000FFFF00000000\n23BD:0000000000000000000000000000FFFF\n23D0:18181818181818181818181818181818\n2409:00CCCCFCCCCCCC003F0C0C0C0C0C0000\n240A:00C0C0C0C0C0F8003F303C3030300000\n240B:00CCCCCCCC7830003F0C0C0C0C0C0000\n240C:00FCC0F0C0C0C0003F303C3030300000\n240D:0078CCC0C0CC78003E33333E36330000\n2424:00CCECFCDCCCCC0030303030303F0000\n2500:00000000000000FFFF00000000000000\n2501:000000000000FFFFFF00000000000000\n2502:18181818181818181818181818181818\n2503:38383838383838383838383838383838\n2508:00000000000000AAAA00000000000000\n2509:000000000000AAAAAA00000000000000\n250A:18181800181818001818180018181800\n250B:38383800383838003838380038383800\n250C:000000000000001F1F18181818181818\n250D:0000000000001F1F1F18181818181818\n250E:000000000000003F3F38383838383838\n250F:0000000000003F3F3F38383838383838\n2510:00000000000000F8F818181818181818\n2511:000000000000F8F8F818181818181818\n2512:00000000000000F8F838383838383838\n2513:000000000000F8F8F838383838383838\n2514:181818181818181F1F00000000000000\n2515:1818181818181F1F1F00000000000000\n2516:383838383838383F3F00000000000000\n2517:3838383838383F3F3F00000000000000\n2518:18181818181818F8F800000000000000\n2519:181818181818F8F8F800000000000000\n251A:38383838383838F8F800000000000000\n251B:383838383838F8F8F800000000000000\n251C:181818181818181F1F18181818181818\n251D:1818181818181F1F1F18181818181818\n251E:383838383838383F3F18181818181818\n251F:181818181818183F3F38383838383838\n2520:383838383838383F3F38383838383838\n2521:3838383838383F3F3F18181818181818\n2522:1818181818183F3F3F38383838383838\n2523:3838383838383F3F3F38383838383838\n2524:18181818181818F8F818181818181818\n2525:181818181818F8F8F818181818181818\n2526:38383838383838F8F818181818181818\n2527:18181818181818F8F838383838383838\n2528:38383838383838F8F838383838383838\n2529:383838383838F8F8F818181818181818\n252A:181818181818F8F8F838383838383838\n252B:383838383838F8F8F838383838383838\n252C:00000000000000FFFF18181818181818\n252D:000000000000F8FFFF18181818181818\n252E:0000000000001FFFFF18181818181818\n252F:000000000000FFFFFF18181818181818\n2530:00000000000000FFFF38383838383838\n2531:000000000000F8FFFF38383838383838\n2532:0000000000003FFFFF38383838383838\n2533:000000000000FFFFFF38383838383838\n2534:18181818181818FFFF00000000000000\n2535:181818181818F8FFFF00000000000000\n2536:1818181818181FFFFF00000000000000\n2537:181818181818FFFFFF00000000000000\n2538:38383838383838FFFF00000000000000\n2539:383838383838F8FFFF00000000000000\n253A:3838383838383FFFFF00000000000000\n253B:383838383838FFFFFF00000000000000\n253C:18181818181818FFFF18181818181818\n253D:181818181818F8FFFF18181818181818\n253E:1818181818181FFFFF18181818181818\n253F:181818181818FFFFFF18181818181818\n2540:38383838383838FFFF18181818181818\n2541:18181818181818FFFF38383838383838\n2542:38383838383838FFFF38383838383838\n2543:383838383838F8FFFF18181818181818\n2544:3838383838383FFFFF18181818181818\n2545:181818181818F8FFFF38383838383838\n2546:1818181818181FFFFF38383838383838\n2547:383838383838FFFFFF18181818181818\n2548:181818181818FFFFFF38383838383838\n2549:383838383838F8FFFF38383838383838\n254A:3838383838383FFFFF38383838383838\n254B:383838383838FFFFFF38383838383838\n2550:0000000000FFFF00FFFF000000000000\n2551:6C6C6C6C6C6C6C6C6C6C6C6C6C6C6C6C\n2552:00000000001F1F181F1F181818181818\n2553:000000000000007F7F6C6C6C6C6C6C6C\n2554:00000000007F7F606F6F6C6C6C6C6C6C\n2555:0000000000F8F818F8F8181818181818\n2556:00000000000000FCFC6C6C6C6C6C6C6C\n2557:0000000000FCFC0CECEC6C6C6C6C6C6C\n2558:18181818181F1F181F1F000000000000\n2559:6C6C6C6C6C6C6C7F7F00000000000000\n255A:6C6C6C6C6C6F6F607F7F000000000000\n255B:1818181818F8F818F8F8000000000000\n255C:6C6C6C6C6C6C6CFCFC00000000000000\n255D:6C6C6C6C6CECEC0CFCFC000000000000\n255E:18181818181F1F181F1F181818181818\n255F:6C6C6C6C6C6C6C6F6F6C6C6C6C6C6C6C\n2560:6C6C6C6C6C6F6F606F6F6C6C6C6C6C6C\n2561:1818181818F8F818F8F8181818181818\n2562:6C6C6C6C6C6C6CECEC6C6C6C6C6C6C6C\n2563:6C6C6C6C6CECEC0CECEC6C6C6C6C6C6C\n2564:0000000000FFFF00FFFF181818181818\n2565:00000000000000FFFF6C6C6C6C6C6C6C\n2566:0000000000FFFF00EFEF6C6C6C6C6C6C\n2567:1818181818FFFF00FFFF000000000000\n2568:6C6C6C6C6C6C6CFFFF00000000000000\n2569:6C6C6C6C6CEFEF00FFFF000000000000\n256A:1818181818FFFF18FFFF181818181818\n256B:6C6C6C6C6C6C6CFFFF6C6C6C6C6C6C6C\n256C:6C6C6C6C6CEFEF00EFEF6C6C6C6C6C6C\n256D:00000000000000070F1C181818181818\n256E:00000000000000E0F038181818181818\n256F:18181818181838F0E000000000000000\n2570:1818181818181C0F0700000000000000\n2571:0101030206040C08181030206040C080\n2572:80C0406020301018080C040602030101\n2573:81C1436226341C18181C34266243C181\n2574:00000000000000F8F800000000000000\n2575:18181818181818181800000000000000\n2576:000000000000001F1F00000000000000\n2577:00000000000000181818181818181818\n2578:000000000000F8F8F800000000000000\n2579:38383838383838383800000000000000\n257A:0000000000001F1F1F00000000000000\n257B:00000000000000383838383838383838\n257C:0000000000001FFFFF00000000000000\n257D:18181818181818383838383838383838\n257E:000000000000F8FFFF00000000000000\n257F:38383838383838383818181818181818\n2580:FFFFFFFFFFFFFFFF0000000000000000\n2581:0000000000000000000000000000FFFF\n2582:000000000000000000000000FFFFFFFF\n2583:00000000000000000000FFFFFFFFFFFF\n2584:0000000000000000FFFFFFFFFFFFFFFF\n2585:000000000000FFFFFFFFFFFFFFFFFFFF\n2586:00000000FFFFFFFFFFFFFFFFFFFFFFFF\n2587:0000FFFFFFFFFFFFFFFFFFFFFFFFFFFF\n2588:FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF\n2589:FEFEFEFEFEFEFEFEFEFEFEFEFEFEFEFE\n258A:FCFCFCFCFCFCFCFCFCFCFCFCFCFCFCFC\n258B:F8F8F8F8F8F8F8F8F8F8F8F8F8F8F8F8\n258C:F0F0F0F0F0F0F0F0F0F0F0F0F0F0F0F0\n258D:E0E0E0E0E0E0E0E0E0E0E0E0E0E0E0E0\n258E:C0C0C0C0C0C0C0C0C0C0C0C0C0C0C0C0\n258F:80808080808080808080808080808080\n2590:0F0F0F0F0F0F0F0F0F0F0F0F0F0F0F0F\n2591:88228822882288228822882288228822\n2592:AA55AA55AA55AA55AA55AA55AA55AA55\n2593:EEBBEEBBEEBBEEBBEEBBEEBBEEBBEEBB\n2596:0000000000000000F0F0F0F0F0F0F0F0\n2597:00000000000000000F0F0F0F0F0F0F0F\n2598:F0F0F0F0F0F0F0F00000000000000000\n2599:F0F0F0F0F0F0F0F0FFFFFFFFFFFFFFFF\n259A:F0F0F0F0F0F0F0F00F0F0F0F0F0F0F0F\n259B:FFFFFFFFFFFFFFFFF0F0F0F0F0F0F0F0\n259C:FFFFFFFFFFFFFFFF0F0F0F0F0F0F0F0F\n259D:0F0F0F0F0F0F0F0F0000000000000000\n259E:0F0F0F0F0F0F0F0FF0F0F0F0F0F0F0F0\n259F:0F0F0F0F0F0F0F0FFFFFFFFFFFFFFFFF\n25A0:00000000007C7C7C7C7C7C0000000000\n25AC:0000000000000000FEFEFEFE00000000\n25AE:0000FEFEFEFEFEFEFEFEFEFE00000000\n25B2:0000000018183C3C7E7EFFFF00000000\n25B6:00000000C0F0FCFFFFFCF0C000000000\n25BA:00000000C0F0FCFFFFFCF0C000000000\n25BC:00000000FFFF7E7E3C3C181800000000\n25C0:00000000030F3FFFFF3F0F0300000000\n25C4:00000000030F3FFFFF3F0F0300000000\n25C6:00000000183C7EFF7E3C180000000000\n25CA:00000000183C66C3663C180000000000\n25CB:00000000003C664242663C0000000000\n25CF:00000000003C7E7E7E7E3C0000000000\n25D8:FFFFFFFFFFFFE7C3C3E7FFFFFFFFFFFF\n25D9:FFFFFFFFFFC399BDBD99C3FFFFFFFFFF\n263A:00007E81A58181BD9981817E00000000\n263B:00007EFFDBFFFFC3E7FFFF7E00000000\n263C:00000018DB7E3CE73C7EDB1800000000\n2640:00003C666666663C187E181800000000\n2642:00003E0E1A3278CCCCCCCC7800000000\n2660:000018183C7EFFFF7E18183C00000000\n2663:0000183C3C185AFFFF5A183C00000000\n2665:0000000066FFFFFFFF7E3C1800000000\n2666:00000000183C7EFF7E3C180000000000\n266A:00003F333F3030303030F0E000000000\n266B:00007F637F636363636367E6C0000000\n2713:000003030606CCCC7878303000000000\n2714:000007070E0EDCFC7878303000000000\n2717:00000CCC7838383C6660C0C000000000\n2718:00000EEE7C3C3C3E7773E0E000000000\n27E8:00000C0C1818303018180C0C00000000\n27E9:0000303018180C0C1818303000000000\n27EA:000036366C6CD8D86C6C363600000000\n27EB:0000D8D86C6C36366C6CD8D800000000\n2800:00000000000000000000000000000000\n2801:00606000000000000000000000000000\n2802:00000000006060000000000000000000\n2803:00606000006060000000000000000000\n2804:00000000000000000060600000000000\n2805:00606000000000000060600000000000\n2806:00000000006060000060600000000000\n2807:00606000006060000060600000000000\n2808:00060600000000000000000000000000\n2809:00666600000000000000000000000000\n280A:00060600006060000000000000000000\n280B:00666600006060000000000000000000\n280C:00060600000000000060600000000000\n280D:00666600000000000060600000000000\n280E:00060600006060000060600000000000\n280F:00666600006060000060600000000000\n2810:00000000000606000000000000000000\n2811:00606000000606000000000000000000\n2812:00000000006666000000000000000000\n2813:00606000006666000000000000000000\n2814:00000000000606000060600000000000\n2815:00606000000606000060600000000000\n2816:00000000006666000060600000000000\n2817:00606000006666000060600000000000\n2818:00060600000606000000000000000000\n2819:00666600000606000000000000000000\n281A:00060600006666000000000000000000\n281B:00666600006666000000000000000000\n281C:00060600000606000060600000000000\n281D:00666600000606000060600000000000\n281E:00060600006666000060600000000000\n281F:00666600006666000060600000000000\n2820:00000000000000000006060000000000\n2821:00606000000000000006060000000000\n2822:00000000006060000006060000000000\n2823:00606000006060000006060000000000\n2824:00000000000000000066660000000000\n2825:00606000000000000066660000000000\n2826:00000000006060000066660000000000\n2827:00606000006060000066660000000000\n2828:00060600000000000006060000000000\n2829:00666600000000000006060000000000\n282A:00060600006060000006060000000000\n282B:00666600006060000006060000000000\n282C:00060600000000000066660000000000\n282D:00666600000000000066660000000000\n282E:00060600006060000066660000000000\n282F:00666600006060000066660000000000\n2830:00000000000606000006060000000000\n2831:00606000000606000006060000000000\n2832:00000000006666000006060000000000\n2833:00606000006666000006060000000000\n2834:00000000000606000066660000000000\n2835:00606000000606000066660000000000\n2836:00000000006666000066660000000000\n2837:00606000006666000066660000000000\n2838:00060600000606000006060000000000\n2839:00666600000606000006060000000000\n283A:00060600006666000006060000000000\n283B:00666600006666000006060000000000\n283C:00060600000606000066660000000000\n283D:00666600000606000066660000000000\n283E:00060600006666000066660000000000\n283F:00666600006666000066660000000000\n2840:00000000000000000000000000606000\n2841:00606000000000000000000000606000\n2842:00000000006060000000000000606000\n2843:00606000006060000000000000606000\n2844:00000000000000000060600000606000\n2845:00606000000000000060600000606000\n2846:00000000006060000060600000606000\n2847:00606000006060000060600000606000\n2848:00060600000000000000000000606000\n2849:00666600000000000000000000606000\n284A:00060600006060000000000000606000\n284B:00666600006060000000000000606000\n284C:00060600000000000060600000606000\n284D:00666600000000000060600000606000\n284E:00060600006060000060600000606000\n284F:00666600006060000060600000606000\n2850:00000000000606000000000000606000\n2851:00606000000606000000000000606000\n2852:00000000006666000000000000606000\n2853:00606000006666000000000000606000\n2854:00000000000606000060600000606000\n2855:00606000000606000060600000606000\n2856:00000000006666000060600000606000\n2857:00606000006666000060600000606000\n2858:00060600000606000000000000606000\n2859:00666600000606000000000000606000\n285A:00060600006666000000000000606000\n285B:00666600006666000000000000606000\n285C:00060600000606000060600000606000\n285D:00666600000606000060600000606000\n285E:00060600006666000060600000606000\n285F:00666600006666000060600000606000\n2860:00000000000000000006060000606000\n2861:00606000000000000006060000606000\n2862:00000000006060000006060000606000\n2863:00606000006060000006060000606000\n2864:00000000000000000066660000606000\n2865:00606000000000000066660000606000\n2866:00000000006060000066660000606000\n2867:00606000006060000066660000606000\n2868:00060600000000000006060000606000\n2869:00666600000000000006060000606000\n286A:00060600006060000006060000606000\n286B:00666600006060000006060000606000\n286C:00060600000000000066660000606000\n286D:00666600000000000066660000606000\n286E:00060600006060000066660000606000\n286F:00666600006060000066660000606000\n2870:00000000000606000006060000606000\n2871:00606000000606000006060000606000\n2872:00000000006666000006060000606000\n2873:00606000006666000006060000606000\n2874:00000000000606000066660000606000\n2875:00606000000606000066660000606000\n2876:00000000006666000066660000606000\n2877:00606000006666000066660000606000\n2878:00060600000606000006060000606000\n2879:00666600000606000006060000606000\n287A:00060600006666000006060000606000\n287B:00666600006666000006060000606000\n287C:00060600000606000066660000606000\n287D:00666600000606000066660000606000\n287E:00060600006666000066660000606000\n287F:00666600006666000066660000606000\n2880:00000000000000000000000000060600\n2881:00606000000000000000000000060600\n2882:00000000006060000000000000060600\n2883:00606000006060000000000000060600\n2884:00000000000000000060600000060600\n2885:00606000000000000060600000060600\n2886:00000000006060000060600000060600\n2887:00606000006060000060600000060600\n2888:00060600000000000000000000060600\n2889:00666600000000000000000000060600\n288A:00060600006060000000000000060600\n288B:00666600006060000000000000060600\n288C:00060600000000000060600000060600\n288D:00666600000000000060600000060600\n288E:00060600006060000060600000060600\n288F:00666600006060000060600000060600\n2890:00000000000606000000000000060600\n2891:00606000000606000000000000060600\n2892:00000000006666000000000000060600\n2893:00606000006666000000000000060600\n2894:00000000000606000060600000060600\n2895:00606000000606000060600000060600\n2896:00000000006666000060600000060600\n2897:00606000006666000060600000060600\n2898:00060600000606000000000000060600\n2899:00666600000606000000000000060600\n289A:00060600006666000000000000060600\n289B:00666600006666000000000000060600\n289C:00060600000606000060600000060600\n289D:00666600000606000060600000060600\n289E:00060600006666000060600000060600\n289F:00666600006666000060600000060600\n28A0:00000000000000000006060000060600\n28A1:00606000000000000006060000060600\n28A2:00000000006060000006060000060600\n28A3:00606000006060000006060000060600\n28A4:00000000000000000066660000060600\n28A5:00606000000000000066660000060600\n28A6:00000000006060000066660000060600\n28A7:00606000006060000066660000060600\n28A8:00060600000000000006060000060600\n28A9:00666600000000000006060000060600\n28AA:00060600006060000006060000060600\n28AB:00666600006060000006060000060600\n28AC:00060600000000000066660000060600\n28AD:00666600000000000066660000060600\n28AE:00060600006060000066660000060600\n28AF:00666600006060000066660000060600\n28B0:00000000000606000006060000060600\n28B1:00606000000606000006060000060600\n28B2:00000000006666000006060000060600\n28B3:00606000006666000006060000060600\n28B4:00000000000606000066660000060600\n28B5:00606000000606000066660000060600\n28B6:00000000006666000066660000060600\n28B7:00606000006666000066660000060600\n28B8:00060600000606000006060000060600\n28B9:00666600000606000006060000060600\n28BA:00060600006666000006060000060600\n28BB:00666600006666000006060000060600\n28BC:00060600000606000066660000060600\n28BD:00666600000606000066660000060600\n28BE:00060600006666000066660000060600\n28BF:00666600006666000066660000060600\n28C0:00000000000000000000000000666600\n28C1:00606000000000000000000000666600\n28C2:00000000006060000000000000666600\n28C3:00606000006060000000000000666600\n28C4:00000000000000000060600000666600\n28C5:00606000000000000060600000666600\n28C6:00000000006060000060600000666600\n28C7:00606000006060000060600000666600\n28C8:00060600000000000000000000666600\n28C9:00666600000000000000000000666600\n28CA:00060600006060000000000000666600\n28CB:00666600006060000000000000666600\n28CC:00060600000000000060600000666600\n28CD:00666600000000000060600000666600\n28CE:00060600006060000060600000666600\n28CF:00666600006060000060600000666600\n28D0:00000000000606000000000000666600\n28D1:00606000000606000000000000666600\n28D2:00000000006666000000000000666600\n28D3:00606000006666000000000000666600\n28D4:00000000000606000060600000666600\n28D5:00606000000606000060600000666600\n28D6:00000000006666000060600000666600\n28D7:00606000006666000060600000666600\n28D8:00060600000606000000000000666600\n28D9:00666600000606000000000000666600\n28DA:00060600006666000000000000666600\n28DB:00666600006666000000000000666600\n28DC:00060600000606000060600000666600\n28DD:00666600000606000060600000666600\n28DE:00060600006666000060600000666600\n28DF:00666600006666000060600000666600\n28E0:00000000000000000006060000666600\n28E1:00606000000000000006060000666600\n28E2:00000000006060000006060000666600\n28E3:00606000006060000006060000666600\n28E4:00000000000000000066660000666600\n28E5:00606000000000000066660000666600\n28E6:00000000006060000066660000666600\n28E7:00606000006060000066660000666600\n28E8:00060600000000000006060000666600\n28E9:00666600000000000006060000666600\n28EA:00060600006060000006060000666600\n28EB:00666600006060000006060000666600\n28EC:00060600000000000066660000666600\n28ED:00666600000000000066660000666600\n28EE:00060600006060000066660000666600\n28EF:00666600006060000066660000666600\n28F0:00000000000606000006060000666600\n28F1:00606000000606000006060000666600\n28F2:00000000006666000006060000666600\n28F3:00606000006666000006060000666600\n28F4:00000000000606000066660000666600\n28F5:00606000000606000066660000666600\n28F6:00000000006666000066660000666600\n28F7:00606000006666000066660000666600\n28F8:00060600000606000006060000666600\n28F9:00666600000606000006060000666600\n28FA:00060600006666000006060000666600\n28FB:00666600006666000006060000666600\n28FC:00060600000606000066660000666600\n28FD:00666600000606000066660000666600\n28FE:00060600006666000066660000666600\n28FF:00666600006666000066660000666600\n2E2C:0000000000C6C6000000C6C600000000\nE0A0:C0C0CCDEFFCCCCCC983060C0C0C0C0C0\nE0A1:00C0C0C0C0C0FC00333B3F3733330000\nE0A2:003C66666666FFFFE7C3E7FFFFFF0000\nE0B0:80C0E0F0F8FCFEFFFFFEFCF8F0E0C080\nE0B1:80C06030180C060303060C183060C080\nE0B2:0103070F1F3F7FFFFF7F3F1F0F070301\nE0B3:0103060C183060C0C06030180C060301\nF6BE:00000000000E06060606060666663C00\nFFFD:0000FEC6C6C6C6C6C6C6C6FE00000000\n"
  },
  {
    "path": "EFI_RELEASE/EFI/OC/config.plist",
    "content": "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<!DOCTYPE plist PUBLIC \"-//Apple//DTD PLIST 1.0//EN\" \"http://www.apple.com/DTDs/PropertyList-1.0.dtd\">\n<plist version=\"1.0\">\n<dict>\n\t<key>#WARNING - 1</key>\n\t<string>This is just a sample. Do NOT try loading it.</string>\n\t<key>#WARNING - 2</key>\n\t<string>Ensure you understand EVERY field before booting.</string>\n\t<key>#WARNING - 3</key>\n\t<string>In most cases recommended to use Sample.plist</string>\n\t<key>#WARNING - 4</key>\n\t<string>Use SampleCustom.plist only for special cases.</string>\n\t<key>ACPI</key>\n\t<dict>\n\t\t<key>Add</key>\n\t\t<array>\n\t\t\t<dict>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>SSDT-EC.aml</string>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<true/>\n\t\t\t\t<key>Path</key>\n\t\t\t\t<string>SSDT-EC.aml</string>\n\t\t\t</dict>\n\t\t\t<dict>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>SSDT-USBX.aml</string>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<true/>\n\t\t\t\t<key>Path</key>\n\t\t\t\t<string>SSDT-USBX.aml</string>\n\t\t\t</dict>\n\t\t</array>\n\t\t<key>Delete</key>\n\t\t<array>\n\t\t\t<dict>\n\t\t\t\t<key>All</key>\n\t\t\t\t<false/>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>Delete CpuPm</string>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<false/>\n\t\t\t\t<key>OemTableId</key>\n\t\t\t\t<data>Q3B1UG0AAAA=</data>\n\t\t\t\t<key>TableLength</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t\t<key>TableSignature</key>\n\t\t\t\t<data>U1NEVA==</data>\n\t\t\t</dict>\n\t\t\t<dict>\n\t\t\t\t<key>All</key>\n\t\t\t\t<false/>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>Delete Cpu0Ist</string>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<false/>\n\t\t\t\t<key>OemTableId</key>\n\t\t\t\t<data>Q3B1MElzdAA=</data>\n\t\t\t\t<key>TableLength</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t\t<key>TableSignature</key>\n\t\t\t\t<data>U1NEVA==</data>\n\t\t\t</dict>\n\t\t</array>\n\t\t<key>Patch</key>\n\t\t<array>\n\t\t\t<dict>\n\t\t\t\t<key>Base</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>BaseSkip</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>Replace one byte sequence with another</string>\n\t\t\t\t<key>Count</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<false/>\n\t\t\t\t<key>Find</key>\n\t\t\t\t<data>ESIzRA==</data>\n\t\t\t\t<key>Limit</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t\t<key>Mask</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>OemTableId</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>Replace</key>\n\t\t\t\t<data>RDMiEQ==</data>\n\t\t\t\t<key>ReplaceMask</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>Skip</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t\t<key>TableLength</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t\t<key>TableSignature</key>\n\t\t\t\t<data></data>\n\t\t\t</dict>\n\t\t\t<dict>\n\t\t\t\t<key>Base</key>\n\t\t\t\t<string>\\_SB.PCI0.LPCB.HPET</string>\n\t\t\t\t<key>BaseSkip</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>HPET _CRS to XCRS</string>\n\t\t\t\t<key>Count</key>\n\t\t\t\t<integer>1</integer>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<false/>\n\t\t\t\t<key>Find</key>\n\t\t\t\t<data>X0NSUw==</data>\n\t\t\t\t<key>Limit</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t\t<key>Mask</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>OemTableId</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>Replace</key>\n\t\t\t\t<data>WENSUw==</data>\n\t\t\t\t<key>ReplaceMask</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>Skip</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t\t<key>TableLength</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t\t<key>TableSignature</key>\n\t\t\t\t<data></data>\n\t\t\t</dict>\n\t\t</array>\n\t\t<key>Quirks</key>\n\t\t<dict>\n\t\t\t<key>FadtEnableReset</key>\n\t\t\t<false/>\n\t\t\t<key>NormalizeHeaders</key>\n\t\t\t<false/>\n\t\t\t<key>RebaseRegions</key>\n\t\t\t<false/>\n\t\t\t<key>ResetHwSig</key>\n\t\t\t<false/>\n\t\t\t<key>ResetLogoStatus</key>\n\t\t\t<false/>\n\t\t\t<key>SyncTableIds</key>\n\t\t\t<false/>\n\t\t</dict>\n\t</dict>\n\t<key>Booter</key>\n\t<dict>\n\t\t<key>MmioWhitelist</key>\n\t\t<array>\n\t\t\t<dict>\n\t\t\t\t<key>Address</key>\n\t\t\t\t<integer>4275159040</integer>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>Haswell: SB_RCBA is a 0x4 page memory region, containing SPI_BASE at 0x3800 (SPI_BASE_ADDRESS)</string>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<false/>\n\t\t\t</dict>\n\t\t\t<dict>\n\t\t\t\t<key>Address</key>\n\t\t\t\t<integer>4278190080</integer>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>Generic: PCI root is a 0x1000 page memory region used by some types of firmware</string>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<false/>\n\t\t\t</dict>\n\t\t</array>\n\t\t<key>Patch</key>\n\t\t<array>\n\t\t\t<dict>\n\t\t\t\t<key>Arch</key>\n\t\t\t\t<string>Any</string>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>macOS to hacOS</string>\n\t\t\t\t<key>Count</key>\n\t\t\t\t<integer>1</integer>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<false/>\n\t\t\t\t<key>Find</key>\n\t\t\t\t<data>bWFjT1M=</data>\n\t\t\t\t<key>Identifier</key>\n\t\t\t\t<string>Apple</string>\n\t\t\t\t<key>Limit</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t\t<key>Mask</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>Replace</key>\n\t\t\t\t<data>aGFjT1M=</data>\n\t\t\t\t<key>ReplaceMask</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>Skip</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t</dict>\n\t\t</array>\n\t\t<key>Quirks</key>\n\t\t<dict>\n\t\t\t<key>AllowRelocationBlock</key>\n\t\t\t<false/>\n\t\t\t<key>AvoidRuntimeDefrag</key>\n\t\t\t<true/>\n\t\t\t<key>ClearTaskSwitchBit</key>\n\t\t\t<false/>\n\t\t\t<key>DevirtualiseMmio</key>\n\t\t\t<false/>\n\t\t\t<key>DisableSingleUser</key>\n\t\t\t<false/>\n\t\t\t<key>DisableVariableWrite</key>\n\t\t\t<false/>\n\t\t\t<key>DiscardHibernateMap</key>\n\t\t\t<false/>\n\t\t\t<key>EnableSafeModeSlide</key>\n\t\t\t<false/>\n\t\t\t<key>EnableWriteUnprotector</key>\n\t\t\t<true/>\n\t\t\t<key>FixupAppleEfiImages</key>\n\t\t\t<false/>\n\t\t\t<key>ForceBooterSignature</key>\n\t\t\t<false/>\n\t\t\t<key>ForceExitBootServices</key>\n\t\t\t<false/>\n\t\t\t<key>ProtectMemoryRegions</key>\n\t\t\t<false/>\n\t\t\t<key>ProtectSecureBoot</key>\n\t\t\t<false/>\n\t\t\t<key>ProtectUefiServices</key>\n\t\t\t<false/>\n\t\t\t<key>ProvideCustomSlide</key>\n\t\t\t<false/>\n\t\t\t<key>ProvideMaxSlide</key>\n\t\t\t<integer>0</integer>\n\t\t\t<key>RebuildAppleMemoryMap</key>\n\t\t\t<false/>\n\t\t\t<key>ResizeAppleGpuBars</key>\n\t\t\t<integer>0</integer>\n\t\t\t<key>SetupVirtualMap</key>\n\t\t\t<false/>\n\t\t\t<key>SignalAppleOS</key>\n\t\t\t<false/>\n\t\t\t<key>SyncRuntimePermissions</key>\n\t\t\t<false/>\n\t\t</dict>\n\t</dict>\n\t<key>DeviceProperties</key>\n\t<dict>\n\t\t<key>Add</key>\n\t\t<dict>\n\t\t\t<key>PciRoot(0x0)/Pci(0x2,0x0)</key>\n\t\t\t<dict>\n\t\t\t\t<key>AAPL,ig-platform-id</key>\n\t\t\t\t<data></data>\n\t\t\t</dict>\n\t\t\t<key>PciRoot(0x0)/Pci(0x1b,0x0)</key>\n\t\t\t<dict>\n\t\t\t\t<key>layout-id</key>\n\t\t\t\t<data>AQAAAA==</data>\n\t\t\t</dict>\n\t\t\t<key>PciRoot(0x0)/Pci(0x1E,0x0)/Pci(0x1,0x0)/Pci(0x12,0x0)</key>\n\t\t\t<dict>\n\t\t\t\t<key>built-in</key>\n\t\t\t\t<data>AQ==</data>\n\t\t\t</dict>\n\t\t\t<key>PciRoot(0x0)/Pci(0x1E,0x0)/Pci(0x1,0x0)/Pci(0x7,0x0)</key>\n\t\t\t<dict>\n\t\t\t\t<key>built-in</key>\n\t\t\t\t<data>AQ==</data>\n\t\t\t</dict>\n\t\t\t<key>PciRoot(0x0)/Pci(0x12,0x0)</key>\n\t\t\t<dict>\n\t\t\t\t<key>built-in</key>\n\t\t\t\t<data>AQ==</data>\n\t\t\t</dict>\n\t\t\t<key>PciRoot(0x0)/Pci(0x13,0x0)</key>\n\t\t\t<dict>\n\t\t\t\t<key>built-in</key>\n\t\t\t\t<data>AQ==</data>\n\t\t\t</dict>\n\t\t\t<key>PciRoot(0x0)/Pci(0x1E,0x0)/Pci(0x1,0x0)/Pci(0x13,0x0)</key>\n\t\t\t<dict>\n\t\t\t\t<key>built-in</key>\n\t\t\t\t<data>AQ==</data>\n\t\t\t</dict>\n\t\t</dict>\n\t\t<key>Delete</key>\n\t\t<dict/>\n\t</dict>\n\t<key>Kernel</key>\n\t<dict>\n\t\t<key>Add</key>\n\t\t<array>\n\t\t\t<dict>\n\t\t\t\t<key>Arch</key>\n\t\t\t\t<string>Any</string>\n\t\t\t\t<key>BundlePath</key>\n\t\t\t\t<string>Lilu.kext</string>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>Lilu.kext</string>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<true/>\n\t\t\t\t<key>ExecutablePath</key>\n\t\t\t\t<string>Contents/MacOS/Lilu</string>\n\t\t\t\t<key>MaxKernel</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>MinKernel</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>PlistPath</key>\n\t\t\t\t<string>Contents/Info.plist</string>\n\t\t\t</dict>\n\t\t\t<dict>\n\t\t\t\t<key>Arch</key>\n\t\t\t\t<string>Any</string>\n\t\t\t\t<key>BundlePath</key>\n\t\t\t\t<string>VirtualSMC.kext</string>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>VirtualSMC.kext</string>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<true/>\n\t\t\t\t<key>ExecutablePath</key>\n\t\t\t\t<string>Contents/MacOS/VirtualSMC</string>\n\t\t\t\t<key>MaxKernel</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>MinKernel</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>PlistPath</key>\n\t\t\t\t<string>Contents/Info.plist</string>\n\t\t\t</dict>\n\t\t\t<dict>\n\t\t\t\t<key>Arch</key>\n\t\t\t\t<string>Any</string>\n\t\t\t\t<key>BundlePath</key>\n\t\t\t\t<string>WhateverGreen.kext</string>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>WhateverGreen.kext</string>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<true/>\n\t\t\t\t<key>ExecutablePath</key>\n\t\t\t\t<string>Contents/MacOS/WhateverGreen</string>\n\t\t\t\t<key>MaxKernel</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>MinKernel</key>\n\t\t\t\t<string>10.0.0</string>\n\t\t\t\t<key>PlistPath</key>\n\t\t\t\t<string>Contents/Info.plist</string>\n\t\t\t</dict>\n\t\t\t<dict>\n\t\t\t\t<key>Arch</key>\n\t\t\t\t<string>Any</string>\n\t\t\t\t<key>BundlePath</key>\n\t\t\t\t<string>VoodooPS2Controller.kext</string>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>Acidanthera VoodooPS2Controller.kext</string>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<true/>\n\t\t\t\t<key>ExecutablePath</key>\n\t\t\t\t<string>Contents/MacOS/VoodooPS2Controller</string>\n\t\t\t\t<key>MaxKernel</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>MinKernel</key>\n\t\t\t\t<string>15.0.0</string>\n\t\t\t\t<key>PlistPath</key>\n\t\t\t\t<string>Contents/Info.plist</string>\n\t\t\t</dict>\n\t\t\t<dict>\n\t\t\t\t<key>Arch</key>\n\t\t\t\t<string>Any</string>\n\t\t\t\t<key>BundlePath</key>\n\t\t\t\t<string>VoodooPS2Controller.kext/Contents/PlugIns/VoodooPS2Keyboard.kext</string>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>Acidanthera VoodooPS2Keyboard.kext</string>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<true/>\n\t\t\t\t<key>ExecutablePath</key>\n\t\t\t\t<string>Contents/MacOS/VoodooPS2Keyboard</string>\n\t\t\t\t<key>MaxKernel</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>MinKernel</key>\n\t\t\t\t<string>15.0.0</string>\n\t\t\t\t<key>PlistPath</key>\n\t\t\t\t<string>Contents/Info.plist</string>\n\t\t\t</dict>\n\t\t\t<dict>\n\t\t\t\t<key>Arch</key>\n\t\t\t\t<string>Any</string>\n\t\t\t\t<key>BundlePath</key>\n\t\t\t\t<string>AppleMCEReporterDisabler.kext</string>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>Fix kernel panic MacPro SMBIOS</string>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<true/>\n\t\t\t\t<key>ExecutablePath</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>MaxKernel</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>MinKernel</key>\n\t\t\t\t<string>21.0.0</string>\n\t\t\t\t<key>PlistPath</key>\n\t\t\t\t<string>Contents/Info.plist</string>\n\t\t\t</dict>\n\t\t</array>\n\t\t<key>Block</key>\n\t\t<array>\n\t\t\t<dict>\n\t\t\t\t<key>Arch</key>\n\t\t\t\t<string>Any</string>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<false/>\n\t\t\t\t<key>Identifier</key>\n\t\t\t\t<string>com.apple.driver.AppleTyMCEDriver</string>\n\t\t\t\t<key>MaxKernel</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>MinKernel</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>Strategy</key>\n\t\t\t\t<string>Disable</string>\n\t\t\t</dict>\n\t\t\t<dict>\n\t\t\t\t<key>Arch</key>\n\t\t\t\t<string>x86_64</string>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<false/>\n\t\t\t\t<key>Identifier</key>\n\t\t\t\t<string>com.apple.iokit.IOSkywalkFamily</string>\n\t\t\t\t<key>MaxKernel</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>MinKernel</key>\n\t\t\t\t<string>23.0.0</string>\n\t\t\t\t<key>Strategy</key>\n\t\t\t\t<string>Exclude</string>\n\t\t\t</dict>\n\t\t</array>\n\t\t<key>Emulate</key>\n\t\t<dict>\n\t\t\t<key>Cpuid1Data</key>\n\t\t\t<data></data>\n\t\t\t<key>Cpuid1Mask</key>\n\t\t\t<data></data>\n\t\t\t<key>DummyPowerManagement</key>\n\t\t\t<true/>\n\t\t\t<key>MaxKernel</key>\n\t\t\t<string></string>\n\t\t\t<key>MinKernel</key>\n\t\t\t<string></string>\n\t\t</dict>\n\t\t<key>Force</key>\n\t\t<array>\n\t\t\t<dict>\n\t\t\t\t<key>Arch</key>\n\t\t\t\t<string>Any</string>\n\t\t\t\t<key>BundlePath</key>\n\t\t\t\t<string>System/Library/Extensions/IONetworkingFamily.kext</string>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<false/>\n\t\t\t\t<key>ExecutablePath</key>\n\t\t\t\t<string>Contents/MacOS/IONetworkingFamily</string>\n\t\t\t\t<key>Identifier</key>\n\t\t\t\t<string>com.apple.iokit.IONetworkingFamily</string>\n\t\t\t\t<key>MaxKernel</key>\n\t\t\t\t<string>13.99.99</string>\n\t\t\t\t<key>MinKernel</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>PlistPath</key>\n\t\t\t\t<string>Contents/Info.plist</string>\n\t\t\t</dict>\n\t\t</array>\n\t\t<key>Patch</key>\n\t\t<array>\n\t\t\t<dict>\n\t\t\t\t<key>Arch</key>\n\t\t\t\t<string>Any</string>\n\t\t\t\t<key>Base</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>Enable TRIM/discard on QEMU SATA SSD - 10.7+</string>\n\t\t\t\t<key>Count</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<true/>\n\t\t\t\t<key>Find</key>\n\t\t\t\t<data>AEFQUExFIFNTRAA=</data>\n\t\t\t\t<key>Identifier</key>\n\t\t\t\t<string>com.apple.iokit.IOAHCIBlockStorage</string>\n\t\t\t\t<key>Limit</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t\t<key>Mask</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>MaxKernel</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>MinKernel</key>\n\t\t\t\t<string>11.0.0</string>\n\t\t\t\t<key>Replace</key>\n\t\t\t\t<data>AAAAAAAAAAAAAAA=</data>\n\t\t\t\t<key>ReplaceMask</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>Skip</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t</dict>\n\t\t\t<dict>\n\t\t\t\t<key>Arch</key>\n\t\t\t\t<string>Any</string>\n\t\t\t\t<key>Base</key>\n\t\t\t\t<string>__ZN8AppleRTC18setupDateTimeAlarmEPK11RTCDateTime</string>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>Disable RTC wake scheduling</string>\n\t\t\t\t<key>Count</key>\n\t\t\t\t<integer>1</integer>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<false/>\n\t\t\t\t<key>Find</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>Identifier</key>\n\t\t\t\t<string>com.apple.driver.AppleRTC</string>\n\t\t\t\t<key>Limit</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t\t<key>Mask</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>MaxKernel</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>MinKernel</key>\n\t\t\t\t<string>19.0.0</string>\n\t\t\t\t<key>Replace</key>\n\t\t\t\t<data>ww==</data>\n\t\t\t\t<key>ReplaceMask</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>Skip</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t</dict>\n\t\t\t<dict>\n\t\t\t\t<key>Arch</key>\n\t\t\t\t<string>Any</string>\n\t\t\t\t<key>Base</key>\n\t\t\t\t<string>_AcpiOsVprintf</string>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>Disable ACPI logging</string>\n\t\t\t\t<key>Count</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<false/>\n\t\t\t\t<key>Find</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>Identifier</key>\n\t\t\t\t<string>com.apple.driver.AppleACPIPlatform</string>\n\t\t\t\t<key>Limit</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t\t<key>Mask</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>MaxKernel</key>\n\t\t\t\t<string>18.5.0</string>\n\t\t\t\t<key>MinKernel</key>\n\t\t\t\t<string>18.5.0</string>\n\t\t\t\t<key>Replace</key>\n\t\t\t\t<data>ww==</data>\n\t\t\t\t<key>ReplaceMask</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>Skip</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t</dict>\n\t\t\t<dict>\n\t\t\t\t<key>Arch</key>\n\t\t\t\t<string>x86_64</string>\n\t\t\t\t<key>Base</key>\n\t\t\t\t<string>__ZN11BCM5701Enet14getAdapterInfoEv</string>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>Broadcom BCM57785 patch</string>\n\t\t\t\t<key>Count</key>\n\t\t\t\t<integer>1</integer>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<false/>\n\t\t\t\t<key>Find</key>\n\t\t\t\t<data>6AAA//9miYMABQAA</data>\n\t\t\t\t<key>Identifier</key>\n\t\t\t\t<string>com.apple.iokit.AppleBCM5701Ethernet</string>\n\t\t\t\t<key>Limit</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t\t<key>Mask</key>\n\t\t\t\t<data>/wAA////////////</data>\n\t\t\t\t<key>MaxKernel</key>\n\t\t\t\t<string>19.9.9</string>\n\t\t\t\t<key>MinKernel</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>Replace</key>\n\t\t\t\t<data>uLQWAABmiYMABQAA</data>\n\t\t\t\t<key>ReplaceMask</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>Skip</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t</dict>\n\t\t\t<dict>\n\t\t\t\t<key>Arch</key>\n\t\t\t\t<string>x86_64</string>\n\t\t\t\t<key>Base</key>\n\t\t\t\t<string>__ZN24IOBluetoothHCIController5startEP9IOService</string>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>Disable Bluetooth entirely</string>\n\t\t\t\t<key>Count</key>\n\t\t\t\t<integer>1</integer>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<false/>\n\t\t\t\t<key>Find</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>Identifier</key>\n\t\t\t\t<string>com.apple.iokit.IOBluetoothFamily</string>\n\t\t\t\t<key>Limit</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t\t<key>Mask</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>MaxKernel</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>MinKernel</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>Replace</key>\n\t\t\t\t<data>ww==</data>\n\t\t\t\t<key>ReplaceMask</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>Skip</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t</dict>\n\t\t\t<dict>\n\t\t\t\t<key>Arch</key>\n\t\t\t\t<string>x86_64</string>\n\t\t\t\t<key>Base</key>\n\t\t\t\t<string>_panic</string>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>Send panic string to serial port</string>\n\t\t\t\t<key>Count</key>\n\t\t\t\t<integer>1</integer>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<false/>\n\t\t\t\t<key>Find</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>Identifier</key>\n\t\t\t\t<string>kernel</string>\n\t\t\t\t<key>Limit</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t\t<key>Mask</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>MaxKernel</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>MinKernel</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>Replace</key>\n\t\t\t\t<data>MfaKD4TJdQT/xrEKZrr9A+yoIHT7Zrr4A4jI7kj/x4X2dN/r/g==</data>\n\t\t\t\t<key>ReplaceMask</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>Skip</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t</dict>\n\t\t\t<dict>\n\t\t\t\t<key>Arch</key>\n\t\t\t\t<string>x86_64</string>\n\t\t\t\t<key>Base</key>\n\t\t\t\t<string>_kernel_debug_string_early</string>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>Send early prints to serial port</string>\n\t\t\t\t<key>Count</key>\n\t\t\t\t<integer>1</integer>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<false/>\n\t\t\t\t<key>Find</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>Identifier</key>\n\t\t\t\t<string>kernel</string>\n\t\t\t\t<key>Limit</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t\t<key>Mask</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>MaxKernel</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>MinKernel</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>Replace</key>\n\t\t\t\t<data>MfaKD4TJdQT/xrEKZrr9A+yoIHT7Zrr4A4jI7kj/x4X2dN/D</data>\n\t\t\t\t<key>ReplaceMask</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>Skip</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t</dict>\n\t\t\t<dict>\n\t\t\t\t<key>Arch</key>\n\t\t\t\t<string>Any</string>\n\t\t\t\t<key>Base</key>\n\t\t\t\t<string>_disable_serial_output</string>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>Enable early serial output on RELEASE kernel</string>\n\t\t\t\t<key>Count</key>\n\t\t\t\t<integer>1</integer>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<false/>\n\t\t\t\t<key>Find</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>Identifier</key>\n\t\t\t\t<string>kernel</string>\n\t\t\t\t<key>Limit</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t\t<key>Mask</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>MaxKernel</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>MinKernel</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>Replace</key>\n\t\t\t\t<data>AA==</data>\n\t\t\t\t<key>ReplaceMask</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>Skip</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t</dict>\n\t\t\t<dict>\n\t\t\t\t<key>Arch</key>\n\t\t\t\t<string>Any</string>\n\t\t\t\t<key>Base</key>\n\t\t\t\t<string>_vstart</string>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>Print K and dead loop</string>\n\t\t\t\t<key>Count</key>\n\t\t\t\t<integer>1</integer>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<false/>\n\t\t\t\t<key>Find</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>Identifier</key>\n\t\t\t\t<string>kernel</string>\n\t\t\t\t<key>Limit</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t\t<key>Mask</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>MaxKernel</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>MinKernel</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>Replace</key>\n\t\t\t\t<data>sUtmuv0D7KggdPtmuvgDiMjusQpmuv0D7KggdPtmuvgDiMju6/4=</data>\n\t\t\t\t<key>ReplaceMask</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>Skip</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t</dict>\n\t\t\t<dict>\n\t\t\t\t<key>Arch</key>\n\t\t\t\t<string>Any</string>\n\t\t\t\t<key>Base</key>\n\t\t\t\t<string>_vstart</string>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>Early reboot</string>\n\t\t\t\t<key>Count</key>\n\t\t\t\t<integer>1</integer>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<false/>\n\t\t\t\t<key>Find</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>Identifier</key>\n\t\t\t\t<string>kernel</string>\n\t\t\t\t<key>Limit</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t\t<key>Mask</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>MaxKernel</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>MinKernel</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>Replace</key>\n\t\t\t\t<data>McCwBrr5DAAA7uv+</data>\n\t\t\t\t<key>ReplaceMask</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>Skip</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t</dict>\n\t\t\t<dict>\n\t\t\t\t<key>Arch</key>\n\t\t\t\t<string>x86_64</string>\n\t\t\t\t<key>Base</key>\n\t\t\t\t<string>_early_random</string>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>SurPlus v1 - PART 1 of 2 - Patch read_erandom (inlined in _early_random)</string>\n\t\t\t\t<key>Count</key>\n\t\t\t\t<integer>1</integer>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<false/>\n\t\t\t\t<key>Find</key>\n\t\t\t\t<data>AHQjSIs=</data>\n\t\t\t\t<key>Identifier</key>\n\t\t\t\t<string>kernel</string>\n\t\t\t\t<key>Limit</key>\n\t\t\t\t<integer>800</integer>\n\t\t\t\t<key>Mask</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>MaxKernel</key>\n\t\t\t\t<string>21.1.0</string>\n\t\t\t\t<key>MinKernel</key>\n\t\t\t\t<string>20.4.0</string>\n\t\t\t\t<key>Replace</key>\n\t\t\t\t<data>AOsjSIs=</data>\n\t\t\t\t<key>ReplaceMask</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>Skip</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t</dict>\n\t\t\t<dict>\n\t\t\t\t<key>Arch</key>\n\t\t\t\t<string>x86_64</string>\n\t\t\t\t<key>Base</key>\n\t\t\t\t<string>_register_and_init_prng</string>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>SurPlus v1 - PART 2 of 2 - Patch register_and_init_prng</string>\n\t\t\t\t<key>Count</key>\n\t\t\t\t<integer>1</integer>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<false/>\n\t\t\t\t<key>Find</key>\n\t\t\t\t<data>ukgBAAAx9g==</data>\n\t\t\t\t<key>Identifier</key>\n\t\t\t\t<string>kernel</string>\n\t\t\t\t<key>Limit</key>\n\t\t\t\t<integer>256</integer>\n\t\t\t\t<key>Mask</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>MaxKernel</key>\n\t\t\t\t<string>21.1.0</string>\n\t\t\t\t<key>MinKernel</key>\n\t\t\t\t<string>20.4.0</string>\n\t\t\t\t<key>Replace</key>\n\t\t\t\t<data>ukgBAADrBQ==</data>\n\t\t\t\t<key>ReplaceMask</key>\n\t\t\t\t<data></data>\n\t\t\t\t<key>Skip</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t</dict>\n\t\t</array>\n\t\t<key>Quirks</key>\n\t\t<dict>\n\t\t\t<key>AppleCpuPmCfgLock</key>\n\t\t\t<false/>\n\t\t\t<key>AppleXcpmCfgLock</key>\n\t\t\t<false/>\n\t\t\t<key>AppleXcpmExtraMsrs</key>\n\t\t\t<false/>\n\t\t\t<key>AppleXcpmForceBoost</key>\n\t\t\t<false/>\n\t\t\t<key>CustomPciSerialDevice</key>\n\t\t\t<false/>\n\t\t\t<key>CustomSMBIOSGuid</key>\n\t\t\t<false/>\n\t\t\t<key>DisableIoMapper</key>\n\t\t\t<false/>\n\t\t\t<key>DisableIoMapperMapping</key>\n\t\t\t<false/>\n\t\t\t<key>DisableLinkeditJettison</key>\n\t\t\t<true/>\n\t\t\t<key>DisableRtcChecksum</key>\n\t\t\t<false/>\n\t\t\t<key>ExtendBTFeatureFlags</key>\n\t\t\t<false/>\n\t\t\t<key>ExternalDiskIcons</key>\n\t\t\t<false/>\n\t\t\t<key>ForceAquantiaEthernet</key>\n\t\t\t<false/>\n\t\t\t<key>ForceSecureBootScheme</key>\n\t\t\t<true/>\n\t\t\t<key>IncreasePciBarSize</key>\n\t\t\t<false/>\n\t\t\t<key>LapicKernelPanic</key>\n\t\t\t<false/>\n\t\t\t<key>LegacyCommpage</key>\n\t\t\t<false/>\n\t\t\t<key>PanicNoKextDump</key>\n\t\t\t<false/>\n\t\t\t<key>PowerTimeoutKernelPanic</key>\n\t\t\t<false/>\n\t\t\t<key>ProvideCurrentCpuInfo</key>\n\t\t\t<true/>\n\t\t\t<key>SetApfsTrimTimeout</key>\n\t\t\t<integer>-1</integer>\n\t\t\t<key>ThirdPartyDrives</key>\n\t\t\t<false/>\n\t\t\t<key>XhciPortLimit</key>\n\t\t\t<false/>\n\t\t</dict>\n\t\t<key>Scheme</key>\n\t\t<dict>\n\t\t\t<key>CustomKernel</key>\n\t\t\t<false/>\n\t\t\t<key>FuzzyMatch</key>\n\t\t\t<true/>\n\t\t\t<key>KernelArch</key>\n\t\t\t<string>Auto</string>\n\t\t\t<key>KernelCache</key>\n\t\t\t<string>Auto</string>\n\t\t</dict>\n\t</dict>\n\t<key>Misc</key>\n\t<dict>\n\t\t<key>BlessOverride</key>\n\t\t<array/>\n\t\t<key>Boot</key>\n\t\t<dict>\n\t\t\t<key>ConsoleAttributes</key>\n\t\t\t<integer>0</integer>\n\t\t\t<key>HibernateMode</key>\n\t\t\t<string>None</string>\n\t\t\t<key>HibernateSkipsPicker</key>\n\t\t\t<false/>\n\t\t\t<key>HideAuxiliary</key>\n\t\t\t<true/>\n\t\t\t<key>InstanceIdentifier</key>\n\t\t\t<string></string>\n\t\t\t<key>LauncherOption</key>\n\t\t\t<string>Disabled</string>\n\t\t\t<key>LauncherPath</key>\n\t\t\t<string>Default</string>\n\t\t\t<key>PickerAttributes</key>\n\t\t\t<integer>17</integer>\n\t\t\t<key>PickerAudioAssist</key>\n\t\t\t<false/>\n\t\t\t<key>PickerMode</key>\n\t\t\t<string>External</string>\n\t\t\t<key>PickerVariant</key>\n\t\t\t<string>Auto</string>\n\t\t\t<key>PollAppleHotKeys</key>\n\t\t\t<true/>\n\t\t\t<key>ShowPicker</key>\n\t\t\t<true/>\n\t\t\t<key>TakeoffDelay</key>\n\t\t\t<integer>0</integer>\n\t\t\t<key>Timeout</key>\n\t\t\t<integer>2</integer>\n\t\t</dict>\n\t\t<key>Debug</key>\n\t\t<dict>\n\t\t\t<key>AppleDebug</key>\n\t\t\t<false/>\n\t\t\t<key>ApplePanic</key>\n\t\t\t<false/>\n\t\t\t<key>DisableWatchDog</key>\n\t\t\t<false/>\n\t\t\t<key>DisplayDelay</key>\n\t\t\t<integer>0</integer>\n\t\t\t<key>DisplayLevel</key>\n\t\t\t<integer>2147483650</integer>\n\t\t\t<key>LogModules</key>\n\t\t\t<string>*</string>\n\t\t\t<key>SysReport</key>\n\t\t\t<false/>\n\t\t\t<key>Target</key>\n\t\t\t<integer>0</integer>\n\t\t</dict>\n\t\t<key>Entries</key>\n\t\t<array>\n\t\t\t<dict>\n\t\t\t\t<key>Arguments</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>Auxiliary</key>\n\t\t\t\t<false/>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>Not signed for security reasons</string>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<false/>\n\t\t\t\t<key>Flavour</key>\n\t\t\t\t<string>Auto</string>\n\t\t\t\t<key>Name</key>\n\t\t\t\t<string>CustomOS</string>\n\t\t\t\t<key>Path</key>\n\t\t\t\t<string>PciRoot(0x0)/Pci(0x1,0x1)/Pci(0x0,0x0)/NVMe(0x1,11-22-33-44-55-66-77-88)/HD(1,GPT,00000000-0000-0000-0000-000000000000,0x800,0x64000)/\\EFI\\BOOT\\BOOTX64.EFI</string>\n\t\t\t\t<key>TextMode</key>\n\t\t\t\t<false/>\n\t\t\t</dict>\n\t\t</array>\n\t\t<key>Security</key>\n\t\t<dict>\n\t\t\t<key>AllowSetDefault</key>\n\t\t\t<true/>\n\t\t\t<key>ApECID</key>\n\t\t\t<integer>0</integer>\n\t\t\t<key>AuthRestart</key>\n\t\t\t<false/>\n\t\t\t<key>BlacklistAppleUpdate</key>\n\t\t\t<true/>\n\t\t\t<key>DmgLoading</key>\n\t\t\t<string>Signed</string>\n\t\t\t<key>EnablePassword</key>\n\t\t\t<false/>\n\t\t\t<key>ExposeSensitiveData</key>\n\t\t\t<integer>6</integer>\n\t\t\t<key>HaltLevel</key>\n\t\t\t<integer>2147483648</integer>\n\t\t\t<key>PasswordHash</key>\n\t\t\t<data></data>\n\t\t\t<key>PasswordSalt</key>\n\t\t\t<data></data>\n\t\t\t<key>ScanPolicy</key>\n\t\t\t<integer>0</integer>\n\t\t\t<key>SecureBootModel</key>\n\t\t\t<string>Disabled</string>\n\t\t\t<key>Vault</key>\n\t\t\t<string>Optional</string>\n\t\t</dict>\n\t\t<key>Serial</key>\n\t\t<dict>\n\t\t\t<key>Init</key>\n\t\t\t<false/>\n\t\t\t<key>Override</key>\n\t\t\t<false/>\n\t\t</dict>\n\t\t<key>Tools</key>\n\t\t<array/>\n\t</dict>\n\t<key>NVRAM</key>\n\t<dict>\n\t\t<key>Add</key>\n\t\t<dict>\n\t\t\t<key>4D1EDE05-38C7-4A6A-9CC6-4BCCA8B38C14</key>\n\t\t\t<dict>\n\t\t\t\t<key>DefaultBackgroundColor</key>\n\t\t\t\t<data>AAAAAA==</data>\n\t\t\t</dict>\n\t\t\t<key>4D1FDA02-38C7-4A6A-9CC6-4BCCA8B30102</key>\n\t\t\t<dict>\n\t\t\t\t<key>rtc-blacklist</key>\n\t\t\t\t<data></data>\n\t\t\t</dict>\n\t\t\t<key>7C436110-AB2A-4BBB-A880-FE41995C9F82</key>\n\t\t\t<dict>\n\t\t\t\t<key>#INFO (prev-lang:kbd)</key>\n\t\t\t\t<string>en:252 (ABC), set 656e3a323532</string>\n\t\t\t\t<key>ForceDisplayRotationInEFI</key>\n\t\t\t\t<integer>0</integer>\n\t\t\t\t<key>SystemAudioVolume</key>\n\t\t\t\t<data>Rg==</data>\n\t\t\t\t<key>boot-args</key>\n\t\t\t\t<string>keepsyms=1</string>\n\t\t\t\t<key>csr-active-config</key>\n\t\t\t\t<data>AAAAAA==</data>\n\t\t\t\t<key>prev-lang:kbd</key>\n\t\t\t\t<data>ZW4tVVM6MA==</data>\n\t\t\t\t<key>run-efi-updater</key>\n\t\t\t\t<string>No</string>\n\t\t\t</dict>\n\t\t</dict>\n\t\t<key>Delete</key>\n\t\t<dict>\n\t\t\t<key>4D1EDE05-38C7-4A6A-9CC6-4BCCA8B38C14</key>\n\t\t\t<array>\n\t\t\t\t<string>DefaultBackgroundColor</string>\n\t\t\t</array>\n\t\t\t<key>4D1FDA02-38C7-4A6A-9CC6-4BCCA8B30102</key>\n\t\t\t<array>\n\t\t\t\t<string>rtc-blacklist</string>\n\t\t\t</array>\n\t\t\t<key>7C436110-AB2A-4BBB-A880-FE41995C9F82</key>\n\t\t\t<array>\n\t\t\t\t<string>boot-args</string>\n\t\t\t\t<string>ForceDisplayRotationInEFI</string>\n\t\t\t</array>\n\t\t</dict>\n\t\t<key>LegacyOverwrite</key>\n\t\t<false/>\n\t\t<key>LegacySchema</key>\n\t\t<dict>\n\t\t\t<key>7C436110-AB2A-4BBB-A880-FE41995C9F82</key>\n\t\t\t<array>\n\t\t\t\t<string>EFILoginHiDPI</string>\n\t\t\t\t<string>EFIBluetoothDelay</string>\n\t\t\t\t<string>LocationServicesEnabled</string>\n\t\t\t\t<string>SystemAudioVolume</string>\n\t\t\t\t<string>SystemAudioVolumeDB</string>\n\t\t\t\t<string>SystemAudioVolumeSaved</string>\n\t\t\t\t<string>bluetoothActiveControllerInfo</string>\n\t\t\t\t<string>bluetoothInternalControllerInfo</string>\n\t\t\t\t<string>flagstate</string>\n\t\t\t\t<string>fmm-computer-name</string>\n\t\t\t\t<string>fmm-mobileme-token-FMM</string>\n\t\t\t\t<string>fmm-mobileme-token-FMM-BridgeHasAccount</string>\n\t\t\t\t<string>nvda_drv</string>\n\t\t\t\t<string>prev-lang:kbd</string>\n\t\t\t\t<string>backlight-level</string>\n\t\t\t\t<string>BootCampHD</string>\n\t\t\t</array>\n\t\t\t<key>8BE4DF61-93CA-11D2-AA0D-00E098032B8C</key>\n\t\t\t<array>\n\t\t\t\t<string>Boot0080</string>\n\t\t\t\t<string>Boot0081</string>\n\t\t\t\t<string>Boot0082</string>\n\t\t\t\t<string>BootNext</string>\n\t\t\t\t<string>BootOrder</string>\n\t\t\t</array>\n\t\t</dict>\n\t\t<key>WriteFlash</key>\n\t\t<true/>\n\t</dict>\n\t<key>PlatformInfo</key>\n\t<dict>\n\t\t<key>Automatic</key>\n\t\t<true/>\n\t\t<key>CustomMemory</key>\n\t\t<false/>\n\t\t<key>Generic</key>\n\t\t<dict>\n\t\t\t<key>AdviseFeatures</key>\n\t\t\t<false/>\n\t\t\t<key>MLB</key>\n\t\t\t<string>M0000000000000001</string>\n\t\t\t<key>MaxBIOSVersion</key>\n\t\t\t<false/>\n\t\t\t<key>ProcessorType</key>\n\t\t\t<integer>0</integer>\n\t\t\t<key>ROM</key>\n\t\t\t<data>ESIzRFVm</data>\n\t\t\t<key>SpoofVendor</key>\n\t\t\t<true/>\n\t\t\t<key>SystemMemoryStatus</key>\n\t\t\t<string>Auto</string>\n\t\t\t<key>SystemProductName</key>\n\t\t\t<string>iMac19,1</string>\n\t\t\t<key>SystemSerialNumber</key>\n\t\t\t<string>W00000000001</string>\n\t\t\t<key>SystemUUID</key>\n\t\t\t<string>00000000-0000-0000-0000-000000000000</string>\n\t\t</dict>\n\t\t<key>UpdateDataHub</key>\n\t\t<true/>\n\t\t<key>UpdateNVRAM</key>\n\t\t<true/>\n\t\t<key>UpdateSMBIOS</key>\n\t\t<true/>\n\t\t<key>UpdateSMBIOSMode</key>\n\t\t<string>Create</string>\n\t\t<key>UseRawUuidEncoding</key>\n\t\t<false/>\n\t</dict>\n\t<key>UEFI</key>\n\t<dict>\n\t\t<key>APFS</key>\n\t\t<dict>\n\t\t\t<key>EnableJumpstart</key>\n\t\t\t<true/>\n\t\t\t<key>GlobalConnect</key>\n\t\t\t<false/>\n\t\t\t<key>HideVerbose</key>\n\t\t\t<true/>\n\t\t\t<key>JumpstartHotPlug</key>\n\t\t\t<false/>\n\t\t\t<key>MinDate</key>\n\t\t\t<integer>-1</integer>\n\t\t\t<key>MinVersion</key>\n\t\t\t<integer>-1</integer>\n\t\t</dict>\n\t\t<key>AppleInput</key>\n\t\t<dict>\n\t\t\t<key>AppleEvent</key>\n\t\t\t<string>Builtin</string>\n\t\t\t<key>CustomDelays</key>\n\t\t\t<false/>\n\t\t\t<key>GraphicsInputMirroring</key>\n\t\t\t<true/>\n\t\t\t<key>KeyInitialDelay</key>\n\t\t\t<integer>50</integer>\n\t\t\t<key>KeySubsequentDelay</key>\n\t\t\t<integer>5</integer>\n\t\t\t<key>PointerDwellClickTimeout</key>\n\t\t\t<integer>0</integer>\n\t\t\t<key>PointerDwellDoubleClickTimeout</key>\n\t\t\t<integer>0</integer>\n\t\t\t<key>PointerDwellRadius</key>\n\t\t\t<integer>0</integer>\n\t\t\t<key>PointerPollMask</key>\n\t\t\t<integer>-1</integer>\n\t\t\t<key>PointerPollMax</key>\n\t\t\t<integer>80</integer>\n\t\t\t<key>PointerPollMin</key>\n\t\t\t<integer>10</integer>\n\t\t\t<key>PointerSpeedDiv</key>\n\t\t\t<integer>1</integer>\n\t\t\t<key>PointerSpeedMul</key>\n\t\t\t<integer>1</integer>\n\t\t</dict>\n\t\t<key>Audio</key>\n\t\t<dict>\n\t\t\t<key>AudioCodec</key>\n\t\t\t<integer>0</integer>\n\t\t\t<key>AudioDevice</key>\n\t\t\t<string>PciRoot(0x0)/Pci(0x1b,0x0)</string>\n\t\t\t<key>AudioOutMask</key>\n\t\t\t<integer>1</integer>\n\t\t\t<key>AudioSupport</key>\n\t\t\t<false/>\n\t\t\t<key>DisconnectHda</key>\n\t\t\t<false/>\n\t\t\t<key>MaximumGain</key>\n\t\t\t<integer>-15</integer>\n\t\t\t<key>MinimumAssistGain</key>\n\t\t\t<integer>-30</integer>\n\t\t\t<key>MinimumAudibleGain</key>\n\t\t\t<integer>-55</integer>\n\t\t\t<key>PlayChime</key>\n\t\t\t<string>Auto</string>\n\t\t\t<key>ResetTrafficClass</key>\n\t\t\t<false/>\n\t\t\t<key>SetupDelay</key>\n\t\t\t<integer>0</integer>\n\t\t</dict>\n\t\t<key>ConnectDrivers</key>\n\t\t<true/>\n\t\t<key>Drivers</key>\n\t\t<array>\n\t\t\t<dict>\n\t\t\t\t<key>Arguments</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>OpenCanopy.efi</string>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<true/>\n\t\t\t\t<key>LoadEarly</key>\n\t\t\t\t<false/>\n\t\t\t\t<key>Path</key>\n\t\t\t\t<string>OpenCanopy.efi</string>\n\t\t\t</dict>\n\t\t\t<dict>\n\t\t\t\t<key>Arguments</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>OpenHfsPlus.efi</string>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<true/>\n\t\t\t\t<key>LoadEarly</key>\n\t\t\t\t<false/>\n\t\t\t\t<key>Path</key>\n\t\t\t\t<string>OpenHfsPlus.efi</string>\n\t\t\t</dict>\n\t\t\t<dict>\n\t\t\t\t<key>Arguments</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>OpenRuntime.efi</string>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<true/>\n\t\t\t\t<key>LoadEarly</key>\n\t\t\t\t<false/>\n\t\t\t\t<key>Path</key>\n\t\t\t\t<string>OpenRuntime.efi</string>\n\t\t\t</dict>\n\t\t\t<dict>\n\t\t\t\t<key>Arguments</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>ResetNvramEntry.efi</string>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<true/>\n\t\t\t\t<key>LoadEarly</key>\n\t\t\t\t<false/>\n\t\t\t\t<key>Path</key>\n\t\t\t\t<string>ResetNvramEntry.efi</string>\n\t\t\t</dict>\n\t\t\t<dict>\n\t\t\t\t<key>Arguments</key>\n\t\t\t\t<string></string>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>ToggleSipEntry.efi</string>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<true/>\n\t\t\t\t<key>LoadEarly</key>\n\t\t\t\t<false/>\n\t\t\t\t<key>Path</key>\n\t\t\t\t<string>ToggleSipEntry.efi</string>\n\t\t\t</dict>\n\t\t</array>\n\t\t<key>Input</key>\n\t\t<dict>\n\t\t\t<key>KeyFiltering</key>\n\t\t\t<false/>\n\t\t\t<key>KeyForgetThreshold</key>\n\t\t\t<integer>5</integer>\n\t\t\t<key>KeySupport</key>\n\t\t\t<true/>\n\t\t\t<key>KeySupportMode</key>\n\t\t\t<string>Auto</string>\n\t\t\t<key>KeySwap</key>\n\t\t\t<false/>\n\t\t\t<key>PointerSupport</key>\n\t\t\t<false/>\n\t\t\t<key>PointerSupportMode</key>\n\t\t\t<string>ASUS</string>\n\t\t\t<key>TimerResolution</key>\n\t\t\t<integer>50000</integer>\n\t\t</dict>\n\t\t<key>Output</key>\n\t\t<dict>\n\t\t\t<key>ClearScreenOnModeSwitch</key>\n\t\t\t<false/>\n\t\t\t<key>ConsoleFont</key>\n\t\t\t<string></string>\n\t\t\t<key>ConsoleMode</key>\n\t\t\t<string></string>\n\t\t\t<key>DirectGopRendering</key>\n\t\t\t<false/>\n\t\t\t<key>ForceResolution</key>\n\t\t\t<false/>\n\t\t\t<key>GopBurstMode</key>\n\t\t\t<false/>\n\t\t\t<key>GopPassThrough</key>\n\t\t\t<string>Disabled</string>\n\t\t\t<key>IgnoreTextInGraphics</key>\n\t\t\t<false/>\n\t\t\t<key>InitialMode</key>\n\t\t\t<string>Auto</string>\n\t\t\t<key>ProvideConsoleGop</key>\n\t\t\t<true/>\n\t\t\t<key>ReconnectGraphicsOnConnect</key>\n\t\t\t<false/>\n\t\t\t<key>ReconnectOnResChange</key>\n\t\t\t<false/>\n\t\t\t<key>ReplaceTabWithSpace</key>\n\t\t\t<false/>\n\t\t\t<key>Resolution</key>\n\t\t\t<string></string>\n\t\t\t<key>SanitiseClearScreen</key>\n\t\t\t<false/>\n\t\t\t<key>TextRenderer</key>\n\t\t\t<string>BuiltinGraphics</string>\n\t\t\t<key>UIScale</key>\n\t\t\t<integer>0</integer>\n\t\t\t<key>UgaPassThrough</key>\n\t\t\t<false/>\n\t\t</dict>\n\t\t<key>ProtocolOverrides</key>\n\t\t<dict>\n\t\t\t<key>AppleAudio</key>\n\t\t\t<false/>\n\t\t\t<key>AppleBootPolicy</key>\n\t\t\t<false/>\n\t\t\t<key>AppleDebugLog</key>\n\t\t\t<false/>\n\t\t\t<key>AppleEg2Info</key>\n\t\t\t<false/>\n\t\t\t<key>AppleFramebufferInfo</key>\n\t\t\t<false/>\n\t\t\t<key>AppleImageConversion</key>\n\t\t\t<false/>\n\t\t\t<key>AppleImg4Verification</key>\n\t\t\t<false/>\n\t\t\t<key>AppleKeyMap</key>\n\t\t\t<false/>\n\t\t\t<key>AppleRtcRam</key>\n\t\t\t<false/>\n\t\t\t<key>AppleSecureBoot</key>\n\t\t\t<false/>\n\t\t\t<key>AppleSmcIo</key>\n\t\t\t<false/>\n\t\t\t<key>AppleUserInterfaceTheme</key>\n\t\t\t<false/>\n\t\t\t<key>DataHub</key>\n\t\t\t<false/>\n\t\t\t<key>DeviceProperties</key>\n\t\t\t<false/>\n\t\t\t<key>FirmwareVolume</key>\n\t\t\t<true/>\n\t\t\t<key>HashServices</key>\n\t\t\t<false/>\n\t\t\t<key>OSInfo</key>\n\t\t\t<false/>\n\t\t\t<key>PciIo</key>\n\t\t\t<false/>\n\t\t\t<key>UnicodeCollation</key>\n\t\t\t<false/>\n\t\t</dict>\n\t\t<key>Quirks</key>\n\t\t<dict>\n\t\t\t<key>ActivateHpetSupport</key>\n\t\t\t<false/>\n\t\t\t<key>DisableSecurityPolicy</key>\n\t\t\t<false/>\n\t\t\t<key>EnableVectorAcceleration</key>\n\t\t\t<true/>\n\t\t\t<key>EnableVmx</key>\n\t\t\t<false/>\n\t\t\t<key>ExitBootServicesDelay</key>\n\t\t\t<integer>0</integer>\n\t\t\t<key>ForceOcWriteFlash</key>\n\t\t\t<false/>\n\t\t\t<key>ForgeUefiSupport</key>\n\t\t\t<false/>\n\t\t\t<key>IgnoreInvalidFlexRatio</key>\n\t\t\t<false/>\n\t\t\t<key>ReleaseUsbOwnership</key>\n\t\t\t<false/>\n\t\t\t<key>ReloadOptionRoms</key>\n\t\t\t<false/>\n\t\t\t<key>RequestBootVarRouting</key>\n\t\t\t<true/>\n\t\t\t<key>ResizeGpuBars</key>\n\t\t\t<integer>-1</integer>\n\t\t\t<key>ResizeUsePciRbIo</key>\n\t\t\t<false/>\n\t\t\t<key>ShimRetainProtocol</key>\n\t\t\t<false/>\n\t\t\t<key>TscSyncTimeout</key>\n\t\t\t<integer>0</integer>\n\t\t\t<key>UnblockFsConnect</key>\n\t\t\t<false/>\n\t\t</dict>\n\t\t<key>ReservedMemory</key>\n\t\t<array>\n\t\t\t<dict>\n\t\t\t\t<key>Address</key>\n\t\t\t\t<integer>268435456</integer>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>HD3000: IGPU memory corruption errata</string>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<false/>\n\t\t\t\t<key>Size</key>\n\t\t\t\t<integer>268435456</integer>\n\t\t\t\t<key>Type</key>\n\t\t\t\t<string>Reserved</string>\n\t\t\t</dict>\n\t\t\t<dict>\n\t\t\t\t<key>Address</key>\n\t\t\t\t<integer>569344</integer>\n\t\t\t\t<key>Comment</key>\n\t\t\t\t<string>Fix black screen on wake from hibernation for Lenovo Thinkpad T490</string>\n\t\t\t\t<key>Enabled</key>\n\t\t\t\t<false/>\n\t\t\t\t<key>Size</key>\n\t\t\t\t<integer>4096</integer>\n\t\t\t\t<key>Type</key>\n\t\t\t\t<string>RuntimeCode</string>\n\t\t\t</dict>\n\t\t</array>\n\t\t<key>Unload</key>\n\t\t<array/>\n\t</dict>\n</dict>\n</plist>\n"
  },
  {
    "path": "Install_Python3.command",
    "content": "#!/bin/bash\n# Copyright (c) 2024-2025, LongQT-sea\n\n# macOS Python3 Silent Installer\n# Installs appropriate Python3 version based on macOS version\n# Checks if installer exists in current directory first; if not, downloads from python.org\n# Supports macOS 10.6 and later\n\nset -e\n\nRED='\\033[0;31m'\nGREEN='\\033[0;32m'\nYELLOW='\\033[1;33m'\nNC='\\033[0m'\n\nprint_info()    { echo -e \"${GREEN}[INFO]${NC} $1\"; }\nprint_warning() { echo -e \"${YELLOW}[WARNING]${NC} $1\"; }\nprint_error()   { echo -e \"${RED}[ERROR]${NC} $1\"; }\n\nif [ \"$EUID\" -ne 0 ]; then\n    echo \"\"\n    echo -e \"${YELLOW}[INFO]${NC} Administrator privileges required...\"\n    exec sudo \"$0\" \"$@\"\n    exit\nfi\n\nget_macos_version() {\n    sw_vers -productVersion\n}\n\nget_latest_version() {\n    local branch=$1\n    local fallback=$2\n    local api_url=\"https://www.python.org/api/v2/downloads/release/?version=3&pre_release=false&is_published=true\"\n    local raw=\"\"\n\n    if command -v curl &> /dev/null; then\n        raw=$(curl -sf --connect-timeout 10 --max-time 20 \"$api_url\" 2>/dev/null || true)\n    elif command -v wget &> /dev/null; then\n        raw=$(wget -qO- --timeout=20 \"$api_url\" 2>/dev/null || true)\n    fi\n\n    if [ -z \"$raw\" ]; then\n        print_warning \"Could not reach python.org API. Using fallback version: $fallback\"\n        echo \"$fallback\"\n        return\n    fi\n\n    local latest=\"\"\n    latest=$(echo \"$raw\" \\\n        | grep -o '\"name\":\"Python [^\"]*\"' \\\n        | sed 's/\"name\":\"Python //;s/\"//' \\\n        | grep -E \"^${branch//./\\\\.}\\\\.[0-9]+$\" \\\n        | sort -t. -k3 -n \\\n        | tail -n 1)\n\n    if [ -z \"$latest\" ]; then\n        print_warning \"Could not parse version for branch ${branch}. Using fallback: $fallback\"\n        echo \"$fallback\"\n    else\n        echo \"$latest\"\n    fi\n}\n\ndetermine_python_version() {\n    local macos_version=$1\n    local major\n    local minor\n    major=$(echo \"$macos_version\" | cut -d. -f1)\n    minor=$(echo \"$macos_version\" | cut -d. -f2)\n\n    if [ \"$major\" -eq 10 ]; then\n        if [ \"$minor\" -ge 15 ]; then\n            print_info \"Fetching latest Python 3.14 release...\"\n            PYTHON_VERSION=$(get_latest_version \"3.14\" \"3.14.3\")\n            PYTHON_PKG=\"python-${PYTHON_VERSION}-macos11.pkg\"\n            DOWNLOAD_URL=\"https://www.python.org/ftp/python/${PYTHON_VERSION}/${PYTHON_PKG}\"\n\n        elif [ \"$minor\" -ge 13 ] && [ \"$minor\" -le 14 ]; then\n            print_info \"Fetching latest Python 3.13 release...\"\n            PYTHON_VERSION=$(get_latest_version \"3.13\" \"3.13.12\")\n            PYTHON_PKG=\"python-${PYTHON_VERSION}-macos11.pkg\"\n            DOWNLOAD_URL=\"https://www.python.org/ftp/python/${PYTHON_VERSION}/${PYTHON_PKG}\"\n\n        elif [ \"$minor\" -ge 9 ] && [ \"$minor\" -le 12 ]; then\n            # EOL — 3.9.13 is the last release with a macosx10.9 pkg\n            PYTHON_VERSION=\"3.9.13\"\n            PYTHON_PKG=\"python-3.9.13-macosx10.9.pkg\"\n            DOWNLOAD_URL=\"https://www.python.org/ftp/python/3.9.13/${PYTHON_PKG}\"\n\n        elif [ \"$minor\" -ge 6 ] && [ \"$minor\" -le 8 ]; then\n            # EOL — 3.6.8 is the last release with a macosx10.6 pkg\n            PYTHON_VERSION=\"3.6.8\"\n            PYTHON_PKG=\"python-3.6.8-macosx10.6.pkg\"\n            DOWNLOAD_URL=\"https://www.python.org/ftp/python/3.6.8/${PYTHON_PKG}\"\n\n        else\n            print_error \"Unsupported macOS version: $macos_version\"\n            exit 1\n        fi\n\n    elif [ \"$major\" -ge 11 ]; then\n        print_info \"Fetching latest Python 3.14 release...\"\n        PYTHON_VERSION=$(get_latest_version \"3.14\" \"3.14.3\")\n        PYTHON_PKG=\"python-${PYTHON_VERSION}-macos11.pkg\"\n        DOWNLOAD_URL=\"https://www.python.org/ftp/python/${PYTHON_VERSION}/${PYTHON_PKG}\"\n\n    else\n        print_error \"Unsupported macOS version: $macos_version\"\n        exit 1\n    fi\n}\n\nfind_pkg_in_dir() {\n    local dir=$1\n    local f\n    for f in \"$dir\"/python-\"${PYTHON_VERSION}\"*.pkg; do\n        if [ -f \"$f\" ]; then\n            echo \"$f\"\n            return 0\n        fi\n    done\n    return 1\n}\n\ncheck_local_installer() {\n    local script_dir\n    local current_dir\n    script_dir=\"$(cd \"$(dirname \"$0\")\" && pwd)\"\n    current_dir=\"$(pwd)\"\n\n    local found\n    if found=$(find_pkg_in_dir \"$script_dir\"); then\n        echo \"$found\"\n        return 0\n    fi\n\n    if [ \"$current_dir\" != \"$script_dir\" ]; then\n        if found=$(find_pkg_in_dir \"$current_dir\"); then\n            echo \"$found\"\n            return 0\n        fi\n    fi\n\n    return 1\n}\n\ndownload_installer() {\n    local url=$1\n    local output=$2\n\n    print_info \"Downloading Python installer from: $url\"\n\n    if command -v curl &> /dev/null; then\n        curl -L -o \"$output\" \"$url\" --connect-timeout 30 --max-time 600\n    elif command -v wget &> /dev/null; then\n        wget -O \"$output\" \"$url\" --timeout=30\n    else\n        print_error \"Neither curl nor wget found. Cannot download installer.\"\n        return 1\n    fi\n}\n\ninstall_python() {\n    local pkg_path=$1\n\n    print_info \"Installing Python from: $pkg_path\"\n\n    if [ ! -f \"$pkg_path\" ]; then\n        print_error \"Installer file not found: $pkg_path\"\n        exit 1\n    fi\n\n    if sudo installer -pkg \"$pkg_path\" -target / -verbose; then\n        print_info \"Python installed successfully!\"\n    else\n        print_error \"Installation failed!\"\n        return 1\n    fi\n}\n\nmain() {\n    print_info \"macOS Python Silent Installer\"\n    echo \"\"\n\n    local MACOS_VERSION\n    MACOS_VERSION=$(get_macos_version)\n    print_info \"Detected macOS version: $MACOS_VERSION\"\n\n    determine_python_version \"$MACOS_VERSION\"\n    print_info \"Target Python version: $PYTHON_VERSION\"\n    print_info \"Installer package: $PYTHON_PKG\"\n    echo \"\"\n\n    print_info \"Checking for local installer...\"\n    print_info \"Script directory: $(cd \"$(dirname \"$0\")\" && pwd)\"\n    print_info \"Current directory: $(pwd)\"\n\n    local INSTALLER_PATH\n    local LOCAL_PKG\n\n    if LOCAL_PKG=$(check_local_installer); then\n        print_info \"Found local installer: $LOCAL_PKG\"\n        INSTALLER_PATH=\"$LOCAL_PKG\"\n    else\n        print_warning \"Local installer not found. Attempting to download...\"\n        local DOWNLOADS_DIR=\"$HOME/Downloads\"\n        INSTALLER_PATH=\"$DOWNLOADS_DIR/$PYTHON_PKG\"\n        print_info \"Will save installer to: $INSTALLER_PATH\"\n\n        if ! download_installer \"$DOWNLOAD_URL\" \"$INSTALLER_PATH\"; then\n            print_error \"Download failed!\"\n            echo \"\"\n            print_warning \"This may be due to outdated SSL/TLS support on older macOS versions.\"\n            print_warning \"Please try one of the following options:\"\n            echo \"  1. Download the installer on a newer macOS system and transfer it here\"\n            echo \"  2. Download manually from: $DOWNLOAD_URL\"\n            echo \"  3. Place the installer in the same directory as this script and run again\"\n            echo \"\"\n            print_info \"Looking for: $PYTHON_PKG\"\n            exit 1\n        fi\n\n        print_info \"Download completed successfully!\"\n    fi\n\n    echo \"\"\n\n    if install_python \"$INSTALLER_PATH\"; then\n        echo \"\"\n        print_info \"Installation complete!\"\n\n        if command -v python3 &> /dev/null; then\n            local INSTALLED_VERSION\n            INSTALLED_VERSION=$(python3 --version 2>&1)\n            print_info \"Installed: $INSTALLED_VERSION\"\n        fi\n    else\n        exit 1\n    fi\n}\n\nmain\n\nexit 0"
  },
  {
    "path": "LICENSE",
    "content": "MIT License\n\nCopyright (c) 2024-2025, LongQT-sea\n\nPermission is hereby granted, free of charge, to any person obtaining a copy\nof this software and associated documentation files (the \"Software\"), to deal\nin the Software without restriction, including without limitation the rights\nto use, copy, modify, merge, publish, distribute, sublicense, and/or sell\ncopies of the Software, and to permit persons to whom the Software is\nfurnished to do so, subject to the following conditions:\n\nThe above copyright notice and this permission notice shall be included in all\ncopies or substantial portions of the Software.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\nIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\nFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\nAUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\nLIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\nOUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\nSOFTWARE."
  },
  {
    "path": "LICENSE-OpenCore.txt",
    "content": "Copyright (c) 2016-2017, The HermitCrabs Lab\nCopyright (c) 2016-2020, Download-Fritz\nCopyright (c) 2017-2020, savvas\nCopyright (c) 2016-2020, vit9696\n\nAll rights reserved.\n\nRedistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:\n\n1. Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer.\n\n2. Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution.\n\n3. Neither the name of the copyright holder nor the names of its contributors may be used to endorse or promote products derived from this software without specific prior written permission.\n\nTHIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n"
  },
  {
    "path": "Make_ISO.command",
    "content": "#!/usr/bin/env bash\n\nISO_FILE_NAME=LongQT-OpenCore-v0.7.iso\nVOL_NAME=LongQT-OpenCore\nSOURCE_DIR=./\nBOOT_IMG=BOOT.img\n\ncd \"$(dirname \"$0\")\"\n\n# Cleanup\nfind ${SOURCE_DIR} \\\n    \\( \\\n        -name \".DS_Store\" \\\n        -o -name \"._*\" \\\n        -o -name \".Spotlight-V100\" \\\n        -o -name \".Trashes\" \\\n        -o -name \".fseventsd\" \\\n        -o -name \".DocumentRevisions-V100\" \\\n        -o -name \".TemporaryItems\" \\\n        -o -name \"__MACOSX\" \\\n    \\) \\\n    -exec rm -rf {} +\n\nif ! command -v xorriso >/dev/null 2>&1; then\n  echo \"xorriso not found. Please install it with: brew install xorriso\"\n  exit 1\nfi\n\nxorriso -rockridge off -as mkisofs \\\n  -iso-level 3 \\\n  -V \"${VOL_NAME}\" \\\n  -J -joliet-long\\\n  -e \"${BOOT_IMG}\" \\\n  -no-emul-boot \\\n  --boot-catalog-hide \\\n  -m \".git*\" \\\n  -m \"README.md\" \\\n  -m \"Make_ISO*\" \\\n  -m \"LICENSE*\" \\\n  -m \"cpu-models.conf\" \\\n  -m \"Create_Recovery_ISO*\" \\\n  -output ~/Desktop/${ISO_FILE_NAME} \\\n  ${SOURCE_DIR}\n"
  },
  {
    "path": "Mount_EFI.command",
    "content": "#!/bin/bash\n\n# Simple EFI Mount Script for VM, mount disk0s1 only\n\n# Color codes\nRED='\\033[0;31m'\nGREEN='\\033[0;32m'\nYELLOW='\\033[1;33m'\nNC='\\033[0m'\n\nclear\necho -e \"${GREEN}=== EFI Partition Mount Script ===${NC}\"\necho \"\"\n\n# Check if already mounted\nif mount | grep -q \"/dev/disk0s1\"; then\n    echo -e \"${YELLOW}disk0s1 is already mounted${NC}\"\n    mount | grep \"/dev/disk0s1\"\nelse\n    # Create mount point\n    echo \"Creating /Volumes/EFI...\"\n    echo \"\"\n    echo -e \"${YELLOW} Administrator privileges required.${NC}\"\n    sudo mkdir -p /Volumes/EFI\n    \n    # Mount disk0s1\n    echo \"Mounting /dev/disk0s1 to /Volumes/EFI...\"\n    if sudo mount -t msdos /dev/disk0s1 /Volumes/EFI 2>/dev/null; then\n        echo -e \"${GREEN}Successfully mounted!${NC}\"\n    else\n        echo -e \"${RED}Failed to mount disk0s1${NC}\"\n    fi\nfi\n\necho \"\"\necho \"────────────────────────────────────\"\necho \"Press Command-W to close this window\"\necho \"────────────────────────────────────\""
  },
  {
    "path": "README.md",
    "content": "## About\n\nA carefully crafted OpenCore **ISO** image for running macOS virtual machines on **Proxmox VE** and **QEMU/KVM**.\nBuilt from scratch with a clean, efficient architecture — no legacy configurations, no OVMF patches, no kernel patches, true vanilla macOS.\n\nSupports every Intel-based macOS release from **[Mac OS X 10.4 Tiger](https://dortania.github.io/OpenCore-Install-Guide/installer-guide/mac-install-dmg.html#acidanthera-images)** through **[macOS 26 Tahoe](https://github.com/LongQT-sea/macos-iso-builder)**.\n\n> [!TIP]\n> This is likely the best way to run macOS on AMD hardware while retaining full hypervisor access for other VMs.\n> Also overcomes a lot of AMD CPU limitations listed on [Dortania guide](https://dortania.github.io/Anti-Hackintosh-Buyers-Guide/CPU.html#cpus-to-avoid).\n\n---\n\n<details>\n<summary>Table of Contents</summary>\n\n- [Download](#download)\n- [Quick Start Guide](#quick-start-guide)\n  - [1. Create a New VM](#1-create-a-new-vm)\n  - [2. General](#2-general)\n  - [3. OS](#3-os)\n  - [4. System](#4-system)\n  - [5. Hard Disk](#5-hard-disk)\n  - [6. CPU](#6-cpu)\n  - [7. Memory](#7-memory)\n  - [8. Network](#8-network)\n  - [9. Finalize](#9-finalize)\n  - [10. Troubleshooting](#10-troubleshooting)\n- [Post-Install](#post-install)\n- [macOS Tahoe Cursor Freeze Fix](#macos-tahoe-cursor-freeze-fix)\n- [Contributing](#contributing)\n- [Credits](#credits)\n- [License & Attribution](#license--attribution)\n- [Disclaimer](#disclaimer)\n</details>\n\n---\n\n## Download\n\n* Latest OpenCore-ISO: [LongQT-OpenCore-v0.7.iso](https://github.com/LongQT-sea/OpenCore-ISO/releases/download/v0.7/LongQT-OpenCore-v0.7.iso)\n* For legit macOS installers and recovery ISOs: [LongQT-sea/macos-iso-builder](https://github.com/LongQT-sea/macos-iso-builder)\n\n> [!CAUTION]\n> These iso are **true CD/DVD ISO image**.\n> Add them to your VM as a **CD/DVD drive**. Do **NOT** change **`media=cdrom`** to **`media=disk`** in the VM config.\n\n> [!TIP]\n> Run [`Create_macOS_ISO.command`](/Create_macOS_ISO.command) inside your VM to download the full macOS installer from Apple and generate a proper DVD-format macOS installer ISO.\n\n---\n\n## Quick Start Guide\n\n### 1. Create a New VM\nOpen the Proxmox VE web interface and create a new VM.\n\n---\n\n### 2. General\n\n* **VM ID**: Any available ID\n* **Name**: Any name you like\n\n---\n\n### 3. OS\n\n* **ISO Image**: Select `LongQT-OpenCore-v0.X.iso`\n* **Guest OS Type**: Leave as default (`Linux`)\n\n---\n\n### 4. System\n\n* **Machine Type**: q35\n* **BIOS**: OVMF (UEFI)\n* **Add EFI Disk**: [✓] Enabled\n* **Pre-Enroll Keys**: [✗] Untick to disable Secure Boot\n* **QEMU Guest Agent**:\n\n  * [✓] Enable for macOS 10.14 – macOS 26\n  * [✗] Leave as default for macOS 10.4 – macOS 10.13\n\n---\n\n### 5. Hard Disk\n\nThe **disk bus type** depends on your needs:\n\n* **VirtIO** – Better performance\n* **SATA** – Supports TRIM/Discard for more efficient storage usage\n\n| macOS Version            | Supports Bus Type       |\n| ------------------------ | ----------------------- |\n| macOS 10.15 – macOS 26   | `SATA` / `VirtIO Block` |\n| macOS 10.4 – macOS 10.14 | `SATA`                  |\n\n> [!Tip]\n> Using SATA with **SSD emulation** and **Discard** enabled automatically enables TRIM — no need to run `trimforce enable`.\n\n---\n\n### 6. CPU\n\n> [!CAUTION]\n> Follow these CPU settings carefully! Incorrect CPU configuration will cause boot failure.\n\n#### Cores\nChoose based on your hardware (`power of 2`): 1 / 2 / 4 / 8 / 16 / 32 / 64\n> [!TIP]\n> For non-power-of-2 counts, use multiple sockets:\n> | Target Cores | Cores | Sockets |\n> |---|---|---|\n> | 6 | 2 | 3 |\n> | 12 | 4 | 3 |\n> | 20 | 4 | 5 |\n> | 24 | 8 | 3 |\n\n#### Type (Model)\n\n| macOS Version            | Recommended CPU Type                               |\n| ------------------------ | -------------------------------------------------- |\n| macOS 10.11 – macOS 26   | `Skylake-Client-v4`, `Skylake-Server-v4` (AVX-512) |\n| macOS 10.4 – macOS 10.10 | `Nehalem`                                          |\n\n> [!NOTE]\n> **AMD CPUs:**\n> * **macOS 10.4 – macOS 12**, tick [✓] **Advanced**, under **Extra CPU Flags**, turn off `pcid` and `spec-ctrl`. [^amdcpu1]\n> * **macOS 13 – macOS 26**, need to set the CPU manually via the Proxmox VE Shell[^amdcpu2], example:\n>\n>   ```\n>   # For CPUs with AVX2 support\n>   qm set [VMID] --args \"-cpu Skylake-Client-v4,vendor=GenuineIntel\"\n>   \n>   # For CPUs with AVX-512 support\n>   qm set [VMID] --args \"-cpu Skylake-Server-v4,vendor=GenuineIntel\"\n>   ```\n> * If the VM fails to boot with more than 1 core, add `tsc=reliable` to the host kernel command line (`/etc/default/grub`).\n> ---\n>  **Intel CPUs:**\n> * Intel HEDT / E5-2xxx v3/v4 need to override CPUID `model`[^intel-hedt], example:\n>\n>   ```\n>   qm set [VMID] --args \"-cpu Broadwell-noTSX,model=158\"\n>   qm set [VMID] --args \"-cpu Haswell-noTSX,model=158\"\n>   ```\n> * Intel Haswell desktops need to override `stepping` when using `Haswell-noTSX`[^haswell]:\n>   ```\n>   qm set [VMID] --args \"-cpu Haswell-noTSX,stepping=3\"\n>   ```\n> * If you need to run nested virtualization software (such as Docker Desktop, VMware Fusion, or VirtualBox) inside macOS VM, use QEMU named CPU model with the `+vmx` CPU flag, example:\n>   ```\n>   qm set [VMID] --args \"-cpu Skylake-Client-v4,+vmx\"\n>   ```\n> * Avoid using `host` passthrough CPU types[^hostcpu] — they can be [**~30% slower (single-core)** and **~44% slower (multi-core)**](https://browser.geekbench.com/v6/cpu/compare/14205183?baseline=14313138) compared to recommended CPU types.\n\nFor more details, see [QEMU CPU Guide – macOS Guests](https://github.com/LongQT-sea/qemu-cpu-guide?#macos-guests).\n\n---\n\n### 7. Memory\n\n* **RAM**: Minimum 2 GB (4 GB or more recommended)\n* Disable [✗] Ballooning Device\n\n---\n\n### 8. Network\n\nChoose the correct adapter based on macOS version:\n\n| macOS Version       | Network Adapter    |\n| ------------------- | ------------------ |\n| macOS 11 – 26       | `VirtIO` (default) |\n| macOS 10.11 – 10.15 | `VMware vmxnet3`   |\n| macOS 10.4 – 10.10  | `Intel E1000`      |\n\n---\n\n### 9. Finalize\n\nAdd an **additional CD/DVD drive** for the macOS installer or Recovery ISO, then start the VM to begin installation.\n\n> [!Tip]\n> * First-time installing macOS? Format the disk in **Disk Utility** before installing macOS.\n> * **Skip iCloud login** during setup (configure it later, see [Post-Install](#post-install))\n\n**Got it running?** Maybe give the repo a star... nah nevermind, do whatever.\n\n### 10. Troubleshooting\n\nIf you encounter boot issues, check:\n* Secure Boot is **disabled** (`Pre-Enroll Keys` unchecked)\n* The ISO is mounted as a **CD/DVD**, not a disk\n* Try a different **CPU model**\n* For Mac OS X 10.4 Tiger, choose machine type q35, version <= 10.0\n\nLegacy OS X no-keyboard issue:\n* Either add `-device usb-kbd` to the QEMU args or run `device_add usb-kbd` in the VM Monitor tab.\n\n---\n\n## Post-Install\n\n### 1. Install OpenCore onto the macOS startup disk (macOS 10.11 – macOS 26)\n   * After macOS installation is complete, open **`LongQT-OpenCore`** on the Desktop and run **`Mount_EFI.command`** to mount the EFI partition on the macOS startup disk.\n   * Copy the **EFI** folder from **`LongQT-OpenCore/EFI_RELEASE/`** to the mounted EFI partition. This ensures that macOS will boot using the OpenCore EFI stored on the macOS startup disk in future startups.\n   * Run **`Install_Python3.command`** to install Python 3, many apps and scripts need it.\n   * Copy **`Mount_EFI.command`**, **`ProperTree`**, and **`GenSMBIOS`** to the Desktop for later use when you need to edit **`config.plist`**.\n   * You can now remove the **LongQT-OpenCore** ISO CD/DVD from the VM **Hardware** tab.\n\n### 2. To enable iCloud, iMessage, and other iServices\n   * Follow [Dortania iServices](https://dortania.github.io/OpenCore-Post-Install/universal/iservices.html) guide to generate your own SMBIOS.\n   * macOS 15 and macOS 26 need to install [VMHide.kext](https://github.com/Carnations-Botanica/VMHide)\n\n### 3. For smooth GUI performance and 3D acceleration\n\n* Pass through a supported Intel iGPU or dGPU:\n\n  * **Intel iGPU passthrough:** see [LongQT-sea/intel-igpu-passthru](https://github.com/LongQT-sea/intel-igpu-passthru)\n  * **dGPU passthrough:** ensure you have a supported dGPU, see [Dortania GPU Buyers Guide](https://dortania.github.io/GPU-Buyers-Guide/modern-gpus/amd-gpu.html#native-amd-gpus)\n\n> [!IMPORTANT]\n> PCIe/dGPU passthrough on a **q35** machine requires:\n> * Disable Resizable BAR / Smart Access Memory in UEFI/BIOS.\n> * Disable QEMU ACPI-based PCI hotplug (revert to native PCIe hotplug). Run this in the Proxmox shell:\n> ```\n> clear; read -p \"Enter your macOS VM ID number: \" VMID; \\\n> ARGS=\"$(qm config $VMID --current | grep ^args: | cut -d' ' -f2-)\"; \\\n> qm set $VMID -args \"$ARGS -global ICH9-LPC.acpi-pci-hotplug-with-bridge-support=off\"\n> ```\n\n> [!Tip]\n> If you need ReBAR enabled (for multi-GPU systems), set **BAR 0** of the dGPU you intend to passthrough to **256 MB**, example:\n> ```\n> # Unbind from the current driver:\n> echo 0000:01:00.0 > /sys/bus/pci/drivers/amdgpu/unbind\n> echo 0000:01:00.0 > /sys/bus/pci/drivers/vfio-pci/unbind\n> # Set BAR 0 to 256MB:\n> echo 8 > /sys/bus/pci/devices/0000:04:00.0/resource0_resize\n> ```\n\n> [!Tip]\n> On modern macOS versions, if you need a dummy virtual sound device (e.g., for **Parsec, Sunshine/MoonLight**), run this in Proxmox shell:\n> ```\n> clear; read -p \"Enter your macOS VM ID number: \" VMID; \\\n> ARGS=\"$(qm config $VMID --current | grep ^args: | cut -d' ' -f2-)\"; \\\n> qm set $VMID -args \"$ARGS -device virtio-sound,audiodev=dummy -audiodev none,id=dummy\"\n> ```\n\n> [!Tip]\n> To disable SIP, press <kbd>Spacebar</kbd> in the OpenCore boot menu and select the \"Toggle SIP\" option.\n\n---\n\n## macOS Tahoe Cursor Freeze Fix\n\nOn **macOS 26**, the cursor may randomly freeze. A temporary workaround is to toggle **Use tablet for pointer** in VM’s **Options** tab.\n\nA better fix is to use **`virtio-tablet-pci`**. To do this, disable **Use tablet for pointer** in VM’s **Options** tab, then run this in Proxmox shell:\n   ```\n   clear; read -p \"Enter your macOS VM ID number: \" VMID; \\\n   ARGS=\"$(qm config $VMID --current | grep ^args: | cut -d' ' -f2-)\"; \\\n   qm set $VMID -args \"$ARGS -device virtio-tablet\"\n   ```\n> [!Note]\n> With **`virtio-tablet-pci`**, middle-click on your real mouse acts as a right-click in the VM.\n \nThe most reliable solution is to passthrough a physical mouse and keyboard together with an iGPU or dGPU.\n\nAlternatively, use a remote desktop solution, e.g. **VNC Screen Sharing** (Settings → General → Sharing) or **Chrome Remote Desktop**.\n\n---\n\n## Contributing\nContributions are welcome! Please feel free to submit a pull request. For major changes, open a **Discussion** first to discuss what you would like to change.\n\n## Credits\n- [Acidanthera](https://github.com/acidanthera) team for OpenCorePkg and kexts.\n- [CorpNewt](https://github.com/corpnewt) for ProperTree, GenSMBIOS.\n- [Dortania](https://dortania.github.io/) for comprehensive guides.\n\n## License & Attribution\n\nThis project is licensed under the MIT License (see [LICENSE](LICENSE) file).\n\nIt also includes components from Acidanthera and other developers, each with their own licenses. All third-party components retain their original licenses.\n\n**If you create content using this project** (videos, blog posts, tutorials, articles):\n- Please link back to this repository: `https://github.com/LongQT-sea/OpenCore-ISO`\n- Mention that detailed **instructions** are in this GitHub repo.\n\nThank you for respecting the work that went into this project!\n\n## Disclaimer\nThis project is provided “as‑is”, without any warranties, and is intended for educational, research, and security testing purposes. In no event shall the authors or contributors be liable for any direct, indirect, incidental, special, or consequential damages arising from use of the project, even if advised of the possibility of such damages.\n\nAll product names, trademarks, and registered trademarks are property of their respective owners. All company, product, and service names used in this repository are for identification purposes only.\n\n[^amdcpu1]: The `pcid` and `spec-ctrl` flags are Intel-only CPU features.\n[^amdcpu2]: On macOS 13–26 running on AMD processors, these CPU flags `enforce,+kvm_pv_eoi,+kvm_pv_unhalt` (the default in Proxmox) prevent macOS from booting, so we override them with custom `-cpu` args.\n[^intel-hedt]: Override the CPUID model to one used in real Macs (e.g., `model=158`, which corresponds to the Coffee Lake CPUID model).\n[^haswell]: QEMU Haswell-noTSX CPU model has `stepping=4`, but macOS expects an earlier stepping (below 4).\n[^hostcpu]: This is one of the main reasons I created this project. All other project use `host` when running on supported Intel CPUs.\n"
  },
  {
    "path": "README.rtf",
    "content": "{\\rtf1\\ansi\\ansicpg1252\\cocoartf2865\n\\cocoatextscaling0\\cocoaplatform0{\\fonttbl\\f0\\froman\\fcharset0 Times-Bold;\\f1\\froman\\fcharset0 Times-Roman;}\n{\\colortbl;\\red255\\green255\\blue255;}\n{\\*\\expandedcolortbl;;}\n{\\*\\listtable{\\list\\listtemplateid1\\listhybrid{\\listlevel\\levelnfc23\\levelnfcn23\\leveljc0\\leveljcn0\\levelfollow0\\levelstartat1\\levelspace360\\levelindent0{\\*\\levelmarker \\{disc\\}}{\\leveltext\\leveltemplateid1\\'01\\uc0\\u8226 ;}{\\levelnumbers;}\\fi-360\\li720\\lin720 }{\\listname ;}\\listid1}}\n{\\*\\listoverridetable{\\listoverride\\listid1\\listoverridecount0\\ls1}}\n\\margl1440\\margr1440\\vieww18700\\viewh10820\\viewkind0\n\\deftab720\n\\pard\\pardeftab720\\sa298\\partightenfactor0\n\n\\f0\\b\\fs36 \\cf0 \\expnd0\\expndtw0\\kerning0\nNote:\\\n\\pard\\tx220\\tx720\\pardeftab720\\li720\\fi-720\\sa240\\partightenfactor0\n\\ls1\\ilvl0\n\\f1\\b0 \\cf0 \\kerning1\\expnd0\\expndtw0 {\\listtext\t\\uc0\\u8226 \t}\\expnd0\\expndtw0\\kerning0\nFor macOS 10.10 or older: Keep using this ISO to boot, or use the EFI inside BOOT.img.\\\n\\ls1\\ilvl0\\kerning1\\expnd0\\expndtw0 {\\listtext\t\\uc0\\u8226 \t}\\expnd0\\expndtw0\\kerning0\nFor macOS 10.11 or newer: Use either EFI_RELEASE or EFI_DEBUG.\\\n\\pard\\tx720\\pardeftab720\\sa240\\partightenfactor0\n\\cf0 Source: https://github.com/LongQT-sea/OpenCore-ISO}"
  },
  {
    "path": "cpu-models.conf",
    "content": "# Proxmox VE custom CPU models for macOS on i440fx machine type (iGPU passthrough)\n# Location: /etc/pve/virtual-guest/cpu-models.conf\n# Usage: qm set [VMID] --cpu Skylake-Client-with-invtsc\n# Use host-with-invtsc as a last resort\n\ncpu-model: host-with-invtsc\n    flags +invtsc\n    phys-bits host\n    hidden 0\n    hv-vendor-id intel\n    reported-model host\n\ncpu-model: Skylake-Client-with-invtsc\n    flags +invtsc\n    phys-bits host\n    hidden 0\n    hv-vendor-id intel\n    reported-model Skylake-Client-v4\n\ncpu-model: Broadwell-with-invtsc\n    flags +invtsc\n    phys-bits host\n    hidden 0\n    hv-vendor-id intel\n    reported-model Broadwell-noTSX"
  }
]