Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp5277463imu; Wed, 19 Dec 2018 08:25:33 -0800 (PST) X-Google-Smtp-Source: AFSGD/XQD6lQ+cP3cg+ni2GL/Aal7jXDeat1lfeeUTIs/WpzE0j4i03E4NufSYoJHCLouCfXTd8H X-Received: by 2002:a65:6684:: with SMTP id b4mr20049809pgw.55.1545236733640; Wed, 19 Dec 2018 08:25:33 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1545236733; cv=none; d=google.com; s=arc-20160816; b=hQYcSB2aEx4qVy4WIII+v3nisoEGTX81Q6VoNW7SVBK0upBOcHC0R15oHgXttvrb18 r8amN8pQ2szQI+0N4L7gR5qGA8xjJbQNVSZ9CfqUrB9tHNgrClckwN42tQXJ0BEGorph M8VrppZ13K06ja1eE0XrBKG06CQefIb0Td1h3OCIdId1uHyYTaDrsTXs38mua7/WjNkQ 65Oyck8DeiK1vMZtd4yyuRHe4tb7f6K9H2hd5zoxiRsKPv7FFJ0cZhboBkAOJ9dVSYcJ u0Im3pNml+E7gBUIkQLl6y3hoFYx49VrIyIGMDtbcAACoK+Q1yt3A3SURNQYDFTcjoKS ag1w== 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:mime-version :references:in-reply-to:date:cc:to:from:subject:message-id; bh=1o3ciaFZdLvC4BKrTLkqJg57EH7pE5vI7qwC9XnQ/wQ=; b=ihJO68/qy367qP+K3+ktHwm2xfhGMEFy5vsfVLTe25Pizi9e68hSWWz3w7skSWsXUS 7QdyWVjhTBMe8pZl8st2LJk0WFEq2Zs5wXOIr+cvmJKBy41YCga0hTjLlr1NnZKzAS6S ZR/9Tn5Y/qG3q67kr/lYDAuQM9nxmS2/hzpWwrKWCwqLiHfqt4RX4zps6Cqwj3gPGwS1 ucx1AcU2hLz53Wwvs+Qxcp86T1fFHn6HYiJDiRlCg0pqMT4HqmfODjEipq7Ww5cpFPk1 udNrSUx29a/eDfPizVzE3eTcJWjyTmUXJouiENpTYnDao4RuZK7+llxr0ztVQdROF1yo rh1A== 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 h191si7327223pgc.302.2018.12.19.08.25.17; Wed, 19 Dec 2018 08:25:33 -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; 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 S1728926AbeLSPwR (ORCPT + 99 others); Wed, 19 Dec 2018 10:52:17 -0500 Received: from metis.ext.pengutronix.de ([85.220.165.71]:45439 "EHLO metis.ext.pengutronix.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727479AbeLSPwR (ORCPT ); Wed, 19 Dec 2018 10:52:17 -0500 Received: from kresse.hi.pengutronix.de ([2001:67c:670:100:1d::2a]) by metis.ext.pengutronix.de with esmtp (Exim 4.89) (envelope-from ) id 1gZe8q-0006dU-M4; Wed, 19 Dec 2018 16:52:12 +0100 Message-ID: <1545234725.5874.38.camel@pengutronix.de> Subject: Re: [v4] PCI: imx: make msi work without CONFIG_PCIEPORTBUS=y From: Lucas Stach To: Bjorn Helgaas , Richard Zhu Cc: Lorenzo Pieralisi , Andrew Smirnov , linux-pci@vger.kernel.org, linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org, Sven Van Asbroeck , Niklas Cassel , Kishon Vijay Abraham I , Gustavo Pimentel , Shawn Lin , Trent Piepho Date: Wed, 19 Dec 2018 16:52:05 +0100 In-Reply-To: <20181219141241.GB12763@google.com> References: <1544768762-18124-1-git-send-email-hongxing.zhu@nxp.com> <20181219141241.GB12763@google.com> Content-Type: text/plain; charset="UTF-8" X-Mailer: Evolution 3.22.6-1+deb9u1 Mime-Version: 1.0 Content-Transfer-Encoding: 8bit X-SA-Exim-Connect-IP: 2001:67c:670:100:1d::2a X-SA-Exim-Mail-From: l.stach@pengutronix.de X-SA-Exim-Scanned: No (on metis.ext.pengutronix.de); SAEximRunCond expanded to false X-PTX-Original-Recipient: linux-kernel@vger.kernel.org Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Am Mittwoch, den 19.12.2018, 08:12 -0600 schrieb Bjorn Helgaas: > [+cc Sven, Trent, et al from related report: > https://lore.kernel.org/linux-pci/20181218210444.5950-1-TheSven73@googlemail.com] > > On Fri, Dec 14, 2018 at 06:44:15AM +0000, Richard Zhu wrote: > > Assertion of the MSI Enable bit of RC's MSI CAP is mandatory required to > > trigger MSI on i.MX6 PCIe. > > This bit would be asserted when CONFIG_PCIEPORTBUS=y. > > Thus, the MSI works fine on i.MX6 PCIe before the commit "f3fdfc4". > > > > Assert it unconditionally when MSI is enabled. > > Otherwise, the MSI wouldn't be triggered although the EP is present and > > the MSIs are assigned. > > OK, I think I finally understand most of what's going on.  Please > check the following possible changelog text: > >   The MSI Enable bit in the MSI Capability (PCIe r4.0, sec 7.7.1.2) >   controls whether a Function can request service using MSI. > >   i.MX6 Root Ports implement the MSI Capability and may use MSI to >   request service for events like PME, hotplug, AER, etc.  In >   addition, on i.MX6, the MSI Enable bit controls delivery of MSI >   interrupts from components below the Root Port. > >   Prior to f3fdfc4ac3a2 ("PCI: Remove host driver Kconfig selection of >   CONFIG_PCIEPORTBUS"), enabling CONFIG_PCI_IMX6 automatically also >   enabled CONFIG_PCIEPORTBUS, and when portdrv claimed the Root Ports, >   it set the MSI Enable bit so it could use PME, hotplug, AER, etc. >   As a side effect, that also enabled delivery of MSI interrupts from >   downstream components. > >   After f3fdfc4ac3a2, the imx6q-pcie driver can operate without >   portdrv, but that means imx6q-pcie must set the MSI Enable bit >   itself if downstream components use MSI. > >   Fixes: f3fdfc4ac3a2 ("PCI: Remove host driver Kconfig selection of CONFIG_PCIEPORTBUS") > > I still don't understand exactly *how* MSI Enable affects MSI from > downstream components, since the downstream component just does a DMA > write, and the Root Port can't tell whether the write is to memory or > interrupt controller unless the Root Port knows where the MSI targets > are, e.g., if the interrupt controller is actually part of the RC. The controller terminating the MSI write is part of the DWC PCIe host controller on i.MX6, which is questionable at least when you think about how a MSI should be self-synchronizing to memory writes, but that's reality... As to why the controller needs the MSI Enable bit set, I have no idea. But then the DWC controller is known to have some funky design limitations regarding MSI, like not forwarding legacy PCI interrupts anymore when MSI is enabled, so it's not totally surprising that we need some quirky setup here. Regards, Lucas