MINOR: mux-fcgi: remove the now unneeded conn_stream from the fcgi_strm

Since we always have a valid endpoint we can safely use it to access
the conn_stream and stop using fstrm->cs. That's one less pointer to
care about.
diff --git a/src/mux_fcgi.c b/src/mux_fcgi.c
index ab3d013..023c652 100644
--- a/src/mux_fcgi.c
+++ b/src/mux_fcgi.c
@@ -154,7 +154,6 @@
 
 /* FCGI stream descriptor */
 struct fcgi_strm {
-	struct conn_stream *cs;
 	struct cs_endpoint *endp;
 	struct session *sess;
 	struct fcgi_conn *fconn;
@@ -379,7 +378,6 @@
 
 /* a dmumy management stream */
 static const struct fcgi_strm *fcgi_mgmt_stream = &(const struct fcgi_strm){
-	.cs        = NULL,
 	.endp      = (struct cs_endpoint*)&closed_ep,
 	.fconn     = NULL,
 	.state     = FCGI_SS_CLOSED,
@@ -389,7 +387,6 @@
 
 /* and a dummy idle stream for use with any unknown stream */
 static const struct fcgi_strm *fcgi_unknown_stream = &(const struct fcgi_strm){
-	.cs        = NULL,
 	.endp      = (struct cs_endpoint*)&closed_ep,
 	.fconn     = NULL,
 	.state     = FCGI_SS_IDLE,
@@ -602,7 +599,7 @@
 	}
 
 	if ((fconn->flags & FCGI_CF_DEM_SALLOC) &&
-	    (fstrm = fcgi_conn_st_by_id(fconn, fconn->dsi)) && fstrm->cs &&
+	    (fstrm = fcgi_conn_st_by_id(fconn, fconn->dsi)) && fstrm->endp->cs &&
 	    b_alloc(&fstrm->rxbuf)) {
 		TRACE_STATE("unblocking fstrm, rxbuf allocated", FCGI_EV_STRM_RECV|FCGI_EV_FSTRM_BLK|FCGI_EV_STRM_WAKE, fconn->conn, fstrm);
 		fconn->flags &= ~FCGI_CF_DEM_SALLOC;
@@ -924,8 +921,7 @@
 			fstrm->state = FCGI_SS_ERROR;
 			TRACE_STATE("switching to ERROR", FCGI_EV_FSTRM_ERR, fstrm->fconn->conn, fstrm);
 		}
-		if (fstrm->cs)
-			cs_ep_set_error(fstrm->endp);
+		cs_ep_set_error(fstrm->endp);
 	}
 }
 
@@ -975,9 +971,9 @@
 		fcgi_strm_notify_recv(fstrm);
 		fcgi_strm_notify_send(fstrm);
 	}
-	else if (fstrm->cs && fstrm->cs->data_cb->wake != NULL) {
+	else if (fstrm->endp->cs && fstrm->endp->cs->data_cb->wake != NULL) {
 		TRACE_POINT(FCGI_EV_STRM_WAKE, fstrm->fconn->conn, fstrm);
-		fstrm->cs->data_cb->wake(fstrm->cs);
+		fstrm->endp->cs->data_cb->wake(fstrm->endp->cs);
 	}
 }
 
@@ -1010,7 +1006,7 @@
 		fstrm->fconn->nb_streams--;
 		if (!fstrm->id)
 			fstrm->fconn->nb_reserved--;
-		if (fstrm->cs) {
+		if (fstrm->endp->cs) {
 			if (!(fstrm->endp->flags & CS_EP_EOS) && !b_data(&fstrm->rxbuf))
 				fcgi_strm_notify_recv(fstrm);
 		}
@@ -1079,7 +1075,6 @@
 	fstrm->shut_tl->context = fstrm;
 	LIST_INIT(&fstrm->send_list);
 	fstrm->fconn = fconn;
-	fstrm->cs = NULL;
 	fstrm->endp = NULL;
 	fstrm->flags = FCGI_SF_NONE;
 	fstrm->proto_status = 0;
@@ -1136,7 +1131,6 @@
 	}
 	if (cs_attach_mux(cs, fstrm, fconn->conn) < 0)
 		goto out;
-	fstrm->cs = cs;
 	fstrm->endp = cs->endp;
 	fstrm->sess = sess;
 	fconn->nb_cs++;
@@ -1161,7 +1155,7 @@
 
 	TRACE_ENTER(FCGI_EV_STRM_WAKE, fconn->conn, fstrm);
 
