Received: by 2002:a05:6a10:1a4d:0:0:0:0 with SMTP id nk13csp1811991pxb; Wed, 2 Feb 2022 13:05:22 -0800 (PST) X-Google-Smtp-Source: ABdhPJzO81awSg0+NQAREliO5Z+ZHbhhoOdZRaFg9vGRu5/+mjbqR55WuBOB55vW7Sv/qWnmiR1j X-Received: by 2002:a17:903:22d2:: with SMTP id y18mr32311902plg.155.1643835922244; Wed, 02 Feb 2022 13:05:22 -0800 (PST) ARC-Seal: i=2; a=rsa-sha256; t=1643835922; cv=pass; d=google.com; s=arc-20160816; b=RMIsGhD0YNHIcQ90PZ2jSexy/pPbrjlmP9VxlsP29kVq2QWgw5HuV04qXq6viJvXzM vlkWQOrkycoMpye0i6Xq5LKchd/pF5+TqJlky+JQ7HjFAXMWZe5DoTMEaeDpO7Dmep1q mWnDQ9TeAfpCkFkAu/AFQWf+JzodQcST9+Zza/f1KEV8OLNjOpY5f9Cmr5mrGxw1w5Vb MKTvGu3z5Kul+CMX+wbMOIzkljjGUaMlRf6Ij+9GGvcxr5FmXsZGqZy0wxDHytLZ6/pM pMIg0cCoCnQX2Evjtgok9r3jddqgxZWu1g40hyWClamwZ3XErOY5ugDBAfYUsj4ih9m7 ZrZQ== ARC-Message-Signature: i=2; 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=CFEn0UUnaUvIrAwe2SsbLn28fGMHteelCuGN/CViotY=; b=wASF6vvxa9yHCgma1tFSs/TXnUnZ9vDH8KXSgE8+b+N2Tz7QC5FkyhpZAlJfqYtE1h aUhB8c5yZhQ6Y1zOKiUfV3BF+WRzR6bU1v844Z8N+MQhZ0/d01kq3e/E/iNYR2ZPjv6w 6UfVJcCOcGz9FDjc4mEGAw9d4T5wdT+A79Arr4vXqtFRSrsUYsLXh5ROl+IscrsSILpj qes3M3lXeidHSffYtTKfM8n05LvRAef0dl60gkJ3bugGrht6aq/jkq+UC624zr6J48I7 dcAPtytJ8XGS2ZhlOLPfwAUyBPd4LL7MH9fvBv/yC2gnPcLhGMxKavpiaA9eJ9Oy0IOF hfow== ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@amd.com header.s=selector1 header.b=n+90alCJ; arc=pass (i=1 spf=pass spfdomain=amd.com dmarc=pass fromdomain=amd.com); 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=QUARANTINE sp=QUARANTINE dis=NONE) header.from=amd.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id k15si24285145pga.737.2022.02.02.13.05.10; Wed, 02 Feb 2022 13:05:22 -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=@amd.com header.s=selector1 header.b=n+90alCJ; arc=pass (i=1 spf=pass spfdomain=amd.com dmarc=pass fromdomain=amd.com); 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=QUARANTINE sp=QUARANTINE dis=NONE) header.from=amd.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S237607AbiBBPPr (ORCPT + 99 others); Wed, 2 Feb 2022 10:15:47 -0500 Received: from mail-bn7nam10on2040.outbound.protection.outlook.com ([40.107.92.40]:21799 "EHLO NAM10-BN7-obe.outbound.protection.outlook.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S229758AbiBBPPq (ORCPT ); Wed, 2 Feb 2022 10:15:46 -0500 ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=nR+IdV3g3kbSmEtRGhtoyZycA28QvnPLjM2aICjb8dyPe9tBZMki0jwJZyYXJfTfSmIrkIB+8UpH8O9PpSY+C3MppT2Mf0VSnxD8gWvl5at8eixqsLj2kyb47hreQfMBxVjnCW5SsuL6vIRjFtk7rYQJZ0nrEAPt2x22HtzxGLSH8GFhmONuxI1fMSb8s+MS/TpTBTg0L3fP3RCQGo04XfNq8HXJ2YFIzT38hm/89PR2ObviJfBInjM5WIPKpbeBqSx2uZS5XW3z9yh5LenBHm22nZXQaLJbeH+rKGTQTmKePt2vPmSMAvrIg0xTV1xoofxfPKPtSoDj2Ei3yv8pHQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-AntiSpam-MessageData-ChunkCount:X-MS-Exchange-AntiSpam-MessageData-0:X-MS-Exchange-AntiSpam-MessageData-1; bh=CFEn0UUnaUvIrAwe2SsbLn28fGMHteelCuGN/CViotY=; b=go/rKBifldCbcyJRIbiuVtgr+Ik80jLE696iPcjmi53Mcphui+8iPsbo5Qe+awRAuoHNNwjayaylu5cJwZAF3QYiWWXT1wFpCxpcLBkham8nnXaBB+982p263nzMR+F5eLlV2TnzUeIORsSWBTfz7xPn1qI6cqr5SUjMDDaStIY1jSzCnZ8fOhyyeCEYA2ih5F0/YqvVcPE1kPsF1GBJWn9S6+AlAq7cTR3Z4MuYWO9oqfVvQv4WHewHJpFWDXJJgyhGWkk8pDrMz0Y/54mscGaFt8oaZVy/ImE8fX+/Jc7T2WIzlQa6zSALyJxPcO3P7daCaBk5TLNE7feFuvZyhw== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass (sender ip is 165.204.84.17) smtp.rcpttodomain=kernel.org smtp.mailfrom=amd.com; dmarc=pass (p=quarantine sp=quarantine pct=100) action=none header.from=amd.com; dkim=none (message not signed); arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=amd.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=CFEn0UUnaUvIrAwe2SsbLn28fGMHteelCuGN/CViotY=; b=n+90alCJcS8qj/x4xLQ6yqIDeJoSJpK+N8yjjEbkTcueDVsU9ilvIe/I6Ji5xZcUPBQCPGAkrIbFhycNSdJJ5TXUeArYnRfUJnok/QqmqT9YDdldGCN/HsUi1b//iK9u+2IUTtHapfDg9yn54ETCIbmt0GSB/Ssf9Xqucgb8/Vk= Received: from CO1PR15CA0067.namprd15.prod.outlook.com (2603:10b6:101:20::11) by DM5PR1201MB0219.namprd12.prod.outlook.com (2603:10b6:4:56::19) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.4930.15; Wed, 2 Feb 2022 15:15:43 +0000 Received: from CO1NAM11FT050.eop-nam11.prod.protection.outlook.com (2603:10b6:101:20:cafe::73) by CO1PR15CA0067.outlook.office365.com (2603:10b6:101:20::11) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.4951.12 via Frontend Transport; Wed, 2 Feb 2022 15:15:42 +0000 X-MS-Exchange-Authentication-Results: spf=pass (sender IP is 165.204.84.17) smtp.mailfrom=amd.com; dkim=none (message not signed) header.d=none;dmarc=pass action=none header.from=amd.com; Received-SPF: Pass (protection.outlook.com: domain of amd.com designates 165.204.84.17 as permitted sender) receiver=protection.outlook.com; client-ip=165.204.84.17; helo=SATLEXMB04.amd.com; Received: from SATLEXMB04.amd.com (165.204.84.17) by CO1NAM11FT050.mail.protection.outlook.com (10.13.174.79) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.20.4951.12 via Frontend Transport; Wed, 2 Feb 2022 15:15:42 +0000 Received: from sanjuamdntb2.amd.com (10.180.168.240) by SATLEXMB04.amd.com (10.181.40.145) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2375.18; Wed, 2 Feb 2022 09:15:38 -0600 From: Sanjay R Mehta To: CC: , , , , , , , , Sanjay R Mehta Subject: [PATCH v2 1/2] dmaengine: ptdma: fix concurrency issue with multiple dma transfer Date: Wed, 2 Feb 2022 09:14:39 -0600 Message-ID: <1643814880-3882-2-git-send-email-Sanju.Mehta@amd.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1643814880-3882-1-git-send-email-Sanju.Mehta@amd.com> References: <1643814880-3882-1-git-send-email-Sanju.Mehta@amd.com> MIME-Version: 1.0 Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit X-Originating-IP: [10.180.168.240] X-ClientProxiedBy: SATLEXMB04.amd.com (10.181.40.145) To SATLEXMB04.amd.com (10.181.40.145) X-EOPAttributedMessage: 0 X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id: f8681760-4db6-4865-259a-08d9e65ee125 X-MS-TrafficTypeDiagnostic: DM5PR1201MB0219:EE_ X-Microsoft-Antispam-PRVS: X-MS-Oob-TLC-OOBClassifiers: OLM:7691; X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: Dn2k1CPKx3tevrp3kTDVsJVkXtSjmY00/+ONpE/Wv9oe1Z27FW7mg7/0sph+2LCvMyZfDlI8Nb/Wpeha81TbSWuGuMHm5mPw4rfm0zsaqkciIYTBSc5aeBLZjwACjALG2y7rpsYIdxsoboyHnYtFtyr2m86/fZyNcFziB1BbSxMNmI8WVAkJEzkr1/zm+feUsWQeDyrQZ6K+nXixgI6+kz2Eeyvww9WUs1cjPNZVifNX/H9CBhc0Ty3VNJsf3EqHBQXPiw7ijOhNE1XMaHiJAj8F11e1GeyaWfmO53L+Xy2Yfnposs2H/6ia0rBSTDr++63lkjnZsJb+KGa4YJO9P/lTBS9skzpIi6x3p+yhgy1n4VeGb/8cV0grSwoEvNsHLDvQ48tu2rFF8bgFjBWDKAozCKBWGaGtYt4dMIY7Xa7CHRk2uzAswxEJkJNPFZ/MlN72ThKDNgkA8Vj9l3OwP4LRY7DJGOa3S5U4xYuh6zDmy2IfRvlZNA2YnrrXumxrPNmEsM601qM2YmCE9MCEF8SAsVBXCMFZ7H1fkz6mq4TViX/y9nhn5gIgeiZNIflIuaL6mgFsXR6asuonv/srBnnIaqKP1EyunFqeCNUZe91PK2HZkXYzWVdcGqoOw3eZr2LGRPeTe+dsHN1Bg7Ml+3jXBO7ytG30WpCYp1WHDKGcBZcCzWtirappozAti8DfQjC4+R9lu2ItN8s+vtiCfQ== X-Forefront-Antispam-Report: CIP:165.204.84.17;CTRY:US;LANG:en;SCL:1;SRV:;IPV:CAL;SFV:NSPM;H:SATLEXMB04.amd.com;PTR:InfoDomainNonexistent;CAT:NONE;SFS:(13230001)(4636009)(46966006)(40470700004)(36840700001)(86362001)(82310400004)(81166007)(356005)(40460700003)(36860700001)(8936002)(8676002)(70586007)(70206006)(4326008)(54906003)(316002)(6916009)(5660300002)(26005)(16526019)(36756003)(2616005)(426003)(47076005)(83380400001)(336012)(508600001)(7696005)(2906002)(186003)(36900700001);DIR:OUT;SFP:1101; X-OriginatorOrg: amd.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 02 Feb 2022 15:15:42.6383 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: f8681760-4db6-4865-259a-08d9e65ee125 X-MS-Exchange-CrossTenant-Id: 3dd8961f-e488-4e60-8e11-a82d994e183d X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=3dd8961f-e488-4e60-8e11-a82d994e183d;Ip=[165.204.84.17];Helo=[SATLEXMB04.amd.com] X-MS-Exchange-CrossTenant-AuthSource: CO1NAM11FT050.eop-nam11.prod.protection.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Anonymous X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: DM5PR1201MB0219 Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Sanjay R Mehta The command should be submitted only if the engine is idle, for this, the next available descriptor is checked and set the flag to false in case the descriptor is non-empty. Signed-off-by: Sanjay R Mehta --- drivers/dma/ptdma/ptdma-dmaengine.c | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/drivers/dma/ptdma/ptdma-dmaengine.c b/drivers/dma/ptdma/ptdma-dmaengine.c index c9e52f6..e38dca4 100644 --- a/drivers/dma/ptdma/ptdma-dmaengine.c +++ b/drivers/dma/ptdma/ptdma-dmaengine.c @@ -233,9 +233,14 @@ static void pt_issue_pending(struct dma_chan *dma_chan) struct pt_dma_chan *chan = to_pt_chan(dma_chan); struct pt_dma_desc *desc; unsigned long flags; + bool engine_is_idle = true; spin_lock_irqsave(&chan->vc.lock, flags); + desc = pt_next_dma_desc(chan); + if (desc) + engine_is_idle = false; + vchan_issue_pending(&chan->vc); desc = pt_next_dma_desc(chan); @@ -243,7 +248,7 @@ static void pt_issue_pending(struct dma_chan *dma_chan) spin_unlock_irqrestore(&chan->vc.lock, flags); /* If there was nothing active, start processing */ - if (desc) + if (engine_is_idle) pt_cmd_callback(desc, 0); } -- 2.7.4