Received: by 2002:a25:824b:0:0:0:0:0 with SMTP id d11csp3307405ybn; Fri, 27 Sep 2019 04:30:23 -0700 (PDT) X-Google-Smtp-Source: APXvYqzca/eo/MaetFeQ/x+QZVDMCD8m4GlhDq3sOVdgTh4n91hOl8ytgf1kX1hKJtc9CyuH9sfp X-Received: by 2002:a05:6402:1583:: with SMTP id c3mr3923325edv.286.1569583823492; Fri, 27 Sep 2019 04:30:23 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1569583823; cv=none; d=google.com; s=arc-20160816; b=H+cQ8dzdX1iBv845OUCiw1Fxycku+ljZ4uago1196nMWJOc23SJ7/zdhcHISCbJUVa xmYenf7kTTaSsvV8Em7RYvuHJEZ54ZzSB7QNIPQq8zPO/Fvlhw+BeM1zeY/50NuEjYq7 NqGG5RSPCCmUvyvHjQa/uXji6C7C9USoUVvdoPIXyhWeMxu0rxntQjoMuQjOAImQiykQ j8ebkBXqeArMS+tPY/Cb5DrIZZDCxJwQZmCjsdrX5t1g7gz6/sJ7Xhc2nAdLszsW5vKZ ruNhBHgOb/z+OJWWKQpAr1pxPxmfT6ebQVl7U8nLajTJZTY9xTDvX8LXvyavmAWhxWOZ k2cg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from; bh=/h2szd5NPCeHyyVxzzXY3E/UirppkCmHOHfji1Zh8Tc=; b=egdnny0bAsXwxeuyF9mnTXemdZeE4odto2dm2xtDdRSYpYJE/r+2d2emjULCNQKaU4 rb8LdT02jCqRN3fyRy/PoEOfgly1MrqXcRjEJa10wEw+0lA+UZGx319dYTu5kV3In5ys DUSIOWUctMgEeClDDVEl/19JtmewqNBzGFFp22arYvhmLLaaQDfrL9clyc3tmekWWNt/ GDGYqbmRt+5cp+n3LnASqFQn6X6xZhlJTiKpucxZ0uWmlJM5XDCWBPNjB0ik8pFLyErZ 14c6KZbeF934ZMZO3EyHlQCYngmhq6ftsNdjM4kIvyhbG2YMcxOcqIpg+H7b7i/qizRT +tMA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id u1si2584681ejt.143.2019.09.27.04.29.58; Fri, 27 Sep 2019 04:30:23 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727530AbfI0L2J (ORCPT + 99 others); Fri, 27 Sep 2019 07:28:09 -0400 Received: from mx1.redhat.com ([209.132.183.28]:34803 "EHLO mx1.redhat.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725890AbfI0L2J (ORCPT ); Fri, 27 Sep 2019 07:28:09 -0400 Received: from smtp.corp.redhat.com (int-mx04.intmail.prod.int.phx2.redhat.com [10.5.11.14]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mx1.redhat.com (Postfix) with ESMTPS id 425E2300D1C7; Fri, 27 Sep 2019 11:28:08 +0000 (UTC) Received: from steredhat.redhat.com (ovpn-117-249.ams2.redhat.com [10.36.117.249]) by smtp.corp.redhat.com (Postfix) with ESMTP id DEF485D9C3; Fri, 27 Sep 2019 11:27:58 +0000 (UTC) From: Stefano Garzarella To: netdev@vger.kernel.org Cc: linux-hyperv@vger.kernel.org, "K. Y. Srinivasan" , Stefan Hajnoczi , Sasha Levin , linux-kernel@vger.kernel.org, kvm@vger.kernel.org, "David S. Miller" , virtualization@lists.linux-foundation.org, Stephen Hemminger , Jason Wang , "Michael S. Tsirkin" , Haiyang Zhang , Dexuan Cui , Jorgen Hansen Subject: [RFC PATCH 06/13] vsock: add 'struct vsock_sock *' param to vsock_core_get_transport() Date: Fri, 27 Sep 2019 13:26:56 +0200 Message-Id: <20190927112703.17745-7-sgarzare@redhat.com> In-Reply-To: <20190927112703.17745-1-sgarzare@redhat.com> References: <20190927112703.17745-1-sgarzare@redhat.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Scanned-By: MIMEDefang 2.79 on 10.5.11.14 X-Greylist: Sender IP whitelisted, not delayed by milter-greylist-4.5.16 (mx1.redhat.com [10.5.110.40]); Fri, 27 Sep 2019 11:28:08 +0000 (UTC) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Since now the 'struct vsock_sock' object contains a pointer to the transport, this patch adds a parameter to the vsock_core_get_transport() to return the right transport assigned to the socket. This patch modifies also the virtio_transport_get_ops(), that uses the vsock_core_get_transport(), adding the 'struct vsock_sock *' parameter. Signed-off-by: Stefano Garzarella --- include/net/af_vsock.h | 2 +- net/vmw_vsock/af_vsock.c | 4 ++-- net/vmw_vsock/virtio_transport_common.c | 9 +++++---- 3 files changed, 8 insertions(+), 7 deletions(-) diff --git a/include/net/af_vsock.h b/include/net/af_vsock.h index a5e1e134261d..2ca67d048de4 100644 --- a/include/net/af_vsock.h +++ b/include/net/af_vsock.h @@ -166,7 +166,7 @@ static inline int vsock_core_init(const struct vsock_transport *t) void vsock_core_exit(void); /* The transport may downcast this to access transport-specific functions */ -const struct vsock_transport *vsock_core_get_transport(void); +const struct vsock_transport *vsock_core_get_transport(struct vsock_sock *vsk); /**** UTILS ****/ diff --git a/net/vmw_vsock/af_vsock.c b/net/vmw_vsock/af_vsock.c index 81ee2561c76f..f7540a3ac64e 100644 --- a/net/vmw_vsock/af_vsock.c +++ b/net/vmw_vsock/af_vsock.c @@ -1993,12 +1993,12 @@ void vsock_core_exit(void) } EXPORT_SYMBOL_GPL(vsock_core_exit); -const struct vsock_transport *vsock_core_get_transport(void) +const struct vsock_transport *vsock_core_get_transport(struct vsock_sock *vsk) { /* vsock_register_mutex not taken since only the transport uses this * function and only while registered. */ - return transport_single; + return vsk->transport; } EXPORT_SYMBOL_GPL(vsock_core_get_transport); diff --git a/net/vmw_vsock/virtio_transport_common.c b/net/vmw_vsock/virtio_transport_common.c index 382536b69029..fc046c071178 100644 --- a/net/vmw_vsock/virtio_transport_common.c +++ b/net/vmw_vsock/virtio_transport_common.c @@ -29,9 +29,10 @@ /* Threshold for detecting small packets to copy */ #define GOOD_COPY_LEN 128 -static const struct virtio_transport *virtio_transport_get_ops(void) +static const struct virtio_transport * +virtio_transport_get_ops(struct vsock_sock *vsk) { - const struct vsock_transport *t = vsock_core_get_transport(); + const struct vsock_transport *t = vsock_core_get_transport(vsk); return container_of(t, struct virtio_transport, transport); } @@ -168,7 +169,7 @@ static int virtio_transport_send_pkt_info(struct vsock_sock *vsk, struct virtio_vsock_pkt *pkt; u32 pkt_len = info->pkt_len; - src_cid = virtio_transport_get_ops()->transport.get_local_cid(); + src_cid = virtio_transport_get_ops(vsk)->transport.get_local_cid(); src_port = vsk->local_addr.svm_port; if (!info->remote_cid) { dst_cid = vsk->remote_addr.svm_cid; @@ -201,7 +202,7 @@ static int virtio_transport_send_pkt_info(struct vsock_sock *vsk, virtio_transport_inc_tx_pkt(vvs, pkt); - return virtio_transport_get_ops()->send_pkt(pkt); + return virtio_transport_get_ops(vsk)->send_pkt(pkt); } static void virtio_transport_inc_rx_pkt(struct virtio_vsock_sock *vvs, -- 2.21.0