This post is older than 2 years and might not be relevant anymore
More Info: Consider searching for newer posts

connectivity_bridge malfunctions when BLE client disconnects and reconnects

I noticed that when a BLE client disconnects and then reconnects to the, instead of receiving all data arriving over the UART from nRF9160 to nRF52840, there is a delay of several seconds after which a huge block of 2048 bytes is sent over to the BLE client. This size matches the BRIDGE_BUF_SIZE configuration. The issue is observed on both Thingy:91 using the sample provided as part of the precompiled firmware, and also on nRF9160 DK - I ported the sample to work on it, so I observe the same behaviour on both boards. I tried changing BRIDGE_BUF_SIZE, and since I observed that internally 182 bytes are used for BLE transmission, I used that value. Now parts of the NMEA data sent from the GPS sample is randomly scrambled, resulting in 40% or NMEA packets that fail basic validation and CRC.

This attached log has been recorded from nRF9160dk, using the modified connectivity_bridge, which I adapted to run on the DK.
The GPS sample has also been modified, so send a copy of the NMEA strings to its second UART, which on the modified board links to the nRF52840 chip and is forwarded to BLE (application) and USB (this log file).

The following changes have been made:
nrf/samples/nrf9160/gps/src/main.c
static void print_nmea_data(void)
{
for (int i = 0; i < nmea_string_cnt; ++i) {
printk("%s", nmea_strings[i]);
+
+ #if CONFIG_TRACING_TEST
+ TRACING_STRING("%s", nmea_strings[i]);
+ #endif
+
+ #if CONFIG_UART_BLE
+ int uart_ble_send(char * msg, uint16_t length);
+ uart_ble_send(nmea_strings[i], strlen(nmea_strings[i]));
+ #endif
}
}

nrf/applications/connectivity_bridge.nrf9160dk/src/modules/Kconfig
BRIDGE_BUF_SIZE=182

nrf/applications/connectivity_bridge.nrf9160dk/prj.conf
CONFIG_USB_DEVICE_PRODUCT="nrf9160dk UART"

Send a copy of the data being sent to BLE over the debug UART of nRF52840. The USB on nRF9160dk connects to an OpenWRT router which acts as a mobile UART to TCP bridge and is then recorded on a computer using netcat.

nrf/applications/connectivity_bridge_g/src/modules/ble_handler.c
static void bt_send_work_handler(struct k_work *work)
{
uint16_t len;
uint8_t *buf;
int err;
bool notif_disabled = false;

do {
len = ring_buf_get_claim(&ble_tx_ring_buf, &buf, nus_max_send_len);

err = bt_gatt_nus_send(current_conn, buf, len);
if (err == -EINVAL) {
notif_disabled = true;
len = 0;
} else if (err) {
len = 0;
}

+ if (len)
+ {
+ char msg[BLE_TX_BUF_SIZE];
+ memcpy(msg, buf, len);
+ msg[len] = '\0';
+ printk("%s", msg);
+ }


err = ring_buf_get_finish(&ble_tx_ring_buf, len);
if (err) {
LOG_ERR("ring_buf_get_finish: %d", err);
break;
}
} while (len != 0 && !ring_buf_is_empty(&ble_tx_ring_buf));

if (notif_disabled) {
/* Peer has not enabled notifications: don't accumulate data */
ring_buf_reset(&ble_tx_ring_buf);
}
}

The following line is not valid:
$GPGLL,4.31375,N,02445.01620,E,1,04,100.00,312.72,M,0,,*26

Both of the following lines have a valid checksum:
* the first line contains invalid data
* the second line is valid
$GPGGA,085500.23,4208.30949,N,02444.97N,02444.9766.16,217.38,M,0,,*23
$GPGGA,085500.23,4208.30949,N,02444.97660,E,1,10,1.16,217.38,M,0,,*23

Notice how a part of the packet is missing or replaced with data, from
another packet. 40% of the packets are discarded, because they:
* do not begin with $
* do not have * in position line_length - 3
* do not have a valid checksum

From the the remaining 60% of the packets which pass the above validation,
a few are discarded because they:
* have values out of range
* have missing or more than one . character in a float value
* have less or more characters per line of value than expected

In rare events, there are still packets that pass all validation, but
contain slightly invalid data, e.g. there could be a long spike on the map
when our application is drawing the path.