-	if (!fstrm->cs) {
+	if (!fstrm->endp->cs) {
 		/* this stream was already orphaned */
 		fcgi_strm_destroy(fstrm);
 		TRACE_DEVEL("leaving with no fstrm", FCGI_EV_STRM_WAKE, fconn->conn);
@@ -1236,8 +1230,8 @@
 				  struct fcgi_strm_params *params)
 {
 	struct connection *cli_conn = objt_conn(fstrm->sess->origin);
-	const struct sockaddr_storage *src = (cs_check(fstrm->cs) ? conn_src(fconn->conn) : cs_src(cs_opposite(fstrm->cs)));
-	const struct sockaddr_storage *dst = (cs_check(fstrm->cs) ? conn_dst(fconn->conn) : cs_dst(cs_opposite(fstrm->cs)));
+	const struct sockaddr_storage *src = (cs_check(fstrm->endp->cs) ? conn_src(fconn->conn) : cs_src(cs_opposite(fstrm->endp->cs)));
+	const struct sockaddr_storage *dst = (cs_check(fstrm->endp->cs) ? conn_dst(fconn->conn) : cs_dst(cs_opposite(fstrm->endp->cs)));
 	struct ist p;
 
 	if (!sl)
@@ -2623,7 +2617,7 @@
 		/* Only FCGI_CS_RECORD_D or FCGI_CS_RECORD_P */
 		tmp_fstrm = fcgi_conn_st_by_id(fconn, fconn->dsi);
 
-		if (tmp_fstrm != fstrm && fstrm && fstrm->cs &&
+		if (tmp_fstrm != fstrm && fstrm && fstrm->endp->cs &&
 		    (b_data(&fstrm->rxbuf) ||
 		     fcgi_conn_read0_pending(fconn) ||
 		     fstrm->state == FCGI_SS_CLOSED ||
@@ -2704,7 +2698,7 @@
 
  fail:
 	/* we can go here on missing data, blocked response or error */
-	if (fstrm && fstrm->cs &&
+	if (fstrm && fstrm->endp->cs &&
 	    (b_data(&fstrm->rxbuf) ||
 	     fcgi_conn_read0_pending(fconn) ||
 	     fstrm->state == FCGI_SS_CLOSED ||
@@ -3124,7 +3118,7 @@
 
 		while (node) {
 			fstrm = container_of(node, struct fcgi_strm, by_id);
-			if (fstrm->cs && fstrm->endp->flags & CS_EP_WAIT_FOR_HS)
+			if (fstrm->endp->cs && fstrm->endp->flags & CS_EP_WAIT_FOR_HS)
 				fcgi_strm_notify_recv(fstrm);
 			node = eb32_next(node);
 		}
@@ -3319,11 +3313,11 @@
 	struct proxy *other_end;
 	union error_snapshot_ctx ctx;
 
-	if (fstrm->cs && cs_strm(fstrm->cs)) {
+	if (fstrm->endp->cs && cs_strm(fstrm->endp->cs)) {
 		if (sess == NULL)
-			sess = __cs_strm(fstrm->cs)->sess;
+			sess = __cs_strm(fstrm->endp->cs)->sess;
 		if (!(h1m->flags & H1_MF_RESP))
-			other_end = __cs_strm(fstrm->cs)->be;
+			other_end = __cs_strm(fstrm->endp->cs)->be;
 		else
 			other_end = sess->fe;
 	} else
@@ -3563,8 +3557,8 @@
 	node = eb32_first(&fconn->streams_by_id);
 	while (node) {
 		fstrm = container_of(node, struct fcgi_strm, by_id);
-		if (fstrm->cs)
-			return fstrm->cs;
+		if (fstrm->endp->cs)
+			return fstrm->endp->cs;
 		node = eb32_next(node);
 	}
 	return NULL;
@@ -3605,7 +3599,6 @@
 
 	sess = fstrm->sess;
 	fconn = fstrm->fconn;
-	fstrm->cs = NULL;
 	fconn->nb_cs--;
 
 	if (fstrm->proto_status == FCGI_PS_CANT_MPX_CONN) {
@@ -3848,7 +3841,7 @@
 		/* We're done trying to send, remove ourself from the send_list */
 		LIST_DEL_INIT(&fstrm->send_list);
 
-		if (!fstrm->cs) {
+		if (!fstrm->endp->cs) {
 			fcgi_strm_destroy(fstrm);
 			if (fcgi_conn_is_dead(fconn))
 				fcgi_release(fconn);
@@ -4166,7 +4159,7 @@
 	while (node) {
 		fstrm = container_of(node, struct fcgi_strm, by_id);
 		tree_cnt++;
-		if (!fstrm->cs)
+		if (!fstrm->endp->cs)
 			orph_cnt++;
 		node = eb32_next(node);
 	}
@@ -4192,12 +4185,12 @@
 			      fstrm, fstrm->id, fstrm->flags,
 			      (unsigned int)b_data(&fstrm->rxbuf), b_orig(&fstrm->rxbuf),
 			      (unsigned int)b_head_ofs(&fstrm->rxbuf), (unsigned int)b_size(&fstrm->rxbuf),
-			      fstrm->cs);
+			      fstrm->endp->cs);
 		if (fstrm->endp) {
 			chunk_appendf(msg, " .endp.flg=0x%08x", fstrm->endp->flags);
 			if (!(fstrm->endp->flags & CS_EP_ORPHAN))
 				chunk_appendf(msg, " .cs.flg=0x%08x .cs.app=%p",
-					      fstrm->cs->flags, fstrm->cs->app);
+					      fstrm->endp->cs->flags, fstrm->endp->cs->app);
 		}
 		chunk_appendf(&trash, " .subs=%p", fstrm->subs);
 		if (fstrm->subs) {