mirror of
https://github.com/lwip-tcpip/lwip.git
synced 2025-01-15 22:49:16 +00:00
Patch#6802 Add do-while-clauses to those function like macros in tcp.h
This commit is contained in:
parent
f1a9f7ea70
commit
f81ed216db
@ -80,6 +80,10 @@ HISTORY
|
|||||||
|
|
||||||
++ Bugfixes:
|
++ Bugfixes:
|
||||||
|
|
||||||
|
2009-04-09 Kieran Mansley (patch from Roy Lee <roylee17>)
|
||||||
|
* tcp.h: Patch#6802 Add do-while-clauses to those function like
|
||||||
|
macros in tcp.h
|
||||||
|
|
||||||
2009-03-31 Kieran Mansley
|
2009-03-31 Kieran Mansley
|
||||||
* tcp.c, tcp_in.c, tcp_out.c, tcp.h, opt.h: Rework the way window
|
* tcp.c, tcp_in.c, tcp_out.c, tcp.h, opt.h: Rework the way window
|
||||||
updates are calculated and sent (BUG20515)
|
updates are calculated and sent (BUG20515)
|
||||||
|
@ -467,26 +467,48 @@ err_t lwip_tcp_event(void *arg, struct tcp_pcb *pcb,
|
|||||||
#define TCP_EVENT_ERR(errf,arg,err) lwip_tcp_event((arg), NULL, \
|
#define TCP_EVENT_ERR(errf,arg,err) lwip_tcp_event((arg), NULL, \
|
||||||
LWIP_EVENT_ERR, NULL, 0, (err))
|
LWIP_EVENT_ERR, NULL, 0, (err))
|
||||||
#else /* LWIP_EVENT_API */
|
#else /* LWIP_EVENT_API */
|
||||||
|
|
||||||
#define TCP_EVENT_ACCEPT(pcb,err,ret) \
|
#define TCP_EVENT_ACCEPT(pcb,err,ret) \
|
||||||
|
do { \
|
||||||
if((pcb)->accept != NULL) \
|
if((pcb)->accept != NULL) \
|
||||||
(ret = (pcb)->accept((pcb)->callback_arg,(pcb),(err)))
|
(ret) = (pcb)->accept((pcb)->callback_arg,(pcb),(err)); \
|
||||||
|
} while (0)
|
||||||
|
|
||||||
#define TCP_EVENT_SENT(pcb,space,ret) \
|
#define TCP_EVENT_SENT(pcb,space,ret) \
|
||||||
|
do { \
|
||||||
if((pcb)->sent != NULL) \
|
if((pcb)->sent != NULL) \
|
||||||
(ret = (pcb)->sent((pcb)->callback_arg,(pcb),(space)))
|
(ret) = (pcb)->sent((pcb)->callback_arg,(pcb),(space)); \
|
||||||
|
} while (0)
|
||||||
|
|
||||||
#define TCP_EVENT_RECV(pcb,p,err,ret) \
|
#define TCP_EVENT_RECV(pcb,p,err,ret) \
|
||||||
if((pcb)->recv != NULL) \
|
do { \
|
||||||
{ ret = (pcb)->recv((pcb)->callback_arg,(pcb),(p),(err)); } else { \
|
if((pcb)->recv != NULL) { \
|
||||||
ret = ERR_OK; \
|
(ret) = (pcb)->recv((pcb)->callback_arg,(pcb),(p),(err)); \
|
||||||
if (p) pbuf_free(p); }
|
} else { \
|
||||||
|
(ret) = ERR_OK; \
|
||||||
|
if (p != NULL) \
|
||||||
|
pbuf_free(p); \
|
||||||
|
} \
|
||||||
|
} while (0)
|
||||||
|
|
||||||
#define TCP_EVENT_CONNECTED(pcb,err,ret) \
|
#define TCP_EVENT_CONNECTED(pcb,err,ret) \
|
||||||
|
do { \
|
||||||
if((pcb)->connected != NULL) \
|
if((pcb)->connected != NULL) \
|
||||||
(ret = (pcb)->connected((pcb)->callback_arg,(pcb),(err)))
|
(ret) = (pcb)->connected((pcb)->callback_arg,(pcb),(err)); \
|
||||||
|
} while (0)
|
||||||
|
|
||||||
#define TCP_EVENT_POLL(pcb,ret) \
|
#define TCP_EVENT_POLL(pcb,ret) \
|
||||||
|
do { \
|
||||||
if((pcb)->poll != NULL) \
|
if((pcb)->poll != NULL) \
|
||||||
(ret = (pcb)->poll((pcb)->callback_arg,(pcb)))
|
(ret) = (pcb)->poll((pcb)->callback_arg,(pcb)); \
|
||||||
|
} while (0)
|
||||||
|
|
||||||
#define TCP_EVENT_ERR(errf,arg,err) \
|
#define TCP_EVENT_ERR(errf,arg,err) \
|
||||||
|
do { \
|
||||||
if((errf) != NULL) \
|
if((errf) != NULL) \
|
||||||
(errf)((arg),(err))
|
(errf)((arg),(err)); \
|
||||||
|
} while (0)
|
||||||
|
|
||||||
#endif /* LWIP_EVENT_API */
|
#endif /* LWIP_EVENT_API */
|
||||||
|
|
||||||
/* This structure represents a TCP segment on the unsent and unacked queues */
|
/* This structure represents a TCP segment on the unsent and unacked queues */
|
||||||
@ -520,16 +542,23 @@ u8_t tcp_segs_free(struct tcp_seg *seg);
|
|||||||
u8_t tcp_seg_free(struct tcp_seg *seg);
|
u8_t tcp_seg_free(struct tcp_seg *seg);
|
||||||
struct tcp_seg *tcp_seg_copy(struct tcp_seg *seg);
|
struct tcp_seg *tcp_seg_copy(struct tcp_seg *seg);
|
||||||
|
|
||||||
#define tcp_ack(pcb) if((pcb)->flags & TF_ACK_DELAY) { \
|
#define tcp_ack(pcb) \
|
||||||
|
do { \
|
||||||
|
if((pcb)->flags & TF_ACK_DELAY) { \
|
||||||
(pcb)->flags &= ~TF_ACK_DELAY; \
|
(pcb)->flags &= ~TF_ACK_DELAY; \
|
||||||
(pcb)->flags |= TF_ACK_NOW; \
|
(pcb)->flags |= TF_ACK_NOW; \
|
||||||
tcp_output(pcb); \
|
tcp_output(pcb); \
|
||||||
} else { \
|
} \
|
||||||
|
else { \
|
||||||
(pcb)->flags |= TF_ACK_DELAY; \
|
(pcb)->flags |= TF_ACK_DELAY; \
|
||||||
}
|
} \
|
||||||
|
} while (0)
|
||||||
|
|
||||||
#define tcp_ack_now(pcb) (pcb)->flags |= TF_ACK_NOW; \
|
#define tcp_ack_now(pcb) \
|
||||||
tcp_output(pcb)
|
do { \
|
||||||
|
(pcb)->flags |= TF_ACK_NOW; \
|
||||||
|
tcp_output(pcb); \
|
||||||
|
} while (0)
|
||||||
|
|
||||||
err_t tcp_send_ctrl(struct tcp_pcb *pcb, u8_t flags);
|
err_t tcp_send_ctrl(struct tcp_pcb *pcb, u8_t flags);
|
||||||
err_t tcp_enqueue(struct tcp_pcb *pcb, void *dataptr, u16_t len,
|
err_t tcp_enqueue(struct tcp_pcb *pcb, void *dataptr, u16_t len,
|
||||||
@ -627,22 +656,32 @@ extern struct tcp_pcb *tcp_tmp_pcb; /* Only used for temporary storage. */
|
|||||||
} while(0)
|
} while(0)
|
||||||
|
|
||||||
#else /* LWIP_DEBUG */
|
#else /* LWIP_DEBUG */
|
||||||
#define TCP_REG(pcbs, npcb) do { \
|
|
||||||
|
#define TCP_REG(pcbs, npcb) \
|
||||||
|
do { \
|
||||||
npcb->next = *pcbs; \
|
npcb->next = *pcbs; \
|
||||||
*(pcbs) = npcb; \
|
*(pcbs) = npcb; \
|
||||||
tcp_timer_needed(); \
|
tcp_timer_needed(); \
|
||||||
} while(0)
|
} while (0)
|
||||||
#define TCP_RMV(pcbs, npcb) do { \
|
|
||||||
|
#define TCP_RMV(pcbs, npcb) \
|
||||||
|
do { \
|
||||||
if(*(pcbs) == npcb) { \
|
if(*(pcbs) == npcb) { \
|
||||||
(*(pcbs)) = (*pcbs)->next; \
|
(*(pcbs)) = (*pcbs)->next; \
|
||||||
} else for(tcp_tmp_pcb = *pcbs; tcp_tmp_pcb != NULL; tcp_tmp_pcb = tcp_tmp_pcb->next) { \
|
} \
|
||||||
|
else { \
|
||||||
|
for(tcp_tmp_pcb = *pcbs; \
|
||||||
|
tcp_tmp_pcb != NULL; \
|
||||||
|
tcp_tmp_pcb = tcp_tmp_pcb->next) { \
|
||||||
if(tcp_tmp_pcb->next != NULL && tcp_tmp_pcb->next == npcb) { \
|
if(tcp_tmp_pcb->next != NULL && tcp_tmp_pcb->next == npcb) { \
|
||||||
tcp_tmp_pcb->next = npcb->next; \
|
tcp_tmp_pcb->next = npcb->next; \
|
||||||
break; \
|
break; \
|
||||||
} \
|
} \
|
||||||
} \
|
} \
|
||||||
|
} \
|
||||||
npcb->next = NULL; \
|
npcb->next = NULL; \
|
||||||
} while(0)
|
} while(0)
|
||||||
|
|
||||||
#endif /* LWIP_DEBUG */
|
#endif /* LWIP_DEBUG */
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
|
Loading…
Reference in New Issue
Block a user