Received: by 10.223.176.5 with SMTP id f5csp2430204wra; Sun, 28 Jan 2018 20:41:57 -0800 (PST) X-Google-Smtp-Source: AH8x225MRsYvLJ3PTIyasjw07Z5z1aqMI6GeiSFIR2+Lb+sKF++EAX04iSEpKAWaAP9hh7kFJqK5 X-Received: by 10.99.123.27 with SMTP id w27mr20775409pgc.49.1517200917019; Sun, 28 Jan 2018 20:41:57 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1517200916; cv=none; d=google.com; s=arc-20160816; b=QkWKrKPQ9RFDSJT8Exvdi5FNv7jUbJnPoP2k8IrFRFlu02V4aerUV7ZBoky7NUtQVM Zq1MblM4k95hxAXDfw2oqP9wkotkU+uXnU5Duysyas72BsqslwojYNLL2GRT8bGkVYTs /beeTyrXJepupROiQpUgJza12mDyeyBCscpGfFehgvq/lU1YnK42EFV3F+gjabMJvt5A hhyi9I6GwDLHnUAcaR/Uk6REB0T4fmiwrHCXW3cJc1a0LmfVAJnXB6TFw8P1wxBQ+cPy kH9HfgGLrLGVu8C4TFJIRt2f7mCF/PUe+vRbmzfL0AwzcdcCYuhXhbcnwXE5Kr1QXA0t Jjqg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date:arc-authentication-results; bh=xMW1kWSKb3QKIEn7cWIbH7TJBUNwRIU47EQ5w5xYJoE=; b=IWAiZjdEvOHpGWBBtIKVChIdvTP5mIXkereLbdJ/NPzM1nzebg8TM9XQy49j3onuko BiUTuQFPPaFy/H1clgraHQrhj/0Q349v3m50x1TvKE63Rz5jt8cIuQbvqHfj1Ex1sLfL 4ItNJOuAiqmDVFw5uCkjfUlbecSiwnbZ8DeEsA2LiDNEAL8gB4l6xEVehFCdogKpWQGG GTFmsVMb0N8w+rPMMe+6eaLtvfiU9qEFta45HU7MI/JOh+cfrBH0DR4AOuAsQiER4p3p YPthNXxAMjRf0ipVi/2y57WnqHeu6PnMR5dilU232i2QQy1UXVkhtWD+5E2bZTykzqCk uU2Q== 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id f19-v6si8257185plr.197.2018.01.28.20.41.42; Sun, 28 Jan 2018 20:41:56 -0800 (PST) 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751330AbeA2ElS (ORCPT + 99 others); Sun, 28 Jan 2018 23:41:18 -0500 Received: from mga11.intel.com ([192.55.52.93]:22650 "EHLO mga11.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751127AbeA2ElQ (ORCPT ); Sun, 28 Jan 2018 23:41:16 -0500 X-Amp-Result: UNKNOWN X-Amp-Original-Verdict: FILE UNKNOWN X-Amp-File-Uploaded: False Received: from orsmga008.jf.intel.com ([10.7.209.65]) by fmsmga102.fm.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 28 Jan 2018 20:41:16 -0800 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.46,429,1511856000"; d="scan'208";a="13773590" Received: from vkoul-udesk7.iind.intel.com (HELO localhost) ([10.223.84.143]) by orsmga008.jf.intel.com with ESMTP; 28 Jan 2018 20:41:13 -0800 Date: Mon, 29 Jan 2018 10:15:48 +0530 From: Vinod Koul To: Yang Shunyong Cc: dan.j.williams@intel.com, awallis@codeaurora.org, yu.zheng@hxt-semitech.com, dmaengine@vger.kernel.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH] dmaengine: dmatest: fix container_of member in dmatest_callback Message-ID: <20180129044547.GK18649@localhost> References: <1516606108-40562-1-git-send-email-shunyong.yang@hxt-semitech.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <1516606108-40562-1-git-send-email-shunyong.yang@hxt-semitech.com> User-Agent: Mutt/1.5.24 (2015-08-30) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Mon, Jan 22, 2018 at 03:28:28PM +0800, Yang Shunyong wrote: > The type of arg passed to dmatest_callback is struct dmatest_done. > It refers to test_done in struct dmatest_thread, not done_wait. > > Fixes: 6f6a23a213be ("dmaengine: dmatest: move callback wait ...") > Signed-off-by: Yang Shunyong > --- > drivers/dma/dmatest.c | 2 +- > 1 file changed, 1 insertion(+), 1 deletion(-) > > diff --git a/drivers/dma/dmatest.c b/drivers/dma/dmatest.c > index ec5f9d2bc820..906e85d6dedc 100644 > --- a/drivers/dma/dmatest.c > +++ b/drivers/dma/dmatest.c > @@ -355,7 +355,7 @@ static void dmatest_callback(void *arg) > { > struct dmatest_done *done = arg; > struct dmatest_thread *thread = > - container_of(arg, struct dmatest_thread, done_wait); > + container_of(arg, struct dmatest_thread, test_done); This fixes it but one of the reason why compilers didn't catch this was the void arg. I just tested and used 'done' as the argument here rather than 'arg' and compiler was quick to point out the error. So a better fix IMO would be: -- >8 -- diff --git a/drivers/dma/dmatest.c b/drivers/dma/dmatest.c index ec5f9d2bc820..80cc2be6483c 100644 --- a/drivers/dma/dmatest.c +++ b/drivers/dma/dmatest.c @@ -355,7 +355,7 @@ static void dmatest_callback(void *arg) { struct dmatest_done *done = arg; struct dmatest_thread *thread = - container_of(arg, struct dmatest_thread, done_wait); + container_of(done, struct dmatest_thread, test_done); if (!thread->done) { done->done = true; wake_up_all(done->wait); -- ~Vinod