Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

sys/usb_cdc_acm_stdio: only submit and flush for non-empty buffer [backport 2024.10] #20987

Merged

Conversation

benpicco
Copy link
Contributor

Backport of #20986

Contribution description

There seems to be some problem the implementation of stdio over usbus_cdc_acm where printing an empty string sometimes leads to the next character being missed in the printout. I've managed to pin the problem down to the call to usbus_cdc_acm_flush(&cdcacm); in sys/usb/usbus/cdc/acm/cdc_acm_stdio.c and, more specifically, to _ep_xmit in cpu/nrf5x_common/periph/usbdev.c, but since I have no non-nRF hardware at hand, I cannot tell whether it is a nRF specific issue.

In any case, skipping the flushing (and submitting) in the first place seems to fix the issue for now. If anyone has an idea how to investigate this further and maybe fix the root cause somewhere deeper in the usb driver, please tell me, I'm happy to test more.

Testing procedure

  1. apply the following diff:
diff --git a/tests/sys/usbus_cdc_acm_stdio/main.c b/tests/sys/usbus_cdc_acm_stdio/main.c
index c603882121..50c0b9a9d8 100644
--- a/tests/sys/usbus_cdc_acm_stdio/main.c
+++ b/tests/sys/usbus_cdc_acm_stdio/main.c
@@ -21,6 +21,7 @@
 #include <stdlib.h>
 
 #include "shell.h"
+#include "fmt.h"
 
 static int cmd_text(int argc, char **argv)
 {
@@ -30,7 +31,7 @@ static int cmd_text(int argc, char **argv)
         return -1;
     }
     int n = atoi(argv[1]);
-    if (n <= 0) {
+    if (n < 0) {
         puts(usage);
         return -1;
     }
@@ -40,7 +41,9 @@ static int cmd_text(int argc, char **argv)
         }
         putc('0' + (i % 10), stdout);
     }
-    puts("");
+    print_str("");
+    print_str("x");
+    print_str("\n");
     return 0;
 }
  1. pick any (nrf-based?) board using stdio_cdc_acm such as feather-nrf52840-sense
  2. make -C tests/sys/usbus_cdc_acm_stdio BOARD=feather-nrf52840-sense flash term
  3. repeatedly enter text 0

On master, this sometimes skips over the x in the printout. With this PR, I never managed to reproduce the issue.

Issues/PRs references

Found while investigating failing tests for #20980

@benpicco benpicco added Area: sys Area: System Area: USB Area: Universal Serial Bus CI: ready for build If set, CI server will compile all applications for all available boards for the labeled PR Process: release backport Integration Process: The PR is a release backport of a change previously provided to master labels Nov 14, 2024
@benpicco benpicco requested a review from mguetschow November 14, 2024 12:49
@benpicco benpicco enabled auto-merge November 14, 2024 13:46
@benpicco benpicco added the Type: bug The issue reports a bug / The PR fixes a bug (including spelling errors) label Nov 14, 2024
Copy link
Contributor

@mguetschow mguetschow left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks for the backport!

@riot-ci
Copy link

riot-ci commented Nov 14, 2024

Murdock results

✔️ PASSED

ed00724 sys/usb_cdc_acm_stdio: only submit and flush for non-empty buffer

Success Failures Total Runtime
10215 0 10215 19m:58s

Artifacts

@benpicco benpicco added this pull request to the merge queue Nov 14, 2024
@github-merge-queue github-merge-queue bot removed this pull request from the merge queue due to no response for status checks Nov 14, 2024
@dylad dylad added this pull request to the merge queue Nov 15, 2024
@github-merge-queue github-merge-queue bot removed this pull request from the merge queue due to no response for status checks Nov 15, 2024
@mguetschow mguetschow added this pull request to the merge queue Nov 15, 2024
@github-merge-queue github-merge-queue bot removed this pull request from the merge queue due to no response for status checks Nov 15, 2024
@dylad
Copy link
Member

dylad commented Nov 15, 2024

Looks like CI has some troublesome with this one. That's weird.

@benpicco benpicco added this pull request to the merge queue Nov 16, 2024
@benpicco
Copy link
Contributor Author

When the CI queue gets too long, the GitHub merge queue times out.
I wonder if this is configurable somewhere

@github-merge-queue github-merge-queue bot removed this pull request from the merge queue due to no response for status checks Nov 16, 2024
@mguetschow mguetschow added this pull request to the merge queue Nov 18, 2024
@github-merge-queue github-merge-queue bot removed this pull request from the merge queue due to no response for status checks Nov 18, 2024
@dylad
Copy link
Member

dylad commented Nov 18, 2024

This PR is cursed :/ What I don't understand is why this one is failing (taking so long) but not the one which landed in master ?

@maribu
Copy link
Member

maribu commented Nov 18, 2024

The timeout is 360 minutes (maximum timeout supported by GitHub). One PR takes about 3h 30 min to be merged. Hence, the moment another PR is in front of the queue, it will not get merged.

But since the last Murdock run succeeded, we could rerun with compilation tests, as lomg as nothing else gets merged in between.

@maribu maribu added the CI: skip compile test If set, CI server will run only non-compile jobs, but no compile jobs or their dependent jobs label Nov 18, 2024
@maribu maribu enabled auto-merge November 18, 2024 15:33
@maribu maribu added this pull request to the merge queue Nov 18, 2024
@maribu
Copy link
Member

maribu commented Nov 18, 2024

It is now at the head of the merge queue, so the recent passing CI run will still be valid when this gets in.

For reference, here is the output of the last full Murdock run: https://ci.riot-os.org/details/dded58edea91403bb7a189410e01d4fe

@maribu
Copy link
Member

maribu commented Nov 18, 2024

So much for skipping compile tests. But this time - assuming now flaky tests fail - it should pass Murdock before the 360 mins have passed.

Merged via the queue into RIOT-OS:2024.10-branch with commit a54faa7 Nov 18, 2024
33 checks passed
@mguetschow
Copy link
Contributor

Hallelujah 🎉

@benpicco benpicco deleted the backport/2024.10/stdio-cdc-acm-miss branch November 19, 2024 10:58
@benpicco benpicco added this to the Release 2024.10 milestone Nov 27, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Area: sys Area: System Area: USB Area: Universal Serial Bus CI: ready for build If set, CI server will compile all applications for all available boards for the labeled PR CI: skip compile test If set, CI server will run only non-compile jobs, but no compile jobs or their dependent jobs Process: release backport Integration Process: The PR is a release backport of a change previously provided to master Type: bug The issue reports a bug / The PR fixes a bug (including spelling errors)
Projects
None yet
Development

Successfully merging this pull request may close these issues.

5 participants