Received: by 2002:a25:ef43:0:0:0:0:0 with SMTP id w3csp755038ybm; Fri, 29 May 2020 11:19:29 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyDSNBZS1/5JBU41TrKcWjRWIxlm/ZzNNl7Sm5fN33SFZsDej9rBIcUnMexbLGeSE02Xyj1 X-Received: by 2002:a17:906:6043:: with SMTP id p3mr8788958ejj.29.1590776369572; Fri, 29 May 2020 11:19:29 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1590776369; cv=none; d=google.com; s=arc-20160816; b=Zx9y5fwNtD2ko0nOnn6tff+sM20KjvLk97WmHna636U81Vjn48D4TiNmvc1xarIUFp sGzQ0lCErpmKBO8dVRZt9SbjHDbzmhosLArKzSSOhFKazX7qIXr/yPLHUdnCWv/1Gk4d LiCf2Z8jx79wxtlZDgXXF4zXQXZRarUd043AaxI58toZeYOGnprTusjWFDfgQlkF15iD Ct0vev8lawuNfOQCLXT7thKdZXBy6Y8l2Zee0yoRVDEQoHuW5hTI/GZZf6U7T3M3rjmu qGno7xzKfpycFh8aGtDuHdxhQ6P6gwS+Mp9VkJIKS+klRrqGpggULqeO+OELEtprCN1b H7Sw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date; bh=TuUZEjl7HxIBRP0BY44fSdo4hn++82s5rxoR3yvm0S0=; b=iCm1s8Nz0NdwOxsw4lZQ8I9gdZhzFFWzwo2WjnwgcZg9M8BvueHYiEgDN4YEXD9B8b 2vOuHaykqcRPIjuG3WrGF7tfbrqrQn4H3oPYUZR/ZAI+GxKT6H+WSVvoE248yOrEUKIi x72csAyBBPS2to/7y9GJHuwzpQcnso/4+h1l1ohZ1u0zvcu7ihrTYI9mt4FstdckUU9c UoYIC14KsQRd6AOy856QAGCNBFX5fYGFf1UHG0tZTJQPD4KM5pp3P++gkox+nYUWNpY4 Gq9qmMJArc81T27gKwdpl42s3jLefDFvnr/FASZoSv54FDEJpI51XcM/2sWtvZ9PgI79 yzSQ== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id ci9si3661773ejb.218.2020.05.29.11.19.04; Fri, 29 May 2020 11:19:29 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727030AbgE2SQm (ORCPT + 99 others); Fri, 29 May 2020 14:16:42 -0400 Received: from bmailout2.hostsharing.net ([83.223.78.240]:36393 "EHLO bmailout2.hostsharing.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725839AbgE2SQl (ORCPT ); Fri, 29 May 2020 14:16:41 -0400 Received: from h08.hostsharing.net (h08.hostsharing.net [IPv6:2a01:37:1000::53df:5f1c:0]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (Client CN "*.hostsharing.net", Issuer "COMODO RSA Domain Validation Secure Server CA" (not verified)) by bmailout2.hostsharing.net (Postfix) with ESMTPS id 51AF828004ECF; Fri, 29 May 2020 20:16:40 +0200 (CEST) Received: by h08.hostsharing.net (Postfix, from userid 100393) id 281E12A66; Fri, 29 May 2020 20:16:40 +0200 (CEST) Date: Fri, 29 May 2020 20:16:40 +0200 From: Lukas Wunner To: Florian Fainelli Cc: Nicolas Saenz Julienne , Mark Brown , Ray Jui , Scott Branden , bcm-kernel-feedback-list@broadcom.com, Martin Sperl , linux-spi@vger.kernel.org, linux-rpi-kernel@lists.infradead.org, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH] spi: bcm2835: Enable shared interrupt support Message-ID: <20200529181640.47dt6bfy3wkxbb34@wunner.de> References: <20200528185805.28991-1-nsaenzjulienne@suse.de> <20200529174358.som3snunfxch6phi@wunner.de> <36dd65bb-18a9-9697-b9b6-76eaf8cbe45c@gmail.com> <20200529175350.2wtoqttipa354m2m@wunner.de> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: User-Agent: NeoMutt/20170113 (1.7.2) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Fri, May 29, 2020 at 11:03:48AM -0700, Florian Fainelli wrote: > On 5/29/20 10:53 AM, Lukas Wunner wrote: > > On Fri, May 29, 2020 at 10:46:01AM -0700, Florian Fainelli wrote: > >> On 5/29/20 10:43 AM, Lukas Wunner wrote: > >>> Finally, it would be nice if the check would be optimized away when > >>> compiling for pre-RasPi4 products, maybe something like: > >>> > >>> + if (IS_ENABLED(CONFIG_ARM_LPAE) && !(cs & BCM2835_SPI_CS_INTR)) > >>> + return IRQ_NONE; > >> > >> Rather than keying this off ARM_LPAE or any other option, this should be > >> keyed off a compatible string, that way we can even conditionally pass > >> IRQF_SHARED to the interrupt handler if we care so much about performance. > > > > But a compatible string can't be checked at compile time, can it? > > No, but you can have a different interrupt handler that it set at > runtime if you want to completely eliminate this comparison. Good idea. In fact the IRQ handler for platforms with shared interrupts could just be a wrapper which performs the BCM2835_SPI_CS_INTR check then tail-calls the existing IRQ handler. The compiler would just inline it and everything would be fine. > My point is that CONFIG_ARM_LPAE is just too brittle, there is nothing > that prevents you from using a non-LPAE kernel on the Pi 4, even PCIe > could be made to work if using super section mappings to map the PCIe > outbound space. Even on models with over 4GB of DRAM, if you are willing > to lose some of it, it can work. Agreed. Thanks, Lukas