-
Notifications
You must be signed in to change notification settings - Fork 27
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
"serial" issue in tinyfpga-programmer-gui.py #91
Comments
Can you give the output of pip list/freeze? If you are using the conda environment from quicklogic-fpga-toolchain, it may not install tinyfpgab/pyserial by default (I believe it's fixed in a more recent release). |
Thanks for ur response @jublin . I actually did a |
@AdityaPrakash23 you should be able to restart it. Usually, if I get a hang, it's before the erase/program stage. The erase only erases the m4 app sections of flash, so the bootloader will be intact |
@jublin thanks once again! But the qfprog command is getting stuck at the same place(the erasure command). Could u suggest what I probably could have done wrong in my setup or is there something else I could try out. Also my green LED stays solid after pulsing for a few seconds. Could that be an indicator for something being wrong with the TinyFPGA programmer? |
@coolbreeze413 is the maintainer of the TinyFPGA repo. They may have some insight. If you have a JLINK, you could try flashing all the files from https://github.com/QuickLogic-Corp/qf-initial-bins as if you were recovering a bricked device (or run bootloader from jlink and try m4 app only again) |
@coolbreeze413 , should I try to reprogram the board as mentioned by @jublin ? It would really save me time if I could avoid the hassle of getting a J-Link and using it. Any insight would be helpful since I am dealing with such a complex hardware after a very long gap. |
@AdityaPrakash23 The only time I have seen this kind of a problem was on a Ubuntu 18 machine which was weirdly resetting the USB connection midway - the host drivers were causing a problem, we could not track it down but a different Ubuntu installation worked ok on the same system. Also, you should not be having to use sudo to install pyserial, the python installation may be owned/created by root perhaps? I would suggest to try this method in a separate directory: I recommend to follow the automated setup process first: If you face any issues, we can walk through the manual setup steps(which is basically the same as in the envsetup script) Please let us know which OS and version you are running on, in case you still see issues. |
@AdityaPrakash23 I missed reading this carefully - the green led stops pulsing after a few seconds was exactly the behavior we saw in the one Ubuntu 18 system with the host usb driver problem. If you have access to another Ubuntu system where you could try the setup, it would be great! Once the quickfeather board is in flashing mode (green light pulsing starts with USR button press) Wait for a few seconds without flashing or doing anything, check if the green LED stop blinking after around 10 seconds. Again, check if you still see the USB port in the |
@coolbreeze413 thanks for ur detailed response. I am infact using Ubuntu 18.04. As per ur last response, I set the board in programmer mode and the green Led blinks for around 7-8 seconds and then goes solid green. I check the lsusb command and I do get the message |
@AdityaPrakash23 to confirm, the OpenMoko device is still present in lsusb after the led blinking stops? We have seen the LED blinking stop, not go solid green as far as I remember, let me confirm that though. Maybe you could try hooking up a USB Hub if you have one and then try it out - am not sure if it will work, but worth a try. You could use the Windows 10 WSL2, which should be the same thing as a native Ubuntu installation. (Windows native is not supported because the FPGA toolchain does not really run there yet, though m4 code build, and flash definitely work.) |
@coolbreeze413 Yes, the LED blinking stops and still lsusb shows the openmako device entry. After my disasterous experiments yesterday, whenever I opened the serial port, I was only getting garbage(automaticaly). I just managed to reflash the helloworld program and thankfully it's working properly again both in Windows and Ubuntu 18.04. Thanks a lot @jublin for sharing the initial-bins link! I did the experiment u mentioned with a CP2102 module I got with the Quickfeather board. Here is the output from reset to the green led stopping it's blinking action. |
@AdityaPrakash23 How were you able to reflash the helloworld program using the initial-bins? My understanding was that you were not able to flash the board at all, was it from a different PC? The UART output above does not show any problems as such, so doesnt seem to be any problem with the tool, or the bootloader. |
@coolbreeze413 Yeah I was using my dad's PC with Windows 10. My PC has Ubuntu 18.04. I managed to flash the helloworldsw.bin from Windows 10. But I would definitely love to make it work in Ubuntu 18.04 as all my work happens on that. After so long, working on Windows feels like a real pain in the butt. |
@AdityaPrakash23 We went through multiple approaches to try and fix this on the 2 systems here where flashing fails, with Ubuntu 18.04, but we weren't able to fix this. Strangely, 18.04 on different systems (same exact model as the failing ones) does work though. So, we finally tried to upgrade the 18.04 install to 20.04, and the flashing now works. I think that there is a combination of environment + hardware on 18.04 which causes this, however, we could not narrow the cause down to anything concrete. Upgrading to 20.04 should fix the issue on your system too I believe, and you wouldn't need to have a fresh install or a different system. |
@coolbreeze413 Thanks for the suggestion! I will try that out and hopefully everything works out! But programming the Quickfeather is something I have found to be a bit challenging. I have my own sensors and pins to work with but haven't been able to find related documentation to interface them with the Quickfeather board. Hopefully that problem also goes away soon! |
@AdityaPrakash23 Let me know how it goes for you. For the sensors/pins usage, you could open a separate issue, and we can look at pointing toward the right place to look, or update the documentation if its missing. |
@coolbreeze413 Sure! I do think the documentation is not complete. But I will probably wait for Hackster's webinar. If that doesn't work out too, then I will open a separate issue in the correct repo(probably the qorc-sdk repo). Thanks for all the help! |
@AdityaPrakash23 Yes, we are working toward having complete documentation, and any inputs you have are welcome! |
If the issue is working out which pins to use, you might want to look at the document for the aqi project. I believe that goes through the process of working out which pins to use for that application, which may provide the insight that you need.
From: Aditya Prakash <[email protected]>
Sent: Tuesday, January 12, 2021 10:16 AM
To: QuickLogic-Corp/qorc-sdk <[email protected]>
Cc: Subscribed <[email protected]>
Subject: Re: [QuickLogic-Corp/qorc-sdk] "serial" issue in tinyfpga-programmer-gui.py (#91)
@coolbreeze413<https://github.com/coolbreeze413> Sure! I do think the documentation is not complete. But I will probably wait for Hackster's webinar. If that doesn't work out too, then I will open a separate issue in the correct repo(probably the qorc-sdk repo). Thanks for all the help!
—
You are receiving this because you are subscribed to this thread.
Reply to this email directly, view it on GitHub<#91 (comment)>, or unsubscribe<https://github.com/notifications/unsubscribe-auth/AO4FHEOQEFUYZVJYBWL6T53SZSGV5ANCNFSM4VQGHUQQ>.
|
@AdityaPrakash23 were you able to solve the issue or you upgraded to Ubuntu 20? I'd like to solve it rather than upgrading as I need Ubuntu 18 for my other projects which use some old version of packages. |
@kishangondaliya No I wasn't able to solve the issue. I am using Windows 10 just for flashing and also the SensiML software. I think code modification and building should be fine in Ubuntu 18. |
After some debugging, it looks like that there is a combination of hardware (PC Hardware - USB Controller) and Software (Debian/Ubuntu) that causes this kind of problem. As we have not been able to track down the root cause of this yet, as a work around, I would suggest that you use the UART Bootloader instead of the default Bootloader, using an alternative PC/Laptop where you can flash. Note that you will need to use a 3.3V USB-UART converter and connect that to the S3 UART pins on the QuickFeather to flash images after changing the bootloader. Steps:
Copy the binary from qf_apps/qf_bootloader_uart/GCC_Project/output/bin/qf_bootloader_uart.bin to the alternative PC.
Once this is done, from next reset the UART Bootloader will execute. The images will need to be flashed using the USB-UART converter which will appear as For example
If access to J-Link is available, then this can be done from any PC/Laptop even where the USBSERIAL flashing does not work. |
@kishangondaliya @AdityaPrakash23 It looks possibly like the modem manager is interfering with the usbserial driver, we may need to add udev rules to mitigate this: The instructions to add the rules are in the top of the file. Could you try this on the Ubuntu/Debian sytems where flashing over the serial port does not work? |
@coolbreeze413 I tried following the steps that u linked. After that, when I try to set the quickfeather to flashing mode, the Green LED blinks for a few seconds, and then turns solid green and sometimes even turns off compeltely. I might have not done the steps correctly. I hope this helps. |
@jublin @coolbreeze413 @AdityaPrakash23 i want to write python script that will take the qfprog command and flash my board with the bin file that has been generated please help me with this idea iam struck with this for 1 week right now iam not able to figure it out. |
Hello there!
I am try the qorc-sdk on my new QuickFeather board. My board's initial tests with putty are working fine. I have followed all the steps in the guide but when trying the "Lesson #1a: M4 only – qf_helloworldsw", I am getting stuck at step 3(pushing the code to the board). I keep getting this error
I tried to find the solution and tried them but nothing seems to be fixing it. I already have removed serial and installed pyserial in python3. Can someone please tell what to do? Thanks!
The text was updated successfully, but these errors were encountered: