提交 b311e684 编写于 作者: D David Howells

rxrpc: Add a private skb flag to indicate transmission-phase skbs

    
Add a flag in the private data on an skbuff to indicate that this is a
transmission-phase buffer rather than a receive-phase buffer.
Signed-off-by: NDavid Howells <dhowells@redhat.com>
上级 a641fd00
...@@ -188,6 +188,7 @@ struct rxrpc_skb_priv { ...@@ -188,6 +188,7 @@ struct rxrpc_skb_priv {
u8 nr_subpackets; /* Number of subpackets */ u8 nr_subpackets; /* Number of subpackets */
u8 rx_flags; /* Received packet flags */ u8 rx_flags; /* Received packet flags */
#define RXRPC_SKB_INCL_LAST 0x01 /* - Includes last packet */ #define RXRPC_SKB_INCL_LAST 0x01 /* - Includes last packet */
#define RXRPC_SKB_TX_BUFFER 0x02 /* - Is transmit buffer */
union { union {
int remain; /* amount of space remaining for next write */ int remain; /* amount of space remaining for next write */
......
...@@ -336,6 +336,8 @@ static int rxrpc_send_data(struct rxrpc_sock *rx, ...@@ -336,6 +336,8 @@ static int rxrpc_send_data(struct rxrpc_sock *rx,
if (!skb) if (!skb)
goto maybe_error; goto maybe_error;
sp = rxrpc_skb(skb);
sp->rx_flags |= RXRPC_SKB_TX_BUFFER;
rxrpc_new_skb(skb, rxrpc_skb_tx_new); rxrpc_new_skb(skb, rxrpc_skb_tx_new);
_debug("ALLOC SEND %p", skb); _debug("ALLOC SEND %p", skb);
...@@ -346,7 +348,6 @@ static int rxrpc_send_data(struct rxrpc_sock *rx, ...@@ -346,7 +348,6 @@ static int rxrpc_send_data(struct rxrpc_sock *rx,
skb_reserve(skb, call->conn->security_size); skb_reserve(skb, call->conn->security_size);
skb->len += call->conn->security_size; skb->len += call->conn->security_size;
sp = rxrpc_skb(skb);
sp->remain = chunk; sp->remain = chunk;
if (sp->remain > skb_tailroom(skb)) if (sp->remain > skb_tailroom(skb))
sp->remain = skb_tailroom(skb); sp->remain = skb_tailroom(skb);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册