Skip to content

Latest commit

 

History

History
57 lines (42 loc) · 1.84 KB

README.md

File metadata and controls

57 lines (42 loc) · 1.84 KB

Fossbeamer

WIP

This provides an application, as well as the tooling around a single full-screen application running on displays at wip.bar.

Development setup

[Nix] is used to pin dependencies, and [Direnv] to enter a development environment automatically, from which you can use cargo to build the project, taking care of all necessary system dependencies.

Install Nix and [hook direnv into your shell][hook-direnv] to get started.

Nix+Rust

For "release builds" we use crate2nix to build Rust crates incrementally and in isolation.

You can build fossbeamer for your current system using nix-build nix -A fossbeamer, and then invoke it via result/bin/fossbeamer.

Whenever there's a change in the crate dependencies, run crate2nix generate --all-features to re-generate Cargo.nix.

Machine configuration

A NixOS machine config is provided in nix/configuration.nix. It describes running fossbeamer in a wayland compositor, cage.

We have two flavours, machine-generic and machine-cm3, as the CM3 variant needs to have its own bootloader.

The system closure can be built with: nix-build nix -A machine-generic.toplevel

An SD-card image can be built with: nix-build nix -A machine-generic.sdImage

If you invoke the build from x86_64-linux, it'll cross-compile the sdcard image. If you build on an aarch64-linux box, it'll natively compile. Both works.

VM Test

For a smaller feedback loop, it's possible to build a script running the software stack in a local qemu (KVM). It might have another virtual screen resolution, and obviously doesn't test the hardware bits.

To run it, invoke:

$(nix-build nix -A vm)/bin/run-fossbeamer-vm

-- [wip.bar]: https://wip.bar [Nix]: https://nixos.org [Direnv]: https://direnv.net/docs/hook.html [hook-direnv]: https://direnv.net/docs/hook.html