Lines Matching refs:pkt

48 	struct virtio_vsock_pkt *pkt;  in virtio_transport_alloc_pkt()  local
51 pkt = kzalloc(sizeof(*pkt), GFP_KERNEL); in virtio_transport_alloc_pkt()
52 if (!pkt) in virtio_transport_alloc_pkt()
55 pkt->hdr.type = cpu_to_le16(info->type); in virtio_transport_alloc_pkt()
56 pkt->hdr.op = cpu_to_le16(info->op); in virtio_transport_alloc_pkt()
57 pkt->hdr.src_cid = cpu_to_le64(src_cid); in virtio_transport_alloc_pkt()
58 pkt->hdr.dst_cid = cpu_to_le64(dst_cid); in virtio_transport_alloc_pkt()
59 pkt->hdr.src_port = cpu_to_le32(src_port); in virtio_transport_alloc_pkt()
60 pkt->hdr.dst_port = cpu_to_le32(dst_port); in virtio_transport_alloc_pkt()
61 pkt->hdr.flags = cpu_to_le32(info->flags); in virtio_transport_alloc_pkt()
62 pkt->len = len; in virtio_transport_alloc_pkt()
63 pkt->hdr.len = cpu_to_le32(len); in virtio_transport_alloc_pkt()
64 pkt->reply = info->reply; in virtio_transport_alloc_pkt()
65 pkt->vsk = info->vsk; in virtio_transport_alloc_pkt()
68 pkt->buf = kmalloc(len, GFP_KERNEL); in virtio_transport_alloc_pkt()
69 if (!pkt->buf) in virtio_transport_alloc_pkt()
72 pkt->buf_len = len; in virtio_transport_alloc_pkt()
74 err = memcpy_from_msg(pkt->buf, info->msg, len); in virtio_transport_alloc_pkt()
80 pkt->hdr.flags |= cpu_to_le32(VIRTIO_VSOCK_SEQ_EOM); in virtio_transport_alloc_pkt()
83 pkt->hdr.flags |= cpu_to_le32(VIRTIO_VSOCK_SEQ_EOR); in virtio_transport_alloc_pkt()
94 return pkt; in virtio_transport_alloc_pkt()
97 kfree(pkt->buf); in virtio_transport_alloc_pkt()
99 kfree(pkt); in virtio_transport_alloc_pkt()
106 struct virtio_vsock_pkt *pkt = opaque; in virtio_transport_build_skb() local
116 payload_len = le32_to_cpu(pkt->hdr.len); in virtio_transport_build_skb()
117 payload_buf = pkt->buf + pkt->off; in virtio_transport_build_skb()
119 skb = alloc_skb(sizeof(*hdr) + sizeof(pkt->hdr) + payload_len, in virtio_transport_build_skb()
127 hdr->src_cid = pkt->hdr.src_cid; in virtio_transport_build_skb()
128 hdr->src_port = pkt->hdr.src_port; in virtio_transport_build_skb()
129 hdr->dst_cid = pkt->hdr.dst_cid; in virtio_transport_build_skb()
130 hdr->dst_port = pkt->hdr.dst_port; in virtio_transport_build_skb()
133 hdr->len = cpu_to_le16(sizeof(pkt->hdr)); in virtio_transport_build_skb()
136 switch (le16_to_cpu(pkt->hdr.op)) { in virtio_transport_build_skb()
157 skb_put_data(skb, &pkt->hdr, sizeof(pkt->hdr)); in virtio_transport_build_skb()
166 void virtio_transport_deliver_tap_pkt(struct virtio_vsock_pkt *pkt) in virtio_transport_deliver_tap_pkt() argument
168 if (pkt->tap_delivered) in virtio_transport_deliver_tap_pkt()
171 vsock_deliver_tap(virtio_transport_build_skb, pkt); in virtio_transport_deliver_tap_pkt()
172 pkt->tap_delivered = true; in virtio_transport_deliver_tap_pkt()
195 struct virtio_vsock_pkt *pkt; in virtio_transport_send_pkt_info() local
227 pkt = virtio_transport_alloc_pkt(info, pkt_len, in virtio_transport_send_pkt_info()
230 if (!pkt) { in virtio_transport_send_pkt_info()
235 virtio_transport_inc_tx_pkt(vvs, pkt); in virtio_transport_send_pkt_info()
237 return t_ops->send_pkt(pkt); in virtio_transport_send_pkt_info()
241 struct virtio_vsock_pkt *pkt) in virtio_transport_inc_rx_pkt() argument
243 if (vvs->rx_bytes + pkt->len > vvs->buf_alloc) in virtio_transport_inc_rx_pkt()
246 vvs->rx_bytes += pkt->len; in virtio_transport_inc_rx_pkt()
251 struct virtio_vsock_pkt *pkt) in virtio_transport_dec_rx_pkt() argument
253 vvs->rx_bytes -= pkt->len; in virtio_transport_dec_rx_pkt()
254 vvs->fwd_cnt += pkt->len; in virtio_transport_dec_rx_pkt()
257 void virtio_transport_inc_tx_pkt(struct virtio_vsock_sock *vvs, struct virtio_vsock_pkt *pkt) in virtio_transport_inc_tx_pkt() argument
261 pkt->hdr.fwd_cnt = cpu_to_le32(vvs->fwd_cnt); in virtio_transport_inc_tx_pkt()
262 pkt->hdr.buf_alloc = cpu_to_le32(vvs->buf_alloc); in virtio_transport_inc_tx_pkt()
306 struct virtio_vsock_pkt *pkt; in virtio_transport_stream_do_peek() local
312 list_for_each_entry(pkt, &vvs->rx_queue, list) { in virtio_transport_stream_do_peek()
313 off = pkt->off; in virtio_transport_stream_do_peek()
318 while (total < len && off < pkt->len) { in virtio_transport_stream_do_peek()
320 if (bytes > pkt->len - off) in virtio_transport_stream_do_peek()
321 bytes = pkt->len - off; in virtio_transport_stream_do_peek()
328 err = memcpy_to_msg(msg, pkt->buf + off, bytes); in virtio_transport_stream_do_peek()
355 struct virtio_vsock_pkt *pkt; in virtio_transport_stream_do_dequeue() local
362 pkt = list_first_entry(&vvs->rx_queue, in virtio_transport_stream_do_dequeue()
366 if (bytes > pkt->len - pkt->off) in virtio_transport_stream_do_dequeue()
367 bytes = pkt->len - pkt->off; in virtio_transport_stream_do_dequeue()
374 err = memcpy_to_msg(msg, pkt->buf + pkt->off, bytes); in virtio_transport_stream_do_dequeue()
381 pkt->off += bytes; in virtio_transport_stream_do_dequeue()
382 if (pkt->off == pkt->len) { in virtio_transport_stream_do_dequeue()
383 virtio_transport_dec_rx_pkt(vvs, pkt); in virtio_transport_stream_do_dequeue()
384 list_del(&pkt->list); in virtio_transport_stream_do_dequeue()
385 virtio_transport_free_pkt(pkt); in virtio_transport_stream_do_dequeue()
417 struct virtio_vsock_pkt *pkt; in virtio_transport_seqpacket_do_dequeue() local
430 pkt = list_first_entry(&vvs->rx_queue, struct virtio_vsock_pkt, list); in virtio_transport_seqpacket_do_dequeue()
436 pkt_len = (size_t)le32_to_cpu(pkt->hdr.len); in virtio_transport_seqpacket_do_dequeue()
447 err = memcpy_to_msg(msg, pkt->buf, bytes_to_copy); in virtio_transport_seqpacket_do_dequeue()
464 if (le32_to_cpu(pkt->hdr.flags) & VIRTIO_VSOCK_SEQ_EOM) { in virtio_transport_seqpacket_do_dequeue()
468 if (le32_to_cpu(pkt->hdr.flags) & VIRTIO_VSOCK_SEQ_EOR) in virtio_transport_seqpacket_do_dequeue()
472 virtio_transport_dec_rx_pkt(vvs, pkt); in virtio_transport_seqpacket_do_dequeue()
473 list_del(&pkt->list); in virtio_transport_seqpacket_do_dequeue()
474 virtio_transport_free_pkt(pkt); in virtio_transport_seqpacket_do_dequeue()
812 struct virtio_vsock_pkt *pkt) in virtio_transport_reset() argument
816 .reply = !!pkt, in virtio_transport_reset()
821 if (pkt && le16_to_cpu(pkt->hdr.op) == VIRTIO_VSOCK_OP_RST) in virtio_transport_reset()
831 struct virtio_vsock_pkt *pkt) in virtio_transport_reset_no_sock() argument
836 .type = le16_to_cpu(pkt->hdr.type), in virtio_transport_reset_no_sock()
841 if (le16_to_cpu(pkt->hdr.op) == VIRTIO_VSOCK_OP_RST) in virtio_transport_reset_no_sock()
845 le64_to_cpu(pkt->hdr.dst_cid), in virtio_transport_reset_no_sock()
846 le32_to_cpu(pkt->hdr.dst_port), in virtio_transport_reset_no_sock()
847 le64_to_cpu(pkt->hdr.src_cid), in virtio_transport_reset_no_sock()
848 le32_to_cpu(pkt->hdr.src_port)); in virtio_transport_reset_no_sock()
864 struct virtio_vsock_pkt *pkt, *tmp; in virtio_transport_remove_sock() local
869 list_for_each_entry_safe(pkt, tmp, &vvs->rx_queue, list) { in virtio_transport_remove_sock()
870 list_del(&pkt->list); in virtio_transport_remove_sock()
871 virtio_transport_free_pkt(pkt); in virtio_transport_remove_sock()
987 struct virtio_vsock_pkt *pkt) in virtio_transport_recv_connecting() argument
993 switch (le16_to_cpu(pkt->hdr.op)) { in virtio_transport_recv_connecting()
1014 virtio_transport_reset(vsk, pkt); in virtio_transport_recv_connecting()
1023 struct virtio_vsock_pkt *pkt) in virtio_transport_recv_enqueue() argument
1028 pkt->len = le32_to_cpu(pkt->hdr.len); in virtio_transport_recv_enqueue()
1029 pkt->off = 0; in virtio_transport_recv_enqueue()
1033 can_enqueue = virtio_transport_inc_rx_pkt(vvs, pkt); in virtio_transport_recv_enqueue()
1039 if (le32_to_cpu(pkt->hdr.flags) & VIRTIO_VSOCK_SEQ_EOM) in virtio_transport_recv_enqueue()
1046 if (pkt->len <= GOOD_COPY_LEN && !list_empty(&vvs->rx_queue)) { in virtio_transport_recv_enqueue()
1058 if ((pkt->len <= last_pkt->buf_len - last_pkt->len) && in virtio_transport_recv_enqueue()
1060 memcpy(last_pkt->buf + last_pkt->len, pkt->buf, in virtio_transport_recv_enqueue()
1061 pkt->len); in virtio_transport_recv_enqueue()
1062 last_pkt->len += pkt->len; in virtio_transport_recv_enqueue()
1064 last_pkt->hdr.flags |= pkt->hdr.flags; in virtio_transport_recv_enqueue()
1069 list_add_tail(&pkt->list, &vvs->rx_queue); in virtio_transport_recv_enqueue()
1074 virtio_transport_free_pkt(pkt); in virtio_transport_recv_enqueue()
1079 struct virtio_vsock_pkt *pkt) in virtio_transport_recv_connected() argument
1084 switch (le16_to_cpu(pkt->hdr.op)) { in virtio_transport_recv_connected()
1086 virtio_transport_recv_enqueue(vsk, pkt); in virtio_transport_recv_connected()
1096 if (le32_to_cpu(pkt->hdr.flags) & VIRTIO_VSOCK_SHUTDOWN_RCV) in virtio_transport_recv_connected()
1098 if (le32_to_cpu(pkt->hdr.flags) & VIRTIO_VSOCK_SHUTDOWN_SEND) in virtio_transport_recv_connected()
1107 if (le32_to_cpu(pkt->hdr.flags)) in virtio_transport_recv_connected()
1118 virtio_transport_free_pkt(pkt); in virtio_transport_recv_connected()
1124 struct virtio_vsock_pkt *pkt) in virtio_transport_recv_disconnecting() argument
1128 if (le16_to_cpu(pkt->hdr.op) == VIRTIO_VSOCK_OP_RST) in virtio_transport_recv_disconnecting()
1134 struct virtio_vsock_pkt *pkt) in virtio_transport_send_response() argument
1138 .remote_cid = le64_to_cpu(pkt->hdr.src_cid), in virtio_transport_send_response()
1139 .remote_port = le32_to_cpu(pkt->hdr.src_port), in virtio_transport_send_response()
1148 struct virtio_vsock_pkt *pkt) in virtio_transport_space_update() argument
1164 vvs->peer_buf_alloc = le32_to_cpu(pkt->hdr.buf_alloc); in virtio_transport_space_update()
1165 vvs->peer_fwd_cnt = le32_to_cpu(pkt->hdr.fwd_cnt); in virtio_transport_space_update()
1173 virtio_transport_recv_listen(struct sock *sk, struct virtio_vsock_pkt *pkt, in virtio_transport_recv_listen() argument
1181 if (le16_to_cpu(pkt->hdr.op) != VIRTIO_VSOCK_OP_REQUEST) { in virtio_transport_recv_listen()
1182 virtio_transport_reset_no_sock(t, pkt); in virtio_transport_recv_listen()
1187 virtio_transport_reset_no_sock(t, pkt); in virtio_transport_recv_listen()
1193 virtio_transport_reset_no_sock(t, pkt); in virtio_transport_recv_listen()
1204 vsock_addr_init(&vchild->local_addr, le64_to_cpu(pkt->hdr.dst_cid), in virtio_transport_recv_listen()
1205 le32_to_cpu(pkt->hdr.dst_port)); in virtio_transport_recv_listen()
1206 vsock_addr_init(&vchild->remote_addr, le64_to_cpu(pkt->hdr.src_cid), in virtio_transport_recv_listen()
1207 le32_to_cpu(pkt->hdr.src_port)); in virtio_transport_recv_listen()
1215 virtio_transport_reset_no_sock(t, pkt); in virtio_transport_recv_listen()
1220 if (virtio_transport_space_update(child, pkt)) in virtio_transport_recv_listen()
1225 virtio_transport_send_response(vchild, pkt); in virtio_transport_recv_listen()
1243 struct virtio_vsock_pkt *pkt) in virtio_transport_recv_pkt() argument
1250 vsock_addr_init(&src, le64_to_cpu(pkt->hdr.src_cid), in virtio_transport_recv_pkt()
1251 le32_to_cpu(pkt->hdr.src_port)); in virtio_transport_recv_pkt()
1252 vsock_addr_init(&dst, le64_to_cpu(pkt->hdr.dst_cid), in virtio_transport_recv_pkt()
1253 le32_to_cpu(pkt->hdr.dst_port)); in virtio_transport_recv_pkt()
1257 le32_to_cpu(pkt->hdr.len), in virtio_transport_recv_pkt()
1258 le16_to_cpu(pkt->hdr.type), in virtio_transport_recv_pkt()
1259 le16_to_cpu(pkt->hdr.op), in virtio_transport_recv_pkt()
1260 le32_to_cpu(pkt->hdr.flags), in virtio_transport_recv_pkt()
1261 le32_to_cpu(pkt->hdr.buf_alloc), in virtio_transport_recv_pkt()
1262 le32_to_cpu(pkt->hdr.fwd_cnt)); in virtio_transport_recv_pkt()
1264 if (!virtio_transport_valid_type(le16_to_cpu(pkt->hdr.type))) { in virtio_transport_recv_pkt()
1265 (void)virtio_transport_reset_no_sock(t, pkt); in virtio_transport_recv_pkt()
1276 (void)virtio_transport_reset_no_sock(t, pkt); in virtio_transport_recv_pkt()
1281 if (virtio_transport_get_type(sk) != le16_to_cpu(pkt->hdr.type)) { in virtio_transport_recv_pkt()
1282 (void)virtio_transport_reset_no_sock(t, pkt); in virtio_transport_recv_pkt()
1293 (void)virtio_transport_reset_no_sock(t, pkt); in virtio_transport_recv_pkt()
1299 space_available = virtio_transport_space_update(sk, pkt); in virtio_transport_recv_pkt()
1310 virtio_transport_recv_listen(sk, pkt, t); in virtio_transport_recv_pkt()
1311 virtio_transport_free_pkt(pkt); in virtio_transport_recv_pkt()
1314 virtio_transport_recv_connecting(sk, pkt); in virtio_transport_recv_pkt()
1315 virtio_transport_free_pkt(pkt); in virtio_transport_recv_pkt()
1318 virtio_transport_recv_connected(sk, pkt); in virtio_transport_recv_pkt()
1321 virtio_transport_recv_disconnecting(sk, pkt); in virtio_transport_recv_pkt()
1322 virtio_transport_free_pkt(pkt); in virtio_transport_recv_pkt()
1325 (void)virtio_transport_reset_no_sock(t, pkt); in virtio_transport_recv_pkt()
1326 virtio_transport_free_pkt(pkt); in virtio_transport_recv_pkt()
1339 virtio_transport_free_pkt(pkt); in virtio_transport_recv_pkt()
1343 void virtio_transport_free_pkt(struct virtio_vsock_pkt *pkt) in virtio_transport_free_pkt() argument
1345 kfree(pkt->buf); in virtio_transport_free_pkt()
1346 kfree(pkt); in virtio_transport_free_pkt()