Quellcode durchsuchen

Fix serail stall when too-fast baud rates attempted

main
PaulStoffregen vor 7 Jahren
Ursprung
Commit
d51854082b
6 geänderte Dateien mit 9 neuen und 0 gelöschten Zeilen
  1. +2
    -0
      teensy3/serial1.c
  2. +2
    -0
      teensy3/serial2.c
  3. +2
    -0
      teensy3/serial3.c
  4. +1
    -0
      teensy3/serial4.c
  5. +1
    -0
      teensy3/serial5.c
  6. +1
    -0
      teensy3/serial6.c

+ 2
- 0
teensy3/serial1.c Datei anzeigen

@@ -139,6 +139,7 @@ void serial_begin(uint32_t divisor)
#endif
}
#if defined(HAS_KINETISK_UART0)
if (divisor < 32) divisor = 32;
UART0_BDH = (divisor >> 13) & 0x1F;
UART0_BDL = (divisor >> 5) & 0xFF;
UART0_C4 = divisor & 0x1F;
@@ -152,6 +153,7 @@ void serial_begin(uint32_t divisor)
UART0_PFIFO = 0;
#endif
#elif defined(HAS_KINETISL_UART0)
if (divisor < 1) divisor = 1;
UART0_BDH = (divisor >> 8) & 0x1F;
UART0_BDL = divisor & 0xFF;
UART0_C1 = 0;

+ 2
- 0
teensy3/serial2.c Datei anzeigen

@@ -139,6 +139,7 @@ void serial2_begin(uint32_t divisor)
CORE_PIN10_CONFIG = PORT_PCR_DSE | PORT_PCR_SRE | PORT_PCR_MUX(3);
#endif
#if defined(HAS_KINETISK_UART1)
if (divisor < 32) divisor = 32;
UART1_BDH = (divisor >> 13) & 0x1F;
UART1_BDL = (divisor >> 5) & 0xFF;
UART1_C4 = divisor & 0x1F;
@@ -152,6 +153,7 @@ void serial2_begin(uint32_t divisor)
UART1_PFIFO = 0;
#endif
#elif defined(HAS_KINETISL_UART1)
if (divisor < 1) divisor = 1;
UART1_BDH = (divisor >> 8) & 0x1F;
UART1_BDL = divisor & 0xFF;
UART1_C1 = 0;

+ 2
- 0
teensy3/serial3.c Datei anzeigen

@@ -128,12 +128,14 @@ void serial3_begin(uint32_t divisor)
}
#endif
#if defined(HAS_KINETISK_UART2)
if (divisor < 32) divisor = 32;
UART2_BDH = (divisor >> 13) & 0x1F;
UART2_BDL = (divisor >> 5) & 0xFF;
UART2_C4 = divisor & 0x1F;
UART2_C1 = 0;
UART2_PFIFO = 0;
#elif defined(HAS_KINETISL_UART2)
if (divisor < 1) divisor = 1;
UART2_BDH = (divisor >> 8) & 0x1F;
UART2_BDL = divisor & 0xFF;
UART2_C1 = 0;

+ 1
- 0
teensy3/serial4.c Datei anzeigen

@@ -112,6 +112,7 @@ void serial4_begin(uint32_t divisor)
case 32: CORE_PIN32_CONFIG = PORT_PCR_DSE | PORT_PCR_SRE | PORT_PCR_MUX(3); break;
case 62: CORE_PIN62_CONFIG = PORT_PCR_DSE | PORT_PCR_SRE | PORT_PCR_MUX(3); break;
}
if (divisor < 32) divisor = 32;
UART3_BDH = (divisor >> 13) & 0x1F;
UART3_BDL = (divisor >> 5) & 0xFF;
UART3_C4 = divisor & 0x1F;

+ 1
- 0
teensy3/serial5.c Datei anzeigen

@@ -105,6 +105,7 @@ void serial5_begin(uint32_t divisor)
transmitting = 0;
CORE_PIN34_CONFIG = PORT_PCR_PE | PORT_PCR_PS | PORT_PCR_PFE | PORT_PCR_MUX(3);
CORE_PIN33_CONFIG = PORT_PCR_DSE | PORT_PCR_SRE | PORT_PCR_MUX(3);
if (divisor < 32) divisor = 32;
UART4_BDH = (divisor >> 13) & 0x1F;
UART4_BDL = (divisor >> 5) & 0xFF;
UART4_C4 = divisor & 0x1F;

+ 1
- 0
teensy3/serial6.c Datei anzeigen

@@ -105,6 +105,7 @@ void serial6_begin(uint32_t divisor)
transmitting = 0;
CORE_PIN47_CONFIG = PORT_PCR_PE | PORT_PCR_PS | PORT_PCR_PFE | PORT_PCR_MUX(3);
CORE_PIN48_CONFIG = PORT_PCR_DSE | PORT_PCR_SRE | PORT_PCR_MUX(3);
if (divisor < 32) divisor = 32;
UART5_BDH = (divisor >> 13) & 0x1F;
UART5_BDL = (divisor >> 5) & 0xFF;
UART5_C4 = divisor & 0x1F;

Laden…
Abbrechen
Speichern