MINOR: sconn: Set SE_FL_ERROR only when there is no more data to read
SE_FL_ERR_PENDING flag is used when there is still data to be read. So we must take care to not set SE_FL_ERROR too early. Thus, on sending path, it must be set if SE_FL_EOS was already set.
This commit is contained in:
parent
ab79b321d6
commit
7f6aa56d47
|
@ -792,7 +792,7 @@ static void sc_app_chk_snd_conn(struct stconn *sc)
|
||||||
|
|
||||||
if (sc_ep_test(sc, SE_FL_ERROR | SE_FL_ERR_PENDING) || sc_is_conn_error(sc)) {
|
if (sc_ep_test(sc, SE_FL_ERROR | SE_FL_ERR_PENDING) || sc_is_conn_error(sc)) {
|
||||||
/* Write error on the file descriptor */
|
/* Write error on the file descriptor */
|
||||||
if (sc->state >= SC_ST_CON)
|
if (sc->state >= SC_ST_CON && sc_ep_test(sc, SE_FL_EOS))
|
||||||
sc_ep_set(sc, SE_FL_ERROR);
|
sc_ep_set(sc, SE_FL_ERROR);
|
||||||
goto out_wakeup;
|
goto out_wakeup;
|
||||||
}
|
}
|
||||||
|
@ -1650,6 +1650,7 @@ static int sc_conn_send(struct stconn *sc)
|
||||||
*/
|
*/
|
||||||
if (sc->state < SC_ST_CON)
|
if (sc->state < SC_ST_CON)
|
||||||
return 0;
|
return 0;
|
||||||
|
if (sc_ep_test(sc, SE_FL_EOS))
|
||||||
sc_ep_set(sc, SE_FL_ERROR);
|
sc_ep_set(sc, SE_FL_ERROR);
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
@ -1764,6 +1765,7 @@ static int sc_conn_send(struct stconn *sc)
|
||||||
}
|
}
|
||||||
|
|
||||||
if (sc_ep_test(sc, SE_FL_ERROR | SE_FL_ERR_PENDING)) {
|
if (sc_ep_test(sc, SE_FL_ERROR | SE_FL_ERR_PENDING)) {
|
||||||
|
if (sc_ep_test(sc, SE_FL_EOS))
|
||||||
sc_ep_set(sc, SE_FL_ERROR);
|
sc_ep_set(sc, SE_FL_ERROR);
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue