Received: by 2002:ac0:a5a7:0:0:0:0:0 with SMTP id m36-v6csp153076imm; Fri, 3 Aug 2018 00:57:31 -0700 (PDT) X-Google-Smtp-Source: AAOMgpdgihzdtHsUadLpwqT0VK6lRwT+eTRB25Acwj5YLrU5EI2adGW1jWYd4h9CB9VaXh2Mr9R+ X-Received: by 2002:a17:902:9696:: with SMTP id n22-v6mr2535922plp.212.1533283051231; Fri, 03 Aug 2018 00:57:31 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1533283051; cv=none; d=google.com; s=arc-20160816; b=pDCYklkKtZB0ngM1KPRHoldT+lZChrMwz3vTouxsdh8Jn+S5s532nM4pssAIy5xpcC 4vxciqvqf0iDFwLmRXb/p3gTyI1toqOOU3z1inmifPScZQsBmJdthLACA+CbEUHGSqK6 GhQheRyDiodVnsVu5BOYsbkT1QBFDV+2HG9Pwx6H21tlps0Jp1cHpBeKcq5ondp21hQL CxU3DlWScsnZELRc7CBFhVOyjLkNw4XYZdLEbogbJLgQ3+zaD5tCK6omUs5SGn8ba5gI BsnbkajCbhCWKJSzF+b6xLKv4D62rKSPcvO1pjtOdO2e2bqUN2X4v4KSY2dQ9tvWnETl lwTg== 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 :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:dkim-signature :arc-authentication-results; bh=TtmRGzYiYl89s1qnvC2204ZWt8WRN2Pzv/dACAC6nwU=; b=Sl0yfkcFBVgjugVq6oD7QNdl6aGMXvNVT0vLwKIioOGbxQVsJovxaIKMi+gIeNKa0Q D2bllXNZcFwZOlihM3D/5/qzlriSbreJ79ChAbhvVHGEoZosExz6Lpt3jE/UXjYrhTZX /VjRKb5w5bVkJeR8cB9yO7wC3eFmb9TvxdHG6zoY3amCwDoKcdbz0pI1mgUNZMzrgY63 GCqnFC0O/6EjJDJEj+bAU29iK0g6gRwNoZ4oRSHJDEKZRLNXb3WuytultuzgqUsFlcwx g8IExXSq+KL6lHssBFIKaacq5zDgLKG4jWJslrA13kchTvSnKwkj/L+00ie2APw20wVM M5SQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@ti.com header.s=ti-com-17Q1 header.b=mCVUqD62; 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=QUARANTINE sp=NONE dis=NONE) header.from=ti.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id h2-v6si4200057pgk.330.2018.08.03.00.57.16; Fri, 03 Aug 2018 00:57: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=@ti.com header.s=ti-com-17Q1 header.b=mCVUqD62; 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=QUARANTINE sp=NONE dis=NONE) header.from=ti.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729790AbeHCJuu (ORCPT + 99 others); Fri, 3 Aug 2018 05:50:50 -0400 Received: from lelv0142.ext.ti.com ([198.47.23.249]:36418 "EHLO lelv0142.ext.ti.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727594AbeHCJut (ORCPT ); Fri, 3 Aug 2018 05:50:49 -0400 Received: from dflxv15.itg.ti.com ([128.247.5.124]) by lelv0142.ext.ti.com (8.15.2/8.15.2) with ESMTP id w737tMPN084470; Fri, 3 Aug 2018 02:55:22 -0500 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ti.com; s=ti-com-17Q1; t=1533282922; bh=TtmRGzYiYl89s1qnvC2204ZWt8WRN2Pzv/dACAC6nwU=; h=Subject:To:CC:References:From:Date:In-Reply-To; b=mCVUqD62pmw71/zUm12CFOEfqoRkvHUdFdhexqL0ssrFFLoM63HRSFzBNNrHjLfAN BsbceucmcFObrful/mtdGuxex10NPpyhK5t9i9CPUbiMY4XEMpI3KocVpBd7wZHoy2 053VjYgg6yYJNHbyFAMAMuTLv1Ux1NwkhtvgMM8c= Received: from DLEE113.ent.ti.com (dlee113.ent.ti.com [157.170.170.24]) by dflxv15.itg.ti.com (8.14.3/8.13.8) with ESMTP id w737tMLN005133; Fri, 3 Aug 2018 02:55:22 -0500 Received: from DLEE114.ent.ti.com (157.170.170.25) by DLEE113.ent.ti.com (157.170.170.24) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256_P256) id 15.1.1466.3; Fri, 3 Aug 2018 02:55:22 -0500 Received: from dlep32.itg.ti.com (157.170.170.100) by DLEE114.ent.ti.com (157.170.170.25) with Microsoft SMTP Server (version=TLS1_0, cipher=TLS_RSA_WITH_AES_256_CBC_SHA) id 15.1.1466.3 via Frontend Transport; Fri, 3 Aug 2018 02:55:22 -0500 Received: from [192.168.2.6] (ileax41-snat.itg.ti.com [10.172.224.153]) by dlep32.itg.ti.com (8.14.3/8.13.8) with ESMTP id w737tHhr000650; Fri, 3 Aug 2018 02:55:18 -0500 Subject: Re: [PATCH 09/46] dmaengine: cppi41: use dmaenginem_async_device_register to simplify the code To: Huang Shijie , CC: , , , , , , , , , , , , , , , , References: <20180803072016.21544-1-sjhuang@iluvatar.ai> <20180803072016.21544-10-sjhuang@iluvatar.ai> From: Peter Ujfalusi Message-ID: <43458794-d124-13df-c944-e473dc8ee1c2@ti.com> Date: Fri, 3 Aug 2018 10:55:25 +0300 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.9.0 MIME-Version: 1.0 In-Reply-To: <20180803072016.21544-10-sjhuang@iluvatar.ai> Content-Type: text/plain; charset="utf-8" Content-Language: en-US Content-Transfer-Encoding: 8bit X-EXCLAIMER-MD-CONFIG: e1e8a2fd-e40a-4ac6-ac9b-f7e9cc9ee180 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 2018-08-03 10:19, Huang Shijie wrote: > Use dmaenginem_async_device_register to simplify the code: > remove dma_async_device_unregister > > Signed-off-by: Huang Shijie > --- > drivers/dma/ti/cppi41.c | 7 ++----- > 1 file changed, 2 insertions(+), 5 deletions(-) > > diff --git a/drivers/dma/ti/cppi41.c b/drivers/dma/ti/cppi41.c > index 1497da367710..d2998a19ed2e 100644 > --- a/drivers/dma/ti/cppi41.c > +++ b/drivers/dma/ti/cppi41.c > @@ -1096,21 +1096,19 @@ static int cppi41_dma_probe(struct platform_device *pdev) > goto err_chans; > cdd->irq = irq; > > - ret = dma_async_device_register(&cdd->ddev); > + ret = dmaenginem_async_device_register(&cdd->ddev); > if (ret) > goto err_chans; > > ret = of_dma_controller_register(dev->of_node, > cppi41_dma_xlate, &cpp41_dma_info); > if (ret) > - goto err_of; > + goto err_chans; > > pm_runtime_mark_last_busy(dev); > pm_runtime_put_autosuspend(dev); > > return 0; > -err_of: > - dma_async_device_unregister(&cdd->ddev); > err_chans: > deinit_cppi41(dev, cdd); > err_init_cppi: > @@ -1132,7 +1130,6 @@ static int cppi41_dma_remove(struct platform_device *pdev) > dev_err(&pdev->dev, "%s could not pm_runtime_get: %i\n", > __func__, error); > of_dma_controller_free(pdev->dev.of_node); > - dma_async_device_unregister(&cdd->ddev); If I read the code right then this is not safe. We would have deinitalized cppi41 driver which is not functional, but we will still have the dma device registered and if a channel is requested we will have kernel crash. It falls in the same case as omap-dma, edma. > > devm_free_irq(&pdev->dev, cdd->irq, cdd); > deinit_cppi41(&pdev->dev, cdd); > - Péter Texas Instruments Finland Oy, Porkkalankatu 22, 00180 Helsinki. Y-tunnus/Business ID: 0615521-4. Kotipaikka/Domicile: Helsinki