If BRIDGE_BUF_SIZE is reverted to its default value of 2048,
Once the BLE client disconnects and then reconnects, the connectivity bridge
starts working incorrectly and will send large blocks of 2048 bytes containg
multiple NMEA packets.

ble_handler.test.c is my attempt to add tracing code and investigate what
is wrong with the connectivity_bridge. It seems that the ble_handler is holding
all buffers, so the uart_handler has no space to store arriving data.
At some point the buffers are freed by BLE, but then UART sends another 2048 bytes
of data, which arrave at bt_send_work_handler(). It starts sending blocks of
nus_max_send_len=182 until the BLE driver chokes. At this point BLE transmission
stalls for a few seconds, and UART RX will drop some data. Next the process repeats.
I am sorry for not being able to provid more details, and this parragraph may not be
fully accurate, because the code is extremely hard to follow.

I need to make one very important note towards the Nordic SDK developers:
Please make things simple and reliable!
I cannot say if the above issue is due to the existing design patterns in Zephyr OS,
but I see that all design patters are extremely complex and hard to follow, even
for taks that are very simple to implement, such as read/write from UART or BLE,
I see that you write 400 lines of code for each!
Hence it comes to no surprise that such a complex code has bugs which are hard to
diagnose or resolve. For example, as part of my testing I needed to change the
gps sample for nRF9160dk, so that in addition to its normal output, it sends a copy
with only the NMEA strings to its second UART, which I routed to the nRF52840 chip to
forward over BLE. My expectation was that I can simply write the data to UART.
But instead of a one line solution, I was forced to dedicate 330 lines of code:
zephyr/boards/arm/nrf9160dk_nrf9160_g/uart_ble.c
with a lot of handling routines and thigs that should normally be handled by
the driver, and any decent operating system provides a simple to use interface.

Using Nordic SDK master

nrf
commit ecf5d334f1577cc7fca11ae7b5a7fb86f0ea757a

zephyr
commit 7d20f2ebf25991b2897b91275939f8d16d38513a

 4572.projects.7z

