From patchwork Tue Sep 15 21:30:35 2020 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: John Villalovos X-Patchwork-Id: 263983 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-12.8 required=3.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID, DKIM_VALID_AU, HEADER_FROM_DIFFERENT_DOMAINS, INCLUDES_PATCH, MAILING_LIST_MULTI, MSGID_FROM_MTA_HEADER, SIGNED_OFF_BY, SPF_HELO_NONE, SPF_PASS, URIBL_BLOCKED, USER_AGENT_GIT autolearn=ham autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id B74C2C2D0E3 for ; Tue, 15 Sep 2020 21:42:24 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by mail.kernel.org (Postfix) with ESMTP id 737CA2078E for ; Tue, 15 Sep 2020 21:42:24 +0000 (UTC) Authentication-Results: mail.kernel.org; dkim=pass (1024-bit key) header.d=os.amperecomputing.com header.i=@os.amperecomputing.com header.b="djDh3Vuu" Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727971AbgIOVmV (ORCPT ); Tue, 15 Sep 2020 17:42:21 -0400 Received: from mail-bn8nam12on2133.outbound.protection.outlook.com ([40.107.237.133]:5473 "EHLO NAM12-BN8-obe.outbound.protection.outlook.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1728122AbgIOVbt (ORCPT ); Tue, 15 Sep 2020 17:31:49 -0400 ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=AisxWY/hKReXzqOOlwlF0I5LPy3Di+XTxo1wKEtEdVBduQCVX6MacePAIsAqp69/ZrlP9fiJHHA5I5BNGs4bToCXg3I4oOUwZkiF2qwyeAMWquc7pPsMh6oNedOKVByrn5vrs/k9nuysXfHFwOqjwm7w2I39MxhTfH5lVDtDl5CZhX158A8H0G7AIjxFcvd/dvFwKV4TLoO/td/WsPKVds7vdFHIvBHX3JjYneJs68TdPCb+xL01QNs46s+8sD0wNXJSLmyIY3b2iCzaFrWW/diHVVzqpexcW+XnrbZMjPU8OGPdC1mLdp0DlFft/akDqH6aDHcAt4FKS7gF7O2PfQ== 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-SenderADCheck; bh=JRgoaYwsptwvSEGhZtkanK8RAy0s3MnugJYQQU77ibE=; b=JhfYGV0h7F+kXoRvnquFrwaKoTCyrzqpYCO2NmwPEBcsERN2jAwscRErxPQtTujDkHh6JBqayk8HvLM+Xop6WMB0+jyCMqpkPCLK2dvCZmhDO4m/K5vDQd4h0Qs39AKaOBJUmc3P5CeyQFRZ8fUXfvo5lZ5QcvDou+predpLdnvZKSx9xIIFduZv/+YawEaRCtyWKV5BAlUGR7Kw6t+ID02Soc+20mLeU2t97tWwhfrLgJZqXqjpTQ8dm5VXPLLTSUN9KWY3J8pu1JYIpAPRNyT+6GMF2XqVfLz61iszxjx7ZMglV2SrBfj5Uj4WDZPlGIOR6vnV6owOUwZdy2VG6g== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=os.amperecomputing.com; dmarc=pass action=none header.from=os.amperecomputing.com; dkim=pass header.d=os.amperecomputing.com; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=os.amperecomputing.com; s=selector2; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=JRgoaYwsptwvSEGhZtkanK8RAy0s3MnugJYQQU77ibE=; b=djDh3VuuWJ+0E9TfjWcCxoWr7sCn69Kb/vijzN9MVkHUVHqt9McPmy1LUbuY/rrrsxqdW5e7xhmFAlbUjCjN7BVhGdUNHy/YA9Lt8EXcESHFgYIuX6xts3QsyT/UqnZQaNerLMBmPGmJWBL2R7zzI008vvZZQOr2fnVcZepPjqM= Authentication-Results: vger.kernel.org; dkim=none (message not signed) header.d=none;vger.kernel.org; dmarc=none action=none header.from=os.amperecomputing.com; Received: from DM6PR01MB5802.prod.exchangelabs.com (2603:10b6:5:203::17) by DM6PR01MB5516.prod.exchangelabs.com (2603:10b6:5:153::22) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.3370.17; Tue, 15 Sep 2020 21:31:08 +0000 Received: from DM6PR01MB5802.prod.exchangelabs.com ([fe80::ed9e:20e7:332a:704b]) by DM6PR01MB5802.prod.exchangelabs.com ([fe80::ed9e:20e7:332a:704b%7]) with mapi id 15.20.3391.011; Tue, 15 Sep 2020 21:31:08 +0000 From: "John L. Villalovos" To: stable@vger.kernel.org Cc: "John L. Villalovos" , Fredrik Noring , Greg Kroah-Hartman , Christoph Hellwig Subject: [PATCH 4.19 1/5] lib/genalloc: add gen_pool_dma_zalloc() for zeroed DMA allocations Date: Tue, 15 Sep 2020 14:30:35 -0700 Message-Id: <20200915213039.862123-2-jlvillal@os.amperecomputing.com> X-Mailer: git-send-email 2.26.2 In-Reply-To: <20200915213039.862123-1-jlvillal@os.amperecomputing.com> References: <20200915213039.862123-1-jlvillal@os.amperecomputing.com> X-ClientProxiedBy: CY4PR14CA0040.namprd14.prod.outlook.com (2603:10b6:903:101::26) To DM6PR01MB5802.prod.exchangelabs.com (2603:10b6:5:203::17) MIME-Version: 1.0 X-MS-Exchange-MessageSentRepresentingType: 1 Received: from localhost.localdomain (4.28.12.214) by CY4PR14CA0040.namprd14.prod.outlook.com (2603:10b6:903:101::26) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.3370.16 via Frontend Transport; Tue, 15 Sep 2020 21:31:07 +0000 X-Mailer: git-send-email 2.26.2 X-Originating-IP: [4.28.12.214] X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id: 1f1483e1-ac62-4958-4249-08d859bea884 X-MS-TrafficTypeDiagnostic: DM6PR01MB5516: X-MS-Exchange-Transport-Forked: True X-Microsoft-Antispam-PRVS: X-MS-Oob-TLC-OOBClassifiers: OLM:1443; X-MS-Exchange-SenderADCheck: 1 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: J8fNB7lRwBmNPtXp2QioRId0Gyp01aTRdHiS5x8ageq/pkso8Efuwmgk2hP/c3d7YU6zTEU+Irs7JB8kKUZ/1kyiXExYoockdWDdgGZ9HwdoEQgr5H2aL+yEUqHttQddCnfYfIKiJoYEhY2FUzXk1MufHmQ0n2OuAPnlM/P1jhJYCXqxzjc+Zl92Ao3QPDBGoWzQuW/Px9PsbnKGqPd2Zu/vXbc8mGMJIbB0216C9xsPQsvFwQYDnqtXHnfH5NgHYfmNZlw2ISC5k1XIR19dD0x+lqGszlxkx3uZj2wG3emvjwk9iyqh/E5Oku6zlmJc0+AO0GzOt9FxIp6CblSHLbgmaJ7XWpLhwafq5GUJY/n2gjhzkwY+i0/RFbJyctS71cqt94Fd0f0ckLkPBOIkLWh8VyeBE7gRO9iEDqfVnCTqfl1LlGzkeQvtpCYaQ0hO X-Forefront-Antispam-Report: CIP:255.255.255.255; CTRY:; LANG:en; SCL:1; SRV:; IPV:NLI; SFV:NSPM; H:DM6PR01MB5802.prod.exchangelabs.com; PTR:; CAT:NONE; SFS:(4636009)(346002)(396003)(136003)(366004)(376002)(39850400004)(83380400001)(6512007)(8936002)(316002)(66946007)(16526019)(8676002)(4326008)(2616005)(6486002)(956004)(26005)(186003)(1076003)(54906003)(6666004)(6506007)(478600001)(5660300002)(86362001)(2906002)(66476007)(69590400008)(66556008)(52116002)(6916009); DIR:OUT; SFP:1102; X-MS-Exchange-AntiSpam-MessageData: BdSYy7qjYCKJxtk495hASrqodmpJNdiLr06XTd3FXb5UO6TyJSR7kG85weBBJI5ufEOBhKyPcySFQCGV6fFgEcMYAnJGJP6M5JQ3EQmt2zlwK8SK3W15SI+pM9Y12DgF1NFCV2X4ezGUvicEB369JnX+bYXsZlLJx5RkoMnsANFcAqy2QuICFER9BjB6wdBNOuUDNFbGv8omHFkONkNYjBBktL2oM23keAZwSqiI11zIbClgnLrg37sXvoIKrLpEA6kNVVUG+TGh5L2DI+ACPXLNx76OYpCWZJAqkZHg7kU89UG1MoooTHrPFWljdeK6DjZpOTfVp7ELsYmUdg+roN8G4A/aaCdepCnjJpsaK2iE+jsl35qDQFbEPX326ISa8qi+NQtgdJQG606N1qPwWg/YPEcr5KpO/BB2QHfxS37hbbgQpaaFX/ovEPFqeSK8Z7RmPlniq104BwML7MbCt1+kttjG6AIWFHl2ZokrtB/Oi6y/JyC4w3TcN6ywVijQbqzDfT8knzXjOIHjiUJoBRqkybHgiDCdVTZoPIIaCKT1EaTODHoBMv85eej05OehTpF/ExmDNpx0KDSR8Ugpcr4FL8H/xNE9Bte3Q2sT0IYJXDnlov1RLTlbLn/a5VDRK7UdGAcea/Zop2qNw+KEhg== X-OriginatorOrg: os.amperecomputing.com X-MS-Exchange-CrossTenant-Network-Message-Id: 1f1483e1-ac62-4958-4249-08d859bea884 X-MS-Exchange-CrossTenant-AuthSource: DM6PR01MB5802.prod.exchangelabs.com X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 15 Sep 2020 21:31:08.0212 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: 3bc2b170-fd94-476d-b0ce-4229bdc904a7 X-MS-Exchange-CrossTenant-MailboxType: HOSTED X-MS-Exchange-CrossTenant-UserPrincipalName: uLhCj3K11IaZc+o2Ut9peroDRvDRJTsDqxHTHiB/V98Z1eLqtb4j0hWFsxlpL47cp+3sGSVjeWVlX4VZ+FfxYvmXfqQliIR/RmxRQWaWE5xs54Uv0c0ATbPHUcZ1rnDG X-MS-Exchange-Transport-CrossTenantHeadersStamped: DM6PR01MB5516 Sender: stable-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: stable@vger.kernel.org commit da83a722959a82733c3ca60030cc364ca2318c5a upstream. gen_pool_dma_zalloc() is a zeroed memory variant of gen_pool_dma_alloc(). Also document the return values of both, and indicate NULL as a "%NULL" constant. Signed-off-by: Fredrik Noring Reviewed-by: Greg Kroah-Hartman Signed-off-by: Christoph Hellwig Signed-off-by: John L. Villalovos --- include/linux/genalloc.h | 1 + lib/genalloc.c | 29 ++++++++++++++++++++++++++++- 2 files changed, 29 insertions(+), 1 deletion(-) diff --git a/include/linux/genalloc.h b/include/linux/genalloc.h index dd0a452373e7..6c62eeca754f 100644 --- a/include/linux/genalloc.h +++ b/include/linux/genalloc.h @@ -121,6 +121,7 @@ extern unsigned long gen_pool_alloc_algo(struct gen_pool *, size_t, genpool_algo_t algo, void *data); extern void *gen_pool_dma_alloc(struct gen_pool *pool, size_t size, dma_addr_t *dma); +void *gen_pool_dma_zalloc(struct gen_pool *pool, size_t size, dma_addr_t *dma); extern void gen_pool_free(struct gen_pool *, unsigned long, size_t); extern void gen_pool_for_each_chunk(struct gen_pool *, void (*)(struct gen_pool *, struct gen_pool_chunk *, void *), void *); diff --git a/lib/genalloc.c b/lib/genalloc.c index 7e85d1e37a6e..5db43476a19b 100644 --- a/lib/genalloc.c +++ b/lib/genalloc.c @@ -337,12 +337,14 @@ EXPORT_SYMBOL(gen_pool_alloc_algo); * gen_pool_dma_alloc - allocate special memory from the pool for DMA usage * @pool: pool to allocate from * @size: number of bytes to allocate from the pool - * @dma: dma-view physical address return value. Use NULL if unneeded. + * @dma: dma-view physical address return value. Use %NULL if unneeded. * * Allocate the requested number of bytes from the specified pool. * Uses the pool allocation function (with first-fit algorithm by default). * Can not be used in NMI handler on architectures without * NMI-safe cmpxchg implementation. + * + * Return: virtual address of the allocated memory, or %NULL on failure */ void *gen_pool_dma_alloc(struct gen_pool *pool, size_t size, dma_addr_t *dma) { @@ -362,6 +364,31 @@ void *gen_pool_dma_alloc(struct gen_pool *pool, size_t size, dma_addr_t *dma) } EXPORT_SYMBOL(gen_pool_dma_alloc); +/** + * gen_pool_dma_zalloc - allocate special zeroed memory from the pool for + * DMA usage + * @pool: pool to allocate from + * @size: number of bytes to allocate from the pool + * @dma: dma-view physical address return value. Use %NULL if unneeded. + * + * Allocate the requested number of zeroed bytes from the specified pool. + * Uses the pool allocation function (with first-fit algorithm by default). + * Can not be used in NMI handler on architectures without + * NMI-safe cmpxchg implementation. + * + * Return: virtual address of the allocated zeroed memory, or %NULL on failure + */ +void *gen_pool_dma_zalloc(struct gen_pool *pool, size_t size, dma_addr_t *dma) +{ + void *vaddr = gen_pool_dma_alloc(pool, size, dma); + + if (vaddr) + memset(vaddr, 0, size); + + return vaddr; +} +EXPORT_SYMBOL(gen_pool_dma_zalloc); + /** * gen_pool_free - free allocated special memory back to the pool * @pool: pool to free to From patchwork Tue Sep 15 21:30:36 2020 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: John Villalovos X-Patchwork-Id: 263984 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-12.8 required=3.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID, DKIM_VALID_AU, HEADER_FROM_DIFFERENT_DOMAINS, INCLUDES_PATCH, MAILING_LIST_MULTI, MSGID_FROM_MTA_HEADER, SIGNED_OFF_BY, SPF_HELO_NONE, SPF_PASS, URIBL_BLOCKED, USER_AGENT_GIT autolearn=ham autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id C7CB9C43461 for ; Tue, 15 Sep 2020 21:42:22 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by mail.kernel.org (Postfix) with ESMTP id 7C8A72078E for ; Tue, 15 Sep 2020 21:42:22 +0000 (UTC) Authentication-Results: mail.kernel.org; dkim=pass (1024-bit key) header.d=os.amperecomputing.com header.i=@os.amperecomputing.com header.b="g+BPBy1l" Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727787AbgIOVmS (ORCPT ); Tue, 15 Sep 2020 17:42:18 -0400 Received: from mail-bn8nam12on2106.outbound.protection.outlook.com ([40.107.237.106]:50336 "EHLO NAM12-BN8-obe.outbound.protection.outlook.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1728127AbgIOVbv (ORCPT ); Tue, 15 Sep 2020 17:31:51 -0400 ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=aynFijQg75efb21yr4T4utZJb13Y7876m1wStkCIIKQ/MTpi60DmCQ466GUmiT9nZ5cGxxdNslxLdhfqpdR6gvuaYjBLaKOMXxoUIKcF1zpn2x1ssTNQkEZImNaEdXxlWLdjlJX/xxNMUmK19OXlgARRMY3nZmAkAYcdfERJ31lvgF8VTw14IQe65u+/DxzyunP91fy3pdqm1y8SpwL8zyKQTAHVh70GUTusFf44LDt5oSvLSpYY7O2xw6hV98giF0R/UBKm+PZZi+Ir/PQ72bIKSdVX5iUYg67WTPfnkxgHtFv/th6S68vRXoNMGqif1kToVChUwoOFI+p6N4z3nQ== 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-SenderADCheck; bh=QcC5atYKHIVWPnCHh1OvvK5gzJs8/PHMoavVka86r2U=; b=RH8HMvZgVSyA/87i6WB0bVpGqpNgUkw3Pf9vopwdMbipBQHK/aAERYLUGYWKsyCLcRbnGIUumrDphu9P9PZvn1BlJ8nw9Od9BT0fYS0VwqXeTJaD3vb6pJiPV2gpexACFKzKPjqeQ8vzNVF7yNL3W0PP3R6Sq4Yg7FyCymq17TowDJOazhs4zP3sKgE6DI7PlSsGAALmWurdVSojY8Jqi4HQxQCliyMf5ei/bJcoJMHL0z93q2Y5JZ0ZkPge0Cjd8L9S2fPn/fN20O0PLLN8vsOhk88cklQCVFpytTkcRIlLNzZ/bM3W2Vnf89Nds3yRbCHXWekot5LEbl7v6xBaZg== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=os.amperecomputing.com; dmarc=pass action=none header.from=os.amperecomputing.com; dkim=pass header.d=os.amperecomputing.com; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=os.amperecomputing.com; s=selector2; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=QcC5atYKHIVWPnCHh1OvvK5gzJs8/PHMoavVka86r2U=; b=g+BPBy1lHcyUUUzaceIh3MllfGiQxkLFM6b+WykVRK+Lc3V18vOLJTVX/44KQQDGa2XpfjTqRYGeyTrBbZmTDzcLb/By6EZ0FYoQuwosVzMXGRsfBD6XKfSC94ZiSjssoYc9DdrfVnLCF5MXWlvd62V26BdgQ2r4e/CyUrCsZ6w= Authentication-Results: vger.kernel.org; dkim=none (message not signed) header.d=none;vger.kernel.org; dmarc=none action=none header.from=os.amperecomputing.com; Received: from DM6PR01MB5802.prod.exchangelabs.com (2603:10b6:5:203::17) by DM6PR01MB5516.prod.exchangelabs.com (2603:10b6:5:153::22) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.3370.17; Tue, 15 Sep 2020 21:31:11 +0000 Received: from DM6PR01MB5802.prod.exchangelabs.com ([fe80::ed9e:20e7:332a:704b]) by DM6PR01MB5802.prod.exchangelabs.com ([fe80::ed9e:20e7:332a:704b%7]) with mapi id 15.20.3391.011; Tue, 15 Sep 2020 21:31:11 +0000 From: "John L. Villalovos" To: stable@vger.kernel.org Cc: "John L. Villalovos" , Laurentiu Tudor , Fredrik Noring , Greg Kroah-Hartman , Christoph Hellwig Subject: [PATCH 4.19 2/5] USB: use genalloc for USB HCs with local memory Date: Tue, 15 Sep 2020 14:30:36 -0700 Message-Id: <20200915213039.862123-3-jlvillal@os.amperecomputing.com> X-Mailer: git-send-email 2.26.2 In-Reply-To: <20200915213039.862123-1-jlvillal@os.amperecomputing.com> References: <20200915213039.862123-1-jlvillal@os.amperecomputing.com> X-ClientProxiedBy: CY4PR14CA0040.namprd14.prod.outlook.com (2603:10b6:903:101::26) To DM6PR01MB5802.prod.exchangelabs.com (2603:10b6:5:203::17) MIME-Version: 1.0 X-MS-Exchange-MessageSentRepresentingType: 1 Received: from localhost.localdomain (4.28.12.214) by CY4PR14CA0040.namprd14.prod.outlook.com (2603:10b6:903:101::26) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.3370.16 via Frontend Transport; Tue, 15 Sep 2020 21:31:10 +0000 X-Mailer: git-send-email 2.26.2 X-Originating-IP: [4.28.12.214] X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id: 6c166616-ad93-4e14-d728-08d859beaa80 X-MS-TrafficTypeDiagnostic: DM6PR01MB5516: X-MS-Exchange-Transport-Forked: True X-Microsoft-Antispam-PRVS: X-MS-Oob-TLC-OOBClassifiers: OLM:5516; X-MS-Exchange-SenderADCheck: 1 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: 6X76WEG/LuMKvBGF0Tl8Tmp8ghUFlnyASKHbjdx5sSvi4NHIrej4mCSNeiPJUTQFQMmXXi6w1DmTEXHqO3C7GKZPxpD5TJW9Gb5lc1HwDrPiK+7EcymKR8u6+NjGnBlxqYmSE18UWFaiTP6X9aKxWg3bmtIIs/IHexJrOQ29JNYpPt3GpJujV5UiEjJTr5vgvIqJDX4ltGWaHxQj9WlO9ziciynlfboLHPrTuQX/bT76ejWy6ad31Ky36eU0yeCrN/lkd+KvLkhr+qkNNSwZIqacC1kzI2KUwAV0BsX81DPOGNfTtDEiWJMKGPo7F093EfqjW9m1JRPcp3akAue1sJmjqvuvlU1IHq4HyRQSSjY0GAe9TpmyhXSHHA5xIQZuHyBhX6WruYASolSvU/MgAO+Y8olvXm7XMKPdIK3mTAocJG+jcf5y4azIg8XEgzej X-Forefront-Antispam-Report: CIP:255.255.255.255; CTRY:; LANG:en; SCL:1; SRV:; IPV:NLI; SFV:NSPM; H:DM6PR01MB5802.prod.exchangelabs.com; PTR:; CAT:NONE; SFS:(4636009)(346002)(396003)(136003)(366004)(376002)(39850400004)(83380400001)(6512007)(8936002)(316002)(66946007)(16526019)(8676002)(4326008)(2616005)(6486002)(956004)(26005)(186003)(1076003)(54906003)(6666004)(6506007)(478600001)(5660300002)(86362001)(2906002)(66476007)(69590400008)(66556008)(52116002)(6916009); DIR:OUT; SFP:1102; X-MS-Exchange-AntiSpam-MessageData: KbKRFgpCdk6afG6VqxMAaSE74cLSSw4pqsBEj4fTiNWHZlNMkkqZIGOiMiaGZMhZixEKeG31M9ThXMOTk3hZjVUVugVeC42qe0+hX8r4R+jiIkMh670GI4K2HVvAlAAd7merPAdq7qCEpSgTuUg+bBa2O95zZHkQd+5Ml1V1nCD5R1ELT7Qd2n8fc126irCtVY7wfZvMfJZJjqfJGPX/4maUbK1Eh4jKAlNOz7PRjUlNe4P+xfXwUP8+BQNrw5h+m3k6lfh3DU3OuSLHRugQPWxcQOBpSawM4UflHCgW1hrhO/pBGhSVGEi/44PeoKx4svL//xwwsFNgGWaqLuLWNHNiSWuxJJ7tYJXscbIB+z2ShqtZpBuCLXzJoPeXwMNOUjx13GMQeBD8Xu6aQHn+x07YGzfvLqR4et/EiNDVARymrGgMVwN/hSUGldUsCOop0X7gvITVaraBr7xjsmNWf3v6Bbu+ZbNo/z9txZlLZZywGQt045MaBoO/K2lneHiFxT1LpHjU0U+KPOJcBkmpebysX9T3HbjxNDRaO5vNxiS9WJR2fM9XuE5drY8EawF5tRSWBbHqjQlZ+xPGdmLg6nYI3K/nC+zvLGAo5Oi4rrs4BfGXY6cyxRKfaJP6DSzXu12VZubn1TeisxNgebBplw== X-OriginatorOrg: os.amperecomputing.com X-MS-Exchange-CrossTenant-Network-Message-Id: 6c166616-ad93-4e14-d728-08d859beaa80 X-MS-Exchange-CrossTenant-AuthSource: DM6PR01MB5802.prod.exchangelabs.com X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 15 Sep 2020 21:31:11.3922 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: 3bc2b170-fd94-476d-b0ce-4229bdc904a7 X-MS-Exchange-CrossTenant-MailboxType: HOSTED X-MS-Exchange-CrossTenant-UserPrincipalName: 2CvLWkdv2Xx+d98mYU2EjJFCm881vpCzGw/YYwRw9gQitrCNUUsJAX+67CW3SQnYn71BGUXfLywKo53pzz1A1tx1x8CRFwB63ZIe6lIxrqGq6vOMJSaPKrJPDnVWn+8N X-MS-Exchange-Transport-CrossTenantHeadersStamped: DM6PR01MB5516 Sender: stable-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: stable@vger.kernel.org commit b0310c2f09bbe8aebefb97ed67949a3a7092aca6 upstream. For HCs that have local memory, replace the current DMA API usage with a genalloc generic allocator to manage the mappings for these devices. To help users, introduce a new HCD API, usb_hcd_setup_local_mem() that will setup up the genalloc backing up the device local memory. It will be used in subsequent patches. This is in preparation for dropping the existing "coherent" dma mem declaration APIs. The current implementation was relying on a short circuit in the DMA API that in the end, was acting as an allocator for these type of devices. Signed-off-by: Laurentiu Tudor Tested-by: Fredrik Noring Reviewed-by: Greg Kroah-Hartman Signed-off-by: Christoph Hellwig Signed-off-by: John L. Villalovos --- drivers/usb/Kconfig | 1 + drivers/usb/core/buffer.c | 9 +++++++++ drivers/usb/core/hcd.c | 36 ++++++++++++++++++++++++++++++++++++ drivers/usb/host/ohci-hcd.c | 23 ++++++++++++++++++----- drivers/usb/host/ohci-mem.c | 35 +++++++++++++++++++++++++++++++---- drivers/usb/host/ohci.h | 2 ++ include/linux/usb/hcd.h | 5 +++++ 7 files changed, 102 insertions(+), 9 deletions(-) diff --git a/drivers/usb/Kconfig b/drivers/usb/Kconfig index 70e6c956c23c..2b3a76eaa653 100644 --- a/drivers/usb/Kconfig +++ b/drivers/usb/Kconfig @@ -44,6 +44,7 @@ config USB_ARCH_HAS_HCD config USB tristate "Support for Host-side USB" depends on USB_ARCH_HAS_HCD + select GENERIC_ALLOCATOR select USB_COMMON select NLS # for UTF-8 strings ---help--- diff --git a/drivers/usb/core/buffer.c b/drivers/usb/core/buffer.c index 77eef8acff94..a9392b63c175 100644 --- a/drivers/usb/core/buffer.c +++ b/drivers/usb/core/buffer.c @@ -16,6 +16,7 @@ #include #include #include +#include #include #include @@ -128,6 +129,9 @@ void *hcd_buffer_alloc( if (size == 0) return NULL; + if (hcd->localmem_pool) + return gen_pool_dma_alloc(hcd->localmem_pool, size, dma); + /* some USB hosts just use PIO */ if (!IS_ENABLED(CONFIG_HAS_DMA) || (!is_device_dma_capable(bus->sysdev) && @@ -156,6 +160,11 @@ void hcd_buffer_free( if (!addr) return; + if (hcd->localmem_pool) { + gen_pool_free(hcd->localmem_pool, (unsigned long)addr, size); + return; + } + if (!IS_ENABLED(CONFIG_HAS_DMA) || (!is_device_dma_capable(bus->sysdev) && !(hcd->driver->flags & HCD_LOCAL_MEM))) { diff --git a/drivers/usb/core/hcd.c b/drivers/usb/core/hcd.c index b82a7d787add..c1daf3f646d6 100644 --- a/drivers/usb/core/hcd.c +++ b/drivers/usb/core/hcd.c @@ -29,6 +29,8 @@ #include #include #include +#include +#include #include #include @@ -3025,6 +3027,40 @@ usb_hcd_platform_shutdown(struct platform_device *dev) } EXPORT_SYMBOL_GPL(usb_hcd_platform_shutdown); +int usb_hcd_setup_local_mem(struct usb_hcd *hcd, phys_addr_t phys_addr, + dma_addr_t dma, size_t size) +{ + int err; + void *local_mem; + + hcd->localmem_pool = devm_gen_pool_create(hcd->self.sysdev, PAGE_SHIFT, + dev_to_node(hcd->self.sysdev), + dev_name(hcd->self.sysdev)); + if (IS_ERR(hcd->localmem_pool)) + return PTR_ERR(hcd->localmem_pool); + + local_mem = devm_memremap(hcd->self.sysdev, phys_addr, + size, MEMREMAP_WC); + if (!local_mem) + return -ENOMEM; + + /* + * Here we pass a dma_addr_t but the arg type is a phys_addr_t. + * It's not backed by system memory and thus there's no kernel mapping + * for it. + */ + err = gen_pool_add_virt(hcd->localmem_pool, (unsigned long)local_mem, + dma, size, dev_to_node(hcd->self.sysdev)); + if (err < 0) { + dev_err(hcd->self.sysdev, "gen_pool_add_virt failed with %d\n", + err); + return err; + } + + return 0; +} +EXPORT_SYMBOL_GPL(usb_hcd_setup_local_mem); + /*-------------------------------------------------------------------------*/ #if IS_ENABLED(CONFIG_USB_MON) diff --git a/drivers/usb/host/ohci-hcd.c b/drivers/usb/host/ohci-hcd.c index af11887f5f9e..9b2d8b84ae26 100644 --- a/drivers/usb/host/ohci-hcd.c +++ b/drivers/usb/host/ohci-hcd.c @@ -40,6 +40,7 @@ #include #include #include +#include #include #include @@ -514,8 +515,15 @@ static int ohci_init (struct ohci_hcd *ohci) timer_setup(&ohci->io_watchdog, io_watchdog_func, 0); ohci->prev_frame_no = IO_WATCHDOG_OFF; - ohci->hcca = dma_alloc_coherent (hcd->self.controller, - sizeof(*ohci->hcca), &ohci->hcca_dma, GFP_KERNEL); + if (hcd->localmem_pool) + ohci->hcca = gen_pool_dma_alloc(hcd->localmem_pool, + sizeof(*ohci->hcca), + &ohci->hcca_dma); + else + ohci->hcca = dma_alloc_coherent(hcd->self.controller, + sizeof(*ohci->hcca), + &ohci->hcca_dma, + GFP_KERNEL); if (!ohci->hcca) return -ENOMEM; @@ -999,9 +1007,14 @@ static void ohci_stop (struct usb_hcd *hcd) remove_debug_files (ohci); ohci_mem_cleanup (ohci); if (ohci->hcca) { - dma_free_coherent (hcd->self.controller, - sizeof *ohci->hcca, - ohci->hcca, ohci->hcca_dma); + if (hcd->localmem_pool) + gen_pool_free(hcd->localmem_pool, + (unsigned long)ohci->hcca, + sizeof(*ohci->hcca)); + else + dma_free_coherent(hcd->self.controller, + sizeof(*ohci->hcca), + ohci->hcca, ohci->hcca_dma); ohci->hcca = NULL; ohci->hcca_dma = 0; } diff --git a/drivers/usb/host/ohci-mem.c b/drivers/usb/host/ohci-mem.c index b3da3f12e5b1..8e15044be14c 100644 --- a/drivers/usb/host/ohci-mem.c +++ b/drivers/usb/host/ohci-mem.c @@ -36,6 +36,13 @@ static void ohci_hcd_init (struct ohci_hcd *ohci) static int ohci_mem_init (struct ohci_hcd *ohci) { + /* + * HCs with local memory allocate from localmem_pool so there's + * no need to create the below dma pools. + */ + if (ohci_to_hcd(ohci)->localmem_pool) + return 0; + ohci->td_cache = dma_pool_create ("ohci_td", ohci_to_hcd(ohci)->self.controller, sizeof (struct td), @@ -88,8 +95,12 @@ td_alloc (struct ohci_hcd *hc, gfp_t mem_flags) { dma_addr_t dma; struct td *td; + struct usb_hcd *hcd = ohci_to_hcd(hc); - td = dma_pool_zalloc (hc->td_cache, mem_flags, &dma); + if (hcd->localmem_pool) + td = gen_pool_dma_zalloc(hcd->localmem_pool, sizeof(*td), &dma); + else + td = dma_pool_zalloc(hc->td_cache, mem_flags, &dma); if (td) { /* in case hc fetches it, make it look dead */ td->hwNextTD = cpu_to_hc32 (hc, dma); @@ -103,6 +114,7 @@ static void td_free (struct ohci_hcd *hc, struct td *td) { struct td **prev = &hc->td_hash [TD_HASH_FUNC (td->td_dma)]; + struct usb_hcd *hcd = ohci_to_hcd(hc); while (*prev && *prev != td) prev = &(*prev)->td_hash; @@ -110,7 +122,12 @@ td_free (struct ohci_hcd *hc, struct td *td) *prev = td->td_hash; else if ((td->hwINFO & cpu_to_hc32(hc, TD_DONE)) != 0) ohci_dbg (hc, "no hash for td %p\n", td); - dma_pool_free (hc->td_cache, td, td->td_dma); + + if (hcd->localmem_pool) + gen_pool_free(hcd->localmem_pool, (unsigned long)td, + sizeof(*td)); + else + dma_pool_free(hc->td_cache, td, td->td_dma); } /*-------------------------------------------------------------------------*/ @@ -121,8 +138,12 @@ ed_alloc (struct ohci_hcd *hc, gfp_t mem_flags) { dma_addr_t dma; struct ed *ed; + struct usb_hcd *hcd = ohci_to_hcd(hc); - ed = dma_pool_zalloc (hc->ed_cache, mem_flags, &dma); + if (hcd->localmem_pool) + ed = gen_pool_dma_zalloc(hcd->localmem_pool, sizeof(*ed), &dma); + else + ed = dma_pool_zalloc(hc->ed_cache, mem_flags, &dma); if (ed) { INIT_LIST_HEAD (&ed->td_list); ed->dma = dma; @@ -133,6 +154,12 @@ ed_alloc (struct ohci_hcd *hc, gfp_t mem_flags) static void ed_free (struct ohci_hcd *hc, struct ed *ed) { - dma_pool_free (hc->ed_cache, ed, ed->dma); + struct usb_hcd *hcd = ohci_to_hcd(hc); + + if (hcd->localmem_pool) + gen_pool_free(hcd->localmem_pool, (unsigned long)ed, + sizeof(*ed)); + else + dma_pool_free(hc->ed_cache, ed, ed->dma); } diff --git a/drivers/usb/host/ohci.h b/drivers/usb/host/ohci.h index ef4813bfc5bf..b015b00774b2 100644 --- a/drivers/usb/host/ohci.h +++ b/drivers/usb/host/ohci.h @@ -385,6 +385,8 @@ struct ohci_hcd { /* * memory management for queue data structures + * + * @td_cache and @ed_cache are %NULL if &usb_hcd.localmem_pool is used. */ struct dma_pool *td_cache; struct dma_pool *ed_cache; diff --git a/include/linux/usb/hcd.h b/include/linux/usb/hcd.h index 97e2ddec18b1..5f1d57064cc0 100644 --- a/include/linux/usb/hcd.h +++ b/include/linux/usb/hcd.h @@ -211,6 +211,9 @@ struct usb_hcd { #define HC_IS_RUNNING(state) ((state) & __ACTIVE) #define HC_IS_SUSPENDED(state) ((state) & __SUSPEND) + /* memory pool for HCs having local memory, or %NULL */ + struct gen_pool *localmem_pool; + /* more shared queuing code would be good; it should support * smarter scheduling, handle transaction translators, etc; * input size of periodic table to an interrupt scheduler. @@ -461,6 +464,8 @@ extern int usb_add_hcd(struct usb_hcd *hcd, unsigned int irqnum, unsigned long irqflags); extern void usb_remove_hcd(struct usb_hcd *hcd); extern int usb_hcd_find_raw_port_number(struct usb_hcd *hcd, int port1); +int usb_hcd_setup_local_mem(struct usb_hcd *hcd, phys_addr_t phys_addr, + dma_addr_t dma, size_t size); struct platform_device; extern void usb_hcd_platform_shutdown(struct platform_device *dev); From patchwork Tue Sep 15 21:30:37 2020 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: John Villalovos X-Patchwork-Id: 263985 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-12.8 required=3.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID, DKIM_VALID_AU, HEADER_FROM_DIFFERENT_DOMAINS, INCLUDES_PATCH, MAILING_LIST_MULTI, MSGID_FROM_MTA_HEADER, SIGNED_OFF_BY, SPF_HELO_NONE, SPF_PASS, URIBL_BLOCKED, USER_AGENT_GIT autolearn=ham autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id A0BA8C433E2 for ; Tue, 15 Sep 2020 21:41:47 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by mail.kernel.org (Postfix) with ESMTP id 4F64C2078E for ; Tue, 15 Sep 2020 21:41:47 +0000 (UTC) Authentication-Results: mail.kernel.org; dkim=pass (1024-bit key) header.d=os.amperecomputing.com header.i=@os.amperecomputing.com header.b="PPLkipyP" Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727992AbgIOVln (ORCPT ); Tue, 15 Sep 2020 17:41:43 -0400 Received: from mail-bn8nam12on2118.outbound.protection.outlook.com ([40.107.237.118]:22112 "EHLO NAM12-BN8-obe.outbound.protection.outlook.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1728131AbgIOVdA (ORCPT ); Tue, 15 Sep 2020 17:33:00 -0400 ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=OtGoPq0leZvwRPgzdLsiGmVHl6LWRJYswCSj9eValnOTVjlOiOeVB/Lz12Z+q1coqLfORZP545e3GtiqjoHwwPSvYpLzUasXwy7vG6Sdi+Cmh9gYZP2EQfI8bzznB0qXQ//KvqPFxSyEUoT9lpJF97aehPHzOuKO1cAHJJRDFZEZ6r9LEhkf83sIhaD5MnhggdeUDcLQxnNvlDeiVSHZpItQpDClOiCL+NwPuU55Ee2OsQa3xQzdoxDDU9UBBBssXwRueE6pKVHMrjuC8kFhdHg7p/1BCma8YOYaXt6zVkAWKsVT9YSmeCGexqtJd6CW14UeB+gKw3deWESoA/6kfQ== 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-SenderADCheck; bh=6udCXZv0n6zMMzIkdXfMI8YgvTF43uNzbitjkXJVFDI=; b=dknhkAnUqYTfZkAofzZZNkIYM/gdrkW99hDHYAm4AhDfDWsU7Lsu/hlhbb1R5Ti9JAKUbD2g0wx19oYMboNSFNJCJ0jU1f0+E1R//4o26re9w+nyyIOxHRJ2TRFBAobqkLH+TB29UXeyBZOUed3cilftcZSOJKXogphEk/p2f/n6TCfHW8IY6RqhZBQSfQ6zriuWqgCUnHGFxbUlenFAfMXlihrce/in2mnjDCs2cp5Dta7qQhdPHPe3bYSGbQHJNSVoisEURQ/5bm72ipNtMD7pTVaDjaOfRH1lzp/GCSz9mcF8M6lXEYY4Z9QT7Tl/FySPSmQD1zfQy/G6EF0Lyw== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=os.amperecomputing.com; dmarc=pass action=none header.from=os.amperecomputing.com; dkim=pass header.d=os.amperecomputing.com; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=os.amperecomputing.com; s=selector2; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=6udCXZv0n6zMMzIkdXfMI8YgvTF43uNzbitjkXJVFDI=; b=PPLkipyPcP3tWAGFLUr3XtXIkKc8KbawJyEtyGvm+o+Q/z1PhKAVDiKO9QcSnZFZVVijAcT8RvDnxkbTIftfnb2rasLglMNRauK/1Br7uXMM8ZubaD26gzdDKrEontPXj6Vfd6w+micSmxaGqRTNHRbt0CxOjc07cZqbeQ3OWmQ= Authentication-Results: vger.kernel.org; dkim=none (message not signed) header.d=none;vger.kernel.org; dmarc=none action=none header.from=os.amperecomputing.com; Received: from DM6PR01MB5802.prod.exchangelabs.com (2603:10b6:5:203::17) by DM6PR01MB5516.prod.exchangelabs.com (2603:10b6:5:153::22) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.3370.17; Tue, 15 Sep 2020 21:31:13 +0000 Received: from DM6PR01MB5802.prod.exchangelabs.com ([fe80::ed9e:20e7:332a:704b]) by DM6PR01MB5802.prod.exchangelabs.com ([fe80::ed9e:20e7:332a:704b%7]) with mapi id 15.20.3391.011; Tue, 15 Sep 2020 21:31:13 +0000 From: "John L. Villalovos" To: stable@vger.kernel.org Cc: "John L. Villalovos" , Laurentiu Tudor , Fredrik Noring , Greg Kroah-Hartman , Christoph Hellwig Subject: [PATCH 4.19 3/5] USB: drop HCD_LOCAL_MEM flag Date: Tue, 15 Sep 2020 14:30:37 -0700 Message-Id: <20200915213039.862123-4-jlvillal@os.amperecomputing.com> X-Mailer: git-send-email 2.26.2 In-Reply-To: <20200915213039.862123-1-jlvillal@os.amperecomputing.com> References: <20200915213039.862123-1-jlvillal@os.amperecomputing.com> X-ClientProxiedBy: CY4PR14CA0040.namprd14.prod.outlook.com (2603:10b6:903:101::26) To DM6PR01MB5802.prod.exchangelabs.com (2603:10b6:5:203::17) MIME-Version: 1.0 X-MS-Exchange-MessageSentRepresentingType: 1 Received: from localhost.localdomain (4.28.12.214) by CY4PR14CA0040.namprd14.prod.outlook.com (2603:10b6:903:101::26) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.3370.16 via Frontend Transport; Tue, 15 Sep 2020 21:31:12 +0000 X-Mailer: git-send-email 2.26.2 X-Originating-IP: [4.28.12.214] X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id: 7824220b-0c4a-41eb-e506-08d859beab99 X-MS-TrafficTypeDiagnostic: DM6PR01MB5516: X-MS-Exchange-Transport-Forked: True X-Microsoft-Antispam-PRVS: X-MS-Oob-TLC-OOBClassifiers: OLM:765; X-MS-Exchange-SenderADCheck: 1 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: raktIQegyoSkja/q7/XZM3gzV4K1ypuJFP5UcdJuW5H8Xn6lcNkANw6itKUUABIXBVQVIyK6cR8K2K+QZhtyxPNpu2dQREYfQjABMUE8y0xKse/LsVPVrOuEpajZj2b8im6Q0LHTUFTMK7rFTNSVf+OHSy8WYnsmZcvJSkspC4uTjTMMKsdOMLpKXmO6mF3lIgWyiZfyS8hv6Go8U52MMPtT8UUoF/2aXBouiO7cVeqEV0JEcOsNq75+qAsNdavnHhz62UttH0GsrxjFhBmgUpyGKSGeNxVfrEkC27iR0c5fPIpVXQ4/K0BD8wZOVRVir3jxSaEhPXODEkkfkSh5LQcVkoEcpwe2gAjeqdPUegYZkDjguesW0klUc+FBY0GOJGE5dSm8YtH90W/qy5y/MOfNnX7QhmAxzQ/i/013YoGQxjhH3b7uGNYGBVnFphuK X-Forefront-Antispam-Report: CIP:255.255.255.255; CTRY:; LANG:en; SCL:1; SRV:; IPV:NLI; SFV:NSPM; H:DM6PR01MB5802.prod.exchangelabs.com; PTR:; CAT:NONE; SFS:(4636009)(346002)(396003)(136003)(366004)(376002)(39850400004)(83380400001)(6512007)(8936002)(316002)(66946007)(16526019)(8676002)(4326008)(2616005)(6486002)(956004)(26005)(186003)(1076003)(54906003)(6666004)(6506007)(478600001)(5660300002)(86362001)(2906002)(66476007)(69590400008)(66556008)(52116002)(6916009); DIR:OUT; SFP:1102; X-MS-Exchange-AntiSpam-MessageData: ntGNI9maA4gluVHjhlED1yDApOmwszv+Lk6Yrkg2deb0QjniMovQPORB3n0aXgqkHkHnSdyGnmZY7s9Cmpy8Cx12xtPM8bEUIm5MgVA+ggLzdcrOaZZOJs3Tev5J7VbEadlEKAPduzuRAWhqy0pOYvs9yd7xbjpPI4eZOrviGtXwOzGW0d7ZVQt+lEa2Bt/p1jnIs43AnYV+4J0tYQFF1Ttwuwl+7uGGItwR258S0psEZh0y1LndNY7JElssHXzq+sJItOP6guFCeVAm9zsCPJCWixhwBSqPV5VlyTs9dunsD4mcg/FzcAjgA/9G8XSJOtnw8FK8PhFJRGwPFp9LZrIi8oPic8nFXOryCqAqDt3S3Wh100iaFs50xO2inpNePFHbVFe/gGC7dNEXoxNE9C0xip3WD9aUtLPpi3G76XrJBFEyVwGxvte/oW9T0SG88QxiQAgJnToOyiBPG6FN5Bs09SsibW0lKvkAL63hVOPo6/PzahNCJbph/px1Nt9e6jWMMB0LiKSTG55xYfPvHh25h1RAHX6/gzJGWdmFyIMMXK7ZpBkB9fCpkwQW6DwJ0b8PYD47VOFX4rtMVhwv3DMFYPW2PfbczdbsxruU79fwyjaBLIK0Fv8Iot0zlymEXwZvbOTu8zVPUhs0mwTpvw== X-OriginatorOrg: os.amperecomputing.com X-MS-Exchange-CrossTenant-Network-Message-Id: 7824220b-0c4a-41eb-e506-08d859beab99 X-MS-Exchange-CrossTenant-AuthSource: DM6PR01MB5802.prod.exchangelabs.com X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 15 Sep 2020 21:31:13.2012 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: 3bc2b170-fd94-476d-b0ce-4229bdc904a7 X-MS-Exchange-CrossTenant-MailboxType: HOSTED X-MS-Exchange-CrossTenant-UserPrincipalName: nlMrdmxJfRaEEoaphMzbzqkbwNtBmvCi73KGdXSV/cFcOw+JYnRCATIiIY8cnmiUVIMf6wykabvqRasMEvG9nAnrVGbs6YABYsXyNw65Iyh5Yi05PIxfp2AciiBpQJwd X-MS-Exchange-Transport-CrossTenantHeadersStamped: DM6PR01MB5516 Sender: stable-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: stable@vger.kernel.org commit 2d7a3dc3e24f43504b1f25eae8195e600f4cce8b upstream. With the addition of the local memory allocator, the HCD_LOCAL_MEM flag can be dropped and the checks against it replaced with a check for the localmem_pool ptr being initialized. Signed-off-by: Laurentiu Tudor Tested-by: Fredrik Noring Reviewed-by: Greg Kroah-Hartman Signed-off-by: Christoph Hellwig Signed-off-by: John L. Villalovos --- drivers/usb/core/buffer.c | 8 +++----- drivers/usb/core/hcd.c | 15 ++++++--------- drivers/usb/host/ehci-hcd.c | 2 +- drivers/usb/host/fotg210-hcd.c | 2 +- drivers/usb/host/ohci-hcd.c | 2 +- drivers/usb/host/ohci-sm501.c | 2 +- drivers/usb/host/ohci-tmio.c | 2 +- drivers/usb/host/uhci-hcd.c | 2 +- include/linux/usb/hcd.h | 1 - 9 files changed, 15 insertions(+), 21 deletions(-) diff --git a/drivers/usb/core/buffer.c b/drivers/usb/core/buffer.c index a9392b63c175..d93e25aeaf96 100644 --- a/drivers/usb/core/buffer.c +++ b/drivers/usb/core/buffer.c @@ -68,7 +68,7 @@ int hcd_buffer_create(struct usb_hcd *hcd) if (!IS_ENABLED(CONFIG_HAS_DMA) || (!is_device_dma_capable(hcd->self.sysdev) && - !(hcd->driver->flags & HCD_LOCAL_MEM))) + !hcd->localmem_pool)) return 0; for (i = 0; i < HCD_BUFFER_POOLS; i++) { @@ -134,8 +134,7 @@ void *hcd_buffer_alloc( /* some USB hosts just use PIO */ if (!IS_ENABLED(CONFIG_HAS_DMA) || - (!is_device_dma_capable(bus->sysdev) && - !(hcd->driver->flags & HCD_LOCAL_MEM))) { + !is_device_dma_capable(bus->sysdev)) { *dma = ~(dma_addr_t) 0; return kmalloc(size, mem_flags); } @@ -166,8 +165,7 @@ void hcd_buffer_free( } if (!IS_ENABLED(CONFIG_HAS_DMA) || - (!is_device_dma_capable(bus->sysdev) && - !(hcd->driver->flags & HCD_LOCAL_MEM))) { + !is_device_dma_capable(bus->sysdev)) { kfree(addr); return; } diff --git a/drivers/usb/core/hcd.c b/drivers/usb/core/hcd.c index c1daf3f646d6..c991e7ff1875 100644 --- a/drivers/usb/core/hcd.c +++ b/drivers/usb/core/hcd.c @@ -1346,14 +1346,14 @@ EXPORT_SYMBOL_GPL(usb_hcd_unlink_urb_from_ep); * using regular system memory - like pci devices doing bus mastering. * * To support host controllers with limited dma capabilities we provide dma - * bounce buffers. This feature can be enabled using the HCD_LOCAL_MEM flag. + * bounce buffers. This feature can be enabled by initializing + * hcd->localmem_pool using usb_hcd_setup_local_mem(). * For this to work properly the host controller code must first use the * function dma_declare_coherent_memory() to point out which memory area * that should be used for dma allocations. * - * The HCD_LOCAL_MEM flag then tells the usb code to allocate all data for - * dma using dma_alloc_coherent() which in turn allocates from the memory - * area pointed out with dma_declare_coherent_memory(). + * The initialized hcd->localmem_pool then tells the usb code to allocate all + * data for dma using the genalloc API. * * So, to summarize... * @@ -1363,9 +1363,6 @@ EXPORT_SYMBOL_GPL(usb_hcd_unlink_urb_from_ep); * (a) "normal" kernel memory is no good, and * (b) there's not enough to share * - * - The only *portable* hook for such stuff in the - * DMA framework is dma_declare_coherent_memory() - * * - So we use that, even though the primary requirement * is that the memory be "local" (hence addressable * by that device), not "coherent". @@ -1532,7 +1529,7 @@ int usb_hcd_map_urb_for_dma(struct usb_hcd *hcd, struct urb *urb, urb->setup_dma)) return -EAGAIN; urb->transfer_flags |= URB_SETUP_MAP_SINGLE; - } else if (hcd->driver->flags & HCD_LOCAL_MEM) { + } else if (hcd->localmem_pool) { ret = hcd_alloc_coherent( urb->dev->bus, mem_flags, &urb->setup_dma, @@ -1602,7 +1599,7 @@ int usb_hcd_map_urb_for_dma(struct usb_hcd *hcd, struct urb *urb, else urb->transfer_flags |= URB_DMA_MAP_SINGLE; } - } else if (hcd->driver->flags & HCD_LOCAL_MEM) { + } else if (hcd->localmem_pool) { ret = hcd_alloc_coherent( urb->dev->bus, mem_flags, &urb->transfer_dma, diff --git a/drivers/usb/host/ehci-hcd.c b/drivers/usb/host/ehci-hcd.c index 8608ac513fb7..f0a0ddee52d0 100644 --- a/drivers/usb/host/ehci-hcd.c +++ b/drivers/usb/host/ehci-hcd.c @@ -559,7 +559,7 @@ static int ehci_init(struct usb_hcd *hcd) ehci->command = temp; /* Accept arbitrarily long scatter-gather lists */ - if (!(hcd->driver->flags & HCD_LOCAL_MEM)) + if (!hcd->localmem_pool) hcd->self.sg_tablesize = ~0; /* Prepare for unlinking active QHs */ diff --git a/drivers/usb/host/fotg210-hcd.c b/drivers/usb/host/fotg210-hcd.c index 2d5a72c15069..cfaf03008a13 100644 --- a/drivers/usb/host/fotg210-hcd.c +++ b/drivers/usb/host/fotg210-hcd.c @@ -4998,7 +4998,7 @@ static int hcd_fotg210_init(struct usb_hcd *hcd) fotg210->command = temp; /* Accept arbitrarily long scatter-gather lists */ - if (!(hcd->driver->flags & HCD_LOCAL_MEM)) + if (!hcd->localmem_pool) hcd->self.sg_tablesize = ~0; return 0; } diff --git a/drivers/usb/host/ohci-hcd.c b/drivers/usb/host/ohci-hcd.c index 9b2d8b84ae26..81a104fafbc2 100644 --- a/drivers/usb/host/ohci-hcd.c +++ b/drivers/usb/host/ohci-hcd.c @@ -457,7 +457,7 @@ static int ohci_init (struct ohci_hcd *ohci) struct usb_hcd *hcd = ohci_to_hcd(ohci); /* Accept arbitrarily long scatter-gather lists */ - if (!(hcd->driver->flags & HCD_LOCAL_MEM)) + if (!hcd->localmem_pool) hcd->self.sg_tablesize = ~0; if (distrust_firmware) diff --git a/drivers/usb/host/ohci-sm501.c b/drivers/usb/host/ohci-sm501.c index 0a39dc58f376..f9b1279b68ec 100644 --- a/drivers/usb/host/ohci-sm501.c +++ b/drivers/usb/host/ohci-sm501.c @@ -49,7 +49,7 @@ static const struct hc_driver ohci_sm501_hc_driver = { * generic hardware linkage */ .irq = ohci_irq, - .flags = HCD_USB11 | HCD_MEMORY | HCD_LOCAL_MEM, + .flags = HCD_USB11 | HCD_MEMORY, /* * basic lifecycle operations diff --git a/drivers/usb/host/ohci-tmio.c b/drivers/usb/host/ohci-tmio.c index a631dbb369d7..98ecf3e3d74f 100644 --- a/drivers/usb/host/ohci-tmio.c +++ b/drivers/usb/host/ohci-tmio.c @@ -153,7 +153,7 @@ static const struct hc_driver ohci_tmio_hc_driver = { /* generic hardware linkage */ .irq = ohci_irq, - .flags = HCD_USB11 | HCD_MEMORY | HCD_LOCAL_MEM, + .flags = HCD_USB11 | HCD_MEMORY, /* basic lifecycle operations */ .start = ohci_tmio_start, diff --git a/drivers/usb/host/uhci-hcd.c b/drivers/usb/host/uhci-hcd.c index 6218bfe54f52..b4f4f729e080 100644 --- a/drivers/usb/host/uhci-hcd.c +++ b/drivers/usb/host/uhci-hcd.c @@ -581,7 +581,7 @@ static int uhci_start(struct usb_hcd *hcd) hcd->uses_new_polling = 1; /* Accept arbitrarily long scatter-gather lists */ - if (!(hcd->driver->flags & HCD_LOCAL_MEM)) + if (!hcd->localmem_pool) hcd->self.sg_tablesize = ~0; spin_lock_init(&uhci->lock); diff --git a/include/linux/usb/hcd.h b/include/linux/usb/hcd.h index 5f1d57064cc0..e24dade77132 100644 --- a/include/linux/usb/hcd.h +++ b/include/linux/usb/hcd.h @@ -256,7 +256,6 @@ struct hc_driver { int flags; #define HCD_MEMORY 0x0001 /* HC regs use memory (else I/O) */ -#define HCD_LOCAL_MEM 0x0002 /* HC needs local memory */ #define HCD_SHARED 0x0004 /* Two (or more) usb_hcds share HW */ #define HCD_USB11 0x0010 /* USB 1.1 */ #define HCD_USB2 0x0020 /* USB 2.0 */ From patchwork Tue Sep 15 21:30:38 2020 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: John Villalovos X-Patchwork-Id: 309722 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-12.8 required=3.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID, DKIM_VALID_AU, HEADER_FROM_DIFFERENT_DOMAINS, INCLUDES_PATCH, MAILING_LIST_MULTI, MSGID_FROM_MTA_HEADER, SIGNED_OFF_BY, SPF_HELO_NONE, SPF_PASS, URIBL_BLOCKED, USER_AGENT_GIT autolearn=ham autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 79E90C43461 for ; Tue, 15 Sep 2020 21:42:11 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by mail.kernel.org (Postfix) with ESMTP id 3E6082078E for ; Tue, 15 Sep 2020 21:42:11 +0000 (UTC) Authentication-Results: mail.kernel.org; dkim=pass (1024-bit key) header.d=os.amperecomputing.com header.i=@os.amperecomputing.com header.b="NAv2CS1y" Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727591AbgIOVlq (ORCPT ); Tue, 15 Sep 2020 17:41:46 -0400 Received: from mail-bn8nam12on2106.outbound.protection.outlook.com ([40.107.237.106]:50336 "EHLO NAM12-BN8-obe.outbound.protection.outlook.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1728135AbgIOVc7 (ORCPT ); Tue, 15 Sep 2020 17:32:59 -0400 ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=clgcA8Iuj6mWO/RFrwng+7osSgYRlKBMmhfri2eqjpUrNlSCOg8JxCWTQSfhkqcAfFMR3gOQQbZcv+oOJR3oqT2vPo00qPho/kL3baOi6E/oj0fMkHTH9GGEmWvCTsXytT2aiBB6/R3PgVaoJkwVg0UJPpB+M8OZv3Ji4plZhAa14LjeI0zqfq/Qq6yN8/tVpBh5P39aHrv+vhyYOhR+8ZM/k7n29uYd6puJ8Ofhl/iV5x3f5hv+o+33obeXg02oycTOcsvVT21PWT3j2IlLHShCWnDaQhniTMbyl50QxayKCTOgIRaR40Aem0FHYi/k/JaZvoEHzGbaFbF7fTaV6g== 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-SenderADCheck; bh=tUVQl//V8ANAUi+NJzjWQtRn1mzsm7eGW59CCyPuRHo=; b=K96e0wQ/kyY/DRqRnaYcJGQjqSa5Vfv3CMI0OfgH4BPnSEFUsTKx9KS3LeDb9HPIpBhprF+DeMSUHJtR+xxDj9ojIxzOgwB+ZggVvZZZOiV5K7jeuJ6Uhvv7FotpPndmqYEHbBYzpNRvO0yQ0aUAeKo9ub1h8E6w2RHfLivKuoXytCpnOzoCVJf9o9/807YI2KSJbW/di2NJKqU2IhymzSla50LyBu5Fh91m704kHvtkNN/bXGikWZl26uWStCRUexNRb28FG/qObJhEdXCXIhGd+kHsEfWbx/bh0xPVFnxIGqoyCZyqXDLCmq7qfF0TAf4taW4HDmnFvZ+cEROsyA== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=os.amperecomputing.com; dmarc=pass action=none header.from=os.amperecomputing.com; dkim=pass header.d=os.amperecomputing.com; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=os.amperecomputing.com; s=selector2; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=tUVQl//V8ANAUi+NJzjWQtRn1mzsm7eGW59CCyPuRHo=; b=NAv2CS1yo+V7T/EsYvmevjwPNjTCzGshYPOO1ALvdG4GnlP9vhq/cfVSgubMkPJxY9+crHKUXLGenvN/3hyokc2lBW0gdQSkzt33CSJcVzIy6KLecYK6H+/Zdyzvg21nom/jGGkSBxi2M2SuBkW0eDEZLBKsbPUAfcjCGgD05ss= Authentication-Results: vger.kernel.org; dkim=none (message not signed) header.d=none;vger.kernel.org; dmarc=none action=none header.from=os.amperecomputing.com; Received: from DM6PR01MB5802.prod.exchangelabs.com (2603:10b6:5:203::17) by DM6PR01MB5516.prod.exchangelabs.com (2603:10b6:5:153::22) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.3370.17; Tue, 15 Sep 2020 21:31:15 +0000 Received: from DM6PR01MB5802.prod.exchangelabs.com ([fe80::ed9e:20e7:332a:704b]) by DM6PR01MB5802.prod.exchangelabs.com ([fe80::ed9e:20e7:332a:704b%7]) with mapi id 15.20.3391.011; Tue, 15 Sep 2020 21:31:15 +0000 From: "John L. Villalovos" To: stable@vger.kernel.org Cc: "John L. Villalovos" , Christoph Hellwig , Greg Kroah-Hartman Subject: [PATCH 4.19 4/5] usb: don't create dma pools for HCDs with a localmem_pool Date: Tue, 15 Sep 2020 14:30:38 -0700 Message-Id: <20200915213039.862123-5-jlvillal@os.amperecomputing.com> X-Mailer: git-send-email 2.26.2 In-Reply-To: <20200915213039.862123-1-jlvillal@os.amperecomputing.com> References: <20200915213039.862123-1-jlvillal@os.amperecomputing.com> X-ClientProxiedBy: CY4PR14CA0040.namprd14.prod.outlook.com (2603:10b6:903:101::26) To DM6PR01MB5802.prod.exchangelabs.com (2603:10b6:5:203::17) MIME-Version: 1.0 X-MS-Exchange-MessageSentRepresentingType: 1 Received: from localhost.localdomain (4.28.12.214) by CY4PR14CA0040.namprd14.prod.outlook.com (2603:10b6:903:101::26) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.3370.16 via Frontend Transport; Tue, 15 Sep 2020 21:31:14 +0000 X-Mailer: git-send-email 2.26.2 X-Originating-IP: [4.28.12.214] X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id: 55ff969e-d5e2-4e16-9438-08d859beaca8 X-MS-TrafficTypeDiagnostic: DM6PR01MB5516: X-MS-Exchange-Transport-Forked: True X-Microsoft-Antispam-PRVS: X-MS-Oob-TLC-OOBClassifiers: OLM:121; X-MS-Exchange-SenderADCheck: 1 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: 5MjPmsCcmP2ychsfL1sCi0LAlZWV1wV+X2ssWwYTEz+2eDYr/xIrPz3OB2UkJwzqtRdmgDNFKQ34HOvCFRG6a+ynBYplePfdtfcsBWxFK6Rvn+2QRh+m6PuUJ+G3xVVmuH4/G1rPAxxWL/tJvea4nh2srupi98tHAz3dtvEnNcmh2R6a5F7hLP1Cz6Br+GEMc3efz7CeHrN58FjZfrejJez2aMFBwgsg9oYNZ8c+Jx5x13Oz/1t7N5vDP0IbgOgEIwdKs6l7G2Hg80MrREOnj/dS9J4mFvExUbE/bpay/h4Tu3el9PuIlqVS9yQD6nJom/SrPF+rwpviJpnb96VfHp+cjA6OSaD2QRg3PJOKxGG5zAZhKYFTFzfej89rxgJIuY9mENejmKpojTCjzdDhhBdLFuFnMj5JZutJIgKRnG4ERX4tGMrk617Lhl945E1ntqjEJixmqpbUpbcaQ1aAY+sBb+gYqMppxArpnPoBPfLMFLcYaSMcTCjQe5JafbCG X-Forefront-Antispam-Report: CIP:255.255.255.255; CTRY:; LANG:en; SCL:1; SRV:; IPV:NLI; SFV:NSPM; H:DM6PR01MB5802.prod.exchangelabs.com; PTR:; CAT:NONE; SFS:(4636009)(346002)(396003)(136003)(366004)(376002)(39850400004)(83380400001)(6512007)(8936002)(316002)(66946007)(16526019)(8676002)(4326008)(2616005)(6486002)(956004)(26005)(186003)(1076003)(54906003)(6666004)(6506007)(966005)(478600001)(5660300002)(86362001)(2906002)(66476007)(69590400008)(66556008)(52116002)(6916009); DIR:OUT; SFP:1102; X-MS-Exchange-AntiSpam-MessageData: 9GuCbPqokVKvwknGmg39aKe3BkY9+QgZ9IgJ7pEbZv1CTH7XKDol/yHdaml00cdWLz7Ixu78al5nP/9nrloFdfdglVRK9m2+GHeXwSC1q3O2ZulhjXhlM810V2kUyLGHcbKvm8tjWdqul9vYz4VAb7Lxg8zkW3GXhIQZlldSsUg7ai+YbRBJHa/k0ke93ph8z8IAiUlVrAKm2Q2NsGLYhJUSyt3cLDoHFVpn943bYiREsNt5AZ1XWUNGdDg3bYz46arNyXAdBpPnrls426ApVYZLF8aWSCmtAMsYy++zTAcLFBakQG5jxRh7vcEDkb0+HaEQ9dfUSNHWIWuTNrg/QthmN+mJaN1nagAyidyuayWm33enpB7UO4kM+lsb+ZwJjeFSfspsqxqJ5K2egLBuRtvU6fDzMcYgXpN2KKg7PYDUCVpxdcRlrF0JTjqm8/y4JUcMT8jhaFCAo3dwthlHqO4eaKyXd0R0Lc8WnfrGEamCEQ7sYkIIA9YkBugKGi80OMpqQernsQvjdHlGVRJj0ORwlWw/GHCWnU6EsK8cDx9lHtI4DNPRma8yUm39Gpxb/4PQ2f+cJOjscTG6nA9nMLVh1QMmKMDrV32Q54SzdSoIERXD3SSrfzWefrBEwKSUz8rd+38/Zak0PIYmkTUypg== X-OriginatorOrg: os.amperecomputing.com X-MS-Exchange-CrossTenant-Network-Message-Id: 55ff969e-d5e2-4e16-9438-08d859beaca8 X-MS-Exchange-CrossTenant-AuthSource: DM6PR01MB5802.prod.exchangelabs.com X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 15 Sep 2020 21:31:15.0171 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: 3bc2b170-fd94-476d-b0ce-4229bdc904a7 X-MS-Exchange-CrossTenant-MailboxType: HOSTED X-MS-Exchange-CrossTenant-UserPrincipalName: xz1gQyq4XIbKSrdxujzvPYLgNLg/9kOiZi13Xf0xkKqh+m6NU5T14ZLnxICjjw6f4aiaZul7MNddEfDiGiQcwLrBL3b+VQXJAMKvJkPDp67dlmd9J/pv9ryeWVE67kqk X-MS-Exchange-Transport-CrossTenantHeadersStamped: DM6PR01MB5516 Sender: stable-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: stable@vger.kernel.org commit dd3ecf17ba70a70d2c9ef9ba725281b84f8eef12 upstream. If the HCD provides a localmem pool we will never use the DMA pools, so don't create them. Fixes: b0310c2f09bb ("USB: use genalloc for USB HCs with local memory") Signed-off-by: Christoph Hellwig Link: https://lore.kernel.org/r/20190811080520.21712-2-hch@lst.de Signed-off-by: Greg Kroah-Hartman Signed-off-by: John L. Villalovos --- drivers/usb/core/buffer.c | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/drivers/usb/core/buffer.c b/drivers/usb/core/buffer.c index d93e25aeaf96..8f1697bcc170 100644 --- a/drivers/usb/core/buffer.c +++ b/drivers/usb/core/buffer.c @@ -66,9 +66,9 @@ int hcd_buffer_create(struct usb_hcd *hcd) char name[16]; int i, size; - if (!IS_ENABLED(CONFIG_HAS_DMA) || - (!is_device_dma_capable(hcd->self.sysdev) && - !hcd->localmem_pool)) + if (hcd->localmem_pool || + !IS_ENABLED(CONFIG_HAS_DMA) || + !is_device_dma_capable(hcd->self.sysdev)) return 0; for (i = 0; i < HCD_BUFFER_POOLS; i++) { From patchwork Tue Sep 15 21:30:39 2020 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: John Villalovos X-Patchwork-Id: 309723 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-12.8 required=3.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID, DKIM_VALID_AU, HEADER_FROM_DIFFERENT_DOMAINS, INCLUDES_PATCH, MAILING_LIST_MULTI, MSGID_FROM_MTA_HEADER, SIGNED_OFF_BY, SPF_HELO_NONE, SPF_PASS, URIBL_BLOCKED, USER_AGENT_GIT autolearn=ham autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 7CC8FC433E2 for ; Tue, 15 Sep 2020 21:41:34 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by mail.kernel.org (Postfix) with ESMTP id 2A94420809 for ; Tue, 15 Sep 2020 21:41:34 +0000 (UTC) Authentication-Results: mail.kernel.org; dkim=pass (1024-bit key) header.d=os.amperecomputing.com header.i=@os.amperecomputing.com header.b="IZ07XNm4" Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727573AbgIOVla (ORCPT ); Tue, 15 Sep 2020 17:41:30 -0400 Received: from mail-bn8nam12on2133.outbound.protection.outlook.com ([40.107.237.133]:5473 "EHLO NAM12-BN8-obe.outbound.protection.outlook.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1728136AbgIOVdB (ORCPT ); Tue, 15 Sep 2020 17:33:01 -0400 ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=OHO5ndZrSwi9dM5iY9F6vSV3dXFW2aT9Iuir5kEoWJe7V1kHvBoe3vuPWQAimlbDlsR1c5+2ia9zK5lBoYxa6akSMMclkPsDdInmcjUL3AbPyX2hFNsS9A6b2HwKkXmIuD1RdVF9OHVKMZYFWocKgrK2ta5Tw2aETdukHeGrgDKBVS2w0qJafYcuQhk2BX8AkdkOIuRlaNsZl+F8OhHXrUo1OoWyPmbXhs2FnZSwzPmhxugdWwq+fygyVFHMGZuV6+Pk3YaxaISmdE/+4Aa8YjGQgqc+/k5svJJYqUavz5/S1mbK+GDAL7mV/bm8HID1HS5hW3/0lzqpwcO5KpscVA== 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-SenderADCheck; bh=qNedkKmMvY4eHHTkTlFBXTYwRp31+WjUa+1WCw4ML88=; b=I69NVUTbTOrX6SkXiHYfEkkRoRMAztbIBI9rVIugUnDlNtkKWtMLvO/bsPSlZAjJ4o/bPVm1jC263WN+c/Gd5QNct2/S58VNCkahqavbq2lLMbqRICruFvTCMllD1qS0aamRseZmq1G6jgA/CTDco0QZCvXcjdHbQrwqQ5gy0q0BDUFPJIOvyAvTXHSRfeWi6HjmGvVqWkGzrMAcXMUFSNUFxDKkUMGeUzVuycsuh1nEZOcrRf2qxLJcv9/W03DSxEy1gsxVlNxyNoCz4z0rCOVufVaDm8CIO0qUnoIwVxHVx4lu8XWdByY/gTr4vj2AuIhYe6Lv4ZDNFJDXvq2Juw== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=os.amperecomputing.com; dmarc=pass action=none header.from=os.amperecomputing.com; dkim=pass header.d=os.amperecomputing.com; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=os.amperecomputing.com; s=selector2; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=qNedkKmMvY4eHHTkTlFBXTYwRp31+WjUa+1WCw4ML88=; b=IZ07XNm48tmflovamDuYP1HVPVC4GBVQDhwnSOpnwSw8+WhZfJQb0FtmybxVeSshsp8MoUOVvj8L8p6muPk5zTzHJDf7jbqE0fk16C2+s7wEWb4Xv2r9Fc6i80zDq+wLgtTRqLyh0hSag3SVMkRwC8PHuI8yIA2OoGgTnqDHx/Q= Authentication-Results: vger.kernel.org; dkim=none (message not signed) header.d=none;vger.kernel.org; dmarc=none action=none header.from=os.amperecomputing.com; Received: from DM6PR01MB5802.prod.exchangelabs.com (2603:10b6:5:203::17) by DM6PR01MB5516.prod.exchangelabs.com (2603:10b6:5:153::22) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.3370.17; Tue, 15 Sep 2020 21:31:17 +0000 Received: from DM6PR01MB5802.prod.exchangelabs.com ([fe80::ed9e:20e7:332a:704b]) by DM6PR01MB5802.prod.exchangelabs.com ([fe80::ed9e:20e7:332a:704b%7]) with mapi id 15.20.3391.011; Tue, 15 Sep 2020 21:31:17 +0000 From: "John L. Villalovos" To: stable@vger.kernel.org Cc: "John L. Villalovos" , Christoph Hellwig , Greg Kroah-Hartman Subject: [PATCH 4.19 5/5] usb: add a hcd_uses_dma helper Date: Tue, 15 Sep 2020 14:30:39 -0700 Message-Id: <20200915213039.862123-6-jlvillal@os.amperecomputing.com> X-Mailer: git-send-email 2.26.2 In-Reply-To: <20200915213039.862123-1-jlvillal@os.amperecomputing.com> References: <20200915213039.862123-1-jlvillal@os.amperecomputing.com> X-ClientProxiedBy: CY4PR14CA0040.namprd14.prod.outlook.com (2603:10b6:903:101::26) To DM6PR01MB5802.prod.exchangelabs.com (2603:10b6:5:203::17) MIME-Version: 1.0 X-MS-Exchange-MessageSentRepresentingType: 1 Received: from localhost.localdomain (4.28.12.214) by CY4PR14CA0040.namprd14.prod.outlook.com (2603:10b6:903:101::26) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.3370.16 via Frontend Transport; Tue, 15 Sep 2020 21:31:16 +0000 X-Mailer: git-send-email 2.26.2 X-Originating-IP: [4.28.12.214] X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id: b49a4c38-23f6-4468-e695-08d859beadce X-MS-TrafficTypeDiagnostic: DM6PR01MB5516: X-MS-Exchange-Transport-Forked: True X-Microsoft-Antispam-PRVS: X-MS-Oob-TLC-OOBClassifiers: OLM:459; X-MS-Exchange-SenderADCheck: 1 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: sCr5JLw+T7yu1fNsXAOZjlPnayRYRIbg6ECzhqDs+GNsncvtOT+uj2jfLu0bw0AwkWmEyupbR+X1o654zupx7tXQXrpARdy6/KrfXebBlXUvYsjFQ17CNdUt5Q7conPyKk/PmOCkNNtOz1ljNFM1ZCbOqPlYk2mDmL3JIjFn28TP7+rhThtl/ZY1SWjBVgkFvFuEKYboBofUR/ht1lPGdJmkjWh2LsNLEE1c+wnBr0z50A9849QadjtUgUPE6mH8+etvn69yH+wC8N2knHlknMe8pIZUz3Vs5xisy8m2zd6jvILjXrIlpFadD7LKjx/PzaNXsqFrx7fZpPf2kUAIkm0Iwg0eQdFjB+3BjS12q92uqRaV+2FHWTs0Fc74Ei1Yz/TZbmjwCReTAPmBNlz43tOQGfCiXUObsTEFoWepQ9bD3V+VIMykYzBhL5qPmolA0pGis4FzBGhNKrAmxnoNp8sGSpSbs2xFbEDFRJrZt6Ies4rnqDvod/2lgwMhFsZR X-Forefront-Antispam-Report: CIP:255.255.255.255; CTRY:; LANG:en; SCL:1; SRV:; IPV:NLI; SFV:NSPM; H:DM6PR01MB5802.prod.exchangelabs.com; PTR:; CAT:NONE; SFS:(4636009)(346002)(396003)(136003)(366004)(376002)(39850400004)(83380400001)(6512007)(8936002)(316002)(66946007)(16526019)(8676002)(4326008)(2616005)(6486002)(956004)(26005)(186003)(1076003)(54906003)(6666004)(6506007)(966005)(478600001)(5660300002)(86362001)(2906002)(66476007)(69590400008)(66556008)(52116002)(6916009); DIR:OUT; SFP:1102; X-MS-Exchange-AntiSpam-MessageData: 7asIl+zlE2SC+wYZGgDSeW+nQK1Lv6XKrVw1xKyvMhdFCdH8Sw0AvOWptxizmH/3Nv7CzAJEHbOVHNCEcgslpMk1x4WbepnCOQRdGY0d7CTiRB3HoiFP5E26b+3M5M96u3mzXW8SkLnwID0rCQMdoOhAyJ4OHtVCXZ9FbIA3TTFJK4/e21KHOfDHxFAGqOm5j/LzooM/pqhp/qYJen6121bcKkvo9JEQgwaLDufOVbEcwrYuGOrnxa/4K80fp3PQt5rAJpuwUot77bF9BECkmiekqmDB/7GcN8oTcC2BbMcT1YeYduvdDnqHCU17Vgwox8v168J/CG6X8jK9WE6v8iwgtHrfI56vOHhBlHxskaWaogINF2TyJRvL1V/3mzeIdfKFieiQ/1nmoTEoIKSm4t+hYZxchoJxHjetwsQ5Cc2ExDL8uvtVtE9ezFqOFwsFc4alKU0yq3RLZOmk4vRZEn9ADNvv0fyxA30fvKLQcJ838jrWuJkfk7eJzdW5vTxryv0lq7U+OBgWhLK3xDFa1aYxBI2c/BOUF9UgrbpxHclv9TI6aZRugmxb2weWg12QJcSvymSFO7IfCe5LSYWDWC7eRnQ+0fe6AXI5n2oxjyqxXzxWw7flc9Nf5QNXd4ddxsWZ3W8shleZpe7yhP5s/w== X-OriginatorOrg: os.amperecomputing.com X-MS-Exchange-CrossTenant-Network-Message-Id: b49a4c38-23f6-4468-e695-08d859beadce X-MS-Exchange-CrossTenant-AuthSource: DM6PR01MB5802.prod.exchangelabs.com X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 15 Sep 2020 21:31:16.9060 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: 3bc2b170-fd94-476d-b0ce-4229bdc904a7 X-MS-Exchange-CrossTenant-MailboxType: HOSTED X-MS-Exchange-CrossTenant-UserPrincipalName: 8djaI5LOyD4p3Tj6JmZjjdRLR+ALbbOglpMivDeVE/9Wbi7YAKmgl6iaKk2xz9qeZQgeMIQptRJocw65ECRvvESh2gV2c5pqWxFlJ22Bc41nBiD+YqO51Ee8Y+qeoEwt X-MS-Exchange-Transport-CrossTenantHeadersStamped: DM6PR01MB5516 Sender: stable-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: stable@vger.kernel.org commit edfbcb321faf07ca970e4191abe061deeb7d3788 upstream. The USB buffer allocation code is the only place in the usb core (and in fact the whole kernel) that uses is_device_dma_capable, while the URB mapping code uses the uses_dma flag in struct usb_bus. Switch the buffer allocation to use the uses_dma flag used by the rest of the USB code, and create a helper in hcd.h that checks this flag as well as the CONFIG_HAS_DMA to simplify the caller a bit. Signed-off-by: Christoph Hellwig Link: https://lore.kernel.org/r/20190811080520.21712-3-hch@lst.de Signed-off-by: Greg Kroah-Hartman Signed-off-by: John L. Villalovos --- drivers/usb/core/buffer.c | 10 +++------- drivers/usb/core/hcd.c | 4 ++-- drivers/usb/dwc2/hcd.c | 2 +- include/linux/usb.h | 2 +- include/linux/usb/hcd.h | 3 +++ 5 files changed, 10 insertions(+), 11 deletions(-) diff --git a/drivers/usb/core/buffer.c b/drivers/usb/core/buffer.c index 8f1697bcc170..84055ed842ff 100644 --- a/drivers/usb/core/buffer.c +++ b/drivers/usb/core/buffer.c @@ -66,9 +66,7 @@ int hcd_buffer_create(struct usb_hcd *hcd) char name[16]; int i, size; - if (hcd->localmem_pool || - !IS_ENABLED(CONFIG_HAS_DMA) || - !is_device_dma_capable(hcd->self.sysdev)) + if (hcd->localmem_pool || !hcd_uses_dma(hcd)) return 0; for (i = 0; i < HCD_BUFFER_POOLS; i++) { @@ -133,8 +131,7 @@ void *hcd_buffer_alloc( return gen_pool_dma_alloc(hcd->localmem_pool, size, dma); /* some USB hosts just use PIO */ - if (!IS_ENABLED(CONFIG_HAS_DMA) || - !is_device_dma_capable(bus->sysdev)) { + if (!hcd_uses_dma(hcd)) { *dma = ~(dma_addr_t) 0; return kmalloc(size, mem_flags); } @@ -164,8 +161,7 @@ void hcd_buffer_free( return; } - if (!IS_ENABLED(CONFIG_HAS_DMA) || - !is_device_dma_capable(bus->sysdev)) { + if (!hcd_uses_dma(hcd)) { kfree(addr); return; } diff --git a/drivers/usb/core/hcd.c b/drivers/usb/core/hcd.c index c991e7ff1875..8b8ec0c7325d 100644 --- a/drivers/usb/core/hcd.c +++ b/drivers/usb/core/hcd.c @@ -1511,7 +1511,7 @@ int usb_hcd_map_urb_for_dma(struct usb_hcd *hcd, struct urb *urb, if (usb_endpoint_xfer_control(&urb->ep->desc)) { if (hcd->self.uses_pio_for_control) return ret; - if (IS_ENABLED(CONFIG_HAS_DMA) && hcd->self.uses_dma) { + if (hcd_uses_dma(hcd)) { if (is_vmalloc_addr(urb->setup_packet)) { WARN_ONCE(1, "setup packet is not dma capable\n"); return -EAGAIN; @@ -1545,7 +1545,7 @@ int usb_hcd_map_urb_for_dma(struct usb_hcd *hcd, struct urb *urb, dir = usb_urb_dir_in(urb) ? DMA_FROM_DEVICE : DMA_TO_DEVICE; if (urb->transfer_buffer_length != 0 && !(urb->transfer_flags & URB_NO_TRANSFER_DMA_MAP)) { - if (IS_ENABLED(CONFIG_HAS_DMA) && hcd->self.uses_dma) { + if (hcd_uses_dma(hcd)) { if (urb->num_sgs) { int n; diff --git a/drivers/usb/dwc2/hcd.c b/drivers/usb/dwc2/hcd.c index a5c8329fd462..797bb4f2a52c 100644 --- a/drivers/usb/dwc2/hcd.c +++ b/drivers/usb/dwc2/hcd.c @@ -4770,7 +4770,7 @@ static int _dwc2_hcd_urb_enqueue(struct usb_hcd *hcd, struct urb *urb, buf = urb->transfer_buffer; - if (hcd->self.uses_dma) { + if (hcd_uses_dma(hcd)) { if (!buf && (urb->transfer_dma & 3)) { dev_err(hsotg->dev, "%s: unaligned transfer with no transfer_buffer", diff --git a/include/linux/usb.h b/include/linux/usb.h index ff010d1fd1c7..667712d416c1 100644 --- a/include/linux/usb.h +++ b/include/linux/usb.h @@ -1455,7 +1455,7 @@ typedef void (*usb_complete_t)(struct urb *); * field rather than determining a dma address themselves. * * Note that transfer_buffer must still be set if the controller - * does not support DMA (as indicated by bus.uses_dma) and when talking + * does not support DMA (as indicated by hcd_uses_dma()) and when talking * to root hub. If you have to trasfer between highmem zone and the device * on such controller, create a bounce buffer or bail out with an error. * If transfer_buffer cannot be set (is in highmem) and the controller is DMA diff --git a/include/linux/usb/hcd.h b/include/linux/usb/hcd.h index e24dade77132..aa69d7d5762a 100644 --- a/include/linux/usb/hcd.h +++ b/include/linux/usb/hcd.h @@ -422,6 +422,9 @@ static inline bool hcd_periodic_completion_in_progress(struct usb_hcd *hcd, return hcd->high_prio_bh.completing_ep == ep; } +#define hcd_uses_dma(hcd) \ + (IS_ENABLED(CONFIG_HAS_DMA) && (hcd)->self.uses_dma) + extern int usb_hcd_link_urb_to_ep(struct usb_hcd *hcd, struct urb *urb); extern int usb_hcd_check_unlink_urb(struct usb_hcd *hcd, struct urb *urb, int status);