# raspberrypi **Repository Path**: testphpl/raspberrypi ## Basic Information - **Project Name**: raspberrypi - **Description**: It provides scripts for building openEuler image on Raspberry Pi and documents - **Primary Language**: Unknown - **License**: MulanPSL-2.0 - **Default Branch**: master - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 45 - **Created**: 2021-04-03 - **Last Updated**: 2021-04-03 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README # raspberrypi English | [简体中文](./README.md) This repository is main repository of openEuler RaspberryPi SIG, and provides scripts for building openEuler image for Raspberry Pi and related documents. - [raspberrypi](#raspberrypi) - [How to collaborate](#how-to-collaborate) - [File description](#file-description) - [How to download latest image](#how-to-download-latest-image) - [How to Use image](#how-to-use-image) - [How to build image locally](#how-to-build-image-locally) - [Prepare the environment](#prepare-the-environment) - [Run the scripts to build image](#run-the-scripts-to-build-image) - [Quickly Build without kernel compilation(Recommended)](#quickly-build-without-kernel-compilationrecommended) - [Build with kernel compilation](#build-with-kernel-compilation) - [Build on host](#build-on-host) - [Build in a Docker container](#build-in-a-docker-container) ## How to collaborate You can get introduction of openEuler RaspberryPi SIG from [sig-RaspberryPi](https://gitee.com/jianminw/community/tree/master/sig/sig-RaspberryPi). - Issues: welcome to collaborate with us by create new issues or reply opened issues. You can get repository list from [sig-RaspberryPi](https://gitee.com/jianminw/community/tree/master/sig/sig-RaspberryPi). - Join Slack workspace: [openeuler-raspberrypi](https://openeuler-raspberrypi.slack.com ) - [Invite link](https://join.slack.com/t/openeuler-raspberrypi/shared_invite/zt-kp6de2va-2t4k6JqvNWKogtYv1Kg3pQ): This link will be due on Feb 11th, 2021. We will update the link periodically. - Weekly meeting schedule - Meeting Time: The 1st and 3rd Wednesday of each month, 20:00 - 20:30 UTC+8. - Meeting Link: There are two methods to get the meeting link which will be updated before each meeting. - Log in to the [openEuler Community](https://openeuler.org/) website, then view the booking information of `sig-RaspberryPi例会` in the meeting calendar. - Search `openEuler` in mini programs of Wechat, add `openEuler mini program`. Then click `会议` and view the booking information of `sig-RaspberryPi例会`. - [Meeting Agenda](https://etherpad.openeuler.org/p/sig-RaspberryPi-meetings) - [Meeting Minutes](https://gitee.com/openeuler/raspberrypi/issues/I1EYZ6) - Warmly welcome to sumbit Pull Requests. ## File description >![](documents/public_sys-resources/icon-note.gif) **NOTE: ** >- Recommendation: use the openEuler-RaspberryPi images provided in the chapter [How to download latest image](#how-to-download-latest-image) of this documentation. >- If you need to customize the image, please refer to [Building openEuler image for Raspberry Pi](documents/openEuler镜像的构建.md) and [Cross-compile the kernel](documents/交叉编译内核.md). - [documents](./documents/): - [Install openEuler on a SD card](documents/刷写镜像.md) - [How to use Raspberry Pi](documents/树莓派使用.md) - [Building openEuler image for Raspberry Pi](documents/openEuler镜像的构建.md) - [Cross-compile the kernel](documents/交叉编译内核.md) - [openEuler 20.03 LTS alpha version ChangeLog](documents/changelog/changelog-20.03-LTS.en.md) - [openEuler 20.09 alpha version ChangeLog](documents/changelog/changelog-20.09.en.md) - [openEuler 20.09 alpha version (with Xfce desktop environment) ChangeLog](documents/changelog/changelog-20.09-Xfce.en.md) - [openEuler 20.09 ChangeLog](documents/changelog/changelog-20.09-release.en.md) - [openEuler 20.03 LTS SP1 alpha version ChangeLog](documents/changelog/changelog-20.03-LTS-SP1.en.md) - [openEuler 20.03 LTS SP1 alpha version (with UKUI desktop environment) ChangeLog](documents/changelog/changelog-20.03-LTS-SP1-UKUI.en.md) - [openEuler 20.03 LTS SP1 alpha version (with DDE desktop environment) ChangeLog](documents/changelog/changelog-20.03-LTS-SP1-DDE.en.md) - [openEuler 20.03 LTS SP1 ChangeLog](documents/changelog/changelog-20.03-LTS-SP1-release.en.md) - [scripts](./scripts): Script for building openEuler image for Raspberry Pi - [Quickly Build (without kernel compilation)](scripts/build-image.sh) - [Build on host (with kernel compilation)](scripts/build-image-common.sh) - [Build in a Docker container (with kernel compilation)](scripts/build-image-docker.sh) ## How to download latest image Basic information of the image is as follows:

