From patchwork Wed Oct 11 06:45:21 2017 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Bjorn Andersson X-Patchwork-Id: 115508 Delivered-To: patch@linaro.org Received: by 10.140.22.163 with SMTP id 32csp409380qgn; Tue, 10 Oct 2017 23:46:31 -0700 (PDT) X-Received: by 10.98.155.219 with SMTP id e88mr1794653pfk.218.1507704391623; Tue, 10 Oct 2017 23:46:31 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1507704391; cv=none; d=google.com; s=arc-20160816; b=xU2245Gr3/As49O9kPIrroxq6IZ/67IO3yLRa1pkIaRMxDKVacHfuTHDNdmzj4a0Rl 7PfrbEutECQ31iXzEjeofOq/8TD4haQhB4x11HX166ijeWpRHxvAxSczVaPI0iDZSmGD Rg+fsrNopXxNIpeNr0OcT1cJFJ57WYVzaKcCP90LQIuDw1JvJGe1tnM4INzgDybcFVO4 cZtN7iBgVxlXjcP8TDoInJuMbGi6PbyC5mXenLEMRl0c2dZYCldkKtfG9yoKC1dqDAct DqVbqB4oLZEOp15pbk6W6cKaIDrWtt4C1CjnnMO5QZ+WzytAc0vfczN8F09r2Kag3/R5 75eg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from:dkim-signature:arc-authentication-results; bh=QfLJ1GQt2kUmZJ19r3Ql2dtpKB6jNX2WGkqpLg1nQ0E=; b=Zpq+6VnpgJc4AalQznTF/uULmBMB0fB5Z1jwPAsuQpPMYtFxb1cSzvTJ1Y50LyjMDJ IQXXMSUh9Y/uNrzAvoPzC6knCw5Rw56NAehHjzMmq5Te3mzSCk1vN/8nlMxtcSoaBDbT R9dvzjh7tQHXpxijCWgiWZe0ac41zUhS8xGWSJP4icyH+8HWXLa+9CtjeyjC4+XyS6+N aMlzhyPMK1GBsngnbmt3zKl5I5NaddVNtlUcHYioJKzQJJp72fDNU+GrPqnITwBv+HTP tCd3vwGR9w2qVtmHOmDVIj+/r+ruV4UAmnJZcxTF5HuHY6r5IKExXEKiPpZk/IFAofU0 ++LA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=i4O/WzpS; 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=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id v41si10795599plg.597.2017.10.10.23.46.31; Tue, 10 Oct 2017 23:46:31 -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; dkim=pass header.i=@linaro.org header.s=google header.b=i4O/WzpS; 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=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1757258AbdJKGq3 (ORCPT + 26 others); Wed, 11 Oct 2017 02:46:29 -0400 Received: from mail-pg0-f42.google.com ([74.125.83.42]:55571 "EHLO mail-pg0-f42.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1756642AbdJKGpd (ORCPT ); Wed, 11 Oct 2017 02:45:33 -0400 Received: by mail-pg0-f42.google.com with SMTP id b11so512753pgn.12 for ; Tue, 10 Oct 2017 23:45:33 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references; bh=QfLJ1GQt2kUmZJ19r3Ql2dtpKB6jNX2WGkqpLg1nQ0E=; b=i4O/WzpSxGXY6knByDRsQ0l54XrH/76TCDWBHaF5bnYgxEJ0O1IuRtET2yJ+Xsd5ey AQYbfgbVnoX/QuHCg9x6xIGQAhuTDXyOEspx8/U/OuGoGAi5MYM3Cn4Ak8z+VcQbH7H6 WnJGHXlUuqIhT1pME5hNTasor5mjb4ZmdXebY= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references; bh=QfLJ1GQt2kUmZJ19r3Ql2dtpKB6jNX2WGkqpLg1nQ0E=; b=RVu3YhVL/BOIhbShg6n4l+AUT7zx7EPevtP/6zotgyfEJvLyb6HfQEKlx1pptlzux6 GOhJH79PXeu5nXst7lJUCM6qzRvs0mb5xFRFp2tiNkMnMJ4g9uK0trwoiiHLMrGjW260 T+SZKfRr1V4hP9yMJKsvY9o/oR/LTE16KVq8TEhAkZYvn+f9B7qWybc9Cu3o3NyOuDqn CbvY4Xema9FsUw2ACpSzTT+wzjGje36iwYE0ZE4vPek2VEujOdRz+OVbV39/lNReguvh EKor3aInLHSsefnECMSxZLs3F3puCx1HThYzKv+yfyao5xSq7gPjZJf4bCBkqGhDEIdm k+Vg== X-Gm-Message-State: AMCzsaWbFcwXVtQocMG5Cuhy+yvuX13kdpcpTsDDWebN9B/3GZCacXA1 9y5ok4edX37i6EYd8iBHpOO7pA== X-Google-Smtp-Source: AOwi7QBXWVtJKdx+FB5efZq0uLMJ8j2MAX7FXT+L0DXIJV5uMbse+aIRdssj84SZnZa0NuGWNmMYKg== X-Received: by 10.99.149.66 with SMTP id t2mr9226999pgn.105.1507704333044; Tue, 10 Oct 2017 23:45:33 -0700 (PDT) Received: from localhost.localdomain (ip68-111-217-79.sd.sd.cox.net. [68.111.217.79]) by smtp.gmail.com with ESMTPSA id l79sm411779pfb.33.2017.10.10.23.45.31 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Tue, 10 Oct 2017 23:45:32 -0700 (PDT) From: Bjorn Andersson To: "David S. Miller" Cc: netdev@vger.kernel.org, linux-kernel@vger.kernel.org, linux-arm-msm@vger.kernel.org, Chris Lew Subject: [PATCH v2 5/7] net: qrtr: Clean up control packet handling Date: Tue, 10 Oct 2017 23:45:21 -0700 Message-Id: <20171011064523.7902-6-bjorn.andersson@linaro.org> X-Mailer: git-send-email 2.12.0 In-Reply-To: <20171011064523.7902-1-bjorn.andersson@linaro.org> References: <20171011064523.7902-1-bjorn.andersson@linaro.org> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org As the message header generation is deferred the internal functions for generating control packets can be simplified. This patch modifies qrtr_alloc_ctrl_packet() to, in addition to the sk_buff, return a reference to a struct qrtr_ctrl_pkt, which clarifies and simplifies the helpers to the point that these functions can be folded back into the callers. Signed-off-by: Bjorn Andersson --- Changes since v1: - None net/qrtr/qrtr.c | 93 ++++++++++++++++++--------------------------------------- 1 file changed, 29 insertions(+), 64 deletions(-) -- 2.12.0 diff --git a/net/qrtr/qrtr.c b/net/qrtr/qrtr.c index 82dc83789310..a84edba7b1ef 100644 --- a/net/qrtr/qrtr.c +++ b/net/qrtr/qrtr.c @@ -255,9 +255,18 @@ int qrtr_endpoint_post(struct qrtr_endpoint *ep, const void *data, size_t len) } EXPORT_SYMBOL_GPL(qrtr_endpoint_post); -static struct sk_buff *qrtr_alloc_ctrl_packet(u32 type, size_t pkt_len, - u32 src_node, u32 dst_node) +/** + * qrtr_alloc_ctrl_packet() - allocate control packet skb + * @pkt: reference to qrtr_ctrl_pkt pointer + * + * Returns newly allocated sk_buff, or NULL on failure + * + * This function allocates a sk_buff large enough to carry a qrtr_ctrl_pkt and + * on success returns a reference to the control packet in @pkt. + */ +static struct sk_buff *qrtr_alloc_ctrl_packet(struct qrtr_ctrl_pkt **pkt) { + const int pkt_len = sizeof(struct qrtr_ctrl_pkt); struct sk_buff *skb; skb = alloc_skb(QRTR_HDR_SIZE + pkt_len, GFP_KERNEL); @@ -265,64 +274,7 @@ static struct sk_buff *qrtr_alloc_ctrl_packet(u32 type, size_t pkt_len, return NULL; skb_reserve(skb, QRTR_HDR_SIZE); - - return skb; -} - -/* Allocate and construct a resume-tx packet. */ -static struct sk_buff *qrtr_alloc_resume_tx(u32 src_node, - u32 dst_node, u32 port) -{ - const int pkt_len = 20; - struct sk_buff *skb; - __le32 *buf; - - skb = qrtr_alloc_ctrl_packet(QRTR_TYPE_RESUME_TX, pkt_len, - src_node, dst_node); - if (!skb) - return NULL; - - buf = skb_put_zero(skb, pkt_len); - buf[0] = cpu_to_le32(QRTR_TYPE_RESUME_TX); - buf[1] = cpu_to_le32(src_node); - buf[2] = cpu_to_le32(port); - - return skb; -} - -/* Allocate and construct a BYE message to signal remote termination */ -static struct sk_buff *qrtr_alloc_local_bye(u32 src_node) -{ - const int pkt_len = 20; - struct sk_buff *skb; - __le32 *buf; - - skb = qrtr_alloc_ctrl_packet(QRTR_TYPE_BYE, pkt_len, - src_node, qrtr_local_nid); - if (!skb) - return NULL; - - buf = skb_put_zero(skb, pkt_len); - buf[0] = cpu_to_le32(QRTR_TYPE_BYE); - - return skb; -} - -static struct sk_buff *qrtr_alloc_del_client(struct sockaddr_qrtr *sq) -{ - const int pkt_len = 20; - struct sk_buff *skb; - __le32 *buf; - - skb = qrtr_alloc_ctrl_packet(QRTR_TYPE_DEL_CLIENT, pkt_len, - sq->sq_node, QRTR_NODE_BCAST); - if (!skb) - return NULL; - - buf = skb_put_zero(skb, pkt_len); - buf[0] = cpu_to_le32(QRTR_TYPE_DEL_CLIENT); - buf[1] = cpu_to_le32(sq->sq_node); - buf[2] = cpu_to_le32(sq->sq_port); + *pkt = skb_put_zero(skb, pkt_len); return skb; } @@ -337,6 +289,7 @@ static void qrtr_port_put(struct qrtr_sock *ipc); static void qrtr_node_rx_work(struct work_struct *work) { struct qrtr_node *node = container_of(work, struct qrtr_node, work); + struct qrtr_ctrl_pkt *pkt; struct sockaddr_qrtr dst; struct sockaddr_qrtr src; struct sk_buff *skb; @@ -372,10 +325,14 @@ static void qrtr_node_rx_work(struct work_struct *work) } if (confirm) { - skb = qrtr_alloc_resume_tx(dst_node, node->nid, dst_port); + skb = qrtr_alloc_ctrl_packet(&pkt); if (!skb) break; + pkt->cmd = cpu_to_le32(QRTR_TYPE_RESUME_TX); + pkt->client.node = cpu_to_le32(dst.sq_node); + pkt->client.port = cpu_to_le32(dst.sq_port); + if (qrtr_node_enqueue(node, skb, QRTR_TYPE_RESUME_TX, &dst, &src)) break; @@ -429,6 +386,7 @@ void qrtr_endpoint_unregister(struct qrtr_endpoint *ep) struct qrtr_node *node = ep->node; struct sockaddr_qrtr src = {AF_QIPCRTR, node->nid, QRTR_PORT_CTRL}; struct sockaddr_qrtr dst = {AF_QIPCRTR, qrtr_local_nid, QRTR_PORT_CTRL}; + struct qrtr_ctrl_pkt *pkt; struct sk_buff *skb; mutex_lock(&node->ep_lock); @@ -436,9 +394,11 @@ void qrtr_endpoint_unregister(struct qrtr_endpoint *ep) mutex_unlock(&node->ep_lock); /* Notify the local controller about the event */ - skb = qrtr_alloc_local_bye(node->nid); - if (skb) + skb = qrtr_alloc_ctrl_packet(&pkt); + if (skb) { + pkt->cmd = cpu_to_le32(QRTR_TYPE_BYE); qrtr_local_enqueue(NULL, skb, QRTR_TYPE_BYE, &src, &dst); + } qrtr_node_release(node); ep->node = NULL; @@ -474,6 +434,7 @@ static void qrtr_port_put(struct qrtr_sock *ipc) /* Remove port assignment. */ static void qrtr_port_remove(struct qrtr_sock *ipc) { + struct qrtr_ctrl_pkt *pkt; struct sk_buff *skb; int port = ipc->us.sq_port; struct sockaddr_qrtr to; @@ -482,8 +443,12 @@ static void qrtr_port_remove(struct qrtr_sock *ipc) to.sq_node = QRTR_NODE_BCAST; to.sq_port = QRTR_PORT_CTRL; - skb = qrtr_alloc_del_client(&ipc->us); + skb = qrtr_alloc_ctrl_packet(&pkt); if (skb) { + pkt->cmd = cpu_to_le32(QRTR_TYPE_DEL_CLIENT); + pkt->client.node = cpu_to_le32(ipc->us.sq_node); + pkt->client.port = cpu_to_le32(ipc->us.sq_port); + skb_set_owner_w(skb, &ipc->sk); qrtr_bcast_enqueue(NULL, skb, QRTR_TYPE_DEL_CLIENT, &ipc->us, &to);