Received: by 2002:a25:86ce:0:0:0:0:0 with SMTP id y14csp538593ybm; Wed, 22 May 2019 07:31:43 -0700 (PDT) X-Google-Smtp-Source: APXvYqwFoA/TfiWKS7Az/9S34X8oPivGD5dgglM11F2GilwB8rNpk08ScIRZq2YjJBEGL/YsoSAD X-Received: by 2002:a65:620a:: with SMTP id d10mr9686377pgv.42.1558535503837; Wed, 22 May 2019 07:31:43 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1558535503; cv=none; d=google.com; s=arc-20160816; b=v0M2DNRfXsTQwRNwliuKTcvgZReo0nifVMbJkF654BcvG0tPrW0cWcVkmqhk/E3YK+ RKGNoR3PXC7h8muKFTKbdTLT3FAqQNQGPdkXqd3b5aR4LNIyLjPM93xycgeyBikmgthe EPfnHMCA7oqxBKJKPSlkAQgM5Mf8qmS+Nqk0JKUqpd0R/53HoaX6NSgQD7RCrQs1qn0e v/UuBWLrkOKdt8q6zX28RTgyY1GU29Q+4TGzjOyxXfEbl0QaRIuqN0lnxTIK92oeX+Cj aKU5eLpGHP8hR/+iVTTKCIuyqMPWbcgEIaulSJ5szUZdmAYLjKGeuZ4bwramh6fkxElO wvWg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:date:subject:cc:to:from; bh=FzZGjTrCFO4OQXAO6Rmt/c2aVfSpsisXNJVNGtDg4Dw=; b=gEIlGd58b5VINgJuXEJ8+Ff8bSNGjJQqDHPg6cD0sWrAzU4LiKa5EwMP3rXDxUpecj u/XK1J7Rtek5vIRj4K4pgvDFCQ6uSGHiFtcAQbtLOPH8TwaSmDEOOduyOyyNkCgPT/Ko 98+hmIefNIVWW6NhQwZbG/o29Rj1+kmFQrrkGRnxpJ9XgO3yTLBZE0bk8vy6pXnZnkr8 VhFoVD6A85CkHWng2BHRvbTJL3X9cmkFhrLBxidXZ9bnk6dHoFJKSDfrq5oFblwSCPT5 S6V3bGL2T/jJ1C0JKN+VVSwDvTyi8Krk3VuUVVTe8iDI1THLlrQGBcp994cvXv4ZB9mL 79wQ== 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=nxp.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id q8si24380118pgf.3.2019.05.22.07.31.27; Wed, 22 May 2019 07:31:43 -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; 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=fail (p=NONE sp=NONE dis=NONE) header.from=nxp.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729236AbfEVO1y (ORCPT + 99 others); Wed, 22 May 2019 10:27:54 -0400 Received: from inva020.nxp.com ([92.121.34.13]:42188 "EHLO inva020.nxp.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728491AbfEVO1y (ORCPT ); Wed, 22 May 2019 10:27:54 -0400 Received: from inva020.nxp.com (localhost [127.0.0.1]) by inva020.eu-rdc02.nxp.com (Postfix) with ESMTP id 060FD1A0197; Wed, 22 May 2019 16:27:52 +0200 (CEST) Received: from inva024.eu-rdc02.nxp.com (inva024.eu-rdc02.nxp.com [134.27.226.22]) by inva020.eu-rdc02.nxp.com (Postfix) with ESMTP id ED9B11A000F; Wed, 22 May 2019 16:27:51 +0200 (CEST) Received: from fsr-ub1864-101.ea.freescale.net (fsr-ub1864-101.ea.freescale.net [10.171.82.13]) by inva024.eu-rdc02.nxp.com (Postfix) with ESMTP id 6C72E205ED; Wed, 22 May 2019 16:27:51 +0200 (CEST) From: laurentiu.tudor@nxp.com To: hch@lst.de, stern@rowland.harvard.edu, gregkh@linuxfoundation.org, linux-usb@vger.kernel.org, marex@denx.de Cc: leoyang.li@nxp.com, linux-kernel@vger.kernel.org, robin.murphy@arm.com, noring@nocrew.org, JuergenUrban@gmx.de, Laurentiu Tudor Subject: [PATCH v6 0/5] prerequisites for device reserved local mem rework Date: Wed, 22 May 2019 17:27:43 +0300 Message-Id: <20190522142748.10078-1-laurentiu.tudor@nxp.com> X-Mailer: git-send-email 2.17.1 X-Virus-Scanned: ClamAV using ClamSMTP Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Laurentiu Tudor For HCs that have local memory, replace the current DMA API usage with a genalloc generic allocator to manage the mappings for these devices. This is in preparation for dropping the existing "coherent" dma mem declaration APIs. 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. Only compiled tested, so any volunteers willing to test are most welcome. Thank you! For context, see thread here: https://lkml.org/lkml/2019/4/22/357 Changes in v6: - drop some unneeded initializations (Alan) - use device name for genpool instead of misleading "ohci-hcd" (Alan) - updated some comments (Alan, Fredrik) - added Tested-By tags Changes in v5: - updated first patch to preserve bisectability (Christoph, Greg) - fixed a few more places where dma api was still being used (e.g. td_alloc, ed_alloc) (Fredrik) - included patch from Fredrik adding gen_pool_dma_zalloc() api - added patch that drops HCD_LOCAL_MEM altogether (Greg) - set td_cache / ed_cache to null for devices with local mem (Fredrik) - introduce usb_hcd_setup_local_mem() that sets up the genalloc pool for drivers and updated drivers to use it Changes in v4: - created mapping for local mem - fix genalloc misuse Changes in v3: - rearranged calls into genalloc simplifying the code a bit (Christoph) - dropped RFC prefix Changes in v2: - use genalloc also in core usb (based on comment from Robin) - moved genpool decl to usb_hcd to be accesible from core usb Fredrik Noring (1): lib/genalloc.c: Add gen_pool_dma_zalloc() for zeroed DMA allocations Laurentiu Tudor (4): USB: use genalloc for USB HCs with local memory usb: host: ohci-sm501: init genalloc for local memory usb: host: ohci-tmio: init genalloc for local memory USB: drop HCD_LOCAL_MEM flag drivers/usb/core/buffer.c | 17 ++++++++---- drivers/usb/core/hcd.c | 51 ++++++++++++++++++++++++++++------ drivers/usb/host/ehci-hcd.c | 2 +- drivers/usb/host/fotg210-hcd.c | 2 +- drivers/usb/host/ohci-hcd.c | 25 +++++++++++++---- drivers/usb/host/ohci-mem.c | 35 ++++++++++++++++++++--- drivers/usb/host/ohci-sm501.c | 50 +++++++++++++++------------------ drivers/usb/host/ohci-tmio.c | 15 ++++------ drivers/usb/host/ohci.h | 2 ++ drivers/usb/host/uhci-hcd.c | 2 +- include/linux/genalloc.h | 1 + include/linux/usb/hcd.h | 6 +++- lib/genalloc.c | 29 ++++++++++++++++++- 13 files changed, 171 insertions(+), 66 deletions(-) -- 2.17.1