staging:r8188eu: update pkt->(data|tail|len) synchronously with rx_(data|tail|len) in recv_frame structure
Original driver code uses rx_* members to store skb (pkt) fields (instead of pkt->* members), pkt->* updated only after data completely formed, not in process. Update pkt->* after data buffer changed (with rx_*). Signed-off-by: Ivan Safonov <insafonov@gmail.com> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
parent
bdf299c140
commit
e038e67f08
@ -261,6 +261,8 @@ static inline u8 *recvframe_pull(struct recv_frame *precvframe, int sz)
|
|||||||
|
|
||||||
if (precvframe == NULL)
|
if (precvframe == NULL)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
|
skb_pull(precvframe->pkt, sz);
|
||||||
precvframe->rx_data += sz;
|
precvframe->rx_data += sz;
|
||||||
if (precvframe->rx_data > precvframe->rx_tail) {
|
if (precvframe->rx_data > precvframe->rx_tail) {
|
||||||
precvframe->rx_data -= sz;
|
precvframe->rx_data -= sz;
|
||||||
@ -278,7 +280,7 @@ static inline u8 *recvframe_put(struct recv_frame *precvframe, int sz)
|
|||||||
|
|
||||||
if (precvframe == NULL)
|
if (precvframe == NULL)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
skb_put(precvframe->pkt, sz);
|
||||||
precvframe->rx_tail += sz;
|
precvframe->rx_tail += sz;
|
||||||
|
|
||||||
if (precvframe->rx_tail > precvframe->pkt->end) {
|
if (precvframe->rx_tail > precvframe->pkt->end) {
|
||||||
@ -299,6 +301,7 @@ static inline u8 *recvframe_pull_tail(struct recv_frame *precvframe, int sz)
|
|||||||
|
|
||||||
if (precvframe == NULL)
|
if (precvframe == NULL)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
skb_trim(precvframe->pkt, precvframe->pkt->len - sz);
|
||||||
precvframe->rx_tail -= sz;
|
precvframe->rx_tail -= sz;
|
||||||
if (precvframe->rx_tail < precvframe->rx_data) {
|
if (precvframe->rx_tail < precvframe->rx_data) {
|
||||||
precvframe->rx_tail += sz;
|
precvframe->rx_tail += sz;
|
||||||
|
Loading…
Reference in New Issue
Block a user