-
Notifications
You must be signed in to change notification settings - Fork 7.6k
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
fix(UART): sets the correct uart clock source when using begin(baudrate) #11122
Conversation
👋 Hello SuGlider, we appreciate your contribution to this project! 📘 Please review the project's Contributions Guide for key guidelines on code, documentation, testing, and more. 🖊️ Please also make sure you have read and signed the Contributor License Agreement for this project. Click to see more instructions ...
Review and merge process you can expect ...
|
Test Results 76 files 76 suites 13m 31s ⏱️ Results for commit 83e2ad5. ♻️ This comment has been updated with latest results. |
Memory usage test (comparing PR against master branch)The table below shows the summary of memory usage change (decrease - increase) in bytes and percentage for each target.
Click to expand the detailed deltas report [usage change in BYTES]
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM
Description of Change
Arduino HardwareSerial was changed to use XTAL source clock whenever possible. This assures that the UART port doesn't chage its baudrate when APB frequency changes. The exception is related to ESP32 and ESP32-S2 that have no such clock source option.
In that case, ESP32|ESP32-S2 will use REF_TICK as clock source when the baudrate is lower than 250,000.
For a higher baudrate, it will use APB as clock source, which of course, may change the baudrate if its frequency is changed.
This PR fixes an issue using ESP32 | ESP32-S2 when it calls first
begin(baud_rate_lower_than_250K)
followed bybegin(baud_rate_higher_than_250K)
. In the issue, the UART clock source isn't changed and the baud rate is not set correctly.Tests scenarios
Using ESP32 | ESP32-S2
Related links
Fixes #11121