Blog Image


About the blog

In this blog I will keep track of projects I develop though out this year and may be in the future. For now it is juts a testing ground for developing the blog itself but I hope as I put more material it will become a good place for me to hold information.

Good links for FreeRTOS

AWS FreeRTOS, Digital Electronics Posted on 04 Mar, 2021 07:53:50

Not great but some explanation about AWS

Insatlling USB JTAG drivers for Zedboard

Digital Electronics Posted on 29 Aug, 2018 21:17:02

To install the drivers for the zedboard jtag in ubuntu do as follow;

Fist download the following zip file.

In this zip there are two deb files and a folder.

-: sudo dpkg -i digilent.adept.runtime_2.18.3-amd64.deb
-: sudo dpkg -i digilent.adept.utilities_2.2.1-amd64.deb

Then go into the folder and run: sudo ./

Now running: djtgcfg -v should output:

Digilent JTAG Config Utility v2.2.1
Copyright (C) 2010 Digilent, Inc.

and running: djtgcfg enum Should output:

Found 1 device(s)

Device: Zed
Product Name: Digilent Zed
User Name: Zed

If that is the case all is good and vivado should detect your board.


Basic petalinux for zedboard

Digital Electronics Posted on 24 Feb, 2018 22:06:08

In this article I am going to keep track of how to make a Linux distribution with PetaLinux to run in the Zedboard.
I will run Vivado and PetaLinux in Ubuntu 16.04 LTS. This should also work in other distributions but dependencies may defer between them.

First I download the necessary programs from Xilinx. I will use Vivado 2017.4 and PetaLinux 2017.4. I downloaded them from this LINK.
While they download I also installed the following packages which PetaLinux depend on:

  • tofrodos
  • iproute
  • gawk
  • build-essentail
  • git-core
  • make
  • net-tools
  • libncurses5-dev
  • tftpd*
  • zlib1g-dev
  • flex
  • bison
  • lib32z1
  • lib32ncurses5
  • lib32stdc++6
  • libselinux1

This can be installed from the command line by running the apt-get install command follow by all the packages as named in the list above.
Once Vivado and PetaLinux are downloaded Install them in the desire directory and then we will continue by first opening Vivado and creating the basic hardware description to be able to run our Linux operating system on the ZedBoard.

The only component that is needed is the SYNQ7 Processing system. Create a new project in Vivado and make sure you tell the software we are going to use the ZedBoard. Then introduce the ZYNQ7 processing system on the block design and then connect the FCLK_CLK0 to the M_AXI_GP0_ACLK and finally auto configure by pressing the highlighted text on the top of the diagram designing area. Then press F6 to validate the design and crate the wrapper by right clicking on the design source on the source control area. Then generate the bitstream and to finalize export the hardware (File->Export->Export Hardware). When asked, make sure to select to export with bitstream. At this point the Vivado software can be closed as we are finished with it.

From now-on, everything will be done from the terminal. Open a terminal window (Ctrl+Alt+t). To make sure that we can call the petalinux commands from anywhere we need to run the following command:

  • source (path to petalinux)/

Now you need to create a petalinux project to do this go to the directory where you would like to create the petalinux project (this will create a directory) and run the following command:

  • petalinux-create –type project –template zynq –name (project name)

Make sure to change (project name) with the name you want to give the project. This will create a directory with this name. I will refer to this directory as the petalinux root directory.
Next we will configure the petalinux to be build. We need to enter the petalinux root directory and run the following command:

  • petalinux-config –get-hw-description=(path to sdk)

The (path to sdk) needs to be the path to the directory where we exported the hardware from Vivado. Normally this is the same as the project name ended with a “.sdk”.

This will open a semi graphical interface on the terminal where we can configure the linux distribution we what to run. For this project all we need to do is go into Subsystem AUTO Hardware Settings, then Advance bootable images storage Settings and once there we need to set boot image settings, kernel image settings and dtb image settings to Primary sd.
Then we go into Image Packaging Configuration and set root filesystem type to sd card.
After that we exit the semi-graphical interface saving changes and the configuration should be done.
At this point the build of the linux booting system can be done by running the command:

  • petalinux-build

Then the booting files can be made with:

  • petalinux-package –boot –format BIN –force –fsbl images/linux/zynq_fsbl.elf –fpga images/linux/(bit file) –uboot

The bit file has to be changed with the .bit file in the folder ./images/linux/.
At this point the content in the /images/linux/ folder can be copied to the boot partition of the sd card.
Now we have to download the rootfs files for Ubuntu, this can be downloaded from:


It can also be done with the folowing command:

  • wget -c

Then extract the content with:

  • tar xf ubuntu-16.04.2-minimal-armhf-2017-06-18.tar.xz

And copy the content to the SD card rootfs mounted point:

  • sudo tar xfvp ./*-*-*-armhf-*/armhf-rootfs-*.tar -C /media/rootfs/

Follow by:

  • sync

  • sudo chown root:root /media/rootfs/

  • sudo chmod 755 /media/rootfs/

The path to the rootfs mounted point may be deferent in your system.
At this point you can unmount the SD card and use it to boot the Ubuntu system on the zedboard. Connect the usb serial port of the zedboard to your pc and use a software such as Putty to connect to the zedboard from your PC. Use a bauderate of 115200.

  • Username: ubuntu

  • Password: temppwd

Enjoy petalinux in Xilinx zynq devices.