README.md 2.9 KB
Newer Older
A
Andrey1970AppleLife 已提交
1
<img src="/Docs/Logos/OpenCore_with_text_Small.png" width="200" height="48"/>
V
vit9696 已提交
2

A
Andrey1970 已提交
3
[![Build Status](https://github.com/acidanthera/OpenCorePkg/actions/workflows/build.yml/badge.svg?branch=master)](https://github.com/acidanthera/OpenCorePkg/actions) [![Scan Status](https://scan.coverity.com/projects/18169/badge.svg?flat=1)](https://scan.coverity.com/projects/18169)
V
vit9696 已提交
4
-----
A
Andrey1970AppleLife 已提交
5

6
OpenCore bootloader with development SDK.
V
vit9696 已提交
7

8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41
## Libraries

This repository also contains additional UEFI support common libraries shared by other projects in [Acidanthera](https://github.com/acidanthera). The primary purpose of the library set is to provide supplemental functionality for Apple-specific UEFI drivers. Key features:

- Apple disk image loading support
- Apple keyboard input aggregation
- Apple PE image signature verification
- Apple UEFI secure boot supplemental code
- Audio management with screen reading support
- Basic ACPI and SMBIOS manipulation
- CPU information gathering with timer support
- Cryptographic primitives (SHA-256, RSA, etc.)
- Decompression primitives (zlib, lzss, lzvn, etc.)
- Helper code for ACPI reads and modifications
- Higher level abstractions for files, strings, UEFI variables
- Overflow checking arithmetics
- PE image loading with no UEFI Secure Boot conflict
- Plist configuration format parsing
- PNG image manipulation
- Text output and graphics output implementations
- XNU kernel driver injection and patch engine

Early history of the codebase could be found in [AppleSupportPkg](https://github.com/acidanthera/AppleSupportPkg) and PicoLib library set by The HermitCrabs Lab.

#### OcGuardLib

This library implements basic safety features recommended for the use within the project. It implements fast
safe integral arithmetics mapping on compiler builtins, type alignment checking, and UBSan runtime,
based on [NetBSD implementation](https://blog.netbsd.org/tnf/entry/introduction_to_µubsan_a_clean).

The use of UBSan runtime requires the use of Clang compiler and `-fsanitize=undefined` argument. Refer to
[Clang documentation](https://releases.llvm.org/7.0.0/tools/clang/docs/UndefinedBehaviorSanitizer.html) for more
details.

V
vit9696 已提交
42
#### Credits
V
vit9696 已提交
43 44 45

- The HermitCrabs Lab
- All projects providing third-party code (refer to file headers)
V
vit9696 已提交
46 47
- [AppleLife](https://applelife.ru) team and user-contributed resources
- Chameleon and Clover teams for hints and legacy
V
vit9696 已提交
48 49
- [al3xtjames](https://github.com/al3xtjames)
- [Andrey1970AppleLife](https://github.com/Andrey1970AppleLife)
A
Andrey1970AppleLife 已提交
50
- [mhaeuser (ex Download-Fritz)](https://github.com/mhaeuser)
V
vit9696 已提交
51
- [Goldfish64](https://github.com/Goldfish64)
52
- [MikeBeaton](https://github.com/MikeBeaton)
V
vit9696 已提交
53
- [nms42](https://github.com/nms42)
P
PMheart 已提交
54
- [PMheart](https://github.com/PMheart)
V
vit9696 已提交
55
- [savvamitrofanov](https://github.com/savvamitrofanov)
A
Andrey1970AppleLife 已提交
56
- [usr-sse2](https://github.com/usr-sse2)
V
vit9696 已提交
57
- [vit9696](https://github.com/vit9696)
58 59 60

#### Discussion

A
Andrey1970AppleLife 已提交
61
Please refer to the following [list of OpenCore discussion forums](/Docs/FORUMS.md).