Bluetooth: Add minimum required length parameter to bt_uart_read()
There are some places where it's forgivable if bt_uart_read() wasn't able to read as many bytes as requested. In other places it's not acceptable (e.g. when reading ACL or event header). To avoid failing in situations where we can handle receiving less data than requested this patch adds a new parameter to bt_uart_read() to specify the minimum required data amount. Change-Id: I372e3af7aaa6bfabe14896eb10cc71c3deff94f2 Signed-off-by: Johan Hedberg <johan.hedberg@intel.com>
This commit is contained in:
parent
935198e715
commit
099ecbfa7c
|
@ -53,7 +53,7 @@
|
||||||
|
|
||||||
#define UART CONFIG_BLUETOOTH_UART_INDEX
|
#define UART CONFIG_BLUETOOTH_UART_INDEX
|
||||||
|
|
||||||
static int bt_uart_read(int uart, uint8_t *buf, size_t len)
|
static int bt_uart_read(int uart, uint8_t *buf, size_t len, size_t min)
|
||||||
{
|
{
|
||||||
int total = 0;
|
int total = 0;
|
||||||
|
|
||||||
|
@ -63,7 +63,9 @@ static int bt_uart_read(int uart, uint8_t *buf, size_t len)
|
||||||
rx = uart_fifo_read(uart, buf, len);
|
rx = uart_fifo_read(uart, buf, len);
|
||||||
if (rx == 0) {
|
if (rx == 0) {
|
||||||
BT_DBG("Got zero bytes from UART\n");
|
BT_DBG("Got zero bytes from UART\n");
|
||||||
continue;
|
if (total < min)
|
||||||
|
continue;
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
BT_DBG("read %d remaining %d\n", rx, len - rx);
|
BT_DBG("read %d remaining %d\n", rx, len - rx);
|
||||||
|
@ -91,7 +93,7 @@ static struct bt_buf *bt_uart_evt_recv(int *remaining)
|
||||||
struct bt_buf *buf;
|
struct bt_buf *buf;
|
||||||
int read;
|
int read;
|
||||||
|
|
||||||
read = bt_uart_read(UART, (void *)&hdr, sizeof(hdr));
|
read = bt_uart_read(UART, (void *)&hdr, sizeof(hdr), sizeof(hdr));
|
||||||
if (read != sizeof(hdr)) {
|
if (read != sizeof(hdr)) {
|
||||||
BT_ERR("Cannot read event header\n");
|
BT_ERR("Cannot read event header\n");
|
||||||
*remaining = -EIO;
|
*remaining = -EIO;
|
||||||
|
@ -117,7 +119,7 @@ static struct bt_buf *bt_uart_acl_recv(int *remaining)
|
||||||
struct bt_buf *buf;
|
struct bt_buf *buf;
|
||||||
int read;
|
int read;
|
||||||
|
|
||||||
read = bt_uart_read(UART, (void *)&hdr, sizeof(hdr));
|
read = bt_uart_read(UART, (void *)&hdr, sizeof(hdr), sizeof(hdr));
|
||||||
if (read != sizeof(hdr)) {
|
if (read != sizeof(hdr)) {
|
||||||
BT_ERR("Cannot read ACL header\n");
|
BT_ERR("Cannot read ACL header\n");
|
||||||
*remaining = -EIO;
|
*remaining = -EIO;
|
||||||
|
@ -160,10 +162,10 @@ void bt_uart_isr(void *unused)
|
||||||
uint8_t type;
|
uint8_t type;
|
||||||
|
|
||||||
/* Get packet type */
|
/* Get packet type */
|
||||||
read = bt_uart_read(UART, &type, sizeof(type));
|
read = bt_uart_read(UART, &type, sizeof(type), 0);
|
||||||
if (read != sizeof(type)) {
|
if (read != sizeof(type)) {
|
||||||
BT_ERR("Error reading UART\n");
|
BT_WARN("Unable to read H4 packet type\n");
|
||||||
return;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
switch (type) {
|
switch (type) {
|
||||||
|
@ -199,11 +201,7 @@ void bt_uart_isr(void *unused)
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
read = bt_uart_read(UART, bt_buf_tail(buf), remaining);
|
read = bt_uart_read(UART, bt_buf_tail(buf), remaining, 0);
|
||||||
if (read < 0) {
|
|
||||||
BT_ERR("Error reading UART\n");
|
|
||||||
goto failed;
|
|
||||||
}
|
|
||||||
|
|
||||||
buf->len += read;
|
buf->len += read;
|
||||||
remaining -= read;
|
remaining -= read;
|
||||||
|
|
Loading…
Reference in a new issue