Building the MitySOM-5CSX
Added by John Iannuzzi about 1 month ago
Hi,
I have been going thru the build sequence with the makefile and got the following error:
software/preloader/u-boot-socfpga/arch/arm/mach-socfpga/cv_bsp_generator/cv_bsp_generator.py -i hps_isw_handoff/dev_5cs_hps_0 -o software/preloader/u-boot-socfpga/board/cl/mitysom-5cs/qts
/usr/bin/env: ‘python’: No such file or directory
make: *** [Makefile:596: u-boot-socfpga/u-boot-with-spl.sfp] Error 127
I believe this is because its looking for python 2. The original version of the cv_bsp_generator.py script was written in python2 (right from Rocketboards). They never updated it to python3. I found this out a few months ago after pulling my hair out.
Anyway, do you folks have a fix or should I just do the conversion myself? If there is a fix in place already, I would rather use that to keep aligned with your stuff.
Thanks,
John
Replies (18)
RE: Building the MitySOM-5CSX - Added by Seth Graber about 1 month ago
Hi John,
The scripts appears to work fine with python3, below is the output of me running the command manually with python3:
$ python3 software/preloader/u-boot-socfpga/arch/arm/mach-socfpga/cv_bsp_generator/cv_bsp_generator.py -i hps_isw_handoff/dev_5cs_hps_0 -o software/preloader/u-boot-socfpga/board/cl/mitysom-5cs/qts /home/sgraber/work/projects/mitysom-5csx-ref/dev_5cse_l2_3y8/software/preloader/u-boot-socfpga/arch/arm/mach-socfpga/cv_bsp_generator/emif.py:91: SyntaxWarning: invalid escape sequence '\w' if re.match("^#define (\w+_)", line): /home/sgraber/work/projects/mitysom-5csx-ref/dev_5cse_l2_3y8/software/preloader/u-boot-socfpga/arch/arm/mach-socfpga/cv_bsp_generator/emif.py:101: SyntaxWarning: invalid escape sequence '\[' if re.match("^const.*\[", line) or arrayMatchStart: /home/sgraber/work/projects/mitysom-5csx-ref/dev_5cse_l2_3y8/software/preloader/u-boot-socfpga/arch/arm/mach-socfpga/cv_bsp_generator/emif.py:110: SyntaxWarning: invalid escape sequence '\[' self.seqAutoAcTemplateList.append(re.sub("\[.*\]", "[]", line)) /home/sgraber/work/projects/mitysom-5csx-ref/dev_5cse_l2_3y8/software/preloader/u-boot-socfpga/arch/arm/mach-socfpga/cv_bsp_generator/emif.py:116: SyntaxWarning: invalid escape sequence '\[' if re.match("^const.*\[", line) or arrayMatchStart: /home/sgraber/work/projects/mitysom-5csx-ref/dev_5cse_l2_3y8/software/preloader/u-boot-socfpga/arch/arm/mach-socfpga/cv_bsp_generator/emif.py:125: SyntaxWarning: invalid escape sequence '\[' self.seqAutoInstTemplateList.append(re.sub("\[.*\]", "[]", line)) /home/sgraber/work/projects/mitysom-5csx-ref/dev_5cse_l2_3y8/software/preloader/u-boot-socfpga/arch/arm/mach-socfpga/cv_bsp_generator/hps.py:370: SyntaxWarning: invalid escape sequence '\w' p = re.compile('^(\w+)\s+(\w+)$') Generating file: software/preloader/u-boot-socfpga/board/cl/mitysom-5cs/qts/sdram_config.h... Generating file: software/preloader/u-boot-socfpga/board/cl/mitysom-5cs/qts/pinmux_config.h... Generating file: software/preloader/u-boot-socfpga/board/cl/mitysom-5cs/qts/pll_config.h Reading file: hps_isw_handoff/dev_5cs_hps_0/dev_5cs_hps_0.hiof... Generating file: software/preloader/u-boot-socfpga/board/cl/mitysom-5cs/qts/iocsr_config.h...
The Makefile is looking for the PYTHON environment variable to be set up by your system. For example, on my Ubuntu 24.04 this is not set by default. Running export PYTHON=python3
before using the Makefile should resolve your issue.
- Seth
RE: Building the MitySOM-5CSX - Added by John Iannuzzi about 1 month ago
Hi Seth,
Thanks. I’ll give it a shot later on.
Best regards,
John
RE: Building the MitySOM-5CSX - Added by John Iannuzzi 21 days ago
Hi Seth,
Thanks, I got u-boot to build. At this point, I have a basic question: If I continue to follow thru the guide for Quartus 23.1, going thru all the steps and build the SD card, what will I have?, i.e. At the end of all this, will I have manually built the stock version of the SD card that was supplied with the dev kit?
Over the last year, I have been lead thru endless tutorials (mostly from rocketboards) only to end up at dead ends...very frustrating. This was the subject of a conversation I had with Tom C. and what has lead me to the Critical Link Dev board. I am looking to have a reference design that I have gone thru all of the steps to build, study it, and use it as a spring board for other projects.
Can you please comment on this?
Thank you for your help on this.
Best regards,
John
RE: Building the MitySOM-5CSX - Added by Seth Graber 21 days ago
Hi John,
You're welcome, glad to hear you were able to get u-boot to build. If you continue following our Getting Started Guides for the Quartus 23.1 project, then yes, you will end up having manually built the SD card supplied with the dev kit. The goal of these guides is to set you up with the knowledge and tools to get started and then branch out into your own projects, just as you said. We hope they will be a great resource for you and of course we are here to answer any questions and help along the way. The standard build flow would be to build the FPGA, build u-boot, build the filesystem with Yocto, and then build the SD card image. If you have any further questions feel free to let us know and myself or someone else will get back to you as soon as possible.
All the best, Seth
RE: Building the MitySOM-5CSX - Added by John Iannuzzi 15 days ago
Hi Seth,
As mentioned, I have been able to build uboot. I am now studying the steps to build the file system with Yocto. It appears that there a quite a few steps here and, as usual, with Linux, opens the flood gates for mistakes.
So quite simply, is there a pre-built version of the file system that I can simply load onto the sd card and then use the newly built version of my uboot to test it with before I go down the path of building my own?
Thanks again for your support.
Best regards,
John
RE: Building the MitySOM-5CSX - Added by Michael Williamson 15 days ago
Hi John,
On the main wiki landing page, https://support.criticallink.com/redmine/projects/mityarm-5cs/wiki, there are links for full SD pre-built SD cards (which include images of the reference filesystems) as well as a tar-ball of the file system that should boot (in the "universal" table).
With regards,
Mike
RE: Building the MitySOM-5CSX - Added by John Iannuzzi 12 days ago
Ok, Thanks, I'll look into it.
Just so you know, I am quite the novice with this, so, I ask that you please be patient with me if I ask very basic questions.
RE: Building the MitySOM-5CSX - Added by John Iannuzzi 9 days ago
I am using:
Quartus prime 23.1
Ubuntu 24.04.2 LTS ( I noted that this was tested on Ubuntu 22.04...)
1. I went to the page recommended above and downloaded "mitysom-image-base-mitysom-c5.tar.gz"
2. Did some exploring and found, https://support.criticallink.com/redmine/projects/mityarm-5cs/wiki/Building_sd_231, Building the SD card...
Read thru the page and figured that I could just use this tarball so I don't have to build the whole thing myself with Yocto.
Is this ok to do?
3. Installed the prerequisites, sudo apt-get install libguestfs-tools, and
sudo chmod a+r /boot/vmlinuz*
4. Copied the tarball to ...dev_5csx_h6_42a/software/preloader folder
Entered the command to run the script, nios2_command_shell.sh (why do I need this if I am in the embedded command shell?)
5. Went back to the, mitysom-5csx-ref/dev_5csx_h6_42a folder so I could run the "make sd_card" command
6. executed make sd_image...It rebuilt the entire project (why? It was already built.) and then failed at uboot (like the 2nd post above)
I had to re=export the environment variable, export PYTHON=python3, to get uboot to build again with "make uboot".
It seems that I'm back to where I started.
Sorry for the fire hose of info...where am I going wrong?
Thanks,
John
RE: Building the MitySOM-5CSX - Added by Seth Graber 8 days ago
Hi John,
I appreciate all the info, no need to be sorry whatsoever! I'll go ahead and try and answer your questions and concerns below.
Read thru the page and figured that I could just use this tarball so I don't have to build the whole thing myself with Yocto. Is this ok to do?
Yes, this is okay to do. This is the same tarball we use to make the SD card images we make available here.
Entered the command to run the script, nios2_command_shell.sh (why do I need this if I am in the embedded command shell?)
The purpose of this script is to update your shell path so you can use Quartus tools from the command line. So, to answer your question, you should not need to do this if the Quartus tools have already been properly sourced in your shell environment (which you can check by runningenv
).
executed make sd_image...It rebuilt the entire project (why? It was already built.)
make sd_image
rebuilt the entire project because presumably there were no stamp files for the individual parts. The Makefile uses stamp files to determine what has already been built with it's other make targets (likemake u-boot
as you had done prior). If you open or touch any project files before runningmake sd_image
it may cause it to rebuild due to the stamp being update from the expected value. How was the project built previously? If you provide more details we might be able to help determine and explain why it rebuilt.
I had to re=export the environment variable, export PYTHON=python3, to get uboot to build again with "make uboot".
This is likely because the shell you're using does not have this in its path by default. Each time you open a new shell instance, you will need to export the PYTHON variable again. So, presumably you opened a new shell since last building u-boot which is why this issue resurfaced. To work around this, you could look into addingexport PYTHON=python3
to a configuration file like.bashrc
if you're using BASH.
If you need more clarity on anything or have further questions, please feel free to follow up and I or someone else will respond ASAP. Thank you!
All the best, Seth
RE: Building the MitySOM-5CSX - Added by John Iannuzzi 6 days ago
Hi. Taking a few steps back, I was comparing the instructions from
https://support.criticallink.com/redmine/projects/mityarm-5cs/wiki/Building_fpga_231 ,
https://support.criticallink.com/redmine/projects/mityarm-5cs/wiki/Building_uboot_231 and
a "readme" file contained in the directory of dev_5csx_h6_42a$.
Some of the steps don't seem to be in alignment or are mutually exclusive and it's hard
to tell between them...
Specifically:
make rbf and make uboot (web pages)
make generate_from_tcl , make all , and a comment to manually change the SOM_MODEL in the makefile (readme file)
FYI, I realize that you can't make an rbf if the project wasn't compiled generating a sof.
It seems that make generate_from_tcl is the same as re-building the Quartus project.
Can you offer some clarify? I did get it to work but only after playing around and reasoning thru it.
Thanks,
John
RE: Building the MitySOM-5CSX - Added by Mike Fiorenza 4 days ago
John,
For some background, we have a single Quartus reference design project we have setup for the Cyclone V platform. In order to make it easier for end users, we generate this project for every variant of the platform we have and the result of this is the mitysom-5csx-ref repo you have been looking at that has the generated projects in sub-directories (E.g. dev_5csx_h6_42a). Therefore, when you clone the repo and go into the dev_5csx_h6_42a you are in a directory already containing a "generated" Quartus reference for the dev_5csx_h6_42a platform. If you wanted to re-generate all of the project files, you could run "make generate_from_tcl". This command will generate all of the project files needed for the Quartus design. It does this using TCL scripts to generate the project files. You DO NOT need to run this command as it was already done for you. If you had made any changes to the design and then ran this command "make generate_from_tcl" it would regenerate the project files from our TCL scripts, essentially wiping your changes. To know which platform to generate the reference design project for, the scripts use the SOM_MODEL in the Makefile to determine how to generate the design. You DO NOT need to change this as the generated repository already has the SOM_MODELs structured into pre-generated sub folders.
To use our reference design, you should just need to clone our reference design repository, navigate into the correct platform sub-directory (E.g. dev_5csx_h6_42a) and run "make rbf" which compiles the design generating an SOF file which lastly gets converted into an RBF. And then generate the bootloader by running "make uboot". These two make commands are all you need to generate the FPGA binary (RBF) and bootloader (SPL/UBOOT). Lastly, you can combine all of the binaries into an SD card image using "make sd_image" or manually by following the instructions posted on our "Building SD" Wiki.
In summary:
make rbf - Compiles the reference design generating an SOF & RBF
make uboot - Compiles the bootloader SPL/UBOOT
make generate_from_tcl - Generates the reference design project from the TCL scripts (Doesn't compile anything)
make all - Same as running make uboot, which will trigger make rbf to run as well if it needs to
The README file in the subdirectory dev_5csx_h6_42a really pertains to our unified reference design (pre-generated). This should be updated or removed to avoid confusion for end-users.
- Mike
RE: Building the MitySOM-5CSX - Added by John Iannuzzi 4 days ago
Mike,
Thanks. Understood.
Regards,
John
RE: Building the MitySOM-5CSX - Added by John Iannuzzi 3 days ago
Hi, so I was able to make uboot and an sd card image. I took the image and loaded it to a blank sd card and powered up the board. I stopped it at the autoboot countdown.
Then I swapped out the sd card to the one that was provided in the kit and did the same thing. There's quite a difference. I have provided the outputs in the attached file.
Can you please comment on the differences? I re-read thru the instructions and am pretty sure I did everything in order.
Thanks,
John
RE: Building the MitySOM-5CSX - Added by Mike Fiorenza 2 days ago
John,
Taking a look at your output it appears like you successfully recompiled the SPL and UBOOT. The differences you are noticing are due to the SD card provided on the development kit having an older release of the software on it. You happened to follow our instructions on our wiki for our latest release.
If you wanted to compare your build versus our latest release, download the SD card from the landing page of the Wiki (pasted below) and then compare that output with the output from the SD card you created using your binaries. The output should look much similar to yours.
https://support.criticallink.com/redmine/projects/mityarm-5cs/wiki
- Mike
RE: Building the MitySOM-5CSX - Added by John Iannuzzi about 17 hours ago
Ok, so I downloaded the sd card from the website as instructed, and loaded it onto a fresh card.
I now have 3 different boot outputs. I have attached 3 files with the outputs of each boot screen.
I included the output of the originally provided sd card as a reference (even though it's an older image, but it works perfectly)
My expectation was that the directly downloaded image would work similarly. I also cannot access the 256M partition to write the .rbf. I actually thought it would be there similar to the image that I built.
It also appears that the image that I built from the instructions has many errors/warnings.
I don't see any zImage file either.
Where am I going wrong?
RE: Building the MitySOM-5CSX - Added by Seth Graber about 5 hours ago
Hi John,
Thank you for providing the 3 boot outputs. I've gone ahead and taken a look and I'll make some comments below.
My expectation was that the directly downloaded image would work similarly. I also cannot access the 256M partition to write the .rbf. I actually thought it would be there similar to the image that I built.
The directly downloaded image (for the 5CSX-H6-42A) should work similarly, you're correct. How did you go about copying it to the SD card? The step seen here covers how I did it and I am able to boot and see the .rbf file in the 256M partition if I mount it (I used sudo mount /dev/sdc1 /mnt and then ls /mnt to look for the rbf). The .rbf should be there as it's a part of the image. I would try and run the dd command again per the link I attached (ensure to umount prior and sync after as shown) and see if you're able to boot and see the .rbf and boot to the user space.
It also appears that the image that I built from the instructions has many errors/warnings. I don't see any zImage file either.
Based off your output log, the zImage should be present (you can check the 762M patitions /boot directory where it lives alongside the device trees). Line 48 of your output, "Kernel image @ 0x00a000 [ 0x000000 - 0x5263e8 ]", shows the image being loaded. The kernel should be handled in the filesystem tarball you used prior by the Makefile for the SD card image. Could you please provide more information on the Makefile command(s) and the order in which you ran them to generate the image that's causing this output? With some more detail I think we could get to the bottom of this, thank you!
All the best, Seth
RE: Building the MitySOM-5CSX - Added by John Iannuzzi about 1 hour ago
Hi Seth,
All I did was extract the image and dd it right to the sd card. I will read in more detail your comments when I get home tonight and give it another go over the weekend…I’m doing this on my own time.
Something funny though. Whenever I did this in the past with other sd cards (with dd as above) , it took a while for the command line to return to the prompt, and then I would type in sync and all was good. This downloaded sd card image returned to the prompt almost immediately (after dd) but I could see that the sd card reader was accessing (LED flashing) so I just waited for it to stop and then sync. Sync returned quickly also at least quickly enough for me to notice.
I this a clue for something?
Thanks,
John
RE: Building the MitySOM-5CSX - Added by Seth Graber about 1 hour ago
Hi John,
Thank you for the additional details. dd typically will take a moment to return the prompt, it does on my end as well.
If the command itself returned earlier than anticipated there's a good chance something went wrong. It's interesting the SD card reader continued to flash, perhaps the error that caused it to return never properly stopped communication with the SD card and it timed out in someway eventually. I would definitely give it another shot knowing this. As an additional note, tagging status=progress to the end of your dd call (like in the link I provided above, here, does) should give you a rough idea of the progress of the command. If you're already doing this then please disregard, but you should see the amount of data copied as it runs and it should give you more confidence if it succeeded or not. You should see it copy around 1GB of data before returning to the prompt, similar to below:
sgraber@pc216:~/Downloads/dev_5csx_h6_42a$ sudo dd if=sd_card.img of={insert proper output path here} status=progress [sudo] password for sgraber: 1067201024 bytes (1.1 GB, 1018 MiB) copied, 177 s, 6.0 MB/s 2097152+0 records in 2097152+0 records out 1073741824 bytes (1.1 GB, 1.0 GiB) copied, 182.885 s, 5.9 MB/s sgraber@pc216:~/Downloads/dev_5csx_h6_42a$ sync
Another note would be if you accidentally dd to a device that doesn't exist, Linux will create a file with that name and if you continue to try and dd to that same location it will instantaneously return, like what appeared to happen on your end. It could be worth running ls -l /dev/sd* (the sd* is assuming you tried to dd to a device with the sd plus a letter name) to ensure this didn't happen. If you'd like to attach your output from this we can take a look as well.
Hope this helps, please let us know how it goes and enjoy your weekend! If you have further questions, comments, or concerns please let us know and we'll get back to you ASAP.
All the best, Seth