Skip to content

Commit

Permalink
vmci_transport: switch ->enqeue_dgram, ->enqueue_stream and ->dequeue…
Browse files Browse the repository at this point in the history
…_stream to msghdr

Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
  • Loading branch information
Al Viro committed Nov 24, 2014
1 parent 45dcc68 commit 0f7db23
Show file tree
Hide file tree
Showing 3 changed files with 13 additions and 13 deletions.
6 changes: 3 additions & 3 deletions include/net/af_vsock.h
Original file line number Diff line number Diff line change
Expand Up @@ -103,14 +103,14 @@ struct vsock_transport {
int (*dgram_dequeue)(struct kiocb *kiocb, struct vsock_sock *vsk,
struct msghdr *msg, size_t len, int flags);
int (*dgram_enqueue)(struct vsock_sock *, struct sockaddr_vm *,
struct iovec *, size_t len);
struct msghdr *, size_t len);
bool (*dgram_allow)(u32 cid, u32 port);

/* STREAM. */
/* TODO: stream_bind() */
ssize_t (*stream_dequeue)(struct vsock_sock *, struct iovec *,
ssize_t (*stream_dequeue)(struct vsock_sock *, struct msghdr *,
size_t len, int flags);
ssize_t (*stream_enqueue)(struct vsock_sock *, struct iovec *,
ssize_t (*stream_enqueue)(struct vsock_sock *, struct msghdr *,
size_t len);
s64 (*stream_has_data)(struct vsock_sock *);
s64 (*stream_has_space)(struct vsock_sock *);
Expand Down
6 changes: 3 additions & 3 deletions net/vmw_vsock/af_vsock.c
Original file line number Diff line number Diff line change
Expand Up @@ -1013,7 +1013,7 @@ static int vsock_dgram_sendmsg(struct kiocb *kiocb, struct socket *sock,
goto out;
}

err = transport->dgram_enqueue(vsk, remote_addr, msg->msg_iov, len);
err = transport->dgram_enqueue(vsk, remote_addr, msg, len);

out:
release_sock(sk);
Expand Down Expand Up @@ -1617,7 +1617,7 @@ static int vsock_stream_sendmsg(struct kiocb *kiocb, struct socket *sock,
*/

written = transport->stream_enqueue(
vsk, msg->msg_iov,
vsk, msg,
len - total_written);
if (written < 0) {
err = -ENOMEM;
Expand Down Expand Up @@ -1739,7 +1739,7 @@ vsock_stream_recvmsg(struct kiocb *kiocb,
break;

read = transport->stream_dequeue(
vsk, msg->msg_iov,
vsk, msg,
len - copied, flags);
if (read < 0) {
err = -ENOMEM;
Expand Down
14 changes: 7 additions & 7 deletions net/vmw_vsock/vmci_transport.c
Original file line number Diff line number Diff line change
Expand Up @@ -1697,7 +1697,7 @@ static int vmci_transport_dgram_bind(struct vsock_sock *vsk,
static int vmci_transport_dgram_enqueue(
struct vsock_sock *vsk,
struct sockaddr_vm *remote_addr,
struct iovec *iov,
struct msghdr *msg,
size_t len)
{
int err;
Expand All @@ -1714,7 +1714,7 @@ static int vmci_transport_dgram_enqueue(
if (!dg)
return -ENOMEM;

memcpy_fromiovec(VMCI_DG_PAYLOAD(dg), iov, len);
memcpy_from_msg(VMCI_DG_PAYLOAD(dg), msg, len);

dg->dst = vmci_make_handle(remote_addr->svm_cid,
remote_addr->svm_port);
Expand Down Expand Up @@ -1835,22 +1835,22 @@ static int vmci_transport_connect(struct vsock_sock *vsk)

static ssize_t vmci_transport_stream_dequeue(
struct vsock_sock *vsk,
struct iovec *iov,
struct msghdr *msg,
size_t len,
int flags)
{
if (flags & MSG_PEEK)
return vmci_qpair_peekv(vmci_trans(vsk)->qpair, iov, len, 0);
return vmci_qpair_peekv(vmci_trans(vsk)->qpair, msg->msg_iov, len, 0);
else
return vmci_qpair_dequev(vmci_trans(vsk)->qpair, iov, len, 0);
return vmci_qpair_dequev(vmci_trans(vsk)->qpair, msg->msg_iov, len, 0);
}

static ssize_t vmci_transport_stream_enqueue(
struct vsock_sock *vsk,
struct iovec *iov,
struct msghdr *msg,
size_t len)
{
return vmci_qpair_enquev(vmci_trans(vsk)->qpair, iov, len, 0);
return vmci_qpair_enquev(vmci_trans(vsk)->qpair, msg->msg_iov, len, 0);
}

static s64 vmci_transport_stream_has_data(struct vsock_sock *vsk)
Expand Down

0 comments on commit 0f7db23

Please sign in to comment.