Lines Matching refs:txb
22 struct rxrpc_txbuf *txb; in rxrpc_alloc_txbuf() local
24 txb = kmalloc(sizeof(*txb), gfp); in rxrpc_alloc_txbuf()
25 if (txb) { in rxrpc_alloc_txbuf()
26 INIT_LIST_HEAD(&txb->call_link); in rxrpc_alloc_txbuf()
27 INIT_LIST_HEAD(&txb->tx_link); in rxrpc_alloc_txbuf()
28 refcount_set(&txb->ref, 1); in rxrpc_alloc_txbuf()
29 txb->call_debug_id = call->debug_id; in rxrpc_alloc_txbuf()
30 txb->debug_id = atomic_inc_return(&rxrpc_txbuf_debug_ids); in rxrpc_alloc_txbuf()
31 txb->space = sizeof(txb->data); in rxrpc_alloc_txbuf()
32 txb->len = 0; in rxrpc_alloc_txbuf()
33 txb->offset = 0; in rxrpc_alloc_txbuf()
34 txb->flags = 0; in rxrpc_alloc_txbuf()
35 txb->ack_why = 0; in rxrpc_alloc_txbuf()
36 txb->seq = call->tx_prepared + 1; in rxrpc_alloc_txbuf()
37 txb->wire.epoch = htonl(call->conn->proto.epoch); in rxrpc_alloc_txbuf()
38 txb->wire.cid = htonl(call->cid); in rxrpc_alloc_txbuf()
39 txb->wire.callNumber = htonl(call->call_id); in rxrpc_alloc_txbuf()
40 txb->wire.seq = htonl(txb->seq); in rxrpc_alloc_txbuf()
41 txb->wire.type = packet_type; in rxrpc_alloc_txbuf()
42 txb->wire.flags = call->conn->out_clientflag; in rxrpc_alloc_txbuf()
43 txb->wire.userStatus = 0; in rxrpc_alloc_txbuf()
44 txb->wire.securityIndex = call->security_ix; in rxrpc_alloc_txbuf()
45 txb->wire._rsvd = 0; in rxrpc_alloc_txbuf()
46 txb->wire.serviceId = htons(call->dest_srx.srx_service); in rxrpc_alloc_txbuf()
48 trace_rxrpc_txbuf(txb->debug_id, in rxrpc_alloc_txbuf()
49 txb->call_debug_id, txb->seq, 1, in rxrpc_alloc_txbuf()
56 return txb; in rxrpc_alloc_txbuf()
59 void rxrpc_get_txbuf(struct rxrpc_txbuf *txb, enum rxrpc_txbuf_trace what) in rxrpc_get_txbuf() argument
63 __refcount_inc(&txb->ref, &r); in rxrpc_get_txbuf()
64 trace_rxrpc_txbuf(txb->debug_id, txb->call_debug_id, txb->seq, r + 1, what); in rxrpc_get_txbuf()
67 void rxrpc_see_txbuf(struct rxrpc_txbuf *txb, enum rxrpc_txbuf_trace what) in rxrpc_see_txbuf() argument
69 int r = refcount_read(&txb->ref); in rxrpc_see_txbuf()
71 trace_rxrpc_txbuf(txb->debug_id, txb->call_debug_id, txb->seq, r, what); in rxrpc_see_txbuf()
76 struct rxrpc_txbuf *txb = container_of(rcu, struct rxrpc_txbuf, rcu); in rxrpc_free_txbuf() local
78 trace_rxrpc_txbuf(txb->debug_id, txb->call_debug_id, txb->seq, 0, in rxrpc_free_txbuf()
80 kfree(txb); in rxrpc_free_txbuf()
84 void rxrpc_put_txbuf(struct rxrpc_txbuf *txb, enum rxrpc_txbuf_trace what) in rxrpc_put_txbuf() argument
91 if (txb) { in rxrpc_put_txbuf()
92 debug_id = txb->debug_id; in rxrpc_put_txbuf()
93 call_debug_id = txb->call_debug_id; in rxrpc_put_txbuf()
94 seq = txb->seq; in rxrpc_put_txbuf()
95 dead = __refcount_dec_and_test(&txb->ref, &r); in rxrpc_put_txbuf()
98 call_rcu(&txb->rcu, rxrpc_free_txbuf); in rxrpc_put_txbuf()
107 struct rxrpc_txbuf *txb; in rxrpc_shrink_call_tx_buffer() local
113 while ((txb = list_first_entry_or_null(&call->tx_buffer, in rxrpc_shrink_call_tx_buffer()
116 if (before(hard_ack, txb->seq)) in rxrpc_shrink_call_tx_buffer()
119 if (txb->seq != call->tx_bottom + 1) in rxrpc_shrink_call_tx_buffer()
120 rxrpc_see_txbuf(txb, rxrpc_txbuf_see_out_of_step); in rxrpc_shrink_call_tx_buffer()
121 ASSERTCMP(txb->seq, ==, call->tx_bottom + 1); in rxrpc_shrink_call_tx_buffer()
123 list_del_rcu(&txb->call_link); in rxrpc_shrink_call_tx_buffer()
127 rxrpc_put_txbuf(txb, rxrpc_txbuf_put_rotated); in rxrpc_shrink_call_tx_buffer()