Received: by 2002:a05:6358:489b:b0:bb:da1:e618 with SMTP id x27csp6734260rwn; Tue, 13 Sep 2022 08:20:14 -0700 (PDT) X-Google-Smtp-Source: AA6agR6Uy1EhomwOOTySxg0LM/4Mysejn4Y+AmnvY6ul59iGjo31oq/H0xPPu57KPRNOZvPaPz4G X-Received: by 2002:a17:907:3f24:b0:77b:1916:7967 with SMTP id hq36-20020a1709073f2400b0077b19167967mr11382911ejc.558.1663082414412; Tue, 13 Sep 2022 08:20:14 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1663082414; cv=none; d=google.com; s=arc-20160816; b=usYyD7Yd5TdSbIFCrcmHQOw+sIDDyAmRluOvi6oHe6XGuCQG5gBF8mX7d0hbDvDrQ1 R2K6txOVekOjgq+2pDs63ypU5l5If5A0at5VAZcJlGmXrUZaXBaO7Mfeid0mid5LBf// t0dmxuV4yS632QwNNb5EqPC+90XOv7grm2rm9e9Z/pFmyrvihLkBHHI06ZQy92ZeI7T0 5AwGJd9VT0wIxnxEKqXqRjIfPeqi8pP78AYE1aNJ/rUS7IOHsnv42pjNsbnkPxkJLVFm W1kfwxBE/w2A8uA0Z7jnMPu1fbzsqQHwdDd3+PHUF+3sIOWYnB1Rl0ykSASmdPwwmJVp rrSA== 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:dkim-signature; bh=r1BbAaIYphXM8kEX7BlFmPYXKRn9fe68imxk+A0IPao=; b=kXP6lyi8IKLmfj8/5k58KitVR5Hl8J37RvLxnUeQbvQ4clPVQpvQ8IPBxEh8W/0pl8 D2K3t3fYXq4Nkp+CUp/4I45qwGvQ2UstnE556C/VrhDPtuXhW5e7qCBqKEQ2VFW+WASh BuCAxA4SZNnahdtBrQzjrk/+Q5DPsGMSebKa6ApjyqvysKisqyn3+6CtSnEoNu5RvOpE AOa81aQh3AFYG5u4Y/Q2XqUB2+QV9Vlp/EMWbA23EHUeQsvGe9qPOtQeUYVBV7xH69wO b3IjQILtGtOjKn4hLega4V3AqjFreOJDIpcASrnqVqi3SzFCyCIvRrglH58ALOacXkI2 /dag== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@kapsi.fi header.s=20161220 header.b=JZS0LSq3; 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=fail (p=NONE sp=NONE dis=NONE) header.from=kapsi.fi Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id qw10-20020a1709066a0a00b0073d6b849d4fsi11533389ejc.731.2022.09.13.08.19.45; Tue, 13 Sep 2022 08:20:14 -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; dkim=fail header.i=@kapsi.fi header.s=20161220 header.b=JZS0LSq3; 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=fail (p=NONE sp=NONE dis=NONE) header.from=kapsi.fi Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232202AbiIMNP1 (ORCPT + 99 others); Tue, 13 Sep 2022 09:15:27 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:42370 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229592AbiIMNPN (ORCPT ); Tue, 13 Sep 2022 09:15:13 -0400 Received: from mail.kapsi.fi (mail.kapsi.fi [IPv6:2001:67c:1be8::25]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 0CF231146B; Tue, 13 Sep 2022 06:15:08 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=kapsi.fi; s=20161220; h=Content-Transfer-Encoding:MIME-Version:Message-Id:Date:Subject: Cc:To:From:Sender:Reply-To:Content-Type:Content-ID:Content-Description: Resent-Date:Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID: In-Reply-To:References:List-Id:List-Help:List-Unsubscribe:List-Subscribe: List-Post:List-Owner:List-Archive; bh=r1BbAaIYphXM8kEX7BlFmPYXKRn9fe68imxk+A0IPao=; b=JZS0LSq3xIHEhZihIIoyptxrNo Q4z0lwtzclSGTyB+6/2p3dl9/YJabgcEtdhFfJHwr7+U/PMhpuH2j1CKIoDbQglQesrjEDuRhQRNj EfsLeBOpiMFEv9LE3da6nMQtaD6/VCqbn9n96cH1p9MMz7ZXTu1EorVcv/Oj0IpTTFMaGol3YgDfY d6QrRJfE6P5nXo2vb5p8lkM5TfeR41AXw67AypyrW3mBjwzXBy1tNOqotrG1jnaLyNZcCrZYmvdWg CXH5iwrEeRNadszT8elmqb+c6lj1GPcUpPnD7XtZHkttA9KdzIq0jiKm+aTMylAWxJnbtNpEvdnJx /JhN0E8w==; Received: from 91-158-25-70.elisa-laajakaista.fi ([91.158.25.70] helo=toshino.localdomain) by mail.kapsi.fi with esmtpsa (TLS1.3) tls TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384 (Exim 4.94.2) (envelope-from ) id 1oY5kg-00EVnM-JY; Tue, 13 Sep 2022 16:14:58 +0300 From: Mikko Perttunen To: Thierry Reding , David Airlie , Daniel Vetter , Rob Herring , Krzysztof Kozlowski , Jonathan Hunter Cc: Mikko Perttunen , Ashish Mhetre , Sameer Pujar , dri-devel@lists.freedesktop.org, linux-tegra@vger.kernel.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org Subject: [PATCH v2 0/8] Support for NVDEC on Tegra234 Date: Tue, 13 Sep 2022 16:14:38 +0300 Message-Id: <20220913131447.2877280-1-cyndis@kapsi.fi> X-Mailer: git-send-email 2.37.0 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-SA-Exim-Connect-IP: 91.158.25.70 X-SA-Exim-Mail-From: cyndis@kapsi.fi X-SA-Exim-Scanned: No (on mail.kapsi.fi); SAEximRunCond expanded to false 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_NONE,SPF_PASS, T_SCC_BODY_TEXT_LINE 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 From: Mikko Perttunen v2: * Updated patches 1,3 based on comments * Added Acked-by to patch 2 Original message: Hi all, this series adds support for the HW video decoder, NVDEC, on Tegra234 (Orin). The main change is a switch from Falcon to RISC-V for the internal microcontroller, which brings along a change in how the engine is booted. Otherwise it is backwards compatible with earlier versions. In previous iterations, firmware was simply loaded from disk and written into engine internal memory. Now, the engine has a bootrom that loads the firmware from a carveout where it has been loaded by the system bootloader; however, we still need to tell it where that carveout is loaded and some offsets into it. For that, the first patch adds a new memory controller API to query the carveout address. The offsets are read from device tree -- the expectation is that at flashing time (when the firmware is also flashed), the flasher also delivers a device tree overlay with values corresponding to the flashed firmware. The currently available Linux for Tegra release doesn't yet include this device tree overlay flashing, and the firmware version it contains is incompatible with this series. The plan is to fix that for the next Linux for Tegra release, but if necessary, we can postpone merging of this series to once those changes are available. Thanks! Mikko Mikko Perttunen (8): memory: tegra: Add API for retrieving carveout bounds dt-bindings: Add headers for NVDEC on Tegra234 dt-bindings: Add bindings for Tegra234 NVDEC arm64: tegra: Add NVDEC on Tegra234 gpu: host1x: Add stream ID register data for NVDEC on Tegra234 drm/tegra: nvdec: Support multiple clocks drm/tegra: Add code for booting RISC-V based engines drm/tegra: Add Tegra234 support to NVDEC driver .../gpu/host1x/nvidia,tegra234-nvdec.yaml | 154 ++++++++++++++++ arch/arm64/boot/dts/nvidia/tegra234.dtsi | 27 +++ drivers/gpu/drm/tegra/Makefile | 3 +- drivers/gpu/drm/tegra/drm.c | 1 + drivers/gpu/drm/tegra/nvdec.c | 171 +++++++++++++++--- drivers/gpu/drm/tegra/riscv.c | 106 +++++++++++ drivers/gpu/drm/tegra/riscv.h | 30 +++ drivers/gpu/host1x/dev.c | 12 ++ drivers/memory/tegra/mc.c | 25 +++ drivers/memory/tegra/tegra234.c | 5 + include/dt-bindings/clock/tegra234-clock.h | 4 + include/dt-bindings/memory/tegra234-mc.h | 3 + .../dt-bindings/power/tegra234-powergate.h | 1 + include/dt-bindings/reset/tegra234-reset.h | 1 + include/soc/tegra/mc.h | 11 ++ 15 files changed, 528 insertions(+), 26 deletions(-) create mode 100644 Documentation/devicetree/bindings/gpu/host1x/nvidia,tegra234-nvdec.yaml create mode 100644 drivers/gpu/drm/tegra/riscv.c create mode 100644 drivers/gpu/drm/tegra/riscv.h -- 2.37.0