[IrDA]: Fix Rx/Tx path race.
From: G. Liakhovetski <gl@dsa-ac.de> We need to switch to NRM _before_ sending the final packet otherwise we might hit a race condition where we get the first packet from the peer while we're still in LAP_XMIT_P. Signed-off-by: Samuel Ortiz <samuel@sortiz.org> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
committed by
David S. Miller
parent
81d84a94be
commit
c0cfe7faa1
@@ -316,23 +316,6 @@ void irlap_do_event(struct irlap_cb *self, IRLAP_EVENT event,
|
||||
}
|
||||
}
|
||||
|
||||
/*
|
||||
* Function irlap_next_state (self, state)
|
||||
*
|
||||
* Switches state and provides debug information
|
||||
*
|
||||
*/
|
||||
static inline void irlap_next_state(struct irlap_cb *self, IRLAP_STATE state)
|
||||
{
|
||||
/*
|
||||
if (!self || self->magic != LAP_MAGIC)
|
||||
return;
|
||||
|
||||
IRDA_DEBUG(4, "next LAP state = %s\n", irlap_state[state]);
|
||||
*/
|
||||
self->state = state;
|
||||
}
|
||||
|
||||
/*
|
||||
* Function irlap_state_ndm (event, skb, frame)
|
||||
*
|
||||
@@ -1086,7 +1069,6 @@ static int irlap_state_xmit_p(struct irlap_cb *self, IRLAP_EVENT event,
|
||||
} else {
|
||||
/* Final packet of window */
|
||||
irlap_send_data_primary_poll(self, skb);
|
||||
irlap_next_state(self, LAP_NRM_P);
|
||||
|
||||
/*
|
||||
* Make sure state machine does not try to send
|
||||
|
Reference in New Issue
Block a user