Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/rgl/tinkerbell-debian-osie
Debian based Tinkerbell Operating System Installation Environment (OSIE)
https://github.com/rgl/tinkerbell-debian-osie
debian osie tinkerbell
Last synced: about 1 month ago
JSON representation
Debian based Tinkerbell Operating System Installation Environment (OSIE)
- Host: GitHub
- URL: https://github.com/rgl/tinkerbell-debian-osie
- Owner: rgl
- Created: 2021-10-08T18:36:50.000Z (over 3 years ago)
- Default Branch: main
- Last Pushed: 2021-11-03T08:33:35.000Z (about 3 years ago)
- Last Synced: 2024-10-26T13:06:51.267Z (3 months ago)
- Topics: debian, osie, tinkerbell
- Language: Shell
- Homepage:
- Size: 12.7 KB
- Stars: 1
- Watchers: 3
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# About
[![build](https://github.com/rgl/tinkerbell-debian-osie/actions/workflows/build.yml/badge.svg)](https://github.com/rgl/tinkerbell-debian-osie/actions/workflows/build.yml)
This creates a Debian based [Tinkerbell](https://tinkerbell.org/) Operating System Installation Environment (OSIE).
**this is a WIP and this repository will be rebased**
# Usage
Install the [Base Debian Vagrant Box](https://github.com/rgl/debian-vagrant).
Run `vagrant up builder --no-destroy-on-error` to build the `tinkerbell-debian-osie-amd64.iso` file.
Run `vagrant up bios` to boot the generated ISO in [BIOS](https://en.wikipedia.org/wiki/BIOS) mode.
Run `vagrant up uefi` to boot the generated ISO in [UEFI](https://en.wikipedia.org/wiki/Unified_Extensible_Firmware_Interface) mode.
The default user and password are `osie`.
To build the arm64 architecture image, set the `LB_BUILD_ARCH` environment variable to `arm64` before launching vagrant, e.g. `LB_BUILD_ARCH=arm64 vagrant up builder`. To execute this image in an emulated virtual machine see the [qemu arm64 emulation](#qemu-arm64-emulation) section.
**NB** Building the arm64 image takes longer than the native amd64. In my machine it takes about 40m (vs 10m for amd64).
# qemu arm64 emulation
The arm64 architecture image can be executed in an emulated virtual machine as:
```bash
# NB in my humble machine (i3-3245) emulating arm64 is very slow and it takes
# several minutes until you can login.
# NB in the qemu window use the "View" menu to switch between the
# virtio-gpu-pci and serial0 console.
mkdir tmp
cd tmp
sudo apt-get install -y qemu-efi-aarch64
cp /usr/share/AAVMF/AAVMF_CODE.fd firmware-code-arm64.fd
cp /usr/share/AAVMF/AAVMF_VARS.fd firmware-vars-arm64.fd
qemu-img create -f qcow2 hd0.img 20G
qemu-img info hd0.img
qemu-system-aarch64 \
-name arm64 \
-machine virt \
--accel tcg,thread=multi \
-cpu cortex-a57 \
-smp cores=4 \
-m 2g \
-k pt \
-device virtio-gpu-pci \
-device nec-usb-xhci,id=usb0 \
-device usb-kbd,bus=usb0.0 \
-device usb-tablet,bus=usb0.0 \
-device virtio-scsi-pci,id=scsi0 \
-drive if=pflash,file=firmware-code-arm64.fd,format=raw,readonly \
-drive if=pflash,file=firmware-vars-arm64.fd,format=raw \
-drive if=none,file=hd0.img,discard=unmap,cache=unsafe,id=hd0 \
-drive if=none,file=$PWD/../tinkerbell-debian-osie-arm64.iso,media=cdrom,cache=unsafe,readonly,id=cd0 \
-device scsi-hd,drive=hd0,bus=scsi0.0,bootindex=1 \
-device scsi-cd,drive=cd0,bus=scsi0.0,bootindex=2 \
-netdev user,id=net0,hostfwd=tcp::2222-:22 \
-device virtio-net-pci,netdev=net0 \
-device virtio-rng-pci,rng=rng0 \
-object rng-random,filename=/dev/urandom,id=rng0 \
-qmp unix:arm64.socket,server,nowait
echo info qtree | qmp-shell -H arm64.socket
ssh vagrant@localhost -p 2222
```# Reference
* [rgl/debian-live-builder-vagrant](https://github.com/rgl/debian-live-builder-vagrant)
* [Live Systems Manual](https://live-team.pages.debian.net/live-manual/html/live-manual/index.en.html)
* [lb(1)](https://manpages.debian.org/bullseye/live-build/lb.1.en.html)
* [live-build(7)](https://manpages.debian.org/bullseye/live-build/live-build.7.en.html)
* [lb_config(1)](https://manpages.debian.org/bullseye/live-build/lb_config.1.en.html)
* [Debian Live Team Repositories](https://salsa.debian.org/live-team)
* [Debian Live Wiki](http://wiki.debian.org/DebianLive): Information about the Debian Live team and its contacts.
* [run emulated arm under qemu](https://gist.github.com/rgl/b02c24f9eb1b4bdb4ac6f970d4bfc885)