Compare commits
128 commits
yunohost-b
...
yunohost-b
Author | SHA1 | Date | |
---|---|---|---|
|
3160118e71 | ||
|
6ef21accb8 | ||
|
5d19d7a550 | ||
|
457bf5b273 | ||
|
61fb4124dd | ||
|
c26cb0c3c7 | ||
|
73ca540dc7 | ||
|
17edfe2dc3 | ||
|
c1fb6dd148 | ||
|
b0c0fd7e82 | ||
|
41140df950 | ||
|
5304de9929 | ||
|
0d70397754 | ||
|
5e1b2dd071 | ||
|
33a07557dc | ||
|
04250ea50d | ||
|
2b9b537243 | ||
|
62a032601d | ||
|
5e4a5f38c7 | ||
|
5df037c936 | ||
|
ca06d62f2e | ||
|
18aee5cfb8 | ||
|
3385618efb | ||
|
27a8050c3c | ||
|
226b479f8d | ||
|
151f3ff80f | ||
|
f651a43337 | ||
|
e5bd8d5433 | ||
|
f1f6722ba4 | ||
|
10a538ff92 | ||
|
1b635daf30 | ||
|
09ebc77e6b | ||
|
b0316ae870 | ||
|
95ac3cfb3b | ||
|
7073d28f22 | ||
|
5d044ba71b | ||
|
d1b8a2005b | ||
|
a120c4128e | ||
|
a0ba64e5c8 | ||
|
c5a906b676 | ||
|
1ad53be314 | ||
|
b2bd87c512 | ||
|
733513aa25 | ||
|
b1d54c82fe | ||
|
c63a3aedf9 | ||
|
255288909b | ||
|
b3f6852c3e | ||
|
4721bfe590 | ||
|
2b3ba5b2a6 | ||
|
724820051c | ||
|
8862e4d9ff | ||
|
c393ef105e | ||
|
0b4874f75a | ||
|
fbe448ccdc | ||
|
f01430c9d8 | ||
|
61c6294e23 | ||
|
40f67ce4ba | ||
|
6d2d36e7f2 | ||
|
dec2743355 | ||
|
231487d9d6 | ||
|
43c42bf9e4 | ||
|
cc8f695b9a | ||
|
69cc4146c8 | ||
|
ef933ae156 | ||
|
23f75d6655 | ||
|
0f7ab62ac9 | ||
|
f81afa8282 | ||
|
786af7c5a4 | ||
|
f04a4143e9 | ||
|
45b4cc19d0 | ||
|
351024d3c3 | ||
|
3fb5442494 | ||
|
69cd27944c | ||
|
14a28a729e | ||
|
6117b9bb61 | ||
|
9e5228553f | ||
|
27983073c9 | ||
|
1e0c20690c | ||
|
720f4aea86 | ||
|
68fee340f9 | ||
|
c12b1df4ed | ||
|
288b21fc27 | ||
|
c61f8b72fa | ||
|
85bc296d16 | ||
|
edbc8b604d | ||
|
6d363779ba | ||
|
5ea223355a | ||
|
cd8a82d4fd | ||
|
93beb9fb74 | ||
|
cf938b0549 | ||
|
b542f68d68 | ||
|
268d4c4f44 | ||
|
2e3603d228 | ||
|
5a4b7ec067 | ||
|
ac246e300b | ||
|
d0eed3b76f | ||
|
456aa2e50b | ||
|
7c45f4e11f | ||
|
b23d0b144d | ||
|
d9b4a4a985 | ||
|
5971767590 | ||
|
535ea6c7f0 | ||
|
600f7c1fa4 | ||
|
4b59b5a70d | ||
|
95ea0ba696 | ||
|
071d395635 | ||
|
7cfcace573 | ||
|
04f9b9bb5f | ||
|
2b9e8e9b22 | ||
|
4929d829f2 | ||
|
cfe65b2e64 | ||
|
88e48a8aca | ||
|
31aa04e99c | ||
|
571fe1e26b | ||
|
041b97464c | ||
|
fbdcaaf4f8 | ||
|
ec4562c7f2 | ||
|
8808124cc3 | ||
|
bc3970f9e3 | ||
|
d3553f5ec4 | ||
|
0cab554f7d | ||
|
75123fd64e | ||
|
0f41e41c8c | ||
|
a58e722bee | ||
|
c640efa6e1 | ||
|
d4049eeffb | ||
|
906c587fcd | ||
|
99399d30fc |
35 changed files with 366 additions and 102 deletions
39
.github/workflows/main.yml
vendored
Normal file
39
.github/workflows/main.yml
vendored
Normal file
|
@ -0,0 +1,39 @@
|
||||||
|
# This is a basic workflow to help you get started with Actions
|
||||||
|
|
||||||
|
name: Build yunohost rpi image
|
||||||
|
|
||||||
|
# Controls when the workflow will run
|
||||||
|
on:
|
||||||
|
# Triggers the workflow on push or pull request events but only for the "yunohost-buster" branch
|
||||||
|
push:
|
||||||
|
branches: [ "yunohost-bullseye" ]
|
||||||
|
pull_request:
|
||||||
|
branches: [ "yunohost-bullseye" ]
|
||||||
|
|
||||||
|
# Allows you to run this workflow manually from the Actions tab
|
||||||
|
workflow_dispatch:
|
||||||
|
|
||||||
|
# A workflow run is made up of one or more jobs that can run sequentially or in parallel
|
||||||
|
jobs:
|
||||||
|
# This workflow contains a single job called "build"
|
||||||
|
build:
|
||||||
|
# The type of runner that the job will run on
|
||||||
|
runs-on: ubuntu-22.04
|
||||||
|
|
||||||
|
# Steps represent a sequence of tasks that will be executed as part of the job
|
||||||
|
steps:
|
||||||
|
# Checks-out your repository under $GITHUB_WORKSPACE, so your job can access it
|
||||||
|
- uses: actions/checkout@v3
|
||||||
|
|
||||||
|
# Runs a set of commands using the runners shell
|
||||||
|
- name: Run a multi-line script
|
||||||
|
run: |
|
||||||
|
sudo apt update
|
||||||
|
sudo apt-get -y install coreutils quilt parted qemu-user-static debootstrap zerofree zip dosfstools libarchive-tools libcap2-bin grep rsync xz-utils file git curl bc qemu-utils kpartx gpg pigz
|
||||||
|
sudo curl -fsSL https://get.docker.com -o get-docker.sh
|
||||||
|
sudo sh ./get-docker.sh
|
||||||
|
sudo ./build-docker.sh
|
||||||
|
- uses: actions/upload-artifact@v3
|
||||||
|
with:
|
||||||
|
name: Upload deploy directory as artifact
|
||||||
|
path: deploy/
|
|
@ -1,4 +1,4 @@
|
||||||
ARG BASE_IMAGE=debian:buster
|
ARG BASE_IMAGE=debian:bullseye
|
||||||
FROM ${BASE_IMAGE}
|
FROM ${BASE_IMAGE}
|
||||||
|
|
||||||
ENV DEBIAN_FRONTEND noninteractive
|
ENV DEBIAN_FRONTEND noninteractive
|
||||||
|
@ -8,7 +8,8 @@ RUN apt-get -y update && \
|
||||||
git vim parted \
|
git vim parted \
|
||||||
quilt coreutils qemu-user-static debootstrap zerofree zip dosfstools \
|
quilt coreutils qemu-user-static debootstrap zerofree zip dosfstools \
|
||||||
libarchive-tools libcap2-bin rsync grep udev xz-utils curl xxd file kmod bc\
|
libarchive-tools libcap2-bin rsync grep udev xz-utils curl xxd file kmod bc\
|
||||||
binfmt-support ca-certificates qemu-utils kpartx \
|
binfmt-support ca-certificates qemu-utils kpartx fdisk gpg pigz\
|
||||||
|
procps lsof\
|
||||||
&& rm -rf /var/lib/apt/lists/*
|
&& rm -rf /var/lib/apt/lists/*
|
||||||
|
|
||||||
COPY . /pi-gen/
|
COPY . /pi-gen/
|
||||||
|
|
75
README.md
75
README.md
|
@ -15,12 +15,30 @@ To install the required dependencies for `pi-gen` you should run:
|
||||||
```bash
|
```bash
|
||||||
apt-get install coreutils quilt parted qemu-user-static debootstrap zerofree zip \
|
apt-get install coreutils quilt parted qemu-user-static debootstrap zerofree zip \
|
||||||
dosfstools libarchive-tools libcap2-bin grep rsync xz-utils file git curl bc \
|
dosfstools libarchive-tools libcap2-bin grep rsync xz-utils file git curl bc \
|
||||||
qemu-utils kpartx
|
qemu-utils kpartx gpg pigz
|
||||||
```
|
```
|
||||||
|
|
||||||
The file `depends` contains a list of tools needed. The format of this
|
The file `depends` contains a list of tools needed. The format of this
|
||||||
package is `<tool>[:<debian-package>]`.
|
package is `<tool>[:<debian-package>]`.
|
||||||
|
|
||||||
|
## Getting started with building your images
|
||||||
|
|
||||||
|
Getting started is as simple as cloning this repository on your build machine. You
|
||||||
|
can do so with:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
git clone --depth 1 https://github.com/RPI-Distro/pi-gen.git
|
||||||
|
```
|
||||||
|
|
||||||
|
Using `--depth 1` with `git clone` will create a shallow clone, only containing
|
||||||
|
the latest revision of the repository. Do not do this on your development machine.
|
||||||
|
|
||||||
|
Also, be careful to clone the repository to a base path **NOT** containing spaces.
|
||||||
|
This configuration is not supported by debootstrap and will lead to `pi-gen` not
|
||||||
|
running.
|
||||||
|
|
||||||
|
After cloning the repository, you can move to the next step and start configuring
|
||||||
|
your build.
|
||||||
|
|
||||||
## Config
|
## Config
|
||||||
|
|
||||||
|
@ -37,7 +55,7 @@ The following environment variables are supported:
|
||||||
but you should use something else for a customized version. Export files
|
but you should use something else for a customized version. Export files
|
||||||
in stages may add suffixes to `IMG_NAME`.
|
in stages may add suffixes to `IMG_NAME`.
|
||||||
|
|
||||||
* `USE_QCOW2`(Default: `1` )
|
* `USE_QCOW2` **EXPERIMENTAL** (Default: `0` )
|
||||||
|
|
||||||
Instead of using traditional way of building the rootfs of every stage in
|
Instead of using traditional way of building the rootfs of every stage in
|
||||||
single subdirectories and copying over the previous one to the next one,
|
single subdirectories and copying over the previous one to the next one,
|
||||||
|
@ -60,9 +78,9 @@ The following environment variables are supported:
|
||||||
that the network block device is not disconnected correctly after the Docker process has
|
that the network block device is not disconnected correctly after the Docker process has
|
||||||
ended abnormally. In that case see [Disconnect an image if something went wrong](#Disconnect-an-image-if-something-went-wrong)
|
ended abnormally. In that case see [Disconnect an image if something went wrong](#Disconnect-an-image-if-something-went-wrong)
|
||||||
|
|
||||||
* `RELEASE` (Default: buster)
|
* `RELEASE` (Default: bullseye)
|
||||||
|
|
||||||
The release version to build images against. Valid values are jessie, stretch
|
The release version to build images against. Valid values are jessie, stretch,
|
||||||
buster, bullseye, and testing.
|
buster, bullseye, and testing.
|
||||||
|
|
||||||
* `APT_PROXY` (Default: unset)
|
* `APT_PROXY` (Default: unset)
|
||||||
|
@ -98,9 +116,28 @@ The following environment variables are supported:
|
||||||
|
|
||||||
Output directory for target system images and NOOBS bundles.
|
Output directory for target system images and NOOBS bundles.
|
||||||
|
|
||||||
* `DEPLOY_ZIP` (Default: `1`)
|
* `DEPLOY_COMPRESSION` (Default: `zip`)
|
||||||
|
|
||||||
Setting to `0` will deploy the actual image (`.img`) instead of a zipped image (`.zip`).
|
Set to:
|
||||||
|
* `none` to deploy the actual image (`.img`).
|
||||||
|
* `zip` to deploy a zipped image (`.zip`).
|
||||||
|
* `gz` to deploy a gzipped image (`.img.gz`).
|
||||||
|
* `xz` to deploy a xzipped image (`.img.xz`).
|
||||||
|
|
||||||
|
|
||||||
|
* `DEPLOY_ZIP` (Deprecated)
|
||||||
|
|
||||||
|
This option has been deprecated in favor of `DEPLOY_COMPRESSION`.
|
||||||
|
|
||||||
|
If `DEPLOY_ZIP=0` is still present in your config file, the behavior is the
|
||||||
|
same as with `DEPLOY_COMPRESSION=none`.
|
||||||
|
|
||||||
|
* `COMPRESSION_LEVEL` (Default: `6`)
|
||||||
|
|
||||||
|
Compression level to be used when using `zip`, `gz` or `xz` for
|
||||||
|
`DEPLOY_COMPRESSION`. From 0 to 9 (refer to the tool man page for more
|
||||||
|
information on this. Usually 0 is no compression but very fast, up to 9 with
|
||||||
|
the best compression but very slow ).
|
||||||
|
|
||||||
* `USE_QEMU` (Default: `"0"`)
|
* `USE_QEMU` (Default: `"0"`)
|
||||||
|
|
||||||
|
@ -428,7 +465,22 @@ Now you should be able to start a new build without running into troubles again.
|
||||||
# Troubleshooting
|
# Troubleshooting
|
||||||
|
|
||||||
## `64 Bit Systems`
|
## `64 Bit Systems`
|
||||||
Please note there is currently an issue when compiling with a 64 Bit OS. See https://github.com/RPi-Distro/pi-gen/issues/271
|
Please note there is currently an issue when compiling with a 64 Bit OS. See
|
||||||
|
https://github.com/RPi-Distro/pi-gen/issues/271
|
||||||
|
|
||||||
|
A 64 bit image can be generated from the `arm64` branch in this repository. Just
|
||||||
|
replace the command from [this section](#getting-started-with-building-your-images)
|
||||||
|
by the one below, and follow the rest of the documentation:
|
||||||
|
```bash
|
||||||
|
git clone --depth 1 --branch arm64 https://github.com/RPI-Distro/pi-gen.git
|
||||||
|
```
|
||||||
|
|
||||||
|
If you want to generate a 64 bits image from a Raspberry Pi running a 32 bits
|
||||||
|
version, you need to add `arm_64bit=1` to your `config.txt` file and reboot your
|
||||||
|
machine. This will restart your machine with a 64 bits kernel. This will only
|
||||||
|
work from a Raspberry Pi with a 64-bit capable processor (i.e. Raspberry Pi Zero
|
||||||
|
2, Raspberry Pi 3 or Raspberry Pi 4).
|
||||||
|
|
||||||
|
|
||||||
## `binfmt_misc`
|
## `binfmt_misc`
|
||||||
|
|
||||||
|
@ -437,11 +489,16 @@ possible to make use of `pi-gen` on an x86_64 system, even though it will be run
|
||||||
ARM binaries. This requires support from the [`binfmt_misc`](https://en.wikipedia.org/wiki/Binfmt_misc)
|
ARM binaries. This requires support from the [`binfmt_misc`](https://en.wikipedia.org/wiki/Binfmt_misc)
|
||||||
kernel module.
|
kernel module.
|
||||||
|
|
||||||
You may see the following error:
|
You may see one of the following errors:
|
||||||
|
|
||||||
```
|
```
|
||||||
update-binfmts: warning: Couldn't load the binfmt_misc module.
|
update-binfmts: warning: Couldn't load the binfmt_misc module.
|
||||||
```
|
```
|
||||||
|
```
|
||||||
|
W: Failure trying to run: chroot "/pi-gen/work/test/stage0/rootfs" /bin/true
|
||||||
|
and/or
|
||||||
|
chroot: failed to run command '/bin/true': Exec format error
|
||||||
|
```
|
||||||
|
|
||||||
To resolve this, ensure that the following files are available (install them if necessary):
|
To resolve this, ensure that the following files are available (install them if necessary):
|
||||||
|
|
||||||
|
@ -451,3 +508,5 @@ To resolve this, ensure that the following files are available (install them if
|
||||||
```
|
```
|
||||||
|
|
||||||
You may also need to load the module by hand - run `modprobe binfmt_misc`.
|
You may also need to load the module by hand - run `modprobe binfmt_misc`.
|
||||||
|
|
||||||
|
If you are using WSL to build you may have to enable the service `sudo update-binfmts --enable`
|
||||||
|
|
|
@ -75,16 +75,7 @@ fi
|
||||||
# Modify original build-options to allow config file to be mounted in the docker container
|
# Modify original build-options to allow config file to be mounted in the docker container
|
||||||
BUILD_OPTS="$(echo "${BUILD_OPTS:-}" | sed -E 's@\-c\s?([^ ]+)@-c /config@')"
|
BUILD_OPTS="$(echo "${BUILD_OPTS:-}" | sed -E 's@\-c\s?([^ ]+)@-c /config@')"
|
||||||
|
|
||||||
# Check the arch of the machine we're running on. If it's 64-bit, use a 32-bit base image instead
|
${DOCKER} build --build-arg BASE_IMAGE=debian:bullseye -t pi-gen "${DIR}"
|
||||||
case "$(uname -m)" in
|
|
||||||
x86_64|aarch64)
|
|
||||||
BASE_IMAGE=i386/debian:buster
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
BASE_IMAGE=debian:buster
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
${DOCKER} build --build-arg BASE_IMAGE=${BASE_IMAGE} -t pi-gen "${DIR}"
|
|
||||||
|
|
||||||
if [ "${CONTAINER_EXISTS}" != "" ]; then
|
if [ "${CONTAINER_EXISTS}" != "" ]; then
|
||||||
trap 'echo "got CTRL+C... please wait 5s" && ${DOCKER} stop -t 5 ${CONTAINER_NAME}_cont' SIGINT SIGTERM
|
trap 'echo "got CTRL+C... please wait 5s" && ${DOCKER} stop -t 5 ${CONTAINER_NAME}_cont' SIGINT SIGTERM
|
||||||
|
@ -98,6 +89,8 @@ if [ "${CONTAINER_EXISTS}" != "" ]; then
|
||||||
--volumes-from="${CONTAINER_NAME}" --name "${CONTAINER_NAME}_cont" \
|
--volumes-from="${CONTAINER_NAME}" --name "${CONTAINER_NAME}_cont" \
|
||||||
pi-gen \
|
pi-gen \
|
||||||
bash -e -o pipefail -c "dpkg-reconfigure qemu-user-static &&
|
bash -e -o pipefail -c "dpkg-reconfigure qemu-user-static &&
|
||||||
|
# binfmt_misc is sometimes not mounted with debian bullseye image
|
||||||
|
(mount binfmt_misc -t binfmt_misc /proc/sys/fs/binfmt_misc || true) &&
|
||||||
cd /pi-gen; ./build.sh ${BUILD_OPTS} &&
|
cd /pi-gen; ./build.sh ${BUILD_OPTS} &&
|
||||||
rsync -av work/*/build.log deploy/" &
|
rsync -av work/*/build.log deploy/" &
|
||||||
wait "$!"
|
wait "$!"
|
||||||
|
@ -112,6 +105,8 @@ else
|
||||||
-e "GIT_HASH=${GIT_HASH}" \
|
-e "GIT_HASH=${GIT_HASH}" \
|
||||||
pi-gen \
|
pi-gen \
|
||||||
bash -e -o pipefail -c "dpkg-reconfigure qemu-user-static &&
|
bash -e -o pipefail -c "dpkg-reconfigure qemu-user-static &&
|
||||||
|
# binfmt_misc is sometimes not mounted with debian bullseye image
|
||||||
|
(mount binfmt_misc -t binfmt_misc /proc/sys/fs/binfmt_misc || true) &&
|
||||||
cd /pi-gen; ./build.sh ${BUILD_OPTS} &&
|
cd /pi-gen; ./build.sh ${BUILD_OPTS} &&
|
||||||
rsync -av work/*/build.log deploy/" &
|
rsync -av work/*/build.log deploy/" &
|
||||||
wait "$!"
|
wait "$!"
|
||||||
|
|
26
build.sh
26
build.sh
|
@ -155,6 +155,14 @@ if [ "$(id -u)" != "0" ]; then
|
||||||
fi
|
fi
|
||||||
|
|
||||||
BASE_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
|
BASE_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
|
||||||
|
|
||||||
|
if [[ $BASE_DIR = *" "* ]]; then
|
||||||
|
echo "There is a space in the base path of pi-gen"
|
||||||
|
echo "This is not a valid setup supported by debootstrap."
|
||||||
|
echo "Please remove the spaces, or move pi-gen directory to a base path without spaces" 1>&2
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
export BASE_DIR
|
export BASE_DIR
|
||||||
|
|
||||||
if [ -f config ]; then
|
if [ -f config ]; then
|
||||||
|
@ -195,17 +203,27 @@ fi
|
||||||
export USE_QEMU="${USE_QEMU:-0}"
|
export USE_QEMU="${USE_QEMU:-0}"
|
||||||
export IMG_DATE="${IMG_DATE:-"$(date +%Y-%m-%d)"}"
|
export IMG_DATE="${IMG_DATE:-"$(date +%Y-%m-%d)"}"
|
||||||
export IMG_FILENAME="${IMG_FILENAME:-"${IMG_DATE}-${IMG_NAME}"}"
|
export IMG_FILENAME="${IMG_FILENAME:-"${IMG_DATE}-${IMG_NAME}"}"
|
||||||
export ZIP_FILENAME="${ZIP_FILENAME:-"image_${IMG_DATE}-${IMG_NAME}"}"
|
export ARCHIVE_FILENAME="${ARCHIVE_FILENAME:-"image_${IMG_DATE}-${IMG_NAME}"}"
|
||||||
|
|
||||||
export SCRIPT_DIR="${BASE_DIR}/scripts"
|
export SCRIPT_DIR="${BASE_DIR}/scripts"
|
||||||
export WORK_DIR="${WORK_DIR:-"${BASE_DIR}/work/${IMG_NAME}"}"
|
export WORK_DIR="${WORK_DIR:-"${BASE_DIR}/work/${IMG_NAME}"}"
|
||||||
export DEPLOY_DIR=${DEPLOY_DIR:-"${BASE_DIR}/deploy"}
|
export DEPLOY_DIR=${DEPLOY_DIR:-"${BASE_DIR}/deploy"}
|
||||||
export DEPLOY_ZIP="${DEPLOY_ZIP:-1}"
|
|
||||||
|
# DEPLOY_ZIP was deprecated in favor of DEPLOY_COMPRESSION
|
||||||
|
# This preserve the old behavior with DEPLOY_ZIP=0 where no archive was created
|
||||||
|
if [ -z "${DEPLOY_COMPRESSION}" ] && [ "${DEPLOY_ZIP:-1}" = "0" ]; then
|
||||||
|
echo "DEPLOY_ZIP has been deprecated in favor of DEPLOY_COMPRESSION"
|
||||||
|
echo "Similar behavior to DEPLOY_ZIP=0 can be obtained with DEPLOY_COMPRESSION=none"
|
||||||
|
echo "Please update your config file"
|
||||||
|
DEPLOY_COMPRESSION=none
|
||||||
|
fi
|
||||||
|
export DEPLOY_COMPRESSION=${DEPLOY_COMPRESSION:-zip}
|
||||||
|
export COMPRESSION_LEVEL=${COMPRESSION_LEVEL:-6}
|
||||||
export LOG_FILE="${WORK_DIR}/build.log"
|
export LOG_FILE="${WORK_DIR}/build.log"
|
||||||
|
|
||||||
export TARGET_HOSTNAME=${TARGET_HOSTNAME:-raspberrypi}
|
export TARGET_HOSTNAME=${TARGET_HOSTNAME:-raspberrypi}
|
||||||
|
|
||||||
export RELEASE=${RELEASE:-buster}
|
export RELEASE=${RELEASE:-bullseye}
|
||||||
export WPA_ESSID
|
export WPA_ESSID
|
||||||
export WPA_PASSWORD
|
export WPA_PASSWORD
|
||||||
export WPA_COUNTRY
|
export WPA_COUNTRY
|
||||||
|
@ -251,7 +269,7 @@ source "${SCRIPT_DIR}/common"
|
||||||
source "${SCRIPT_DIR}/dependencies_check"
|
source "${SCRIPT_DIR}/dependencies_check"
|
||||||
|
|
||||||
export NO_PRERUN_QCOW2="${NO_PRERUN_QCOW2:-1}"
|
export NO_PRERUN_QCOW2="${NO_PRERUN_QCOW2:-1}"
|
||||||
export USE_QCOW2="${USE_QCOW2:-1}"
|
export USE_QCOW2="${USE_QCOW2:-0}"
|
||||||
export BASE_QCOW2_SIZE=${BASE_QCOW2_SIZE:-12G}
|
export BASE_QCOW2_SIZE=${BASE_QCOW2_SIZE:-12G}
|
||||||
source "${SCRIPT_DIR}/qcow2_handling"
|
source "${SCRIPT_DIR}/qcow2_handling"
|
||||||
if [ "${USE_QCOW2}" = "1" ]; then
|
if [ "${USE_QCOW2}" = "1" ]; then
|
||||||
|
|
4
config
4
config
|
@ -1,6 +1,6 @@
|
||||||
IMG_NAME="yunohost"
|
IMG_NAME="yunohost"
|
||||||
RELEASE="buster"
|
RELEASE="bullseye"
|
||||||
USE_QEMU="1"
|
USE_QEMU="0"
|
||||||
LOCALE_DEFAULT="en_US.UTF-8"
|
LOCALE_DEFAULT="en_US.UTF-8"
|
||||||
TARGET_HOSTNAME="yunohost"
|
TARGET_HOSTNAME="yunohost"
|
||||||
KEYBOARD_KEYMAP="us"
|
KEYBOARD_KEYMAP="us"
|
||||||
|
|
2
depends
2
depends
|
@ -19,3 +19,5 @@ lsmod:kmod
|
||||||
bc
|
bc
|
||||||
qemu-nbd:qemu-utils
|
qemu-nbd:qemu-utils
|
||||||
kpartx
|
kpartx
|
||||||
|
gpg
|
||||||
|
pigz
|
||||||
|
|
1
export-image/01-user-rename/00-packages
Normal file
1
export-image/01-user-rename/00-packages
Normal file
|
@ -0,0 +1 @@
|
||||||
|
userconf-pi
|
5
export-image/01-user-rename/01-run.sh
Executable file
5
export-image/01-user-rename/01-run.sh
Executable file
|
@ -0,0 +1,5 @@
|
||||||
|
#!/bin/bash -e
|
||||||
|
|
||||||
|
on_chroot << EOF
|
||||||
|
SUDO_USER="${FIRST_USER_NAME}" rename-user -f -s
|
||||||
|
EOF
|
|
@ -78,7 +78,7 @@ cp "$ROOTFS_DIR/etc/rpi-issue" "$INFO_FILE"
|
||||||
|
|
||||||
mkdir -p "${DEPLOY_DIR}"
|
mkdir -p "${DEPLOY_DIR}"
|
||||||
|
|
||||||
rm -f "${DEPLOY_DIR}/${ZIP_FILENAME}${IMG_SUFFIX}.zip"
|
rm -f "${DEPLOY_DIR}/${ARCHIVE_FILENAME}${IMG_SUFFIX}.*"
|
||||||
rm -f "${DEPLOY_DIR}/${IMG_FILENAME}${IMG_SUFFIX}.img"
|
rm -f "${DEPLOY_DIR}/${IMG_FILENAME}${IMG_SUFFIX}.img"
|
||||||
|
|
||||||
mv "$INFO_FILE" "$DEPLOY_DIR/"
|
mv "$INFO_FILE" "$DEPLOY_DIR/"
|
||||||
|
@ -95,11 +95,22 @@ else
|
||||||
make_bootable_image "${STAGE_WORK_DIR}/${IMG_FILENAME}${IMG_SUFFIX}.qcow2" "$IMG_FILE"
|
make_bootable_image "${STAGE_WORK_DIR}/${IMG_FILENAME}${IMG_SUFFIX}.qcow2" "$IMG_FILE"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ "${DEPLOY_ZIP}" == "1" ]; then
|
case "${DEPLOY_COMPRESSION}" in
|
||||||
|
zip)
|
||||||
pushd "${STAGE_WORK_DIR}" > /dev/null
|
pushd "${STAGE_WORK_DIR}" > /dev/null
|
||||||
zip "${DEPLOY_DIR}/${ZIP_FILENAME}${IMG_SUFFIX}.zip" \
|
zip -"${COMPRESSION_LEVEL}" \
|
||||||
"$(basename "${IMG_FILE}")"
|
"${DEPLOY_DIR}/${ARCHIVE_FILENAME}${IMG_SUFFIX}.zip" "$(basename "${IMG_FILE}")"
|
||||||
popd > /dev/null
|
popd > /dev/null
|
||||||
else
|
;;
|
||||||
mv "$IMG_FILE" "$DEPLOY_DIR/"
|
gz)
|
||||||
fi
|
pigz --force -"${COMPRESSION_LEVEL}" "$IMG_FILE" --stdout > \
|
||||||
|
"${DEPLOY_DIR}/${ARCHIVE_FILENAME}${IMG_SUFFIX}.img.gz"
|
||||||
|
;;
|
||||||
|
xz)
|
||||||
|
xz --compress --force --threads 0 --memlimit-compress=50% -"${COMPRESSION_LEVEL}" \
|
||||||
|
--stdout "$IMG_FILE" > "${DEPLOY_DIR}/${ARCHIVE_FILENAME}${IMG_SUFFIX}.img.xz"
|
||||||
|
;;
|
||||||
|
none | *)
|
||||||
|
cp "$IMG_FILE" "$DEPLOY_DIR/"
|
||||||
|
;;
|
||||||
|
esac
|
|
@ -1,18 +1,15 @@
|
||||||
{
|
{
|
||||||
"description": "NOOBS_DESCRIPTION",
|
"description": "NOOBS_DESCRIPTION",
|
||||||
"feature_level": 35120124,
|
|
||||||
"kernel": "KERNEL",
|
"kernel": "KERNEL",
|
||||||
"name": "NOOBS_NAME",
|
"name": "NOOBS_NAME",
|
||||||
"password": "raspberry",
|
"password": "raspberry",
|
||||||
"release_date": "UNRELEASED",
|
"release_date": "UNRELEASED",
|
||||||
"supported_hex_revisions": "2,3,4,5,6,7,8,9,d,e,f,10,11,12,14,19,1040,1041,0092,0093,2082",
|
|
||||||
"supported_models": [
|
"supported_models": [
|
||||||
"Pi Model",
|
"Pi Zero 2",
|
||||||
"Pi 2",
|
|
||||||
"Pi Zero",
|
|
||||||
"Pi 3",
|
"Pi 3",
|
||||||
|
"Pi 4",
|
||||||
"Pi Compute Module 3",
|
"Pi Compute Module 3",
|
||||||
"Pi 4"
|
"Pi Compute Module 4"
|
||||||
],
|
],
|
||||||
"url": "http://www.raspbian.org/",
|
"url": "http://www.raspbian.org/",
|
||||||
"username": "pi",
|
"username": "pi",
|
||||||
|
|
|
@ -1,4 +1,119 @@
|
||||||
UNRELEASED:
|
UNRELEASED:
|
||||||
|
*
|
||||||
|
2022-04-04:
|
||||||
|
* Default "pi” user has been removed; the first-boot wizard enforces the creation of a new user account
|
||||||
|
* rename-user script added to allow existing users to be renamed by temporarily rebooting to cut-down first-boot wizard
|
||||||
|
* Overscan now managed by xrandr under KMS, can be set independently for both monitors, and takes effect on the fly rather than requiring reboot
|
||||||
|
* GTK3 switch control now used in place of paired radio buttons throughout
|
||||||
|
* piwiz - first-boot wizard now runs in a separate session as a different user with different graphics
|
||||||
|
* piwiz - first-boot wizard now has automatic pairing for discoverable Bluetooth mice and keyboards
|
||||||
|
* lxinput - keyboard delay and repeat settings now persist across reboots under mutter
|
||||||
|
* raspi-config / rc_gui - removed pixel doubling option when KMS driver in use
|
||||||
|
* raspi-config - removed composition manager option when legacy driver in use
|
||||||
|
* arandr - restored support for interlaced displays
|
||||||
|
* mutter - implemented more intuitive window and application cycling behaviour
|
||||||
|
* pi-greeter - rebuilt for GTK3
|
||||||
|
* Bug fix - graphical corruption in system tray icons
|
||||||
|
* Bug fix - desktop items vanishing when dragged
|
||||||
|
* Bug fix - terminal windows not focussed correctly when launched
|
||||||
|
* Bug fix - crash after multiple update checks in updater plugin
|
||||||
|
* Bug fix - Raspberry Pi keyboard auto-detect by wizard was broken in previous release
|
||||||
|
* Bug fix - spurious "connected” dialog box shown when reconnecting to Bluetooth LE devices on boot
|
||||||
|
* Support for experimental Wayland backend added - can be enabled as an advanced option in raspi-config
|
||||||
|
* Various small bug fixes and graphical tweaks
|
||||||
|
* Chromium upgraded to version 98.0.4758.106
|
||||||
|
* FFmpeg HW acceleration improved
|
||||||
|
* OpenJDK 17 now defaults to 'client' JVM for ARMv6 compatibility
|
||||||
|
* Raspberry Pi firmware 69277bc713133a54a1d20554d79544da1ae2b6ca
|
||||||
|
* Linux kernel 5.15.30
|
||||||
|
2022-01-28:
|
||||||
|
* Policykit CVE-2021-4034 fix
|
||||||
|
* rc_gui - add combo box to allow resolution to be set for VNC connections
|
||||||
|
* rc_gui - camera interface switch removed
|
||||||
|
* lxpanel - remove appearance settings from preferences dialog; instead add menu option to open general Appearance Settings application
|
||||||
|
* lxpanel - add ellipses to menu items which open dialogs
|
||||||
|
* lxinput - read current mouse acceleration directly from xinput
|
||||||
|
* lxinput - use device IDs rather than names to cope with devices changing when powered-down
|
||||||
|
* lxinput - remove redundant changes to openbox config file
|
||||||
|
* plymouth - set KillMode to mixed to suppress warning message
|
||||||
|
* raspi-config - add option to switch composite video
|
||||||
|
* raspi-config - add option to switch to legacy camera mode
|
||||||
|
* raspi-config - add option to set resolution for headless connections
|
||||||
|
* raspberrypi-ui-mods - disable mutter when VNC server is running and fall back to openbox
|
||||||
|
* pipanel - add command-line option to open on arbitrary tab
|
||||||
|
* lxplug-network - suppress ’scan received’ logging message
|
||||||
|
* raspberrypi-ui-mods - set hover colour for taskbar items based on taskbar colour, not system highlight colour
|
||||||
|
* Legacy camera applications and libraries reinstalled (32-bit only)
|
||||||
|
* Bug fix - lxinput - lxsession config file not being written on first attempt
|
||||||
|
* Bug fix - lxinput - set timer for file write to prevent slider slowing down
|
||||||
|
* Bug fix - lxinput - write values to gsettings as well as xinput and xsettings to take effect within mutter
|
||||||
|
* Bug fix - lxinput - fix failure to parse and write non-English numeric formats
|
||||||
|
* Bug fix - arandr - various fixes to parsing of non-standard EDID blocks to enable model and serial to be correctly extracted
|
||||||
|
* Bug fix - arandr - refresh rate calculated to 3 decimal places for monitors which require it
|
||||||
|
* Bug fix - arandr - enable setting of left and right orientation
|
||||||
|
* Bug fix - arandr - add compatibility with new touchscreen driver
|
||||||
|
* Bug fix - arandr - apply settings correctly to DSI and composite displays
|
||||||
|
* Bug fix - lxplug-magnifier - fix crash when opening preferences without required magnifier package installed
|
||||||
|
* Bug fix - piwiz - launch screen reader install prompt as a new process to prevent audio lockups crashing wizard
|
||||||
|
* Bug fix - lxpanel - not loading some plugins (cpufreq, minimise all windows) due to icon loading code not compatible with GTK+3
|
||||||
|
* Bug fix - gtk+3 - disabled new GDK touch events to enable double-clicks to be detected on touchscreen
|
||||||
|
* Bug fix - xrdp - included backports from bookworm version of xrdp and xorgxrdp to restore window frames with mutter over xrdp connections
|
||||||
|
* Update various translations
|
||||||
|
* udisks2 added to lite image
|
||||||
|
* mkvtoolnix added to lite image
|
||||||
|
* 7z and zip support added to lite image
|
||||||
|
* gnome-keyring added to desktop images
|
||||||
|
* Raspberry Pi firmware c6d56567ff6ef17fd85159770f22abcf2c5953ed
|
||||||
|
* Linux kernel 5.10.92
|
||||||
|
2021-10-30:
|
||||||
|
* Based on Debian version 11 (bullseye)
|
||||||
|
* Desktop components (lxpanel and all plugins, libfm, pcmanfm) now built against GTK+3
|
||||||
|
* Applications (piwiz, pipanel, rc_gui, lxinput) now built against GTK+3
|
||||||
|
* PiXflat GTK+3 theme updated with numerous changes to support the above
|
||||||
|
* GTK+3 : toolbar icon size setting added
|
||||||
|
* GTK+3 : ability to request client-side decoration on windows added
|
||||||
|
* GTK+3 : setting for indent for frame labels in custom style added
|
||||||
|
* mutter window manager used instead of openbox on devices with 2GB or more of RAM
|
||||||
|
* mutter : title bar icon behaviour and appearance modified to match openbox
|
||||||
|
* mutter : additional keyboard shortcuts added
|
||||||
|
* mutter : various performance enhancements
|
||||||
|
* mutter compatibility added to screen magnifier
|
||||||
|
* Numerous changes to Appearance Settings application to support GTK+3 and mutter
|
||||||
|
* Updater plugin added to lxpanel to detect and install software updates
|
||||||
|
* File manager view options simplified to either list or icons, with separate menu option for thumbnails
|
||||||
|
* New file manager toolbar icons
|
||||||
|
* KMS used as default display driver
|
||||||
|
* Modifications to HDMI audio output selection to support the above
|
||||||
|
* xcompmgr enabled when openbox is running under KMS
|
||||||
|
* New default camera subsystem based on libcamera
|
||||||
|
* New camera demo applications (libcamera-still and libcamera-vid) have replaced raspistill and raspivid
|
||||||
|
* Legacy camera subsystem removed from 64-bit RPi OS (still available on 32-bit)
|
||||||
|
* Chromium upgraded to version 92.0.4515.98
|
||||||
|
* VLC media player upgraded to version 3.0.16
|
||||||
|
* Spurious drive removal warning after use of SD card copier removed
|
||||||
|
* Bookshelf application now includes Custom PC magazine
|
||||||
|
* Various translation updates - Italian, Korean, Polish, German, Armenian
|
||||||
|
* Startup wizard now installs Japanese fonts if needed
|
||||||
|
* Progress and information dialog boxes for lxpanel plugins now common to lxpanel, rather than in individual plugins
|
||||||
|
* Icon handling code for lxpanel plugins now common to lxpanel
|
||||||
|
* Package with 4K version of Raspberry Pi wallpaper added to Recommended Software
|
||||||
|
* Python Games and Minecraft removed from Recommended Software - neither is compatible with bullseye
|
||||||
|
* Bluetooth pairing and connection dialogs updated for compatibility with more devices
|
||||||
|
* Bluetooth devices always disconnected before removal to speed up removal process
|
||||||
|
* Bluetooth pairing dialog now only shows devices which offer services which are usable by Pi
|
||||||
|
* Separate Bluetooth unpair dialog removed - unpair now an option for each individual device
|
||||||
|
* Bug fix - mutter : header bar colours not updating when theme is changed
|
||||||
|
* Bug fix - GTK+3 : tooltips being displayed incorrectly at bottom of screen
|
||||||
|
* Bug fix - lxpanel : crash when using keyboard shortcut to enable magnifier when magnifier not installed
|
||||||
|
* Bug fix - lxpanel : lockup in Bluetooth plugin when connecting to certain devices
|
||||||
|
* Bug fix - lxpanel : discoverable mode icon could get out of sync with underlying Bluetooth system state
|
||||||
|
* Bug fix - piwiz : missing cities in timezone list
|
||||||
|
* Bug fix - piwiz : country-specific language packages not being installed
|
||||||
|
* Bug fix - bookshelf : now waits for longer between packets before timing out
|
||||||
|
* Bug fix - accented characters now displayed correctly in localisation dialogs
|
||||||
|
* Raspberry Pi firmware e2bab29767e51c683a312df20014e3277275b8a6
|
||||||
|
* Linux kernel 5.10.63
|
||||||
|
2021-05-07:
|
||||||
* Chromium upgraded to version 88.0.4324.187
|
* Chromium upgraded to version 88.0.4324.187
|
||||||
* NuScratch upgraded to version 20210507
|
* NuScratch upgraded to version 20210507
|
||||||
* Node-RED upgraded to version 1.3.4
|
* Node-RED upgraded to version 1.3.4
|
||||||
|
|
|
@ -3,11 +3,7 @@
|
||||||
NOOBS_DIR="${STAGE_WORK_DIR}/${IMG_NAME}${IMG_SUFFIX}"
|
NOOBS_DIR="${STAGE_WORK_DIR}/${IMG_NAME}${IMG_SUFFIX}"
|
||||||
mkdir -p "${STAGE_WORK_DIR}"
|
mkdir -p "${STAGE_WORK_DIR}"
|
||||||
|
|
||||||
if [ "${DEPLOY_ZIP}" == "1" ]; then
|
|
||||||
IMG_FILE="${WORK_DIR}/export-image/${IMG_FILENAME}${IMG_SUFFIX}.img"
|
IMG_FILE="${WORK_DIR}/export-image/${IMG_FILENAME}${IMG_SUFFIX}.img"
|
||||||
else
|
|
||||||
IMG_FILE="${DEPLOY_DIR}/${IMG_FILENAME}${IMG_SUFFIX}.img"
|
|
||||||
fi
|
|
||||||
|
|
||||||
unmount_image "${IMG_FILE}"
|
unmount_image "${IMG_FILE}"
|
||||||
|
|
||||||
|
|
|
@ -25,7 +25,7 @@ Usage:
|
||||||
-p, --mount-point mount point for image
|
-p, --mount-point mount point for image
|
||||||
|
|
||||||
This tool will use /dev/nbd1 as default for mounting an image. If you want to use another device, execute like this:
|
This tool will use /dev/nbd1 as default for mounting an image. If you want to use another device, execute like this:
|
||||||
NBD_DEV=/dev/nbd2 ./$progname --mount --image <your image> --mount-point <your path>
|
NBD_DEV=/dev/nbd2 ./$progname --mount --image-name <your image> --mount-point <your path>
|
||||||
|
|
||||||
HEREDOC
|
HEREDOC
|
||||||
}
|
}
|
||||||
|
|
|
@ -9,17 +9,16 @@ bootstrap(){
|
||||||
|
|
||||||
export http_proxy=${APT_PROXY}
|
export http_proxy=${APT_PROXY}
|
||||||
|
|
||||||
if [ "$(dpkg --print-architecture)" != "armhf" ] && [ "$(dpkg --print-architecture)" != "aarch64" ]; then
|
BOOTSTRAP_ARGS+=(--arch arm64)
|
||||||
BOOTSTRAP_CMD=qemu-debootstrap
|
BOOTSTRAP_ARGS+=(--include gnupg)
|
||||||
fi
|
|
||||||
|
|
||||||
BOOTSTRAP_ARGS+=(--arch armhf)
|
|
||||||
BOOTSTRAP_ARGS+=(--components "main,contrib,non-free")
|
BOOTSTRAP_ARGS+=(--components "main,contrib,non-free")
|
||||||
BOOTSTRAP_ARGS+=(--keyring "${STAGE_DIR}/files/raspberrypi.gpg")
|
#BOOTSTRAP_ARGS+=(--keyring "${STAGE_DIR}/files/raspberrypi.gpg")
|
||||||
|
BOOTSTRAP_ARGS+=(--exclude=info)
|
||||||
|
BOOTSTRAP_ARGS+=(--include=ca-certificates)
|
||||||
BOOTSTRAP_ARGS+=("$@")
|
BOOTSTRAP_ARGS+=("$@")
|
||||||
printf -v BOOTSTRAP_STR '%q ' "${BOOTSTRAP_ARGS[@]}"
|
printf -v BOOTSTRAP_STR '%q ' "${BOOTSTRAP_ARGS[@]}"
|
||||||
|
|
||||||
setarch linux32 capsh --drop=cap_setfcap -- -c "'${BOOTSTRAP_CMD}' $BOOTSTRAP_STR" || true
|
capsh --drop=cap_setfcap -- -c "'${BOOTSTRAP_CMD}' $BOOTSTRAP_STR" || true
|
||||||
|
|
||||||
if [ -d "$2/debootstrap" ] && ! rmdir "$2/debootstrap"; then
|
if [ -d "$2/debootstrap" ] && ! rmdir "$2/debootstrap"; then
|
||||||
cp "$2/debootstrap/debootstrap.log" "${STAGE_WORK_DIR}"
|
cp "$2/debootstrap/debootstrap.log" "${STAGE_WORK_DIR}"
|
||||||
|
@ -92,7 +91,7 @@ on_chroot() {
|
||||||
mount --bind /sys "${ROOTFS_DIR}/sys"
|
mount --bind /sys "${ROOTFS_DIR}/sys"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
setarch linux32 capsh --drop=cap_setfcap "--chroot=${ROOTFS_DIR}/" -- -e "$@"
|
capsh --drop=cap_setfcap "--chroot=${ROOTFS_DIR}/" -- -e "$@"
|
||||||
}
|
}
|
||||||
export -f on_chroot
|
export -f on_chroot
|
||||||
|
|
||||||
|
|
|
@ -12,8 +12,9 @@ else
|
||||||
rm -f "${ROOTFS_DIR}/etc/apt/apt.conf.d/51cache"
|
rm -f "${ROOTFS_DIR}/etc/apt/apt.conf.d/51cache"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
on_chroot apt-key add - < files/raspberrypi.gpg.key
|
cat files/raspberrypi.gpg.key | gpg --dearmor > "${ROOTFS_DIR}/etc/apt/trusted.gpg.d/raspberrypi-archive-stable.gpg"
|
||||||
on_chroot << EOF
|
on_chroot << EOF
|
||||||
|
dpkg --add-architecture armhf
|
||||||
apt-get update
|
apt-get update
|
||||||
apt-get dist-upgrade -y
|
apt-get dist-upgrade -y
|
||||||
EOF
|
EOF
|
||||||
|
|
1
stage0/00-configure-apt/01-packages
Normal file
1
stage0/00-configure-apt/01-packages
Normal file
|
@ -0,0 +1 @@
|
||||||
|
raspberrypi-archive-keyring
|
|
@ -1,3 +1,7 @@
|
||||||
deb http://raspbian.raspberrypi.org/raspbian/ RELEASE main contrib non-free rpi
|
deb http://deb.debian.org/debian RELEASE main contrib non-free
|
||||||
# Uncomment line below then 'apt-get update' to enable 'apt-get source'
|
deb http://security.debian.org/debian-security RELEASE-security main contrib non-free
|
||||||
#deb-src http://raspbian.raspberrypi.org/raspbian/ RELEASE main contrib non-free rpi
|
deb http://deb.debian.org/debian RELEASE-updates main contrib non-free
|
||||||
|
# Uncomment deb-src lines below then 'apt-get update' to enable 'apt-get source'
|
||||||
|
#deb-src http://deb.debian.org/debian RELEASE main contrib non-free
|
||||||
|
#deb-src http://security.debian.org/debian-security RELEASE-security main contrib non-free
|
||||||
|
#deb-src http://deb.debian.org/debian RELEASE-updates main contrib non-free
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
#!/bin/bash -e
|
#!/bin/bash -e
|
||||||
|
|
||||||
if [ ! -d "${ROOTFS_DIR}" ] || [ "${USE_QCOW2}" = "1" ]; then
|
if [ ! -d "${ROOTFS_DIR}" ] || [ "${USE_QCOW2}" = "1" ]; then
|
||||||
bootstrap ${RELEASE} "${ROOTFS_DIR}" http://raspbian.raspberrypi.org/raspbian/
|
bootstrap ${RELEASE} "${ROOTFS_DIR}" http://deb.debian.org/debian/
|
||||||
fi
|
fi
|
||||||
|
|
|
@ -5,10 +5,6 @@
|
||||||
# uncomment if you get no picture on HDMI for a default "safe" mode
|
# uncomment if you get no picture on HDMI for a default "safe" mode
|
||||||
#hdmi_safe=1
|
#hdmi_safe=1
|
||||||
|
|
||||||
# uncomment this if your display has a black border of unused pixels visible
|
|
||||||
# and your display can output without overscan
|
|
||||||
#disable_overscan=1
|
|
||||||
|
|
||||||
# uncomment the following to adjust overscan. Use positive numbers if console
|
# uncomment the following to adjust overscan. Use positive numbers if console
|
||||||
# goes off screen, and negative if there is too much border
|
# goes off screen, and negative if there is too much border
|
||||||
#overscan_left=16
|
#overscan_left=16
|
||||||
|
@ -56,10 +52,32 @@
|
||||||
# Enable audio (loads snd_bcm2835)
|
# Enable audio (loads snd_bcm2835)
|
||||||
dtparam=audio=on
|
dtparam=audio=on
|
||||||
|
|
||||||
[pi4]
|
# Automatically load overlays for detected cameras
|
||||||
# Enable DRM VC4 V3D driver on top of the dispmanx display stack
|
camera_auto_detect=1
|
||||||
dtoverlay=vc4-fkms-v3d
|
|
||||||
|
# Automatically load overlays for detected DSI displays
|
||||||
|
display_auto_detect=1
|
||||||
|
|
||||||
|
# Enable DRM VC4 V3D driver
|
||||||
|
dtoverlay=vc4-kms-v3d
|
||||||
max_framebuffers=2
|
max_framebuffers=2
|
||||||
|
|
||||||
|
# Run in 64-bit mode
|
||||||
|
arm_64bit=1
|
||||||
|
|
||||||
|
# Disable compensation for displays with overscan
|
||||||
|
disable_overscan=1
|
||||||
|
|
||||||
|
[cm4]
|
||||||
|
# Enable host mode on the 2711 built-in XHCI USB controller.
|
||||||
|
# This line should be removed if the legacy DWC2 controller is required
|
||||||
|
# (e.g. for USB device mode) or if USB support is not required.
|
||||||
|
otg_mode=1
|
||||||
|
|
||||||
|
[all]
|
||||||
|
|
||||||
|
[pi4]
|
||||||
|
# Run as fast as firmware / board allows
|
||||||
|
arm_boost=1
|
||||||
|
|
||||||
[all]
|
[all]
|
||||||
#dtoverlay=vc4-fkms-v3d
|
|
||||||
|
|
1
stage1/01-sys-tweaks/00-packages
Normal file
1
stage1/01-sys-tweaks/00-packages
Normal file
|
@ -0,0 +1 @@
|
||||||
|
raspi-config
|
|
@ -1,3 +1,3 @@
|
||||||
proc /proc proc defaults 0 0
|
proc /proc proc defaults 0 0
|
||||||
BOOTDEV /boot vfat defaults 0 2
|
BOOTDEV /boot vfat defaults,flush 0 2
|
||||||
ROOTDEV / ext4 defaults,noatime 0 1
|
ROOTDEV / ext4 defaults,noatime 0 1
|
||||||
|
|
|
@ -3,4 +3,6 @@
|
||||||
echo "${TARGET_HOSTNAME}" > "${ROOTFS_DIR}/etc/hostname"
|
echo "${TARGET_HOSTNAME}" > "${ROOTFS_DIR}/etc/hostname"
|
||||||
echo "127.0.1.1 ${TARGET_HOSTNAME}" >> "${ROOTFS_DIR}/etc/hosts"
|
echo "127.0.1.1 ${TARGET_HOSTNAME}" >> "${ROOTFS_DIR}/etc/hosts"
|
||||||
|
|
||||||
ln -sf /dev/null "${ROOTFS_DIR}/etc/systemd/network/99-default.link"
|
on_chroot << EOF
|
||||||
|
SUDO_USER="${FIRST_USER_NAME}" raspi-config nonint do_net_names 1
|
||||||
|
EOF
|
||||||
|
|
|
@ -1 +1,2 @@
|
||||||
libraspberrypi-bin libraspberrypi0 raspi-config
|
libraspberrypi-bin libraspberrypi0
|
||||||
|
systemd-timesyncd
|
||||||
|
|
|
@ -1 +0,0 @@
|
||||||
raspi-copies-and-fills
|
|
|
@ -1,6 +0,0 @@
|
||||||
#!/bin/bash -e
|
|
||||||
|
|
||||||
if [ -f "${ROOTFS_DIR}/etc/ld.so.preload" ]; then
|
|
||||||
mv "${ROOTFS_DIR}/etc/ld.so.preload" "${ROOTFS_DIR}/etc/ld.so.preload.disabled"
|
|
||||||
fi
|
|
||||||
|
|
|
@ -1,8 +1,8 @@
|
||||||
ssh less fbset sudo psmisc strace ed ncdu crda
|
ssh less fbset sudo psmisc strace ed ncdu crda
|
||||||
console-setup keyboard-configuration debconf-utils parted unzip
|
console-setup keyboard-configuration debconf-utils parted
|
||||||
build-essential manpages-dev python bash-completion gdb pkg-config
|
build-essential manpages-dev bash-completion gdb pkg-config
|
||||||
python-rpi.gpio v4l-utils
|
python-is-python3
|
||||||
python-gpiozero
|
python3-rpi.gpio v4l-utils
|
||||||
python3-gpiozero
|
python3-gpiozero
|
||||||
avahi-daemon
|
avahi-daemon
|
||||||
lua5.1
|
lua5.1
|
||||||
|
@ -26,8 +26,9 @@ policykit-1
|
||||||
ssh-import-id
|
ssh-import-id
|
||||||
rng-tools
|
rng-tools
|
||||||
ethtool
|
ethtool
|
||||||
vl805fw
|
|
||||||
ntfs-3g
|
ntfs-3g
|
||||||
pciutils
|
pciutils
|
||||||
rpi-eeprom
|
rpi-eeprom
|
||||||
raspinfo
|
raspinfo
|
||||||
|
udisks2
|
||||||
|
unzip zip p7zip-full
|
||||||
|
|
|
@ -1 +1,3 @@
|
||||||
cifs-utils
|
cifs-utils
|
||||||
|
libcamera-apps-lite
|
||||||
|
mkvtoolnix
|
||||||
|
|
|
@ -1,11 +1,12 @@
|
||||||
#!/bin/bash -e
|
#!/bin/bash -e
|
||||||
|
|
||||||
install -v -d "${ROOTFS_DIR}/etc/systemd/system/dhcpcd.service.d"
|
|
||||||
install -v -m 644 files/wait.conf "${ROOTFS_DIR}/etc/systemd/system/dhcpcd.service.d/"
|
|
||||||
|
|
||||||
install -v -d "${ROOTFS_DIR}/etc/wpa_supplicant"
|
install -v -d "${ROOTFS_DIR}/etc/wpa_supplicant"
|
||||||
install -v -m 600 files/wpa_supplicant.conf "${ROOTFS_DIR}/etc/wpa_supplicant/"
|
install -v -m 600 files/wpa_supplicant.conf "${ROOTFS_DIR}/etc/wpa_supplicant/"
|
||||||
|
|
||||||
|
on_chroot << EOF
|
||||||
|
SUDO_USER="${FIRST_USER_NAME}" raspi-config nonint do_boot_wait 0
|
||||||
|
EOF
|
||||||
|
|
||||||
if [ -v WPA_COUNTRY ]; then
|
if [ -v WPA_COUNTRY ]; then
|
||||||
echo "country=${WPA_COUNTRY}" >> "${ROOTFS_DIR}/etc/wpa_supplicant/wpa_supplicant.conf"
|
echo "country=${WPA_COUNTRY}" >> "${ROOTFS_DIR}/etc/wpa_supplicant/wpa_supplicant.conf"
|
||||||
fi
|
fi
|
||||||
|
|
|
@ -1,3 +0,0 @@
|
||||||
[Service]
|
|
||||||
ExecStart=
|
|
||||||
ExecStart=/usr/lib/dhcpcd5/dhcpcd -q -w
|
|
|
@ -36,7 +36,7 @@ EOF
|
||||||
# Run the actual install
|
# Run the actual install
|
||||||
on_chroot << EOF
|
on_chroot << EOF
|
||||||
apt-get install insserv resolvconf -y
|
apt-get install insserv resolvconf -y
|
||||||
curl https://install.yunohost.org/buster | bash -s -- -a
|
curl https://install.yunohost.org/bullseye | bash -s -- -a
|
||||||
rm -f /etc/ssh/ssh_host_*
|
rm -f /etc/ssh/ssh_host_*
|
||||||
EOF
|
EOF
|
||||||
|
|
||||||
|
@ -46,6 +46,10 @@ sed -i '/PermitRootLogin/c\PermitRootLogin yes' /etc/ssh/sshd_config
|
||||||
echo "root:yunohost" | chpasswd
|
echo "root:yunohost" | chpasswd
|
||||||
EOF
|
EOF
|
||||||
|
|
||||||
|
echo "Removing Raspbian sshd banner"
|
||||||
|
rm -f "${ROOTFS_DIR}/etc/ssh/sshd_config.d/rename_user.conf"
|
||||||
|
rm -f "${ROOTFS_DIR}/usr/share/userconf-pi/sshd_banner"
|
||||||
|
|
||||||
install -m 755 files/check_yunohost_is_installed.sh "${ROOTFS_DIR}/etc/profile.d/"
|
install -m 755 files/check_yunohost_is_installed.sh "${ROOTFS_DIR}/etc/profile.d/"
|
||||||
|
|
||||||
echo "Cleaning ..."
|
echo "Cleaning ..."
|
||||||
|
@ -60,7 +64,7 @@ EOF
|
||||||
# the rootfs/image after that ?
|
# the rootfs/image after that ?
|
||||||
while lsof 2>/dev/null | grep -q /root/rpi-image/work/*/export-image/rootfs/dev;
|
while lsof 2>/dev/null | grep -q /root/rpi-image/work/*/export-image/rootfs/dev;
|
||||||
do
|
do
|
||||||
for PID in `ps -ef --forest | grep "qemu-arm-static" | grep -v "grep" | grep "nginx\|nscd\|slapd\|nslcd" | awk '{print $2}'`
|
for PID in `ps -ef --forest | grep "qemu-binfmt" | grep -v "grep" | grep "nginx\|nscd\|slapd\|nslcd" | awk '{print $2}'`
|
||||||
do
|
do
|
||||||
echo "Killing $PID"
|
echo "Killing $PID"
|
||||||
kill -9 $PID || true
|
kill -9 $PID || true
|
||||||
|
@ -68,9 +72,9 @@ do
|
||||||
done
|
done
|
||||||
sleep 5
|
sleep 5
|
||||||
done
|
done
|
||||||
while ps -ef --forest | grep "qemu-arm-static" | grep -v "grep"
|
while ps -ef --forest | grep "qemu-binfmt" | grep -v "grep"
|
||||||
do
|
do
|
||||||
for PID in `ps -ef --forest | grep "qemu-arm-static" | grep -v "grep" | grep "nginx\|nscd\|slapd\|nslcd" | awk '{print $2}'`
|
for PID in `ps -ef --forest | grep "qemu-binfmt" | grep -v "grep" | grep "nginx\|nscd\|slapd\|nslcd" | awk '{print $2}'`
|
||||||
do
|
do
|
||||||
echo "Killing $PID"
|
echo "Killing $PID"
|
||||||
kill -9 $PID || true
|
kill -9 $PID || true
|
||||||
|
|
Loading…
Reference in a new issue