From patchwork Mon Nov 10 19:24:40 2014 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: "Suthikulpanit, Suravee" X-Patchwork-Id: 40532 Return-Path: X-Original-To: linaro@patches.linaro.org Delivered-To: linaro@patches.linaro.org Received: from mail-la0-f72.google.com (mail-la0-f72.google.com [209.85.215.72]) by ip-10-151-82-157.ec2.internal (Postfix) with ESMTPS id 7ED63218DE for ; Mon, 10 Nov 2014 19:25:44 +0000 (UTC) Received: by mail-la0-f72.google.com with SMTP id mc6sf5597019lab.3 for ; Mon, 10 Nov 2014 11:25:43 -0800 (PST) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20130820; h=x-gm-message-state:delivered-to:from:to:cc:subject:date:message-id :in-reply-to:references:mime-version:sender:precedence:list-id :x-original-sender:x-original-authentication-results:mailing-list :list-post:list-help:list-archive:list-unsubscribe:content-type; bh=8xidtaDSbn7rvnNnPWdkjxwjXOYmMQEjFHwepMVt32M=; b=Hb3p/yxa5riUcLELNlK7Rmsnm9RbGQoxhw42bIsWR66oG+3wgQEFAvRN67S9Vqu2ux bFFrEqxEmheO2JL11TJL7s7FLw0pvkK7MGaLRHUkIodOSfjWh8Vz8q1CJHehV5CwR2HT XtdQowKWKvqJyNPa1skDt9TYnqfc9Kst8UmiRHvqLfC0w++KgE/gDKwpKwDIlsZ+xo33 qCRaOQVw62XCqatemY0HfKslxyU27QYYuof0g+62yEZ5/me1qpnBSvigp+Grmpv4bfx4 nxkM/dZtwk2M4Mp7mDlSlFTWk3svbUm6BpVSgY4yjbKVe7w8XmfNLyuoCITfYzsjW27S GfMw== X-Gm-Message-State: ALoCoQmNkoq0lbHykVMNQaKfexXOT230lsCMM4ciCsJ/YWFc7hMxK+073FptQRYaN7zMQfaAZc7v X-Received: by 10.181.27.135 with SMTP id jg7mr4389988wid.5.1415647542922; Mon, 10 Nov 2014 11:25:42 -0800 (PST) X-BeenThere: patchwork-forward@linaro.org Received: by 10.152.27.97 with SMTP id s1ls515866lag.81.gmail; Mon, 10 Nov 2014 11:25:42 -0800 (PST) X-Received: by 10.152.1.74 with SMTP id 10mr31963072lak.61.1415647542302; Mon, 10 Nov 2014 11:25:42 -0800 (PST) Received: from mail-lb0-f182.google.com (mail-lb0-f182.google.com. [209.85.217.182]) by mx.google.com with ESMTPS id 6si28387021lav.119.2014.11.10.11.25.42 for (version=TLSv1 cipher=ECDHE-RSA-RC4-SHA bits=128/128); Mon, 10 Nov 2014 11:25:42 -0800 (PST) Received-SPF: pass (google.com: domain of patch+caf_=patchwork-forward=linaro.org@linaro.org designates 209.85.217.182 as permitted sender) client-ip=209.85.217.182; Received: by mail-lb0-f182.google.com with SMTP id f15so7140212lbj.27 for ; Mon, 10 Nov 2014 11:25:42 -0800 (PST) X-Received: by 10.112.52.37 with SMTP id q5mr31373411lbo.32.1415647542036; Mon, 10 Nov 2014 11:25:42 -0800 (PST) X-Forwarded-To: patchwork-forward@linaro.org X-Forwarded-For: patch@linaro.org patchwork-forward@linaro.org Delivered-To: patch@linaro.org Received: by 10.112.184.201 with SMTP id ew9csp149041lbc; Mon, 10 Nov 2014 11:25:41 -0800 (PST) X-Received: by 10.68.204.232 with SMTP id lb8mr16822649pbc.25.1415647540382; Mon, 10 Nov 2014 11:25:40 -0800 (PST) Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id q8si17593176pds.51.2014.11.10.11.25.39 for ; Mon, 10 Nov 2014 11:25:40 -0800 (PST) Received-SPF: none (google.com: linux-kernel-owner@vger.kernel.org does not designate permitted sender hosts) client-ip=209.132.180.67; Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752332AbaKJTZg (ORCPT + 25 others); Mon, 10 Nov 2014 14:25:36 -0500 Received: from mail-bn1bon0145.outbound.protection.outlook.com ([157.56.111.145]:43136 "EHLO na01-bn1-obe.outbound.protection.outlook.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1752214AbaKJTZF (ORCPT ); Mon, 10 Nov 2014 14:25:05 -0500 Received: from BN1PR02CA0047.namprd02.prod.outlook.com (10.141.56.47) by BY2PR02MB201.namprd02.prod.outlook.com (10.242.232.12) with Microsoft SMTP Server (TLS) id 15.1.11.14; Mon, 10 Nov 2014 19:25:02 +0000 Received: from BN1AFFO11FD016.protection.gbl (2a01:111:f400:7c10::198) by BN1PR02CA0047.outlook.office365.com (2a01:111:e400:2a::47) with Microsoft SMTP Server (TLS) id 15.1.16.15 via Frontend Transport; Mon, 10 Nov 2014 19:25:02 +0000 Received: from atltwp02.amd.com (165.204.84.222) by BN1AFFO11FD016.mail.protection.outlook.com (10.58.52.76) with Microsoft SMTP Server id 15.1.6.13 via Frontend Transport; Mon, 10 Nov 2014 19:25:01 +0000 X-WSS-ID: 0NEU8LL-08-XQ9-02 X-M-MSG: Received: from satlvexedge02.amd.com (satlvexedge02.amd.com [10.177.96.29]) (using TLSv1 with cipher AES128-SHA (128/128 bits)) (No client certificate requested) by atltwp02.amd.com (Axway MailGate 5.3.1) with ESMTPS id 2B764D1601D; Mon, 10 Nov 2014 13:24:56 -0600 (CST) Received: from SATLEXDAG06.amd.com (10.181.40.13) by SATLVEXEDGE02.amd.com (10.177.96.29) with Microsoft SMTP Server (TLS) id 14.3.195.1; Mon, 10 Nov 2014 13:25:12 -0600 Received: from ssuthiku-fedora-lt.amd.com (10.180.168.240) by satlexdag06.amd.com (10.181.40.13) with Microsoft SMTP Server id 14.3.195.1; Mon, 10 Nov 2014 14:24:58 -0500 From: To: CC: , , , , , , Suravee Suthikulpanit Subject: [PATCH 2/2] PCI: generic: Add set_msi_parent callback Date: Mon, 10 Nov 2014 13:24:40 -0600 Message-ID: <1415647480-3320-3-git-send-email-suravee.suthikulpanit@amd.com> X-Mailer: git-send-email 1.9.3 In-Reply-To: <1415647480-3320-1-git-send-email-suravee.suthikulpanit@amd.com> References: <1415647480-3320-1-git-send-email-suravee.suthikulpanit@amd.com> MIME-Version: 1.0 X-EOPAttributedMessage: 0 X-Forefront-Antispam-Report: CIP:165.204.84.222; CTRY:US; IPV:NLI; EFV:NLI; SFV:NSPM; SFS:(10019020)(6009001)(428002)(189002)(199003)(229853001)(50466002)(77096003)(62966003)(77156002)(76176999)(50986999)(120916001)(102836001)(48376002)(107046002)(2351001)(44976005)(50226001)(95666004)(19580405001)(4396001)(19580395003)(20776003)(64706001)(99396003)(92566001)(92726001)(47776003)(89996001)(110136001)(86152002)(36756003)(93916002)(33646002)(53416004)(87286001)(87936001)(88136002)(106466001)(68736004)(105586002)(21056001)(97736003)(84676001)(101416001)(104166001)(46102003)(86362001)(31966008)(41533002); DIR:OUT; SFP:1102; SCL:1; SRVR:BY2PR02MB201; H:atltwp02.amd.com; FPR:; MLV:sfv; PTR:InfoDomainNonexistent; MX:1; A:1; LANG:en; X-Microsoft-Antispam: UriScan:; X-Microsoft-Antispam: BCL:0;PCL:0;RULEID:;SRVR:BY2PR02MB201; X-Exchange-Antispam-Report-Test: UriScan:; X-Exchange-Antispam-Report-CFA: BCL:0;PCL:0;RULEID:;SRVR:BY2PR02MB201; X-Forefront-PRVS: 039178EF4A Received-SPF: None (protection.outlook.com: amd.com does not designate permitted sender hosts) X-Exchange-Antispam-Report-CFA: BCL:0;PCL:0;RULEID:;SRVR:BY2PR02MB201; X-OriginatorOrg: amd4.onmicrosoft.com Sender: linux-kernel-owner@vger.kernel.org Precedence: list List-ID: X-Mailing-List: linux-kernel@vger.kernel.org X-Removed-Original-Auth: Dkim didn't pass. X-Original-Sender: suravee.suthikulpanit@amd.com X-Original-Authentication-Results: mx.google.com; spf=pass (google.com: domain of patch+caf_=patchwork-forward=linaro.org@linaro.org designates 209.85.217.182 as permitted sender) smtp.mail=patch+caf_=patchwork-forward=linaro.org@linaro.org Mailing-list: list patchwork-forward@linaro.org; contact patchwork-forward+owners@linaro.org X-Google-Group-Id: 836684582541 List-Post: , List-Help: , List-Archive: List-Unsubscribe: , From: Suravee Suthikulpanit This patch implement set_msi_parent callback for PCI generic host controller. Cc: Bjorn Helgass Cc: Liviu Dudau Cc: Lorenzo Pieralisi Signed-off-by: Suravee Suthikulpanit --- drivers/pci/host/pci-host-generic.c | 14 ++++++++++++++ 1 file changed, 14 insertions(+) diff --git a/drivers/pci/host/pci-host-generic.c b/drivers/pci/host/pci-host-generic.c index 036ab1b..f9bb97a 100644 --- a/drivers/pci/host/pci-host-generic.c +++ b/drivers/pci/host/pci-host-generic.c @@ -42,6 +42,7 @@ struct gen_pci { struct pci_host_bridge host; struct gen_pci_cfg_windows cfg; struct list_head resources; + struct msi_chip *mchip; }; #ifdef CONFIG_ARM @@ -128,9 +129,19 @@ static int gen_pci_config_write(struct pci_bus *bus, unsigned int devfn, return PCIBIOS_SUCCESSFUL; } +static int gen_pci_set_msi_parent(struct pci_bus *bus) +{ + struct gen_pci *pci = bus_to_gen_pci(bus); + + bus->msi = pci->mchip; + + return PCIBIOS_SUCCESSFUL; +} + static struct pci_ops gen_pci_ops = { .read = gen_pci_config_read, .write = gen_pci_config_write, + .set_msi_parent = gen_pci_set_msi_parent, }; static const struct of_device_id gen_pci_of_match[] = { @@ -313,6 +324,9 @@ static int gen_pci_probe(struct platform_device *pdev) return err; } + pci->mchip = of_pci_find_msi_chip_by_node(of_parse_phandle(np, + "msi-parent", 0)); + #ifdef CONFIG_ARM pci_common_init_dev(dev, &hw); #else