Version

System user(password)

Change log

Release date

Size

Kernel version

Repository of rootfs

openEuler 20.03 LTS alpha5
  • root (openeuler)
  • pi (raspberry)
ChangeLog

2021/01/19

212 MiB

4.19.90-2101.1.0

openEuler 20.03 LTS repository built daily
openEuler 20.09 alpha5
  • root (openeuler)
  • pi (raspberry)
ChangeLog

2021/01/19

236 MiB

4.19.140-2101.1.0.0007

openEuler 20.09 repository built daily
openEuler 20.09 alpha6 (with Xfce desktop environment)
  • root (openeuler)
  • pi (raspberry)
ChangeLog

2021/01/19

903 MiB

4.19.138-2008.1.0.0001

openEuler 20.09 repository
openEuler 20.09

root (openeuler)

ChangeLog

2020/09/30

259 MiB

4.19.138-2008.1.0.0001

openEuler 20.09 repository
openEuler 20.03 LTS SP1 alpha3
  • root (openeuler)
  • pi (raspberry)
ChangeLog

2021/01/19

234 MiB

4.19.90-2012.5.0.0013

openEuler 20.03 LTS SP1 repository built daily
openEuler 20.03 LTS SP1 alpha3 (with UKUI desktop environment)
  • root (openeuler)
  • pi (raspberry)
ChangeLog

2021/01/19

1.0 GiB

4.19.90-2012.5.0.0013

openEuler 20.03 LTS SP1 repository built daily
openEuler 20.03 LTS SP1 alpha3 (with DDE desktop environment)
  • root (openeuler)
  • pi (raspberry)
ChangeLog

2021/01/19

1.0 GiB

4.19.90-2012.5.0.0013

openEuler 20.03 LTS SP1 repository built daily
openEuler 20.03 LTS SP1

root (openeuler)

ChangeLog

2020/12/28

266 MiB

4.19.90-2012.3.0.0011

openEuler 20.03 LTS SP1 repository
Other information: - Firmware source: [firmware](https://github.com/raspberrypi/firmware), [bluez-firmware](https://github.com/RPi-Distro/bluez-firmware), [firmware-nonfree](https://github.com/RPi-Distro/firmware-nonfree) ## How to Use image Refer to [Install openEuler on a SD card](documents/刷写镜像.md) and [How to use Raspberry Pi](documents/树莓派使用.md) for details about how to use the image on Raspberry Pi. ## How to build image locally ### Prepare the environment To build openEuler AArch64 image for Raspberry Pi, the requirements of runing scripts of this repository are as follows: - OS: openEuler or CentOS 7/8 - Hardware: AArch64 hardware, such as Raspberry Pi For other architecture hardware, you can use [QEMU](https://www.qemu.org/) to build AArch64 system emulation. ### Run the scripts to build image Refer to [Script for building openEuler image for Raspberry Pi](documents/openEuler镜像的构建.md) for details. #### Quickly Build without kernel compilation(Recommended) >![](documents/public_sys-resources/icon-notice.gif) **NOTICE:** >Two openEuler versions are currently supported, i.e., 20.09 and 20.03 LTS SP1. >When building an image with Xfce/UKUI/DDE desktop environment, you need to pay attention to three issues: >1. For building an image with Xfce desktop environment, note that only openEuler 20.09 is currently supported. You need to add an additional repository, i.e., the information of `[Xfce]` in the description of the parameter `-r/--repo`. Note that this repository is temporary for test, and it is used to supplement the related software packages of Xfce omitted by the repositories of openEuler 20.09. >2. For building an image with DDE desktop environment, note that only openEuler 20.03 LTS SP1 is currently supported. >3. Need to set the parameter `-s/--spec`. Please refer to the description of this parameter for details. Build images with packages of raspberrypi-kernel, raspberrypi-firmware, and raspberrypi-bluetooth. Run the following command to build an image: `sudo bash build-image.sh -d DIR -r REPO -n IMAGE_NAME -s SPEC` The meaning of each parameter: 1. -d, --dir DIR The directory for storing the image and other temporary files, which defaults to be the directory in which the script resides. If the `DIR` does not exist, it will be created automatically. After building the image, you can find the image in `DIR/raspi_output/img/` as shown in the script output. 2. -r, --repo REPO_INFO The URL/path of target repo file, or the list of repositories' baseurls. Note that, the baseurls should be separated by space and enclosed in double quotes. Examples are as follows: - The URL of target repo file: *currently unavailable* - The path of target repo file: `./openEuler-20.09.repo` The content of the repo file is as follows: ``` [OS] name=OS baseurl=http://repo.openeuler.org/openEuler-20.09/OS/$basearch/ enabled=1 gpgcheck=1 gpgkey=http://repo.openeuler.org/openEuler-20.09/OS/$basearch/RPM-GPG-KEY-openEuler [everything] name=everything baseurl=http://repo.openeuler.org/openEuler-20.09/everything/$basearch/ enabled=1 gpgcheck=1 gpgkey=http://repo.openeuler.org/openEuler-20.09/everything/$basearch/RPM-GPG-KEY-openEuler [EPOL] name=EPOL baseurl=http://repo.openeuler.org/openEuler-20.09/EPOL/$basearch/ enabled=1 gpgcheck=1 gpgkey=http://repo.openeuler.org/openEuler-20.09/EPOL/$basearch/RPM-GPG-KEY-openEuler [debuginfo] name=debuginfo baseurl=http://repo.openeuler.org/openEuler-20.09/debuginfo/$basearch/ enabled=1 gpgcheck=1 gpgkey=http://repo.openeuler.org/openEuler-20.09/debuginfo/$basearch/RPM-GPG-KEY-openEuler [source] name=source baseurl=http://repo.openeuler.org/openEuler-20.09/source/ enabled=1 gpgcheck=1 gpgkey=http://repo.openeuler.org/openEuler-20.09/source/RPM-GPG-KEY-openEuler [Xfce] name=Xfce baseurl=https://eulixos.com/repo/others/openeuler-raspberrypi/pkgs/ enabled=1 gpgcheck=0 ``` - List of repo's baseurls: `"http://repo.openeuler.org/openEuler-20.09/everything/aarch64/ http://repo.openeuler.org/openEuler-20.09/EPOL/aarch64/ https://eulixos.com/repo/others/openeuler-raspberrypi/pkgs/"` 3. -n, --name IMAGE_NAME The image name to be built. For example, `openEuler-20.09.img`. The default is `openEuler-raspi-aarch64.img`, or it is automatically generated based on parameter: `-n, --name IMAGE_NAME`. 4. -s, --spec SPEC Specify the image version: - `headless`, image without desktop environments. - `xfce`, image with Xfce desktop environment and related softwares including CJK fonts and IME. - `ukui`, image with UKUI desktop environment and fundamental softwares without CJK fonts and IME. - `dde`, image with DDE desktop environment and fundamental softwares without CJK fonts and IME. - The file path of rpmlist, the file contains a list of the software to be installed in the image, refer to [rpmlist](./scripts/config/rpmlist) for details. The default is `headless`. 5. -h, --help Display help information. #### Build with kernel compilation Here, we provide two approaches to build an image, which both include compiling kernel and downloading firmware files of Raspberry Pi. These approaches will take considerably longer. >![](documents/public_sys-resources/icon-notice.gif) **NOTICE:** >Three openEuler versions are currently supported, i.e., 20.03 LTS, 20.09 and 20.03 LTS SP1. >When building an image with Xfce/UKUI/DDE desktop environment, you need to pay attention to four issues: >1. For building an image with Xfce desktop environment, note that only openEuler 20.09 is currently supported. You need to select the branch `openEuler-20.09` of the kernel source repository, i.e., set the parameter `-b/--branch` to `openEuler-20.09`. You also need to add an additional repository, i.e., the information of `[Xfce]` in the description of the parameter `-r/--repo`. Note that this repository is temporary for test, and it is used to supplement the related software packages of Xfce omitted by the repositories of openEuler 20.09. >2. For building an image with UKUI desktop environment, note that only openEuler 20.09 and 20.03 LTS SP1 are currently supported. You need to select the branch `openEuler-20.09` or `openEuler-20.03-LTS` of the kernel source repository, i.e., set the parameter `-b/--branch` to `openEuler-20.09` or `openEuler-20.03-LTS`. >3. For building an image with DDE desktop environment, note that only openEuler 20.03 LTS SP1 is currently supported. You need to select the branch `openEuler-20.03-LTS` of the kernel source repository, i.e., set the parameter `-b/--branch` to `openEuler-20.03-LTS`. >4. Need to set the parameter `-s/--spec`. Please refer to the description of this parameter for details. ##### Build on host Run the following command to build an image: `sudo bash build-image-common.sh -n IMAGE_NAME -k KERNEL_URL -b KERNEL_BRANCH -c KERNEL_DEFCONFIG -r REPO -s SPEC --cores N` After building the image, you can find the image in `raspi_output_common/img/` of the directory in which the script resides as shown in the script output. The meaning of each parameter: 1. -n, --name IMAGE_NAME The image name to be built. For example, `openEuler-20.03-LTS.img`. The default is `openEuler-raspi-aarch64.img`, or it is automatically generated based on parameter: `-n, --name IMAGE_NAME`. 2. -k, --kernel KERNEL_URL The URL of kernel source repository, which defaults to `https://gitee.com/openeuler/raspberrypi-kernel.git`. 3. -b, --branch KERNEL_BRANCH The branch name of kernel source repository, which defaults to `master`. `openEuler-20.03-LTS` or `openEuler-20.09` is recommended. 4. -c, --config KERNEL_DEFCONFIG The filename/path of configuration for compiling kernel, which defaults to `openeuler-raspi_defconfig`. If this parameter is the filename of configuration, please make sure the configuration file in arch/arm64/configs of the kernel source. 5. -r, --repo REPO_INFO The URL/path of target repo file, or the list of repositories' baseurls. Note that, the baseurls should be separated by space and enclosed in double quotes. Examples are as follows: - The URL of target repo file: `https://gitee.com/src-openeuler/openEuler-repos/blob/openEuler-20.03-LTS/generic.repo` - The path of target repo file: - `./openEuler-20.03-LTS.repo`: for building openEuler 20.03 LTS image, refer to for details. - `./openEuler-20.09.repo`: for building openEuler 20.09 image, the content of the repo file is as follows: ``` [OS] name=OS baseurl=http://repo.openeuler.org/openEuler-20.09/OS/$basearch/ enabled=1 gpgcheck=1 gpgkey=http://repo.openeuler.org/openEuler-20.09/OS/$basearch/RPM-GPG-KEY-openEuler [everything] name=everything baseurl=http://repo.openeuler.org/openEuler-20.09/everything/$basearch/ enabled=1 gpgcheck=1 gpgkey=http://repo.openeuler.org/openEuler-20.09/everything/$basearch/RPM-GPG-KEY-openEuler [EPOL] name=EPOL baseurl=http://repo.openeuler.org/openEuler-20.09/EPOL/$basearch/ enabled=1 gpgcheck=1 gpgkey=http://repo.openeuler.org/openEuler-20.09/EPOL/$basearch/RPM-GPG-KEY-openEuler [debuginfo] name=debuginfo baseurl=http://repo.openeuler.org/openEuler-20.09/debuginfo/$basearch/ enabled=1 gpgcheck=1 gpgkey=http://repo.openeuler.org/openEuler-20.09/debuginfo/$basearch/RPM-GPG-KEY-openEuler [source] name=source baseurl=http://repo.openeuler.org/openEuler-20.09/source/ enabled=1 gpgcheck=1 gpgkey=http://repo.openeuler.org/openEuler-20.09/source/RPM-GPG-KEY-openEuler [Xfce] name=Xfce baseurl=https://eulixos.com/repo/others/openeuler-raspberrypi/pkgs/ enabled=1 gpgcheck=0 ``` - List of repo's baseurls: `"http://repo.openeuler.org/openEuler-20.03-LTS/OS/aarch64/ http://repo.openeuler.org/openEuler-20.03-LTS/EPOL/aarch64/ http://repo.openeuler.org/openEuler-20.03-LTS/source"` or `"http://repo.openeuler.org/openEuler-20.09/everything/aarch64/ http://repo.openeuler.org/openEuler-20.09/EPOL/aarch64/ https://eulixos.com/repo/others/openeuler-raspberrypi/pkgs/"` 6. -s, --spec SPEC Specify the image version: - `headless`, image without desktop environments. - `xfce`, image with Xfce desktop environment and related softwares including CJK fonts and IME. - `ukui`, image with UKUI desktop environment and fundamental softwares without CJK fonts and IME. - `dde`, image with DDE desktop environment and fundamental softwares without CJK fonts and IME. - The file path of rpmlist, the file contains a list of the software to be installed in the image, refer to [rpmlist](./scripts/config-common/rpmlist) for details. The default is `headless`. 7. --cores N The number of parallel compilations, according to the actual number of CPU of the host running the script. The default is the number of processing units available. ##### Build in a Docker container Run the following command to build an image: `sudo bash build-image-docker.sh -d DOCKER_FILE -n IMAGE_NAME -k KERNEL_URL -b KERNEL_BRANCH -c KERNEL_DEFCONFIG -r REPO --cores N` After building the image, you can find the image in `raspi_output_common/img/` of the directory in which the script resides. Caution, before running the script, you need to install Docker. The script will automatically import the Docker image into the local system according to the script's parameter: DOCKER_FILE. In addition to the parameter DOCKER_FILE, the other parameters are the same as the corresponding parameters in [Build on host](#Build-on-host): 1. -d, --docker DOCKER_FILE The URL/path of the Docker image, which defaults to `https://repo.openeuler.org/openEuler-20.03-LTS-SP1/docker_img/aarch64/openEuler-docker.aarch64.tar.xz`. With the default parameter, the script will automatically download the Docker image of openEuler 20.03 LTS SP1 and import it into the local system.