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

Improve quality of socket loop #1603

Closed
huitema opened this issue Dec 23, 2023 · 8 comments
Closed

Improve quality of socket loop #1603

huitema opened this issue Dec 23, 2023 · 8 comments

Comments

@huitema
Copy link
Collaborator

huitema commented Dec 23, 2023

The initial design of picoquic envisaged that applications would provide their own "socket loop", but we realize now that many would prefer to run picoquic in a background thread. The current "sockloop.c" would work, but it suffers from a few issues:

  • there is no way for the app to "wake up" the stack when new data is ready,
  • the code is a bit too complex because it includes demonstration logic for demo scenarios, such as simulating multihoming with 2 ports.
  • there are two separate loops for Windows and Linux.
  • there is not much documentation.
  • the time check callback should recompute the time if the application calls the API to insert data

In addition, we need to develop automated testing.

@victorstewart
Copy link
Collaborator

if it were Linux only, you could use io_uring and send buffers (which implemented some header + payload message scheme) back and forth between the host and the picoquic loop without any synchronization necessary. this is what i do in my multithreaded processes. all threads run nonstop, harvesting inter-thread communication intertwined in sequence with any other operating system interactions (sendmsg, recvmsg, etc)

@huitema
Copy link
Collaborator Author

huitema commented Dec 25, 2023

Todo -- verify type and use of ifindex -- unsigned int for Linux, ULONG for Windows.

@huitema
Copy link
Collaborator Author

huitema commented Dec 27, 2023

First step is to program a unit test, maybe with a single QUIC context and a loopback socket.

@fbussery
Copy link
Collaborator

Just for your information and to share our experience with using picoquic:

During the phase of selecting our QUIC library, we initially overlooked the picoquic library. The main reason was that, for our project, we don't have direct access to the UDP socket. Instead, an external library provides us with a specific API that uses callbacks for UDP communication. Initially, it appeared challenging to integrate this with your socket loop implementation, and we mistakenly believed this loop was mandatory.

By the way, it is not, and I can confirm that there might be a lack of documentation on this aspect. To provide more insight into our implementation, we rely on Boost Asio to manage our own loop.

@huitema
Copy link
Collaborator Author

huitema commented Dec 29, 2023

In some cases we observe diminished performance. The underlying infrastructure could support Gigabit/s but the application struggles sending more than 10 or 20 Mbps. The simplest explanation is that the background thread is starving. This can happen for example if the thread is waiting on a select call for a limited delay, but the select call only returns long after the delay is passed or messages have arrived.

TODO: evaluate whether the socket thread is starving. Maybe by exposing statistics on expected versus actual wait time.

@huitema
Copy link
Collaborator Author

huitema commented Dec 29, 2023

@fbussery could you open a separate issue for the integration with an 'external' event manager? There are several possible options, maybe Boost Asio, maybe libevent, maybe something else. That's a useful topic, but it poses a set of issues different from the "socket loop in a background thread" discussed here.

@fbussery
Copy link
Collaborator

@fbussery could you open a separate issue for the integration with an 'external' event manager? There are several possible options, maybe Boost Asio, maybe libevent, maybe something else. That's a useful topic, but it poses a set of issues different from the "socket loop in a background thread" discussed here.

Issue opened: #1608

@huitema
Copy link
Collaborator Author

huitema commented Mar 26, 2024

Fixed.

@huitema huitema closed this as completed Mar 26, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

3 participants