mirror of
https://github.com/lwip-tcpip/lwip.git
synced 2024-10-05 22:29:49 +00:00
altcp_tcp: some fixes
- expose `altcp_tcp_setup()` so we can wrap altcp over existing tcp pcb. - avoid calling tcp_close() with NULL pcb. - free altcp_pcb struct when error callback called. According to `mqtt_tcp_err_cb()` in src/apps/mqtt/mqtt.c, altcp socket should work the same way than raw tcp socket. So freeing altcp_pcb ensure this.
This commit is contained in:
parent
9d120c59ea
commit
ee89d906ec
@ -63,8 +63,6 @@
|
|||||||
since it contains pointers to static functions declared here */
|
since it contains pointers to static functions declared here */
|
||||||
extern const struct altcp_functions altcp_tcp_functions;
|
extern const struct altcp_functions altcp_tcp_functions;
|
||||||
|
|
||||||
static void altcp_tcp_setup(struct altcp_pcb *conn, struct tcp_pcb *tpcb);
|
|
||||||
|
|
||||||
/* callback functions for TCP */
|
/* callback functions for TCP */
|
||||||
static err_t
|
static err_t
|
||||||
altcp_tcp_accept(void *arg, struct tcp_pcb *new_tpcb, err_t err)
|
altcp_tcp_accept(void *arg, struct tcp_pcb *new_tpcb, err_t err)
|
||||||
@ -143,14 +141,24 @@ altcp_tcp_err(void *arg, err_t err)
|
|||||||
{
|
{
|
||||||
struct altcp_pcb *conn = (struct altcp_pcb *)arg;
|
struct altcp_pcb *conn = (struct altcp_pcb *)arg;
|
||||||
if (conn) {
|
if (conn) {
|
||||||
conn->state = NULL;
|
conn->state = NULL; /* already freed */
|
||||||
if (conn->err) {
|
if (conn->err) {
|
||||||
conn->err(conn->arg, err);
|
conn->err(conn->arg, err);
|
||||||
}
|
}
|
||||||
|
altcp_free(conn);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* setup functions */
|
/* setup functions */
|
||||||
|
|
||||||
|
static void
|
||||||
|
altcp_tcp_remove_callbacks(struct altcp_pcb *conn, struct tcp_pcb *tpcb)
|
||||||
|
tcp_arg(tpcb, NULL);
|
||||||
|
tcp_recv(tpcb, NULL);
|
||||||
|
tcp_sent(tpcb, NULL);
|
||||||
|
tcp_err(tpcb, NULL);
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
altcp_tcp_setup_callbacks(struct altcp_pcb *conn, struct tcp_pcb *tpcb)
|
altcp_tcp_setup_callbacks(struct altcp_pcb *conn, struct tcp_pcb *tpcb)
|
||||||
{
|
{
|
||||||
@ -162,7 +170,7 @@ altcp_tcp_setup_callbacks(struct altcp_pcb *conn, struct tcp_pcb *tpcb)
|
|||||||
/* listen is set totally different :-) */
|
/* listen is set totally different :-) */
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
void
|
||||||
altcp_tcp_setup(struct altcp_pcb *conn, struct tcp_pcb *tpcb)
|
altcp_tcp_setup(struct altcp_pcb *conn, struct tcp_pcb *tpcb)
|
||||||
{
|
{
|
||||||
altcp_tcp_setup_callbacks(conn, tpcb);
|
altcp_tcp_setup_callbacks(conn, tpcb);
|
||||||
@ -260,7 +268,9 @@ altcp_tcp_abort(struct altcp_pcb *conn)
|
|||||||
if (conn != NULL) {
|
if (conn != NULL) {
|
||||||
struct tcp_pcb *pcb = (struct tcp_pcb *)conn->state;
|
struct tcp_pcb *pcb = (struct tcp_pcb *)conn->state;
|
||||||
ALTCP_TCP_ASSERT_CONN(conn);
|
ALTCP_TCP_ASSERT_CONN(conn);
|
||||||
tcp_abort(pcb);
|
if (pcb) {
|
||||||
|
tcp_abort(pcb);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -273,7 +283,14 @@ altcp_tcp_close(struct altcp_pcb *conn)
|
|||||||
}
|
}
|
||||||
ALTCP_TCP_ASSERT_CONN(conn);
|
ALTCP_TCP_ASSERT_CONN(conn);
|
||||||
pcb = (struct tcp_pcb *)conn->state;
|
pcb = (struct tcp_pcb *)conn->state;
|
||||||
return tcp_close(pcb);
|
if (pcb) {
|
||||||
|
altcp_tcp_remove_callbacks(conn, pcb);
|
||||||
|
err_t res = tcp_close(pcb);
|
||||||
|
if (res != ERR_OK) return res;
|
||||||
|
conn->state = NULL; /* unsafe to reference pcb after tcp_close(). */
|
||||||
|
return ERR_OK;
|
||||||
|
}
|
||||||
|
return ERR_CLSD;
|
||||||
}
|
}
|
||||||
|
|
||||||
static err_t
|
static err_t
|
||||||
|
@ -53,6 +53,10 @@
|
|||||||
extern "C" {
|
extern "C" {
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
/* setup a newly allocated altcp_pcb with existing tcp_pcb */
|
||||||
|
struct tcp_pcb;
|
||||||
|
void altcp_tcp_setup(struct altcp_pcb *conn, struct tcp_pcb *tpcb);
|
||||||
|
|
||||||
struct altcp_pcb *altcp_tcp_new_ip_type(u8_t ip_type);
|
struct altcp_pcb *altcp_tcp_new_ip_type(u8_t ip_type);
|
||||||
|
|
||||||
#define altcp_tcp_new() altcp_tcp_new_ip_type(IPADDR_TYPE_V4)
|
#define altcp_tcp_new() altcp_tcp_new_ip_type(IPADDR_TYPE_V4)
|
||||||
|
Loading…
Reference in New Issue
Block a user