Skip to content
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

Lpc-tmc22xx. Please add support for TMC2209 sensorless homing and stall detection. Also add TMC2209 option to LPC configuration tool. #4

Closed
wants to merge 131 commits into from

Conversation

billtrondsen
Copy link

Sorry, I am unable to help with the code. I do have an SKR V1.3 and TMC2209 drivers and would be glad to test/confirm updates.
Thanks! Bill Trondsen

sdavi added 30 commits July 25, 2018 21:22
* Added config for MKS Sbase and AZSMZ
* Updated configs to use TimerPWM where needed
* Added Boost Preprocessor library to generate tables for TimerPWM and
External Interrupts
sdavi and others added 26 commits October 15, 2019 12:53
# Conflicts:
#	src/RepRapFirmware.h
#	src/Tasks.cpp
This adds support for TMC22XX drivers when using LPC based systems. It
uses the LPC Repetitive Interrupt Timer (RIT) to drive a custom software
UART implemetation. This allows the use of standard GPIO pins to talk to
UART based TMC devices. A single pin is used per device and the UART
operates in half duplex mode. To minimise system impact the UART
operates at a slow speed (9600 baud) and uses a single interrupt per
bit. When the UART is not operating the timer is disabled. The interrupt
handler takes approximately 1uS to execute on an LPC1768 (plus standard
interrupt overhead).

Potential issues
When enabled all active drivers must be TMC22XX devices.

The software UART is sensitive to timing issues. If other parts of the
system delay the RIT interrupt handler then errors will occur. To
improve detection of these errors full CRC checking of responses has
been enabled. Currently no errors are seen when the system is idle, but
during test print jobs an error rate of 0.5% is seen. If there is an
error the operation will be retried. Currently RepRap
firmware polls the drivers constantly to obtain status information. So
far when testing no error has created a false status report. But this is
possible if errors are not detected by the CRC code. It may make sense to change
things so that this polling is optional (can probably be done using the
current M569 R option), the UART interface would then in effect only be
used for configuration.
@gloomyandy
Copy link
Owner

Hi I'm going to close this pull request (as it does not contain any code), if you would like to discus feature requests etc. it is probably best to do that over on the RepRap forum thread. I'd be happy to discus further over there.

@gloomyandy gloomyandy closed this May 5, 2020
@billtrondsen
Copy link
Author

billtrondsen commented May 6, 2020 via email

@gloomyandy gloomyandy deleted the lpc-tmc22xx branch May 20, 2020 19:48
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants