Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

Custom_table_size_100

PetaLinux is brand name used by Xilinx, it is based on Yocto and pretty decent mainstream kernel, what Petalinux adds is the HSI (Hardware Software Interface from Vivado) and special tools for boot image creation.

...

Excerpt

Petalinux Project Creation- Short HOWTO

Getting Linux working on Zynq is very simple, following steps are required

  1. Vivado/SDK/PetaLinux 20xx.x installed (important do not mix versions!)
  2. Create Vivado Project, configure PS, Export HDF (XSA for 19.2 and newer)
  3. Ceate new PetaLinux project
  4. Import HDF(XSA for 19.2 and newer) into project
  5. petalinux-build
  6. copy boot.bin and image.ub to SD Card (only 2 files no more)

This is generic how-to, everything is setup for your by the Vivado->PetaLinux flow. Note, the boot.bin generated by PetaLinux may not always work, in such case it is recommended to make the boot.bin with SDK-GUI or command line tools manually.

There is no need to install anything else, or to fetch anything from any github repos, etc.

PetaLinux 2020.2

PetaLinux Installation

  • (optional) Create new VM with supported Linux OS.

    • Attention: Use English as OS language for your Linux System (Keyboard language can be any language). Other languages may cause errors on PetaLinux build process.

      • with OracleVM:

        • VM Setup:

          • RAM: >= 8GB

          • CPU:  >= 4

          • HDD: 200GB dynanically

            • ubuntu-18.04-desktop-amd64.iso

            • install vm guest additions

            • update to 18.04.5 was done

          • Network: network bridge

          • optional: add shared folder, enable drag and drop


        • Info
          titleAlternative to Oracle VM

          Xilinx Tools and Win10 WSL


  • Download PetaLinux  from Xilinx Website: http://www.xilinx.com/support/download/index.html/content/xilinx/en/downloadNav/embedded-design-tools.html

    • Choose  a PetaLinux Version, that's corresponding to the installed Vivado and SDK Version.

      • Example: Use Vitis (SDK+Vivado) 2020.2 with PetaLinux 2020.2

  • Use UG1144 "PetaLinux Tools Documentation - Reference Guide" that's corresponding with your PetaLinux Version

    1. Use bash as terminal:

      1. $ sudo dpkg-reconfigure dash 

        1. → press no

    2. Check "PetaLinux Tools Installation Requirements" chapter and install missing tool/libraries

      1.  https://www.xilinx.com/support/answers/73296.html

        1. download plnx-env-setup.sh and run

      2. $ sudo apt-get update

      3. $ sudo apt-get install iproute2 gawk python3 python build-essential gcc git make net-tools libncurses5-dev tftpd zlib1g-dev libssl-dev flex bison libselinux1 gnupg wget git-core diffstat chrpath socat xterm autoconf libtool tar unzip texinfo zlib1g-dev gcc-multilib automake zlib1g:i386 screen pax gzip cpio python3-pip python3-pexpect xz-utils debianutils iputils-ping python3-git python3-jinja2 libegl1-mesa libsdl1.2-dev pylint3 -y

        1. This is necessary because lnx-env-setup.sh seems to be not install all packages correctly
    3. Install petalinux (Note: do not start from shared folder, copy installer into home directory)

      1. $ mkdir -p ~/petalinux/2020.2

      2. copy  petalinux-v2020.2-final-installer.run into ~/petalinux/2020.2
      3. $ ./petalinux-v2020.2-final-installer.run

    4. source enviroment

      1. $ source ~/petalinux/2020.2/settings.sh

    5. Deactivate Webtalk:

      1. $ petalinux-util --webtalk off

  • Note:

    • There is no need to install anything else, or to fetch anything from any github repos, etc.

    • It is recommended to test the installation by creating a dummy template project and building it.

      • Download one of the BSP Examples from Xilinx Website (Only to test your installation)

      • Install:$ petalinux-create -t project -s <path-to-bsp>

      • Build: $ petalinux-build

Creating a Project from Vivado Project

Info

Some reference designs contains a preconfigured PetaLinux project as template. This can be used instead of creating a new project described on step two2.

Basic Note to TE Petalinux Templates, see: PetaLinux TE-Template#Template-PetaLinux2019Template#PetaLinux2020.2

  • PetaLinux Working Environment (see UG1144)
    • PetaLinux Tools Installation is completed.
    • (Note: do not create project from shared folder, use home directory)
    • "/bin/sh" is bash

    • Set Working Environment:
      • $ source <path-to-installed-PetaLinux>/settings.sh
  • (optional to create project from scretch instead of Trenz Templates) Create a New Project (see UG1144): 
    1. $ petalinux-create --type project --template <CPU_TYPE> --name <PROJECT_NAME>

      • <CPU_TYPE>: zynqMP, zynq, microblaze
      • <PROJECT_NAME>:The name of the project you are building
  • Import Hardware Configuration (see UG1144):
    • Export Hardware Definition File (*.xsa) from the Vivado Project into the PetaLinux root folder "<plnx-proj-root>":
      • change to PetaLinux root folder:
      • Run:$ petalinux-config --get-hw-description
  • (optional) Configure your PetaLinux:

    New with 2020.2:


    1. PetaLinux Working Environment (see UG1144)
      • PetaLinux Tools Installation is completed.
      • (Note: do not create project from shared folder, use home directory)
      • "/bin/sh" is bash

      • Set Working Environment:
        • $ source <path-to-installed-PetaLinux>/settings.sh
    2. (optional to create project from scretch instead of Trenz Templates) Create a New Project (see UG1144): 
      1. $ petalinux-create --type project --template <CPU_TYPE> --name <PROJECT_NAME>

        • <CPU_TYPE>: zynqMP, zynq, microblaze
        • <PROJECT_NAME>:The name of the project you are building
    3. Import Hardware Configuration (see UG1144):
      • Export Hardware Definition File (*.xsa) from the Vivado Project into the PetaLinux root folder "<plnx-proj-root>":
        • change to PetaLinux root folder:
        • Run:$ petalinux-config --get-hw-description
    4. (optional) Configure your PetaLinux:
      • While anywhere in the project folder tree:
      • Run:$ petalinux-config
      • Run:$ petalinux-config -c u-boot
      • Run:$ petalinux-config -c kernel
      • Run:$ petalinux-config -c rootfs
    5. Build System Image (see UG1144):
      • While anywhere in the project folder tree:
      • Run:$ petalinux-build
    6. Take u-boot.elf,  image.ub,  bl31.elf (ZynqMP only) from "<plnx-proj-root>/images/linux" for BOOT.BIN generation, also boot.scr is used (put separate on SD or include into Boot.bin for QSPI boot only).  It is recommended to create the FSBL and PMU Firmware (ZynqMP only) with Vitis tools.

    Petalinux Configuration

    Most settings can be changed with menu-config*:

  • While anywhere in the project folder tree:
  • Run:$ petalinux-config
  • Run:$
    • petalinux-config
    • petalinux-config -c u-boot
    Run:$
    • petalinux-config -c kernel
    Run:
    • $  petalinux-config -c rootfs
  • Build System Image (see UG1144):
    • While anywhere in the project folder tree:
    • Run:$ petalinux-build
  • * with 2020.2 kernel and u-boot changes must be exported to the user-layer with petalinux-devtool command.

    Manual changes can be done in the subfolder

    Take u-boot.elf,  image.ub,  bl31.elf (ZynqMP only) from 

    "<plnx-proj-root>

    /images/linux" for BOOT.BIN generation.  It is recommended to create the FSBL and PMU Firmware (ZynqMP only) with Vitis tools.

    /project-spec/meta-user/"

    CONFIG
    • project-spec/config/config
    • changes with "petalinux-config" will be saved here
    U-Boot
    • recipes-bsp/u-boot/files
    • recipes-bsp/u-boot/files/platform-top.h
    • changes with "petalinux-config -c u-boot" will be add in the yocto workspace 
    • force changes to the user layer run  "petalinux-devtool finish u-boot-xlnx ${PWD}

    Petalinux Configuration

    Most settings can be changed with menu-config:

    • petalinux-config
    • petalinux-config -c u-boot
    • petalinux-config -c kernel
    • $  petalinux-config -c rootfs
    Manual changes can be done in the subfolder "<plnx-proj-root>
    • /project-spec/meta-user/
    "
    changes kernel" will be add here automatically
    • -f"
    • optional overwrite, add UBoot settings on
    U-Boot
    • recipes-bsp/u-boot/files/ platform-top.h
    overwrite, add UBoot settings
    Device Tree
    • recipes-bsp/device-tree/files/system-user.dtsi
    • recipes-bsp/device-tree/files/pl-custom.dtsi
    • overwrite
    ,
    • or add device tree attributes
    Kernel
    • recipes-kernel/linux/linux-xlnx/
    • changes with "petalinux-config -c kernel" will be add in the yocto workspace 
    • force changes to the user layer run  "petalinux-devtool finish linux-xlnx ${PWD}/project-spec/meta-user/ -f"
    Apps
    • project-spec/meta-user/recipes-apps
    • add simple new app with "petalinux-create -t apps -n myapp --enable"
    • enable/disable
    Kernel
    • recipes-kernel/linux/linux-xlnx/
    • with "petalinux-config -c
    • rootfs"
    ROOTFS
    • project-spec/config/rootfs_config
    Apps
    • project-spec/meta-user/recipesconf/user-appsrootfsconfig
    add simple new app with
    • "petalinux-
    create -t apps -n myapp --enable"enable/disable with "petalinux-config -c rootfs"
    • config -c rootfs" will save changes in the general config spec, only apps will be saved in user-rootfsconfig also
    • user-rootfsconfig must be changed manually and will read after rootfs_config is used
    Xilinx  generated configuration
    • project-spec/config/
    Note: config and rootfs_config are shared at the moment, they include user and xilinx default changes from XSA import


    Additional Descriptions

    Children Display

    References

    1. PetaLinux Tools Documentation - Reference Guide (UG1144)
    2. PetaLinux Tools Documentation - PetaLinux Command Line Reference (UG1157)

    3. https://www.devicetree.org/
      1. https://www.devicetree.org/specifications/
    4. https://github.com/Xilinx/linux-xlnx/tree/master/Documentation/devicetree/bindings

    ...

    1. PetaLinux Working Environment (see UG1144)
      • PetaLinux Tools Installation is completed.
      • "/bin/sh" is bash

      • Set Working Environment:
        • $ source <path-to-installed-PetaLinux>/settings.sh
    2. Create a New Project (see UG1144):
      • $ petalinux-create --type project --template <CPU_TYPE> --name <PROJECT_NAME>

        • <CPU_TYPE>: zynqMP, zynq, microblaze
        • <PROJECT_NAME>:The name of the project you are building
    3. Import Hardware Configuration (see UG1144):
      • Export Hardware Definition File (*.hdf) from the Vivado Project into the PetaLinux root folder "<plnx-proj-root>":
        • change to PetaLinux root folder:
        • Run:$ petalinux-config --get-hw-description
    4. (optional) Configure your PetaLinux:
      • While anywhere in the project folder tree:
      • Run:$ petalinux-config
      • Run:$ petalinux-config -c kernel
      • Run:$ petalinux-config -c rootfs
    5. Build System Image (see UG1144):
      • While anywhere in the project folder tree:
      • Run:$ petalinux-build
    6. Take u-boot.elf,  image.ub,  bl31.elf (ZynqMP only) from "<plnx-proj-root>/images/linux" and make BOOT.BIN.  It is recommended to create the FSBL and PMU Firmware (ZynqMP only) with SDK/HSI tools.
    7. Note: uboot need also boot.scr from the  "<plnx-proj-root>/images/linux" folder. This can be put on SD card or must be included into Boot.bin for QSPI boot without SD usage.

    Petalinux Configuration

    Most settings can be changed with menu-config ($ petalinux-config, petalinux-config -c kernel, petalinux-config -c rootfs).

    ...