Received: by 2002:a5b:505:0:0:0:0:0 with SMTP id o5csp1851823ybp; Fri, 11 Oct 2019 22:55:55 -0700 (PDT) X-Google-Smtp-Source: APXvYqw5zi8LjkbOyQ2gOp/jCStFPYr/gxA3nxS7o9gR6iS5p6jlUYqHvGPKxQz2uqhwXJXxhig4 X-Received: by 2002:a05:6402:1507:: with SMTP id f7mr17393696edw.68.1570859755381; Fri, 11 Oct 2019 22:55:55 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1570859755; cv=none; d=google.com; s=arc-20160816; b=UrNXIicvX2Q7g/7L3yHfZGDwmDdAuVpJgOOhXYSMyHi4G+16eQEGzdXCZmVpNT9XLm dSTV3Rf49MjgAe1e9uCstCoTBhhqrHwADrxgGwKFhnXGAT5dgImYH1D4HW3xMHTcdqf/ GU7Yvoh8c9ooVd2S9jxpZI58+BUaEPxGvqNLozQA7vzPN+uE6R2sbBK8IOGI3AIPxCOg LL6kt+4KjeN2qb/bj6xP5+77QxA262JVER3n2qGN+ysCKofOAU9NmFafLs2xwNaKIFEF 9NokY9RrBVKnXMRmX1uISn3SvCxuA7Ip2GesBcKkWE7TEkEImqLbkE9lV1fKKt7JqZ1G Y9KA== 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 :dkim-signature; bh=6L2bs6j8TutkJs+FzXM4KGo0BcXqh5bqh+8TwgmkM38=; b=kGONYwbRLPTQqk4xDMsJG2thaF6UNaDtud03wtaIAFVL9eAONDyp0Q0s4Y5SjAAT3x 1Sh75KZov/QEk/0phtXnymVgMK6btNBOYpgi0mWhVWy84we/Vdu4Bvvkl/KmXs5NyhTo uQUn8IqkvJ8k5InBVyiyxX9diy8sYRo2uSNU1AoaQbjeG3ixjn+72/aiSD41mzWnBecu w3YZJ537ArdhTTPQIeRSEnCMVw++T+82vdfpvynGghFto5K3hqvSzhWScFUCFd5Fi3bL qHc3Ceos2BxvVS7aI0EUuPkuewD5YSmbsXIC3kQv6PLpi6YQvJqRvlUsUDqvjcIunb2Y WXUA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@colorfullife-com.20150623.gappssmtp.com header.s=20150623 header.b="c/OsgCon"; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id g50si7383275edb.47.2019.10.11.22.55.32; Fri, 11 Oct 2019 22:55:55 -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=@colorfullife-com.20150623.gappssmtp.com header.s=20150623 header.b="c/OsgCon"; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728902AbfJLFua (ORCPT + 99 others); Sat, 12 Oct 2019 01:50:30 -0400 Received: from mail-wr1-f65.google.com ([209.85.221.65]:40674 "EHLO mail-wr1-f65.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728695AbfJLFuO (ORCPT ); Sat, 12 Oct 2019 01:50:14 -0400 Received: by mail-wr1-f65.google.com with SMTP id h4so14018467wrv.7 for ; Fri, 11 Oct 2019 22:50:11 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=colorfullife-com.20150623.gappssmtp.com; s=20150623; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=6L2bs6j8TutkJs+FzXM4KGo0BcXqh5bqh+8TwgmkM38=; b=c/OsgConE2hR9FufXfwmkLkc/BMvs/lb7QyImPUxRnwovMcHIOBdDgg63HMsyU1txn kOXymB5+l69x10z8k3FTQzIEibLI9DKMq+66GEOGSTtdFQRq5bciQfy+Mulj8qU41XHx TaR/a5GEjLjAUoQsUuD8W/V/FbKkmJM0fOZ6AjOuQnEo1GMstqGyma0flYanJUbVvDyp sxGCohTugL04WWwnC3InhswQZN9t3hZlVvK0fO2CRxxz2CvSuhf8XPVtoPkBJAbwnhj/ E2BXXdEKLA1MUwOEM9FViAylgD/thhaQqs9iFYulJN+P+HFp8daTgXLk2svYf+mQA8H8 XpAg== 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:mime-version:content-transfer-encoding; bh=6L2bs6j8TutkJs+FzXM4KGo0BcXqh5bqh+8TwgmkM38=; b=aq33oSqmkWyKiNy1QOiPoFPHoS45hYuNqiqVgci2G3KoOu+iVTZfQcO/nLiorp20Es w7QjJzZ9jyma5JANkzv66fZ0NEf1m/aAbNuBcs7bYjJufv5j/ceqNjiXpP6Fe1nL3Yzj a9S61htlc3/VDpMgOqXvHD7lyFTkkZz/zFbS2Fq8M1PyEdLU0PripkxbDwMvRszs22pn feLpRKYzChG0VoZHoYm/S+0Xkgbd+dJEavZtgtI4Zq15VoCxLmecEZmJ2Bn4mu5AqXCe v/KYHxN5LNINeyGuNmyDxFk0sUCHo7PPwI5DeQhTONS8BvQBijgz8VCOflbnzxbXA1Tv PE3A== X-Gm-Message-State: APjAAAUVkbMeKP/k4HKA4rbqqMYnjtqdbYLlSi1TNobtTSO3FemPG/+Y IW7WVh74636aB/BO1nSwOWrtf3NCw7E4Sg== X-Received: by 2002:a5d:6709:: with SMTP id o9mr16006399wru.116.1570859410632; Fri, 11 Oct 2019 22:50:10 -0700 (PDT) Received: from linux.fritz.box (p200300D9973AD600F159A589C745B52A.dip0.t-ipconnect.de. [2003:d9:973a:d600:f159:a589:c745:b52a]) by smtp.googlemail.com with ESMTPSA id z4sm9344955wrh.93.2019.10.11.22.50.09 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 11 Oct 2019 22:50:10 -0700 (PDT) From: Manfred Spraul To: LKML , Davidlohr Bueso , Waiman Long Cc: 1vier1@web.de, Andrew Morton , Peter Zijlstra , Jonathan Corbet , Manfred Spraul Subject: [PATCH 2/6] ipc/mqueue.c: Remove duplicated code Date: Sat, 12 Oct 2019 07:49:54 +0200 Message-Id: <20191012054958.3624-3-manfred@colorfullife.com> X-Mailer: git-send-email 2.21.0 In-Reply-To: <20191012054958.3624-1-manfred@colorfullife.com> References: <20191012054958.3624-1-manfred@colorfullife.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Patch entirely from Davidlohr: pipelined_send() and pipelined_receive() are identical, so merge them. Signed-off-by: Manfred Spraul Cc: Davidlohr Bueso --- ipc/mqueue.c | 31 ++++++++++++++++++------------- 1 file changed, 18 insertions(+), 13 deletions(-) diff --git a/ipc/mqueue.c b/ipc/mqueue.c index 3d920ff15c80..be48c0ba92f7 100644 --- a/ipc/mqueue.c +++ b/ipc/mqueue.c @@ -918,17 +918,12 @@ SYSCALL_DEFINE1(mq_unlink, const char __user *, u_name) * The same algorithm is used for senders. */ -/* pipelined_send() - send a message directly to the task waiting in - * sys_mq_timedreceive() (without inserting message into a queue). - */ -static inline void pipelined_send(struct wake_q_head *wake_q, +static inline void __pipelined_op(struct wake_q_head *wake_q, struct mqueue_inode_info *info, - struct msg_msg *message, - struct ext_wait_queue *receiver) + struct ext_wait_queue *this) { - receiver->msg = message; - list_del(&receiver->list); - wake_q_add(wake_q, receiver->task); + list_del(&this->list); + wake_q_add(wake_q, this->task); /* * Rely on the implicit cmpxchg barrier from wake_q_add such * that we can ensure that updating receiver->state is the last @@ -937,7 +932,19 @@ static inline void pipelined_send(struct wake_q_head *wake_q, * yet, at that point we can later have a use-after-free * condition and bogus wakeup. */ - receiver->state = STATE_READY; + this->state = STATE_READY; +} + +/* pipelined_send() - send a message directly to the task waiting in + * sys_mq_timedreceive() (without inserting message into a queue). + */ +static inline void pipelined_send(struct wake_q_head *wake_q, + struct mqueue_inode_info *info, + struct msg_msg *message, + struct ext_wait_queue *receiver) +{ + receiver->msg = message; + __pipelined_op(wake_q, info, receiver); } /* pipelined_receive() - if there is task waiting in sys_mq_timedsend() @@ -955,9 +962,7 @@ static inline void pipelined_receive(struct wake_q_head *wake_q, if (msg_insert(sender->msg, info)) return; - list_del(&sender->list); - wake_q_add(wake_q, sender->task); - sender->state = STATE_READY; + __pipelined_op(wake_q, info, sender); } static int do_mq_timedsend(mqd_t mqdes, const char __user *u_msg_ptr, -- 2.21.0