Received: by 2002:a05:6358:a55:b0:ec:fcf4:3ecf with SMTP id 21csp1231666rwb; Fri, 13 Jan 2023 09:28:30 -0800 (PST) X-Google-Smtp-Source: AMrXdXvqpWwPYISumWVD4/t4x4JnIGWKl99LBMuWYdD7fFZ+6NY8vbGiNNgoCvHJFFR5sQNA1vuZ X-Received: by 2002:a17:906:6dd4:b0:836:e6f7:8138 with SMTP id j20-20020a1709066dd400b00836e6f78138mr83275611ejt.13.1673630910496; Fri, 13 Jan 2023 09:28:30 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1673630910; cv=none; d=google.com; s=arc-20160816; b=cHx4ympXMr+OO4wygIUE/65GfYfQDO03jnj+QCnRVQ2DkXfaLygaZ324Mk4trHuFEz qzVGuOWAV3hpter495Iy+vTtEat0Bgr3CoLni34k1r2y/1KbrgT4IpHyUHUFFtxZlm2Y Irz2C2mbPWC3oIqrv4G+b7Q/ZK9C0zcH1B2rC1OK55gYTxDq4RtSiIDeBD4grcGb5k5M lPcGN5SlcHMj6jVysVNGmxEUOAtxH73KoykS2c1jLAQkgvU5IfGX/L+YdCMGjoY4PFR7 nsZY9M/+S//bVDDvtVkretIQkeTVRHUT2o1XONgpqDiOgcZjpzjSWOF8FK7tSKueh73g YnEw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=TXs9MNGZuNThunUHW4Hk0yGJUB85iqE/KufdrUbagcc=; b=kEEsM+wP4a4VOVRhVLYfUu48b8c49A65NLt0Sbv8ciUonquCN9ISa6GzrwlygxddY3 WWAKGLlkIaNEYJtSgGFIi6jCT9UxxGk8XL/5Uvyw/7+7p6fy7aV3EX3P7JAkE5OTjDlz yn6kv5V8Yna/lirNgP00thqJbNqCx3VlyHwsice0Aa9F1b9BPoRlrJcmcLACqV2zOHop ckKlEOmbFEout4LMCruWyBX/wq+rTPHs6TUEtY9hKlEvF/AjhdOD1FLHpFsMNWIPV9dA R5jYRpPnIunqYVwHfaFc7dGWSY8mWacM4Vx1/5yP70UFvIw5HJOq7mUTPkNtvamq8GOs 71ow== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@baikalelectronics.ru header.s=post header.b=GBC2VqXP; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=baikalelectronics.ru Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id ht20-20020a170907609400b007aeef4dd9cfsi24798032ejc.908.2023.01.13.09.28.18; Fri, 13 Jan 2023 09:28:30 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@baikalelectronics.ru header.s=post header.b=GBC2VqXP; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=baikalelectronics.ru Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231164AbjAMR0B (ORCPT + 51 others); Fri, 13 Jan 2023 12:26:01 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:37460 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231250AbjAMRX4 (ORCPT ); Fri, 13 Jan 2023 12:23:56 -0500 Received: from post.baikalelectronics.com (post.baikalelectronics.com [213.79.110.86]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id C34A0A4C70; Fri, 13 Jan 2023 09:14:43 -0800 (PST) Received: from post.baikalelectronics.com (localhost.localdomain [127.0.0.1]) by post.baikalelectronics.com (Proxmox) with ESMTP id 18C4FE0F2D; Fri, 13 Jan 2023 20:14:36 +0300 (MSK) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d= baikalelectronics.ru; h=cc:cc:content-transfer-encoding :content-type:content-type:date:from:from:in-reply-to:message-id :mime-version:references:reply-to:subject:subject:to:to; s=post; bh=TXs9MNGZuNThunUHW4Hk0yGJUB85iqE/KufdrUbagcc=; b=GBC2VqXPUK8M gFjxEzPvvphQuRB4U+NVu5YH754vTvLTLgH+xtgCDYj4ow6sf1cGqgJvKb6Y2Z9C vYbzfwKo/04qtAlQCMdO8HcULHa5J3GN39OmgE9+L3lKNgiDosfALkDZqEodjxNK 43v/xU1pELxZHy4dlJHaEJBgcZ2YKzE= Received: from mail.baikal.int (mail.baikal.int [192.168.51.25]) by post.baikalelectronics.com (Proxmox) with ESMTP id 06D5FE0F13; Fri, 13 Jan 2023 20:14:36 +0300 (MSK) Received: from localhost (10.8.30.26) by mail (192.168.51.25) with Microsoft SMTP Server (TLS) id 15.0.1395.4; Fri, 13 Jan 2023 20:14:35 +0300 From: Serge Semin To: Gustavo Pimentel , Vinod Koul , Rob Herring , Bjorn Helgaas , Lorenzo Pieralisi , Cai Huoqing , Robin Murphy , Jingoo Han , Frank Li , Manivannan Sadhasivam CC: Serge Semin , Serge Semin , Alexey Malahov , Pavel Parkhomenko , =?UTF-8?q?Krzysztof=20Wilczy=C5=84ski?= , caihuoqing , Yoshihiro Shimoda , , , Subject: [PATCH v9 22/27] dmaengine: dw-edma: Skip cleanup procedure if no private data found Date: Fri, 13 Jan 2023 20:14:04 +0300 Message-ID: <20230113171409.30470-23-Sergey.Semin@baikalelectronics.ru> X-Mailer: git-send-email 2.39.0 In-Reply-To: <20230113171409.30470-1-Sergey.Semin@baikalelectronics.ru> References: <20230113171409.30470-1-Sergey.Semin@baikalelectronics.ru> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Content-Type: text/plain X-Originating-IP: [10.8.30.26] X-ClientProxiedBy: MAIL.baikal.int (192.168.51.25) To mail (192.168.51.25) X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,SPF_HELO_PASS,SPF_PASS autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org DW eDMA driver private data is preserved in the passed DW eDMA chip info structure. If either probe procedure failed or for some reason the passed info object doesn't have private data pointer initialized we need to halt the DMA device cleanup procedure in order to prevent possible system crashes. Signed-off-by: Serge Semin Reviewed-by: Manivannan Sadhasivam Tested-by: Manivannan Sadhasivam Acked-by: Vinod Koul --- drivers/dma/dw-edma/dw-edma-core.c | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/drivers/dma/dw-edma/dw-edma-core.c b/drivers/dma/dw-edma/dw-edma-core.c index e3671bfbe186..1906a836f0aa 100644 --- a/drivers/dma/dw-edma/dw-edma-core.c +++ b/drivers/dma/dw-edma/dw-edma-core.c @@ -1011,6 +1011,10 @@ int dw_edma_remove(struct dw_edma_chip *chip) struct dw_edma *dw = chip->dw; int i; + /* Skip removal if no private data found */ + if (!dw) + return -ENODEV; + /* Disable eDMA */ dw_edma_v0_core_off(dw); -- 2.39.0