2021-01-12 18:22:11 +00:00
# m1n1: an experimentation playground for Apple Silicon
2021-02-06 07:43:14 +00:00
(And to some extent a Linux bootloader)
## Building
You need an `aarch64-linux-gnu-gcc` cross-compiler toolchain (or a native one, if running on ARM64).
2022-03-09 12:40:12 +00:00
You also need `convert` (from ImageMagick) for the boot logos.
2021-02-06 07:43:14 +00:00
```shell
$ git clone --recursive https://github.com/AsahiLinux/m1n1.git
$ cd m1n1
$ make
```
The output will be in build/m1n1.macho.
To build on a native arm64 machine, use `make ARCH=` .
2021-11-08 04:52:59 +00:00
Building on ARM64 macOS is supported with clang and LLVM; you need to use Homebrew to
install the required dependencies:
```shell
2022-03-09 12:40:12 +00:00
$ brew install llvm imagemagick
2021-11-08 04:52:59 +00:00
```
After that, just type `make` .
2021-02-07 17:22:22 +00:00
### Building using the container setup
If you have a container runtime installed, like Podman or Docker, you can make use of the compose setup, which contains all build dependencies.
```shell
$ git clone --recursive https://github.com/AsahiLinux/m1n1.git
$ cd m1n1
$ podman-compose run m1n1 make
$ # or
$ docker-compose run m1n1 make
```
2021-02-06 07:43:14 +00:00
## Usage
Our [developer quickstart ](https://github.com/AsahiLinux/docs/wiki/Developer-Quickstart#using-m1n1 )
guide has more information on how to use m1n1.
2021-12-17 12:49:20 +00:00
To install on an OS container based on macOS < 12.1 , use `m1n1.macho` :
```shell
kmutil configure-boot -c m1n1.macho -v < path to your OS volume >
```
To install on an OS container based on macOS >=12.1, use `m1n1.bin` :
```shell
kmutil configure-boot -c m1n1.bin --raw --entry-point 2048 --lowest-virtual-address 0 -v < path to your OS volume >
```
2021-02-06 07:43:14 +00:00
## Payloads
m1n1 supports running payloads by simple concatenation:
```shell
$ cat build/m1n1.macho Image.gz build/dtb/apple-j274.dtb initramfs.cpio.gz > m1n1-payload.macho
2021-12-17 12:49:20 +00:00
$ cat build/m1n1.bin Image.gz build/dtb/apple-j274.dtb initramfs.cpio.gz > m1n1-payload.bin
2021-02-06 07:43:14 +00:00
```
Supported payload file formats:
* Kernel images (or compatible). Must be compressed or last payload.
* Devicetree blobs (FDT). May be uncompressed or compressed.
* Initramfs cpio images. Must be compressed.
Supported compression formats:
* gzip
* xz
2021-01-12 18:22:11 +00:00
## License
m1n1 is licensed under the MIT license, as included in the [LICENSE ](LICENSE ) file.
2021-12-15 11:38:38 +00:00
* Copyright The Asahi Linux Contributors
2021-01-14 19:05:45 +00:00
2021-01-12 18:22:11 +00:00
Please see the Git history for authorship information.
Portions of m1n1 are based on mini:
2021-01-14 18:55:20 +00:00
2021-12-15 11:38:38 +00:00
* Copyright (C) 2008-2010 Hector Martin "marcan" < marcan @ marcan . st >
* Copyright (C) 2008-2010 Sven Peter < sven @ svenpeter . dev >
* Copyright (C) 2008-2010 Andre Heider < a.heider @ gmail . com >
2021-01-14 18:55:20 +00:00
2021-01-23 13:25:34 +00:00
m1n1 embeds libfdt, which is dual [BSD ](3rdparty_licenses/LICENSE.BSD-2.libfdt ) and
[GPL-2 ](3rdparty_licenses/LICENSE.GPL-2 ) licensed and copyright:
2021-01-14 18:55:20 +00:00
2021-12-15 11:38:38 +00:00
* Copyright (C) 2014 David Gibson < david @ gibson . dropbear . id . au >
* Copyright (C) 2018 embedded brains GmbH
* Copyright (C) 2006-2012 David Gibson, IBM Corporation.
* Copyright (C) 2012 David Gibson, IBM Corporation.
* Copyright 2012 Kim Phillips, Freescale Semiconductor.
* Copyright (C) 2016 Free Electrons
* Copyright (C) 2016 NextThing Co.
2021-01-14 18:55:20 +00:00
The ADT code in mini is also based on libfdt and subject to the same license.
2021-01-14 19:05:45 +00:00
2021-01-23 13:25:34 +00:00
m1n1 embeds [minlzma ](https://github.com/ionescu007/minlzma ), which is
[MIT ](3rdparty_licenses/LICENSE.minlzma ) licensed and copyright:
* Copyright (c) 2020 Alex Ionescu
m1n1 embeds a slightly modified version of [tinf ](https://github.com/jibsen/tinf ), which is
[ZLIB ](3rdparty_licenses/LICENSE.tinf ) licensed and copyright:
* Copyright (c) 2003-2019 Joergen Ibsen
2021-01-23 19:51:16 +00:00
m1n1 embeds portions taken from
2021-07-15 01:36:17 +00:00
[arm-trusted-firmware ](https://github.com/ARM-software/arm-trusted-firmware ), which is
2021-01-23 19:51:16 +00:00
[BSD ](3rdparty_licenses/LICENSE.BSD-3.arm ) licensed and copyright:
* Copyright (c) 2013-2020, ARM Limited and Contributors. All rights reserved.
2021-01-29 06:19:34 +00:00
m1n1 embeds [Doug Lea's malloc ](ftp://gee.cs.oswego.edu/pub/misc/malloc.c ) (dlmalloc), which is in
the public domain ([CC0](3rdparty_licenses/LICENSE.CC0)).
m1n1 embeds portions of [PDCLib ](https://github.com/DevSolar/pdclib ), which is in the public
2021-02-05 22:34:14 +00:00
domain ([CC0](3rdparty_licenses/LICENSE.CC0)).
2021-01-29 06:19:34 +00:00
2021-02-12 21:27:39 +00:00
m1n1 embeds the [Source Code Pro ](https://github.com/adobe-fonts/source-code-pro ) font, which is
licensed under the [OFL-1.1 ](3rdparty_licenses/LICENSE.OFL-1.1 ) license and copyright:
2021-12-15 11:38:38 +00:00
* Copyright 2010-2019 Adobe (http://www.adobe.com/), with Reserved Font Name 'Source'. All Rights Reserved. Source is a trademark of Adobe in the United States and/or other countries.
2021-02-12 21:27:39 +00:00
* This Font Software is licensed under the SIL Open Font License, Version 1.1.
2021-03-02 18:11:21 +00:00
m1n1 embeds portions of the [dwc3 usb linux driver ](https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/tree/drivers/usb/dwc3/core.h?id=7bc5a6ba369217e0137833f5955cf0b0f08b0712 ), which was [BSD-or-GPLv2 dual-licensed ](3rdparty_licenses/LICENSE.BSD-3.dwc3 ) and copyright
2021-12-15 11:38:38 +00:00
* Copyright (C) 2010-2011 Texas Instruments Incorporated - http://www.ti.com
2022-03-09 11:47:42 +00:00
m1n1 embeds some rust crates. Licenses can be found in the vendor directory for every crate.