stm32/mpbthciport: Increase char timeout of BT HCI UART.
The 2ms used previously was not long enough and it could lose HCI sync. Also print error on tx failure to make this more obvious in the future.
This commit is contained in:
parent
8b00aeab8f
commit
6077c63a45
|
@ -142,8 +142,9 @@ int mp_bluetooth_hci_uart_init(uint32_t port, uint32_t baudrate) {
|
||||||
mp_bluetooth_hci_uart_obj.base.type = &pyb_uart_type;
|
mp_bluetooth_hci_uart_obj.base.type = &pyb_uart_type;
|
||||||
mp_bluetooth_hci_uart_obj.uart_id = port;
|
mp_bluetooth_hci_uart_obj.uart_id = port;
|
||||||
mp_bluetooth_hci_uart_obj.is_static = true;
|
mp_bluetooth_hci_uart_obj.is_static = true;
|
||||||
mp_bluetooth_hci_uart_obj.timeout = 2;
|
// We don't want to block indefinitely, but expect flow control is doing its job.
|
||||||
mp_bluetooth_hci_uart_obj.timeout_char = 2;
|
mp_bluetooth_hci_uart_obj.timeout = 200;
|
||||||
|
mp_bluetooth_hci_uart_obj.timeout_char = 200;
|
||||||
MP_STATE_PORT(pyb_uart_obj_all)[mp_bluetooth_hci_uart_obj.uart_id - 1] = &mp_bluetooth_hci_uart_obj;
|
MP_STATE_PORT(pyb_uart_obj_all)[mp_bluetooth_hci_uart_obj.uart_id - 1] = &mp_bluetooth_hci_uart_obj;
|
||||||
|
|
||||||
// This also initialises the UART.
|
// This also initialises the UART.
|
||||||
|
@ -184,7 +185,11 @@ int mp_bluetooth_hci_uart_write(const uint8_t *buf, size_t len) {
|
||||||
// DEBUG_printf("mp_bluetooth_hci_uart_write (stm32)\n");
|
// DEBUG_printf("mp_bluetooth_hci_uart_write (stm32)\n");
|
||||||
|
|
||||||
mp_bluetooth_hci_controller_wakeup();
|
mp_bluetooth_hci_controller_wakeup();
|
||||||
uart_tx_strn(&mp_bluetooth_hci_uart_obj, (void *)buf, len);
|
int errcode;
|
||||||
|
uart_tx_data(&mp_bluetooth_hci_uart_obj, (void *)buf, len, &errcode);
|
||||||
|
if (errcode != 0) {
|
||||||
|
printf("\nmp_bluetooth_hci_uart_write: failed to write to UART %d\n", errcode);
|
||||||
|
}
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue