diff options
author | Ivan Safonov <insafonov@gmail.com> | 2017-02-06 20:23:27 +0300 |
---|---|---|
committer | Greg Kroah-Hartman <gregkh@linuxfoundation.org> | 2017-02-09 13:22:09 +0100 |
commit | e038e67f0891b5fddffd779c20f32a7c59288170 (patch) | |
tree | 0ebc6fa09c19e90ba79ced9fe70bf8f8db270556 /drivers/staging/rtl8188eu | |
parent | bdf299c1407b249eb5d623b1ebdd7269a2a88729 (diff) | |
download | linux-e038e67f0891b5fddffd779c20f32a7c59288170.tar.bz2 |
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>
Diffstat (limited to 'drivers/staging/rtl8188eu')
-rw-r--r-- | drivers/staging/rtl8188eu/include/rtw_recv.h | 5 |
1 files changed, 4 insertions, 1 deletions
diff --git a/drivers/staging/rtl8188eu/include/rtw_recv.h b/drivers/staging/rtl8188eu/include/rtw_recv.h index 2e5caa4ac59d..d4d8a740990f 100644 --- a/drivers/staging/rtl8188eu/include/rtw_recv.h +++ b/drivers/staging/rtl8188eu/include/rtw_recv.h @@ -261,6 +261,8 @@ static inline u8 *recvframe_pull(struct recv_frame *precvframe, int sz) if (precvframe == NULL) return NULL; + + skb_pull(precvframe->pkt, sz); precvframe->rx_data += sz; if (precvframe->rx_data > precvframe->rx_tail) { precvframe->rx_data -= sz; @@ -278,7 +280,7 @@ static inline u8 *recvframe_put(struct recv_frame *precvframe, int sz) if (precvframe == NULL) return NULL; - + skb_put(precvframe->pkt, sz); precvframe->rx_tail += sz; 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) return NULL; + skb_trim(precvframe->pkt, precvframe->pkt->len - sz); precvframe->rx_tail -= sz; if (precvframe->rx_tail < precvframe->rx_data) { precvframe->rx_tail += sz; |