1
0
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:
Marian Buschsieweke 2024-04-25 22:28:33 +02:00
parent 9761456363
commit 4c0d6f8f7d
No known key found for this signature in database
GPG Key ID: 77AA882EC78084E6

View File

@ -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;