Received: by 2002:a25:ab43:0:0:0:0:0 with SMTP id u61csp636278ybi; Fri, 31 May 2019 06:48:58 -0700 (PDT) X-Google-Smtp-Source: APXvYqy6CpZTotY7d8Wb3CHt6nOQ3Y6Y89wkWgR2DvEXdky0uscVVlo/2+Sevd+nLb2/oLysV1hg X-Received: by 2002:aa7:82d7:: with SMTP id f23mr10020487pfn.138.1559310538096; Fri, 31 May 2019 06:48:58 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1559310538; cv=none; d=google.com; s=arc-20160816; b=1ATa3g+f5bgmiStgSFxlwPes0WMTB8PeGJohp2ij+f+hqDcr/gyafu4PZ8XZfH3KOa zEenJ93NVTQtut6YEBOtrNN9FR9tsPx8ZgjOnzxyXDdRsWi8Sl4o+CsB/LBLIdmuOYT2 VmhU9vL7RNjsjrloWH+vdbNSXPr118noWcIwx/l/TFQwVeh2gYW2c/U83ABpFIJrkgYq jjrqaoB2zPF1A75G9vxOaevm2kI1LTXXu/500G2MRrgCVneJW71QtsfgbDJujImV8xYS NwFJdx2kBy+tnrwZPFFLe/AHvlcjcLT69tvHdsU/MZMpSn5AWo5+OYOgFOmY+Xp9BsVx yBSw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject; bh=ckHmBA6wJpVuJmk9H8Mwkofgwdcx/4IMj2qV+tb/qEQ=; b=HakWBZhJbsPuvnJbZXg0fV4H5FIj8hLoY9BGRmYjKCUJ+iX5NDlWTIi3QQw3vhXP+d KpwOX2P30ALS1q6pqakCmKFLtsgpcW+EofR2Tf4EZCMuQds23HWqpOeyolzQ187qJw9j 2TBPY9iJwb3QmGX6Hwktbnkh4gY2jIzIb0L+epD1FIYcxPWt5tKNozzWSSuMLC5vggE3 pkqJ95E20AUvYrA24XzA64LNt6TqFHHrhf+CNFRIX9U4mbEgda8yO8pxcbpQ/p4ODjsE yxk6YrZOtT1DN19cVY1LwsY90sXf59pzjX1zw1RK/mn8Wi1xILnmM9QAwQjnejTsACml DwqA== 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id s18si3231155pfh.210.2019.05.31.06.48.41; Fri, 31 May 2019 06:48:58 -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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726682AbfEaNr3 (ORCPT + 99 others); Fri, 31 May 2019 09:47:29 -0400 Received: from foss.arm.com ([217.140.101.70]:51842 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726418AbfEaNr3 (ORCPT ); Fri, 31 May 2019 09:47:29 -0400 Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.72.51.249]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id 73245A78; Fri, 31 May 2019 06:47:28 -0700 (PDT) Received: from [10.1.196.75] (e110467-lin.cambridge.arm.com [10.1.196.75]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id 111CC3F5AF; Fri, 31 May 2019 06:47:25 -0700 (PDT) Subject: Re: [PATCH v6 0/6] Allwinner H6 Mali GPU support To: Tomeu Vizoso Cc: =?UTF-8?B?Q2zDqW1lbnQgUMOpcm9u?= , Mark Rutland , "open list:OPEN FIRMWARE AND FLATTENED DEVICE TREE BINDINGS" , Neil Armstrong , David Airlie , Will Deacon , open list , dri-devel , Steven Price , Maxime Ripard , Chen-Yu Tsai , Rob Herring , Linux IOMMU , "moderated list:ARM/FREESCALE IMX / MXC ARM ARCHITECTURE" References: <20190521161102.29620-1-peron.clem@gmail.com> <4ff02295-6c34-791b-49f4-6558a92ad7a3@arm.com> From: Robin Murphy Message-ID: Date: Fri, 31 May 2019 14:47:24 +0100 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:60.0) Gecko/20100101 Thunderbird/60.6.1 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-GB Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 31/05/2019 13:04, Tomeu Vizoso wrote: > On Wed, 29 May 2019 at 19:38, Robin Murphy wrote: >> >> On 29/05/2019 16:09, Tomeu Vizoso wrote: >>> On Tue, 21 May 2019 at 18:11, Clément Péron wrote: >>>> >>> [snip] >>>> [ 345.204813] panfrost 1800000.gpu: mmu irq status=1 >>>> [ 345.209617] panfrost 1800000.gpu: Unhandled Page fault in AS0 at VA >>>> 0x0000000002400400 >>> >>> From what I can see here, 0x0000000002400400 points to the first byte >>> of the first submitted job descriptor. >>> >>> So mapping buffers for the GPU doesn't seem to be working at all on >>> 64-bit T-760. >>> >>> Steven, Robin, do you have any idea of why this could be? >> >> I tried rolling back to the old panfrost/nondrm shim, and it works fine >> with kbase, and I also found that T-820 falls over in the exact same >> manner, so the fact that it seemed to be common to the smaller 33-bit >> designs rather than anything to do with the other >> job_descriptor_size/v4/v5 complication turned out to be telling. > > Is this complication something you can explain? I don't know what v4 > and v5 are meant here. I was alluding to BASE_HW_FEATURE_V4, which I believe refers to the Midgard architecture version - the older versions implemented by T6xx and T720 seem to be collectively treated as "v4", while T760 and T8xx would effectively be "v5". >> [ as an aside, are 64-bit jobs actually known not to work on v4 GPUs, or >> is it just that nobody's yet observed a 64-bit blob driving one? ] > > I'm looking right now at getting Panfrost working on T720 with 64-bit > descriptors, with the ultimate goal of making Panfrost > 64-bit-descriptor only so we can have a single build of Mesa in > distros. Cool, I'll keep an eye out, and hope that it might be enough for T620 on Juno, too :) >> Long story short, it appears that 'Mali LPAE' is also lacking the start >> level notion of VMSA, and expects a full 4-level table even for <40 bits >> when level 0 effectively redundant. Thus walking the 3-level table that >> io-pgtable comes back with ends up going wildly wrong. The hack below >> seems to do the job for me; if Clément can confirm (on T-720 you'll >> still need the userspace hack to force 32-bit jobs as well) then I think >> I'll cook up a proper refactoring of the allocator to put things right. > > Mmaps seem to work with this patch, thanks. > > The main complication I'm facing right now seems to be that the SFBD > descriptor on T720 seems to be different from the one we already had > (tested on T6xx?). OK - with the 32-bit hack pointed to up-thread, a quick kmscube test gave me the impression that T720 works fine, but on closer inspection some parts of glmark2 do seem to go a bit wonky (although I suspect at least some of it is just down to the FPGA setup being both very slow and lacking in memory bandwidth), and the "nv12-1img" mode of kmscube turns out to render in some delightfully wrong colours. I'll try to get a 'proper' version of the io-pgtable patch posted soon. Thanks, Robin. > > Cheers, > > Tomeu > >> Robin. >> >> >> ----->8----- >> diff --git a/drivers/iommu/io-pgtable-arm.c b/drivers/iommu/io-pgtable-arm.c >> index 546968d8a349..f29da6e8dc08 100644 >> --- a/drivers/iommu/io-pgtable-arm.c >> +++ b/drivers/iommu/io-pgtable-arm.c >> @@ -1023,12 +1023,14 @@ arm_mali_lpae_alloc_pgtable(struct >> io_pgtable_cfg *cfg, void *cookie) >> iop = arm_64_lpae_alloc_pgtable_s1(cfg, cookie); >> if (iop) { >> u64 mair, ttbr; >> + struct arm_lpae_io_pgtable *data = io_pgtable_ops_to_data(&iop->ops); >> >> + data->levels = 4; >> /* Copy values as union fields overlap */ >> mair = cfg->arm_lpae_s1_cfg.mair[0]; >> ttbr = cfg->arm_lpae_s1_cfg.ttbr[0]; >> >> _______________________________________________ >> dri-devel mailing list >> dri-devel@lists.freedesktop.org >> https://lists.freedesktop.org/mailman/listinfo/dri-devel