Parents
  • What tag/commit are you working on? There has been some work on the connectivity_bridge application recently that should improve its stability, could you check out the master branch or NCS v1.4.0 rc1 and see if your problems goes away? These are the commits that is of interest to you:

    If this doesn't solve your problems, please tell me and I'll investigate it more deeply, try to reproduce it and see if I can get to the bottom of it.

    Best regards,

    Simon

  • Hello Simon!

    I updated to nrf e0d62535662ed6e04730b53f5c7b92fa58cedabf, and zephyr 105a1b9e2bc48acdd1f1173ad2ef43a90c120fbe. The connectivity bridge seems to work better, and at first I thought the issue had been resolved, but after leaving my Thingy:91 to recharge during the night, in the morning I discovered that all symptoms have reappeared. I am currently using the default configuration with buffers of 2048 bytes. My iPhone application receives large packets probably of size 2048 with a long delay between each packet. Around 3% of the packets are invalid, which is way less than 40%, but that's probably because the buffer size is 2048 bytes instead of 182 bytes.

    I am sorry for the late replay. Every time I have to update the SDK, I have to adapt my environment on two computers: Visual Studio projects, macros, paths… It's a lot of work. Then I have to port my projects and test all of them to make sure they work correctly. So as you can see, it's a very time consuming process. And due to the many bugs in the SDK, I spend more time in updates then I do in development and productivity work.

    Speaking of bugs, there is another bug in the GPS. After using the nRF9160DK for a few days the GPS demo stops updating and keeps sending the same values and timestamp over and over again:

    $GPGGA,174132.86,,,,,0,,99.99,,M,0,,*3B
    $GPGLL,,,,,174132.86,V,A*49
    $GPGSA,A,1,,,,,,,,,,,,,99.99,99.99,99.99,1*2D
    $GPGSV,1,1,0,,,,,,,,,,,,,,,,,1*54
    $GPRMC,174132.86,V,,,,,,,271020,,,N,V*0D
    $GPGGA,174132.86,,,,,0,,99.99,,M,0,,*3B
    $GPGLL,,,,,174132.86,V,A*49
    $GPGSA,A,1,,,,,,,,,,,,,99.99,99.99,99.99,1*2D
    $GPGSV,1,1,0,,,,,,,,,,,,,,,,,1*54
    $GPRMC,174132.86,V,,,,,,,271020,,,N,V*0D
    $GPGGA,174132.86,,,,,0,,99.99,,M,0,,*3B
    $GPGLL,,,,,174132.86,V,A*49
    $GPGSA,A,1,,,,,,,,,,,,,99.99,99.99,99.99,1*2D
    $GPGSV,1,1,0,,,,,,,,,,,,,,,,,1*54
    $GPRMC,174132.86,V,,,,,,,271020,,,N,V*0D
    $GPGGA,174132.86,,,,,0,,99.99,,M,0,,*3B
    $GPGLL,,,,,174132.86,V,A*49
    $GPGSA,A,1,,,,,,,,,,,,,99.99,99.99,99.99,1*2D
    $GPGSV,1,1,0,,,,,,,,,,,,,,,,,1*54
    $GPRMC,174132.86,V,,,,,,,271020,,,N,V*0D

    During this time I had been working only with the nRF52840 chip. At some point I noticed that I'm receiving the same NMEA data over and over again. After powering off the board or resetting the nRF9160 chip, the data starts updating again for a few days, and then I start getting the same data repeatedly. This looks rather like a firmware issue.

    I'm not sure if I should blame Zephyr or Nordic, but the Nordic SDK is a very unreliable platform. I'm very unproductive building on top of it. This is in huge part because of me, since I am new to this platform, yet also because in order to learn a new platform one has to experiment with working examples and see how things are accomplished. Sadly although there are a lot of good things in the SDK that should make tasks simple, your team has a long road to go, in order to make it a reliable platform. I hope to see the quality improved soon!

    Since reliable grounds are a necessity in order to advance with my work, I ported our own RTOS − Euros on the nRF52840 CPU. So far this has been a very easy process. Let me know if your team is interested in a robust UART driver that can be used bare metal or integrated with any OS. DMA, interrupts, sync and async modes are fully supported. Unlike what is offered by Zephyr, the interface is very simple to use. When send and recv API is used by a task, if a wait is required, the task is put to sleep freeing CPU cycles for other tasks. The API can also run on bare metal, with interrupts disabled or within fault handlers. It just works and is very simple to use. There is only one restriction: it is not currently free software, but we can license it.

  • I don't know the answer to these questions at the top of my head unfortunately. Would you be able to open some new cases and ask there? Then they will get assigned to an engineer with knowledge about the particular topic.

  • Regarding this case. I added some functionality to log out the cpu load regurlarly, and noticed that the log stopped coming out as soon as the issue occured, which may indicate that the CPU has much to do when the choppy behaviour is happening since it's not prioritizing the lower priority cpu load log.

    00> 
    00> Uart received 377 byte
    00> 
    00> USB received 377 byte
    00> 
    00> BLE received 377 byte
    00> 
    00> [09:03:47.529,876] <inf> cpu_load: Load:9,666%
    00> Uart received 377 byte
    00> 
    00> USB received 377 byte
    00> 
    00> BLE received 377 byte
    00> 
    00> Uart received 377 byte
    00> 
    00> USB received 377 byte
    00> 
    00> BLE received 377 byte
    00> 
    00> Uart received 377 byte
    00> 
    00> USB received 377 byte
    00> 
    00> BLE received 377 byte
    00> 
    00> [09:03:49.529,937] <inf> cpu_load: Load:9,524%
    00> Uart received 350 byte
    00> 
    00> USB received 350 byte
    00> 
    00> BLE received 350 byte
    00> 
    00> Uart received 27 byte
    00> 
    00> USB received 27 byte
    00> 
    00> BLE received 27 byte
    00> 
    00> Uart received 377 byte
    00> 
    00> USB received 377 byte
    00> 
    00> BLE received 377 byte
    00> 
    00> Uart received 377 byte
    00> 
    00> USB received 377 byte
    00> 
    00> BLE received 377 byte
    00> 
    00> Uart received 377 byte
    00> 
    00> USB received 377 byte
    00> 
    00> BLE received 377 byte
    00> 
    00> [09:03:51.529,998] <inf> cpu_load: Load:9,609%
    00> Uart received 377 byte
    00> 
    00> USB received 377 byte
    00> 
    00> BLE received 377 byte
    00> 
    00> Uart received 377 byte
    00> 
    00> USB received 377 byte
    00> 
    00> BLE received 377 byte
    00> 
    00> Uart received 136 byte
    00> 
    00> USB received 136 byte
    00> 
    00> BLE received 136 byte
    00> 
    00> Uart received 241 byte
    00> 
    00> USB received 241 byte
    00> 
    00> BLE received 241 byte
    00> 
    00> Uart received 377 byte
    00> 
    00> USB received 377 byte
    00> 
    00> BLE received 377 byte
    00> 
    00> [09:03:53.530,059] <inf> cpu_load: Load:9,593%
    00> Uart received 377 byte
    00> 
    00> USB received 377 byte
    00> 
    00> BLE received 377 byte
    00> 
    00> Uart received 377 byte
    00> 
    00> USB received 377 byte
    00> 
    00> BLE received 377 byte
    00> 
    00> Uart received 377 byte
    00> 
    00> USB received 377 byte
    00> 
    00> BLE received 377 byte
    00> 
    00> Uart received 299 byte
    00> 
    00> USB received 299 byte
    00> 
    00> BLE received 299 byte
    00> 
    00> Uart received 78 byte
    00> 
    00> USB received 78 byte
    00> 
    00> BLE received 78 byte
    00> 
    00> [09:03:55.530,181] <inf> cpu_load: Load:9,602%
    00> Uart received 377 byte
    00> 
    00> USB received 377 byte
    00> 
    00> BLE received 377 byte
    00> 
    00> Uart received 377 byte
    00> 
    00> USB received 377 byte
    00> 
    00> BLE received 377 byte
    00> 
    00> Uart received 377 byte
    00> 
    00> USB received 377 byte
    00> 
    00> BLE received 377 byte
    00> 
    00> [09:03:57.530,273] <inf> cpu_load: Load:9,461%
    00> Uart received 377 byte
    00> 
    00> USB received 377 byte
    00> 
    00> BLE received 377 byte
    00> 
    00> Uart received 377 byte
    00> 
    00> USB received 377 byte
    00> 
    00> BLE received 377 byte
    00> 
    00> Uart received 85 byte
    00> 
    00> USB received 85 byte
    00> 
    00> BLE received 85 byte
    00> 
    00> Uart received 292 byte
    00> 
    00> USB received 292 byte
    00> 
    00> BLE received 292 byte
    00> 
    00> Uart received 377 byte
    00> 
    00> USB received 377 byte
    00> 
    00> BLE received 377 byte
    00> 
    00> [09:03:59.530,334] <inf> cpu_load: Load:9,605%
    00> Uart received 377 byte
    00> 
    00> USB received 377 byte
    00> 
    00> BLE received 377 byte
    00> 
    00> Uart received 377 byte
    00> 
    00> USB received 377 byte
    00> 
    00> BLE received 377 byte
    00> 
    00> Uart received 377 byte
    00> 
    00> USB received 377 byte
    00> 
    00> BLE received 377 byte
    00> 
    00> Uart received 248 byte
    00> 
    00> USB received 248 byte
    00> 
    00> BLE received 248 byte
    00> 
    00> Uart received 129 byte
    00> 
    00> USB received 129 byte
    00> 
    00> BLE received 129 byte
    00> 
    00> [09:04:01.530,395] <inf> cpu_load: Load:9,601%
    00> Uart received 377 byte
    00> 
    00> USB received 377 byte
    00> 
    00> BLE received 377 byte
    00> 
    00> Uart received 377 byte
    00> 
    00> USB received 377 byte
    00> 
    00> BLE received 377 byte
    00> 
    00> Uart received 1165 byte
    00> 
    00> USB received 1165 byte
    00> 
    00> BLE received 1165 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 byte
    00> 
    00> Uart received 2048 byte
    00> 
    00> USB received 2048 byte
    00> 
    00> BLE received 2048 by

  • The developer I've been in contact with has been able to reproduce the issue on his end and has created a new python script that makes it easier to detect it (reads out data from COM-port 1). He has attached a USB analyzer and checked the USB-traffic, but did not see any problems there, and next up is the UART driver.

  • Hello Simon!

    Can you please test the following firmware for Thingy:91 nRF52840, and let me know if I was able to fix the issue?

    Note that currently only UART0 is enabled.

    connectivity_bridge.g.thingy91.2021-04-02.hex

  • It's currently easter vacation in Norway, but I'll be back at work tomorrow and will test out the hex.

    Best regards,

    Simon

Reply Children
Related