return ret;
}
+/* Returns info about the conn_stream <cs>, if not NULL. It call the mux layer's
+ * get_cs_info() function, if it exists. On success, it returns a cs_info
+ * structure. Otherwise, on error, if the mux does not implement get_cs_info()
+ * or if conn_stream is NULL, NULL is returned.
+ */
+static inline const struct cs_info *si_get_cs_info(struct conn_stream *cs)
+{
+ if (cs && cs->conn->mux->get_cs_info)
+ return cs->conn->mux->get_cs_info(cs);
+ return NULL;
+}
+
/* for debugging, reports the stream interface state name */
static inline const char *si_state_str(int state)
{
/* referenced below */
struct connection;
struct conn_stream;
+struct cs_info;
struct buffer;
struct proxy;
struct server;
int (*unsubscribe)(struct conn_stream *cs, int event_type, void *param); /* Unsubscribe to events */
int (*avail_streams)(struct connection *conn); /* Returns the number of streams still available for a connection */
void (*destroy)(struct connection *conn); /* Let the mux know one of its users left, so it may have to disappear */
+ const struct cs_info *(*get_cs_info)(struct conn_stream *cs); /* Return info on the specified conn_stream or NULL if not defined */
unsigned int flags; /* some flags characterizing the mux's capabilities (MX_FL_*) */
char name[8]; /* mux layer name, zero-terminated */
};
void *ctx; /* mux-specific context */
};
+/*
+ * This structure describes the info related to a conn_stream known by the mux
+ * only but usefull for the upper layer.
+ * For now, only some dates and durations are reported. This structure will
+ * envolved. But for now, only the bare minimum is referenced.
+ */
+struct cs_info {
+ struct timeval create_date; /* Creation date of the conn_stream in user date */
+ struct timeval tv_create; /* Creation date of the conn_stream in internal date (monotonic) */
+ long t_handshake; /* hanshake duration, -1 if never occurs */
+ long t_idle; /* idle duration, -1 if never occurs */
+};
+
/* This structure describes a connection with its methods and data.
* A connection may be performed to proxy or server via a local or remote
* socket, and can also be made to an internal applet. It can support