mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2024-12-29 04:50:03 +01:00
cpu/msp430/perriph_usci: fix prescaler values for ACLK
For super low symbol rates the auxiliary clock (ACLK) is used to conserve power. But with only 32,678 Hz clock just prescaling will result in poor bit timing, hence correct modulation control settings to compensate are needed. Since computing this is too expensive, a look-up table (as switch statement) for the four most common symbol rates was used. The datasheet gave the prescaler values ordered by ascending symbol rate, the switch statement was ordered descending. This changes the order to match the datasheets order and matches the correct prescaler setting to the corresponding symbol rate. Fixes https://github.com/RIOT-OS/RIOT/issues/20620
This commit is contained in:
parent
9761456363
commit
4c0d6f8f7d
@ -162,19 +162,19 @@ msp430_usci_prescaler_t msp430_usci_prescale(uint32_t target_hz)
|
|||||||
* be needed. Otherwise the estimation will be good enough.
|
* be needed. Otherwise the estimation will be good enough.
|
||||||
*/
|
*/
|
||||||
switch (target_hz) {
|
switch (target_hz) {
|
||||||
case 9600:
|
case 1200:
|
||||||
result.mctl = 2U << UCBRS_Pos;
|
result.mctl = 2U << UCBRS_Pos;
|
||||||
result.br0 = 27;
|
result.br0 = 27;
|
||||||
return result;
|
return result;
|
||||||
case 4800:
|
case 2400:
|
||||||
result.mctl = 6U << UCBRS_Pos;
|
result.mctl = 6U << UCBRS_Pos;
|
||||||
result.br0 = 13;
|
result.br0 = 13;
|
||||||
return result;
|
return result;
|
||||||
case 2400:
|
case 4800:
|
||||||
result.mctl = 7U << UCBRS_Pos;
|
result.mctl = 7U << UCBRS_Pos;
|
||||||
result.br0 = 6;
|
result.br0 = 6;
|
||||||
return result;
|
return result;
|
||||||
case 1200:
|
case 9600:
|
||||||
result.mctl = 3U << UCBRS_Pos;
|
result.mctl = 3U << UCBRS_Pos;
|
||||||
result.br0 = 3;
|
result.br0 = 3;
|
||||||
return result;
|
return result;
|
||||||
|
Loading…
Reference in New Issue
Block a user