Received: by 2002:a25:1506:0:0:0:0:0 with SMTP id 6csp3274573ybv; Sun, 9 Feb 2020 19:40:21 -0800 (PST) X-Google-Smtp-Source: APXvYqyieo+AErVOfKiCUm1aOHY5Fb9Xv2fuvt1dkYFiuiEhN9FNGt2KB/6nJsPUqSeq2I9DtjAb X-Received: by 2002:a05:6808:658:: with SMTP id z24mr9659065oih.91.1581306021640; Sun, 09 Feb 2020 19:40:21 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1581306021; cv=none; d=google.com; s=arc-20160816; b=jj8+uv4hrGS6ikPQ6aUZMhRm2KgCBcxxfsazMrGj4Bb9F+eHgUOD/GO1mjedHITSpu zqSNuMHnqye4/HKEg5/4EnJvnKU8AJtJFbQUuXNzN2nRPfVrqwQqp2Ad7UJJO9plKLZG tQnJ1LsSFpLv3+R8eWM3mX3QhG0gc3vAn2n855SwiwDp8O0XcEPTKRgJVE08gEaYah3i rncSUcE6OU9kW4S9yPS8YIYXvtVBEaIei64nPdKtfGbwyWB/JaQxX6JuL0eft9xo4suQ CaB4kOPy+/oLPqcjweB7eYTt5jj1db92RZb95SKdR+TDsy5jSve+Tvypia0rVyZvJiyq hbBA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:cc:to:subject:message-id:date:from :in-reply-to:references:mime-version:dkim-signature; bh=XboG0iK7GqoQRLczFWQdphkEeLioL/kipjtAa1M1LsY=; b=0OUW/JnFBD36Fv18czYA45MBxC6Hv5JQ0FLygjEK7XhVF7B9o6dx8YK2BlGPN6c8ON Yl81gDIiONCZCBFTPnq61qVSWhzuY4YzrztP18XNPUG0FWBjVKuezmwPRgVrzteJ1UnY mDe8izc8hmKlI2M/fOZWHRHhx/2SPmjPO/hY2gFbdydZxY7hTfhgcPj7XLDJAEFwc2p0 ZEtT/wR4sffWzckXISv1LBbyP+g42qV3rHUTsfc3rYCoQwIah2VIYmnQf6RvW01wmXDs 7T6H1ouESRWYqp84Xbmi+toR0d1ylz6iFjSPF0bkZYwGuge62UsrqPS1IVUQqU4aDYtj s/rQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@chromium.org header.s=google header.b=S9eLP5gd; 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=pass (p=NONE sp=NONE dis=NONE) header.from=chromium.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id u16si3835390otq.92.2020.02.09.19.40.09; Sun, 09 Feb 2020 19:40:21 -0800 (PST) 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; dkim=pass header.i=@chromium.org header.s=google header.b=S9eLP5gd; 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=pass (p=NONE sp=NONE dis=NONE) header.from=chromium.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727041AbgBJDkD (ORCPT + 99 others); Sun, 9 Feb 2020 22:40:03 -0500 Received: from mail-qt1-f193.google.com ([209.85.160.193]:43820 "EHLO mail-qt1-f193.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726958AbgBJDkD (ORCPT ); Sun, 9 Feb 2020 22:40:03 -0500 Received: by mail-qt1-f193.google.com with SMTP id d18so4129806qtj.10 for ; Sun, 09 Feb 2020 19:40:02 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=chromium.org; s=google; h=mime-version:references:in-reply-to:from:date:message-id:subject:to :cc; bh=XboG0iK7GqoQRLczFWQdphkEeLioL/kipjtAa1M1LsY=; b=S9eLP5gdMgbocUEmd0v0eluLux599RiHqlUQcnPcwg1s2dnQO9l3gpaEh4BGZeyV+z aqL0BOAIJKRMWqW2x4j0jIrP5nmkKgsLxBVMVEI7rpxTyplkU9L/5xFYJ08uOX+ySMYn wxPdSIfqvzNvMmhJnx/14ZbDVlXmOqsrx3X40= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc; bh=XboG0iK7GqoQRLczFWQdphkEeLioL/kipjtAa1M1LsY=; b=f5RHI6NzYBc1ynoKb8qLmMUhhwVHCvuy6tVx1x8v0uuluOmJC31AHFtlJ9b/nscZw0 DSOplxo/9d9gCEmntaJnq3QDaHwUaOSLTAwfIybABYL+mTqtHo5Onohk5qFCTkw4r6R4 Gna6aAhe0RXYNoEI9vsnDGfLNH5tyahEG9ietKVmixFFpDEim6vF5fwkHaq+Pjniujtq T16yIH4ctX+LppUl5IWDJ+92DzobjUFmsUz8/SwraNAc/tsq+hGzE0rWEJPHmnLV4Ei0 ZFNxBWdtQZyyaJ2BttwdsoEUG3iGMrOT131tXka6rTeRbWfWeO3ewe6f+ZdxT5IbnMMi AgaA== X-Gm-Message-State: APjAAAU8y7U8i8M2iaqlgr9yzds7475M7MVuBJVhBhyfrbX0Wcb6F3DF etnxp/wWEGqklmAIBpBUDEDwwwA1qT2jBe+ZfOWbMg== X-Received: by 2002:ac8:3946:: with SMTP id t6mr8396284qtb.278.1581306001942; Sun, 09 Feb 2020 19:40:01 -0800 (PST) MIME-Version: 1.0 References: <20200207052627.130118-1-drinkcat@chromium.org> <5237381b-c232-7087-a3d6-78d6358d80bf@collabora.com> <93aec9ae-00fc-bf55-1d6c-9bd715b78344@collabora.com> In-Reply-To: <93aec9ae-00fc-bf55-1d6c-9bd715b78344@collabora.com> From: Nicolas Boichat Date: Mon, 10 Feb 2020 11:39:50 +0800 Message-ID: Subject: Re: [PATCH v4 0/7] Add dts for mt8183 GPU (and misc panfrost patches) To: Tomeu Vizoso Cc: Rob Herring , David Airlie , Daniel Vetter , Mark Rutland , Matthias Brugger , Steven Price , Alyssa Rosenzweig , Liam Girdwood , Mark Brown , dri-devel , Devicetree List , lkml , linux-arm Mailing List , "moderated list:ARM/Mediatek SoC support" , Hsin-Yi Wang , Ulf Hansson Content-Type: text/plain; charset="UTF-8" Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Fri, Feb 7, 2020 at 4:13 PM Tomeu Vizoso wrote: > > On 2/7/20 8:42 AM, Nicolas Boichat wrote: > > On Fri, Feb 7, 2020 at 2:18 PM Tomeu Vizoso wrote: > >> > >>> Some more changes are still required to get devfreq working, and of course > >>> I do not have a userspace driver to test this with. > >> > >> Have you tried the Panfrost tests in IGT? They are atm quite basic, but > >> could be interesting to check that the different HW units are correctly > >> powered on. > > > > I haven't, you mean this right? > > https://gitlab.freedesktop.org/tomeu/igt-gpu-tools/tree/panfrost > > Yes, though may be better to use the upstream repo: > > https://gitlab.freedesktop.org/drm/igt-gpu-tools > > > Any specific test you have in mind? > > All the panfrost ones, but looks like panfrost_prime:gem-prime-import is > failing atm: > > https://lava.collabora.co.uk/scheduler/job/2214987 (I first removed opp table from device tree to avoid constant spew about devfreq not supporting 2 regulators, I should get around to fix that...) # /usr/libexec/igt-gpu-tools/panfrost_gem_new IGT-Version: 1.24-gd4d574a4 (arm) (Linux: 4.19.99 aarch64) Starting subtest: gem-new-4096 Subtest gem-new-4096: SUCCESS (0.000s) Starting subtest: gem-new-0 Subtest gem-new-0: SUCCESS (0.000s) Starting subtest: gem-new-zeroed Subtest gem-new-zeroed: SUCCESS (0.001s) # /usr/libexec/igt-gpu-tools/panfrost_get_param IGT-Version: 1.24-gd4d574a4 (arm) (Linux: 4.19.99 aarch64) Starting subtest: base-params Subtest base-params: SUCCESS (0.000s) Starting subtest: get-bad-param Subtest get-bad-param: SUCCESS (0.000s) Starting subtest: get-bad-padding Subtest get-bad-padding: SUCCESS (0.000s) # /usr/libexec/igt-gpu-tools/panfrost_prime IGT-Version: 1.24-gd4d574a4 (arm) (Linux: 4.19.99 aarch64) Starting subtest: gem-prime-import (panfrost_prime:1527) ioctl_wrappers-CRITICAL: Test assertion failure function prime_fd_to_handle, file ../igt-gpu-tools-9999/lib/ioctl_wrappers.c:1336: (panfrost_prime:1527) ioctl_wrappers-CRITICAL: Failed assertion: igt_ioctl((fd), ((((2U|1U) << (((0+8)+8)+14)) | ((('d')) << (0+8)) | (((0x2e)) << 0) | ((((sizeof(struct drm_prime_handle)))) << ((0+8)+8)))), (&args)) == 0 (panfrost_prime:1527) ioctl_wrappers-CRITICAL: Last errno: 95, Operation not supported (panfrost_prime:1527) ioctl_wrappers-CRITICAL: error: -1 != 0 Stack trace: Subtest gem-prime-import failed. Subtest gem-prime-import: FAIL (0.004s) (but that looks expected?) Now the trickier ones, I guess we're either missing something, or my dirty 4.19 backport is very broken: # /usr/libexec/igt-gpu-tools/panfrost_submit IGT-Version: 1.24-gd4d574a4 (arm) (Linux: 4.19.99 aarch64) Starting subtest: pan-submit (panfrost_submit:1643) CRITICAL: Test assertion failure function __real_main86, file ../igt-gpu-tools-9999/tests/panfrost_submit.c:103: (panfrost_submit:1643) CRITICAL: Failed assertion: syncobj_wait(fd, &submit->args->out_sync, 1, abs_timeout(SHORT_TIME_NSEC), 0, NULL) Stack trace: Subtest pan-submit failed. **** DEBUG **** (panfrost_submit:1643) CRITICAL: Test assertion failure function __real_main86, file ../igt-gpu-tools-9999/tests/panfrost_submit.c:103: (panfrost_submit:1643) CRITICAL: Failed assertion: syncobj_wait(fd, &submit->args->out_sync, 1, abs_timeout(SHORT_TIME_NSEC), 0, NULL) (panfrost_submit:1643) igt_core-INFO: Stack trace: **** END **** Subtest pan-submit: FAIL (0.119s) Starting subtest: pan-submit-error-no-jc Subtest pan-submit-error-no-jc: SUCCESS (0.000s) Starting subtest: pan-submit-error-bad-in-syncs Subtest pan-submit-error-bad-in-syncs: SUCCESS (0.012s) Starting subtest: pan-submit-error-bad-bo-handles Subtest pan-submit-error-bad-bo-handles: SUCCESS (0.012s) Starting subtest: pan-submit-error-bad-requirements Subtest pan-submit-error-bad-requirements: SUCCESS (0.012s) Starting subtest: pan-submit-error-bad-out-sync Subtest pan-submit-error-bad-out-sync: SUCCESS (0.012s) Starting subtest: pan-reset (panfrost_submit:1643) CRITICAL: Test assertion failure function __real_main86, file ../igt-gpu-tools-9999/tests/panfrost_submit.c:173: (panfrost_submit:1643) CRITICAL: Failed assertion: syncobj_wait(fd, &submit->args->out_sync, 1, abs_timeout(BAD_JOB_TIME_NSEC), 0, NULL) Stack trace: Subtest pan-reset failed. **** DEBUG **** (panfrost_submit:1643) CRITICAL: Test assertion failure function __real_main86, file ../igt-gpu-tools-9999/tests/panfrost_submit.c:173: (panfrost_submit:1643) CRITICAL: Failed assertion: syncobj_wait(fd, &submit->args->out_sync, 1, abs_timeout(BAD_JOB_TIME_NSEC), 0, NULL) (panfrost_submit:1643) igt_core-INFO: Stack trace: **** END **** Subtest pan-reset: FAIL (0.840s) The pan-submit case causes an MMU fault: (full log: https://gist.github.com/drinkcat/1ae36cb1b1b71f30cc4fc29759612d76) [ 1215.234937] [IGT] panfrost_submit: executing [ 1215.318446] [IGT] panfrost_submit: starting subtest pan-submit ... [ 1215.338644] panfrost 13040000.gpu: Unhandled Page fault in AS0 at VA 0x000000FF00000000 Reason: TODO raw fault status: 0xA002C0 decoded fault status: SLAVE FAULT exception type 0xC0: UNKNOWN access type 0x2: READ source id 0xA0 [ 1215.444504] [IGT] panfrost_submit: exiting, ret=98 ... [ 1215.446902] panfrost 13040000.gpu: js fault, js=0, status=JOB_BUS_FAULT, head=0x300b000, tail=0x300b000 [ 1215.446935] panfrost 13040000.gpu: Unhandled Page fault in AS0 at VA 0x000000FF00000000 Reason: TODO raw fault status: 0xA002C0 decoded fault status: SLAVE FAULT exception type 0xC0: UNKNOWN access type 0x2: READ source id 0xA0 pan-reset failure looks similar: https://gist.github.com/drinkcat/2d336d57e6b95262d83e7a28a409bc5b Thanks, > Cheers, > > Tomeu > > > Thanks, > > > >> Regards, > >> > >> Tomeu > >> > >>> I believe at least patches 1, 2, and 3 can be merged. 4 and 5 are mostly > >>> useful in conjunction with 6 and 7 (which are not ready yet), so I'll let > >>> maintainers decide. > >>> > >>> Thanks! > >>> > >>> Nicolas Boichat (7): > >>> dt-bindings: gpu: mali-bifrost: Add Mediatek MT8183 > >>> arm64: dts: mt8183: Add node for the Mali GPU > >>> drm/panfrost: Improve error reporting in panfrost_gpu_power_on > >>> drm/panfrost: Add support for multiple regulators > >>> drm/panfrost: Add support for multiple power domains > >>> RFC: drm/panfrost: Add mt8183-mali compatible string > >>> RFC: drm/panfrost: devfreq: Add support for 2 regulators > >>> > >>> .../bindings/gpu/arm,mali-bifrost.yaml | 25 ++++ > >>> arch/arm64/boot/dts/mediatek/mt8183-evb.dts | 7 + > >>> arch/arm64/boot/dts/mediatek/mt8183.dtsi | 105 +++++++++++++++ > >>> drivers/gpu/drm/panfrost/panfrost_devfreq.c | 17 +++ > >>> drivers/gpu/drm/panfrost/panfrost_device.c | 123 +++++++++++++++--- > >>> drivers/gpu/drm/panfrost/panfrost_device.h | 27 +++- > >>> drivers/gpu/drm/panfrost/panfrost_drv.c | 41 ++++-- > >>> drivers/gpu/drm/panfrost/panfrost_gpu.c | 11 +- > >>> 8 files changed, 326 insertions(+), 30 deletions(-) > >>>