-
Notifications
You must be signed in to change notification settings - Fork 96
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
Issue with optiboot_atmega1284p on Creality 1.1.4 board #26
Comments
Somehow my board started working. All I did was get up to pour a glass of wine, and when I returned and plugged in the board, it negotiated a USB connection and I was able to flash Marlin and then Klipper |
Sounds like a dodgy connection in the chain somewhere (cable?) |
I actually think this came down to timing. When I plugged in the USB within, say, 5 seconds of completing the avrdude ICSP flash, the USB negotiation failed (in the manner described above). When I waited more like 15 seconds after completing the ICSP Flash to plug in USB, then the USB negotiation succeeded. There still remains a minor issue, where, if the board is booted without a USB host connected, then plugging into a USB host at any time after boot will not yield a successful negotiation; for instance, if I turn on my printer's power supply and allow the board to boot, the USB host will not recognize the board. If I plug in the USB host before turning on the printer, the power from USB is sufficient to boot up the board and establish a connection. I don't know what component on the board is responsible for post-boot USB negotiation. Any ideas? |
This issue is not related to this bootloader, as it is simply responsible for allowing the user to upload their firmware via UART and in this case does NOT handle any of the USB communication. Other more advanced bootloaders does handle the USB communication, but in your case this is handled by the USB device to UART chip found on your board i.e. FTDI FT232R or similar. Anyway please try to plug the board into another machine in order to verify that it's not an issue with your Raspberry Pi. |
I'm not 100% sure this is the right location to file the issue; but I'll start here.
I have a Creality Ender 3 Pro 1.1.4 board; which a few guides refer to as a Sanguino / ATMega1284p.
I followed the guide here https://www.fission3d.com/post/flash-bootloader-and-install-firmware-with-raspberry-pi to use the in circuit serial programmer (ICSP) to flash the Optiboot bootloader as obtained from the Arduino IDE Package manager at
C:\Users\USER\AppData\Local\Arduino15\packages\Sanguino\hardware\avr\1.0.3\bootloaders\optiboot
with avrdude.The bootloader seems to have flashed fine, and worked for a period of time (a few weeks( using the klipper installation instructions further on in the guide linked above.
Recently, without explanation, I've been seeing a series of errors in the
dmesg
log of the Raspberry Pi into which this board is plugged:If I plug the board into another Pi, or another computer, the board seems to function; so, yes - this may actually be a problem with my raspberry pi's USB ports.
What I can't explain is why other USB devices continue to work on that pi: only this device is failing to negotiate the USB connection.
Are there settings in the optiboot bootloader which define the USB host negotiation?
The text was updated successfully, but these errors were encountered: