From patchwork Wed Jun 7 10:55:43 2023 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Sui Jingfeng <15330273260@189.cn> X-Patchwork-Id: 10411 Return-Path: Delivered-To: ouuuleilei@gmail.com Received: by 2002:a59:994d:0:b0:3d9:f83d:47d9 with SMTP id k13csp166628vqr; Wed, 7 Jun 2023 03:59:29 -0700 (PDT) X-Google-Smtp-Source: ACHHUZ4wp8jygJLeO1AnrtJmVVYE4YJQ0NdnagIHOnb1plrDHpavRBD07Bkp/GS9fn0udLc+9Tdg X-Received: by 2002:a05:6358:c5a4:b0:123:6953:6754 with SMTP id fc36-20020a056358c5a400b0012369536754mr750407rwb.21.1686135569571; Wed, 07 Jun 2023 03:59:29 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1686135569; cv=none; d=google.com; s=arc-20160816; b=udTk84BJR8/G6eoLOM8X9vzHOpa6//tfOWld/h1uMEdp05kaouMHTOJBkE1qlzSntI tGK3p1ib6knZIcE6wZbiTgC+WGbt8BWkn5Ouy41fxQTuvp+YVSmV0ci+R1hYux424F3X 33kq1B07kkaQyisJ0vuasNccOWEvyi/T9zYiYZGIaxNUPbeUlJ5P+vUy4Hx+t7S0f1tl eD4qLmNXghVnc+6Ktepe/DVqFJDnfx3mBqZkUzml+8N+fbB89jmuVCnbj1/dbp/7xXA6 GIy976RxguIrtmhTBpxnte5zxYcCdFCnqhn6jArPhDvsbfIAtbmhUqJs2Dp8T9EamB1l ADZA== 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 :message-id:date:subject:cc:to:from:sender:hmm_source_type :hmm_attache_num:hmm_source_ip; bh=GYolRExbGSGJM6czthy/irWjz4DqkoTRujZPDSXMdek=; b=Lt7WVtMJWEGy+hz2X+uo4wfIzGBZGaPHbFl28ZBdKTx5ox8oJSPsfAAayuerVN0WH/ F9Juv4lpjoQvhim6bRtRIKanMhebvj3Ar26k6AB5ypr3Wgmshar/BdsFnHPFh64DOyYf 1HGELuraaZvK4ZtBjOFvRV/pjYACWzkCkdaX8uXdEigjBYx9bMcmSEWK0+2Bzob2tb4N 1XumEz9XDRqG3RYNdtbm26YqcWGyVVtBALOE/WzhA8hh6cwfWRp1sIr1owk2YfMv9kRF nhNg+NlrMt7HxUHJg0nJGRaaOWwB5J517NnJIOoTUkn2M2dFP965K062RiGDNgXdn0S6 /m2A== ARC-Authentication-Results: i=1; mx.google.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 Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id w5-20020a17090abc0500b0024799a3324dsi935333pjr.162.2023.06.07.03.59.16; Wed, 07 Jun 2023 03:59:29 -0700 (PDT) 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; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S239782AbjFGK4S (ORCPT + 99 others); Wed, 7 Jun 2023 06:56:18 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:36388 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S234391AbjFGK4K (ORCPT ); Wed, 7 Jun 2023 06:56:10 -0400 Received: from 189.cn (ptr.189.cn [183.61.185.102]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id B2BBE1BD8 for ; Wed, 7 Jun 2023 03:56:01 -0700 (PDT) HMM_SOURCE_IP: 10.64.8.31:55208.1520123491 HMM_ATTACHE_NUM: 0000 HMM_SOURCE_TYPE: SMTP Received: from clientip-114.242.206.180 (unknown [10.64.8.31]) by 189.cn (HERMES) with SMTP id 595B31002AB; Wed, 7 Jun 2023 18:55:58 +0800 (CST) Received: from ([114.242.206.180]) by gateway-151646-dep-75648544bd-xp9j7 with ESMTP id 01a77a006a344abebd1cacd0747ec331 for l.stach@pengutronix.de; Wed, 07 Jun 2023 18:56:00 CST X-Transaction-ID: 01a77a006a344abebd1cacd0747ec331 X-Real-From: 15330273260@189.cn X-Receive-IP: 114.242.206.180 X-MEDUSA-Status: 0 Sender: 15330273260@189.cn From: Sui Jingfeng <15330273260@189.cn> To: Lucas Stach , Russell King , Christian Gmeiner , David Airlie , Daniel Vetter , Li Yi Cc: linux-kernel@vger.kernel.org, etnaviv@lists.freedesktop.org, dri-devel@lists.freedesktop.org, Sui Jingfeng Subject: [PATCH v8 0/8] drm/etnaviv: add pci device driver support Date: Wed, 7 Jun 2023 18:55:43 +0800 Message-Id: <20230607105551.568639-1-15330273260@189.cn> X-Mailer: git-send-email 2.25.1 MIME-Version: 1.0 X-Spam-Status: No, score=-1.7 required=5.0 tests=BAYES_00, FREEMAIL_ENVFROM_END_DIGIT,FREEMAIL_FROM,FROM_LOCAL_DIGITS, FROM_LOCAL_HEX,SPF_HELO_PASS,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=no 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 X-getmail-retrieved-from-mailbox: =?utf-8?q?INBOX?= X-GMAIL-THRID: =?utf-8?q?1768041290970321417?= X-GMAIL-MSGID: =?utf-8?q?1768041290970321417?= From: Sui Jingfeng There is a Vivante GC1000 (v5037) in LS2K1000 and LS7A1000, this GPU is a PCI device, and it has 2D and 3D cores in the same core. Thus, this patch set is trying to add PCI device driver support to etnaviv. v6: * Fix build issue on system without CONFIG_PCI enabled v7: * Add a separate patch for the platform driver rearrangement (Bjorn) * Switch to runtime check if the GPU is dma coherent or not (Lucas) * Add ETNAVIV_PARAM_GPU_COHERENT to allow userspace to query (Lucas) * Remove etnaviv_gpu.no_clk member (Lucas) * Various Typos and coding style fixed (Bjorn) v8: * Fix typos and remove unnecessary header included (Bjorn). * Add a dedicated function to create the virtual master platform device. Sui Jingfeng (8): drm/etnaviv: add a dedicated function to register an irq handler drm/etnaviv: add a dedicated function to get various clocks drm/etnaviv: add dedicated functions to create and destroy platform devices drm/etnaviv: add helpers for private data construction and destruction drm/etnaviv: allow bypass component framework drm/etnaviv: add driver support for the PCI devices drm/etnaviv: add support for the dma coherent device drm/etnaviv: add a dedicated function to create the virtual master drivers/gpu/drm/etnaviv/Kconfig | 10 + drivers/gpu/drm/etnaviv/Makefile | 2 + drivers/gpu/drm/etnaviv/etnaviv_drv.c | 257 ++++++++++++++------ drivers/gpu/drm/etnaviv/etnaviv_drv.h | 10 + drivers/gpu/drm/etnaviv/etnaviv_gem.c | 22 +- drivers/gpu/drm/etnaviv/etnaviv_gem_prime.c | 7 +- drivers/gpu/drm/etnaviv/etnaviv_gpu.c | 168 ++++++++----- drivers/gpu/drm/etnaviv/etnaviv_gpu.h | 9 + drivers/gpu/drm/etnaviv/etnaviv_pci_drv.c | 75 ++++++ drivers/gpu/drm/etnaviv/etnaviv_pci_drv.h | 9 + include/uapi/drm/etnaviv_drm.h | 1 + 11 files changed, 440 insertions(+), 130 deletions(-) create mode 100644 drivers/gpu/drm/etnaviv/etnaviv_pci_drv.c create mode 100644 drivers/gpu/drm/etnaviv/etnaviv_pci_drv.h