Problem in generating binary for DFU Topic is solved

Technical questions regarding the XTC tools and programming with XMOS.
arun.v@emqos.com
Member
Posts: 9
Joined: Wed Dec 04, 2024 9:30 am

Problem in generating binary for DFU

Post by arun.v@emqos.com »

Hello Xmos team:
I am working on Firmware upgrade feature for xmos. When I create a binary for flashing using xobjdump, using the command like "xobjdump --strip mybin.xe"
(a) I get a file 277440 bytes
(b) binary upgrade using the file does not work

So i flashed the build(.xe file) to xmos, and then i copied the file out to try binary flashing. I notice the file size is 280608 bytes and I am able to perform firmware update sucessfully.

I not sharing the binary files, with this post, here as it is a public forum. If anyone from xmos side want to take a look at binary files, please send an email to arun.v@emqos.com

Please provide me the correct way to generate binary file for firmware upgrade.

Regards,
Arun
View Solution
User avatar
fabriceo
Respected Member
Posts: 279
Joined: Mon Jan 08, 2018 4:14 pm

Post by fabriceo »

Hi !
you should have a look in detail on the recent AN02019 here
it describe how this works and the good command line to generate the image (it also depends on your tools version...)

hope this helps
fabriceo
arun.v@emqos.com
Member
Posts: 9
Joined: Wed Dec 04, 2024 9:30 am

Post by arun.v@emqos.com »

Hi fabriceo:
It is not clear to me how to generate the image in command line. I use 15.2.1 version the tool. Can you please provide me exact instructions on how to generate the firmware for dfu

Regards
Arun
User avatar
fabriceo
Respected Member
Posts: 279
Joined: Mon Jan 08, 2018 4:14 pm

Post by fabriceo »

Hi Arun,

assuming you have a working program written in the flash memory as a factory image and also containing a DFU interface recognized on USB, then you can program another upgrade image with a DFU utility like xmosdfu or dfuutil.
The binary file must be generated with the xflash utility and the --upgrade option.
It is important to have the --factory-version option with value aligned with the version of the tools that has been used to generate and flash the factory image, most likely 15.2 in your case. So the command should be:

xflash --factory-version 15.2 --upgrade 1 yourprogram.xe -o yourimage.bin

hope this helps
fabriceo
arun.v@emqos.com
Member
Posts: 9
Joined: Wed Dec 04, 2024 9:30 am

Post by arun.v@emqos.com »

Let me explain the scenario in little bit detail. Our product doesnt have usb port connected to xmos. We have an MSP chip (TI Arm chip), which has connected to modem for external computation. XMOS connects to MSP chip, via a shared flash and uart(for exchanging commands)
The way firmware upgrade works is MSP checks for new firmware in a FTP server, downloads them into shared flash when available. Further after downloading xmos is activated. xmos checks for new firmware in shared flash and upgrades itself.
The question is how to generate the firmware image for download and upgrade.
One of the earlier instruction provided by Andrew(from XMOS) was to use a command like xobjdump --strip mybin.xe to generate firmware file, which could be used. But it doesnt work.
However, when i flash the xmos with an image in factory image (not dfu), and that when i copied out to share flash and then upload it the ftp server, i could use that image successfully for Firmware upgrade. Currently, the only option i have is to flash the image in xmos, and upload it to ftp server, in the way described earlier. My hope is i will be able to write a command in my PC where XMOS drivers are installed and it will generate the binary file from .xe file. I hope this is clear and you will be able to provide a solution.
User avatar
andrewxcav
Verified
Experienced Member
Posts: 88
Joined: Wed Feb 17, 2016 5:10 pm

Post by andrewxcav »

Hi Arun,

I think you want to use xflash with the --outfile option:

https://www.xmos.com/documentation/XM-0 ... sh-outfile

For more details on the .xe file format:

https://www.xmos.com/documentation/XM-0 ... cture.html

Cheers,
-Andrew
arun.v@emqos.com
Member
Posts: 9
Joined: Wed Dec 04, 2024 9:30 am

Post by arun.v@emqos.com »

Hello Andrew/Xmos team:

I created binary image using xflash --factory example_freertos_explorer_board.xe -o XMOS_arun_4.bin

(1) The binary is not working for DFU
(2) The binary has different size than the one uploaded from bollard (and contents also different)

Regards
Arun
User avatar
andrewxcav
Verified
Experienced Member
Posts: 88
Joined: Wed Feb 17, 2016 5:10 pm

Post by andrewxcav »

Try this:

xflash --noinq --factory-version 15.2 --upgrade [UPGRADE_VERSION] [UPGRADE_EXECUTABLE] -o [OUTPUT_BINARY]

For upgrade version just put a version number that is higher than any previous upgrade versions.
Marf
Member
Posts: 8
Joined: Sat Nov 25, 2023 4:10 pm

Post by Marf »

Hi dear XMOS team.

I'm having similar problems. Using XTC Tools 15.3.0 on Win 11 and usb_audio 9.0.0. I ported all my code to the new version and can sucessfully compile, flash and run my factory firmware on my prototype hardware. Now I try the dfu upgrade process. I followed the instructions in the AN2019_1_0_0 sample to compile a factory and an upgrade version (with different -DBCD_DEVICE). Converting the upgrade file to binary also results in a very small file (64kB instead of 2.3MB. Is that normal? Is that a differential upgrade only?)
I try to update using this file via DFU using the TUSBAudio Firmware Upgrade Tool (from the v5.58 driver installation package as it is not included in the newer v5.72 package (why?)). I can select everything and the process starts but gets stuck with the prgress bar at about 10%. After a long time it shows me an error message "TUSBAUDIO_GetDfuStatus: function failed with error 0xEE000003."

My Questions are:
1. Why is the actual TUSB update utility not included anymore in the latest driver version?
2. Is it normal, that the binary is that small? I havent changed much in the source for the upgrade version, so delty could by plausible)
3. I wanted to try a different way but also can't find the xmosdfu in the current version of lib_xua or on the website. What alternatives can I try?

Please help me here as the release date of my product comes closer and I need to be sure to have an upgradeable firmware installed and a validated upgrade process for my clients.

Thanks a lot in advance and best regards...
User avatar
andrewxcav
Verified
Experienced Member
Posts: 88
Joined: Wed Feb 17, 2016 5:10 pm

Post by andrewxcav »

1. I believe the TUSB has been spun out of the driver in order to support composite USB devices, and not just UAC2.0 devices.
2. The binary looks plausible. A .xe file has extra data in it like the XN file, debug symbols, etc. the binary is literally just the bytes that will get written to SRAM on boot.
3. Can you file a support ticket for xmosdfu?

Cheers,
-Andrew