MINOR: stconn: Add a field to specify the room needed by the SC to progress

When the SC is blocked because it is waiting for room in the input buffer,
it will be responsible to specify the minimum free space required to
progress. In this commit, we only introduce the field in the stconn
structure that will be used to store this value. It is a signed value with
the following meaning:

  * -1: The SC is waiting for room but not based on the buffer state. It
        will be typically used during splicing when the pipe is full. In
        this case, only a successful send can unblock the SC.

  * >= 0; The minimum free space in the input buffer to unblock the SC. 0 is
          a special value to specify the SC must be unblocked ASAP, by the
          stream, at the end of process_stream() or when output data are
          consumed on the opposite side.
This commit is contained in:
Christopher Faulet 2023-05-05 11:25:19 +02:00
parent 7a48b72d39
commit 9aed1124ed
2 changed files with 5 additions and 0 deletions

View File

@ -284,6 +284,10 @@ struct stconn {
unsigned int flags; /* SC_FL_* */
unsigned int ioto; /* I/O activity timeout */
ssize_t room_needed; /* free space in the input buffer required to receive more data.
* -1 : the SC is waiting for room but not on a specific amount of data
* >= 0 : min free space required to progress. 0 means SC must be unblocked ASAP
*/
struct wait_event wait_event; /* We're in a wait list */
struct sedesc *sedesc; /* points to the stream endpoint descriptor */
enum obj_type *app; /* points to the applicative point (stream or check) */

View File

@ -136,6 +136,7 @@ static struct stconn *sc_new(struct sedesc *sedesc)
sc->flags = SC_FL_NONE;
sc->state = SC_ST_INI;
sc->ioto = TICK_ETERNITY;
sc->room_needed = 0;
sc->app = NULL;
sc->app_ops = NULL;
sc->src = NULL;