Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S933142AbbLCJ4K (ORCPT ); Thu, 3 Dec 2015 04:56:10 -0500 Received: from mail-bn1on0095.outbound.protection.outlook.com ([157.56.110.95]:34399 "EHLO na01-bn1-obe.outbound.protection.outlook.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S932655AbbLCJzE (ORCPT ); Thu, 3 Dec 2015 04:55:04 -0500 Authentication-Results: spf=softfail (sender IP is 66.35.236.227) smtp.mailfrom=altera.com; vger.kernel.org; dkim=none (message not signed) header.d=none;vger.kernel.org; dmarc=none action=none header.from=altera.com; From: Ley Foon Tan To: Bjorn Helgaas CC: , , Ley Foon Tan , Subject: [PATCH 1/3] PCI: altera: fix incorrect devfn for requester ID Date: Thu, 3 Dec 2015 17:54:47 +0800 Message-ID: <1449136489-2559-2-git-send-email-lftan@altera.com> X-Mailer: git-send-email 1.8.3.2 In-Reply-To: <1449136489-2559-1-git-send-email-lftan@altera.com> References: <1449136489-2559-1-git-send-email-lftan@altera.com> MIME-Version: 1.0 Content-Type: text/plain X-EOPAttributedMessage: 0 X-Microsoft-Exchange-Diagnostics: 1;BY2FFO11FD050;1:4yvSTJHDcic0iM0X4vj78FoUzJxqJdHE4YcEaAdqZ+PiwAapg/WXvOj6CbWNoTzTsEk2+WoBHC9ct3AHYMeAbtaUjoJmauj1UWfFDbzR4VXk2inzMfd2VR/GBawUvOy5efsYj9CHap/z6SjrySW7NRvW6pr2nmXdEw60GUIKmm/M32NM0MFbogI/BEmHbMyUQlslsV4UrtZ+SfyD2qeWLP28iy66H7tWX7FvJJUVgP5FrqxZcVFOMzGELuxgC3DgWzrqV/ftXdJf+3xSGggiBQg2NptEF9xz1jz0qIX3mdy8M8nS0mQjQaJvdW98weXHeoP/KwybxU0w4tdy8nOC9mcxHDTXrrA2xCVaO8L3MnyXlALlrMN3x6KfJV3GCfMLq27bYOds+NPDwrf0L4obQA== X-Forefront-Antispam-Report: CIP:66.35.236.227;CTRY:US;IPV:NLI;EFV:NLI;SFV:NSPM;SFS:(10009020)(6009001)(2980300002)(189002)(199003)(110136002)(5003940100001)(19580395003)(81156007)(586003)(19580405001)(97736004)(189998001)(92566002)(87936001)(33646002)(229853001)(5001960100002)(47776003)(50986999)(76176999)(50466002)(48376002)(2950100001)(86362001)(42186005)(105596002)(50226001)(106466001)(1096002)(36756003)(6806005)(5008740100001)(1220700001)(7099028);DIR:OUT;SFP:1101;SCL:1;SRVR:BY2PR0301MB2072;H:sj-itexedge03.altera.priv.altera.com;FPR:;SPF:SoftFail;PTR:InfoDomainNonexistent;MX:1;A:1;LANG:en; X-Microsoft-Exchange-Diagnostics: 1;BY2PR0301MB2072;2:Df72p3Xm5yzi2I6PuWdh2x2EWjuojZbsl29DKcxh8csw/3XD6xkeLlL7f5C9OK9szIPyaN/835s3Ujbglv8N3dtUfnPXCyWGutTxjJiP3lrvpzyDTXUcBMR2NBvxR6rtbbe76nyYYZQqSzAjRfjeZQ==;3:YeNDZJT+4bC+sPozmuWxVAC24Ax232WzQmOfTgluYDF5h/gpvkQ0ul8GLBX3bXtlU1eOJVW8TsAXeHgC14+ZztEW7Ks7/KdppigmchL1q6RNNlI/kvc7WnKZevrafjcnocqDgtWYQnGMeuTbEmT6wWdptOZNrLZjT0svDHRRX2xoEmrq4397/AQ9v1ZQ8+WbjKOqPviXYmYaG+Mfz4bmiMFd0zRUDpFZ4w2mJti1vXQ=;25:pPDx8rGph5a7oOYU9xwmagX15NVM5a+2Gsyf8PgI3oUDkB00RW3vG4dNugWIFMaf5yvWLDn0Gr8VPQf26/4EqEaCbRGqqwJXQDy14s4/FHafp3nCsKRm61ionAkA2t+SlYXpm5kC2bxoq7d1YP80eIS1mCRsVnL//xlLw2TA6rodsiGKmIZMaDg4iFAdh8Opt0VWlaXn5uEU/BHLnMS7Xunlw+/uWYJPGa0dgjxYBx0t4xbVvFWor9r1rLAZywpOD3VeVnMg7Eb1t5xxY0FcTw==;20:h/cFnEOdAvTVdTLIXqPUr0rz6vdimWcuNz9Rs+9UBNxFbJSwydNhd8pFYYR9AOCPTSybGuXd4c2VCljXXQnZJfrHjcZGyH2Y8ya2SoY9nfMuSjWPrhila/qa2d65LvGpPXBXoukE4sC3zlfAJSDxiTt4DcnEV5UqJquy+0c+Zz8= X-Microsoft-Antispam: UriScan:;BCL:0;PCL:0;RULEID:;SRVR:BY2PR0301MB2072; X-Microsoft-Antispam-PRVS: X-Exchange-Antispam-Report-Test: UriScan:(80048183373757); X-Exchange-Antispam-Report-CFA-Test: BCL:0;PCL:0;RULEID:(601004)(2401047)(5005006)(8121501046)(520078)(3002001)(10201501046);SRVR:BY2PR0301MB2072;BCL:0;PCL:0;RULEID:;SRVR:BY2PR0301MB2072; X-Microsoft-Exchange-Diagnostics: 1;BY2PR0301MB2072;4:jATMPnLXtic7+rDNQ5J5JCxkeDHmILDZI6VGHDk344mnnkB0Jxsh0/ylYqfvtdu4QhhcdfFwORy7co8SqJd4+p09XDUZUtv2XK6B0udWa5Fd/7BIcqE1D0J1R80j3xKDpOBMRzt3ERFEunjgXF79Kjjn+7/XOmFb9ZEMzp8ODx0RBFzrS7n7LidF02lXVcnRu58wrg5BC4S7cSaQEhIJGN2LWT1cdROoCvZPIw/0bvYqj+REctyQQKONOTbLVRuA1Evif8g/gtvb1BRoYWy6UK4eOeiDh2xCfqKmX7Z6wIs0CNg/GIdkkmsv5PiidCz1Om/F1k6FMxVKJ4Uu5ji39SXS2yTt3Yu3Dw1NfB0moHme20L9Gj4TLJDvMbI9YQ4hWlXruj9iObAFwzTlL4/XDbxarmAyWDQG8oPUqdtMAzHz9ji0hnV6kzovG/Awug4p X-Forefront-PRVS: 077929D941 X-Microsoft-Exchange-Diagnostics: 1;BY2PR0301MB2072;23:yxrQ0mYELQReyHDXLqNDDHBBUK3WKayjXkj/9gBMlrfpP1UwpzT69SAJTWDkgzs4QTYNZpOnUrD2RDmBVVdQedvJW7VW/O2xBQ080u4IEFt0nrV2h8YVgQbD7aUueUSncQa4vRnGNqwaHvpXr/xxUuQ7Lxroz8/Axb85Opx1VQLQJHFr6zbMsL/hObWfn9A392hfI1f3LzR86bMXrI/qqWwtlnrRzEg8kErib4AKYUn9KUBDFnrwZoG1xn5csLcBePZSWXnXMjbkUhwE6XSnFrpI76UGk5bZekR1wmxVps12q0gvJcKrDxmBkEBrs0yoPZADeHGTW5zOwA4H24lu9QxjJQVN2QH/DmpkktQW3vuxniyCcXEei60CsKhxQAygeWJle3dei8u+Zhfgz/+6M3XCx+kF0cuNW0zFJeaKpjml5pt+FjmDqauos+jwVonubiTxTO4uiOdldkYhwSy+8RCd298HQ7kGN7rYQroHCgjqlgI4z8gqWePTjxOP5JSi1zizMfE/4T3PLSndF/jtvGk/JzgiCtmx7MJZrrP6hLCRVmKvJ9ODrRLWxegLt//QELVkJu3BQMSoJ3CSmlcS2x+h6FLccNvKOer8qYtgmzIqb8dAbs5dAyWc4HanVa/PQ8M7p7kUhTzzcSXG1VFwC76c8SC3R8waxirKLvLfYI4Aqfi9rZPx7s0BAjhfzknvQxWDdwXJwWG/oByFhm7xR7mX9iMnCZrtxPs7pcVEaBGlK6gUpCl8+cRb+QwFf+ocER9sijxQVcwe8DXTP6Z5V9d/JefepiJnuRM8ddxVxH959/y6wp7TrTffz+jlNgXcqCgBSGQsig9DfZZF19RLNnfHrDQZENER7OMgbGmqnwGSPzzE9cQb8s1nkhPObgGfwXua/hGr5m6jb/TM6EDp+4C2eQqUYWznroLPQXsCeb0= X-Microsoft-Exchange-Diagnostics: 1;BY2PR0301MB2072;5:1qdmLIpqMWobMH9mW1zHGw7oqxM0KN3ZblCIP0iKfhokD0LsbgZW0NQhrOGtkp20KdAfEXpTP+3GcwmMY4tMFGX+Um+AtDzV9Q6KZ6e6t9yw3RkPxu+zmtSNG1enfia86K4d296I08dzkMMsjRERkA==;24:VG0su0frKZoX7iyD3e0LQihfZH4TbaDTnQBZU4kPnS2QbjeIePGMuWXA0V175ME4WaVq1NjySRdhelbS5Hnm4EN+AyeWn53HZDa3OZi+8zQ=;20:mqnnioDIooos2urhS7lMcKnGIhe4hrfwwiL+WuxOopRA4BstzLMgsV5FQ8NnKWjgx/T/8BOXpxhGwjlcwg6ldZGPczYF13zI7UndbqrfsRqHGgX6wUqgLp5QM4dswH8A1HyTh5TO892Z33FfEoktqF/8rPo2QpQ1uoenfqq2Dek= SpamDiagnosticOutput: 1:23 SpamDiagnosticMetadata: NSPM X-OriginatorOrg: altera.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 03 Dec 2015 09:55:00.4358 (UTC) X-MS-Exchange-CrossTenant-Id: fbd72e03-d4a5-4110-adce-614d51f2077a X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=fbd72e03-d4a5-4110-adce-614d51f2077a;Ip=[66.35.236.227];Helo=[sj-itexedge03.altera.priv.altera.com] X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: BY2PR0301MB2072 Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1777 Lines: 50 Requester ID should use the rootport devfn and it should be always 0. But, devfn argument in these 2 functions can be rootport or endpoint. It causes the issue when accessing configuration register from multi-functions PCIe devices. Tested on Ethernet adapter card with multi-functions. Signed-off-by: Ley Foon Tan --- drivers/pci/host/pcie-altera.c | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/drivers/pci/host/pcie-altera.c b/drivers/pci/host/pcie-altera.c index e5dda38..f05180f 100644 --- a/drivers/pci/host/pcie-altera.c +++ b/drivers/pci/host/pcie-altera.c @@ -57,6 +57,7 @@ #define TLP_REQ_ID(bus, devfn) (((bus) << 8) | (devfn)) #define TLP_HDR_SIZE 3 #define TLP_LOOP 500 +#define RP_DEVFN 0 #define INTX_NUM 4 @@ -233,7 +234,7 @@ static int tlp_cfg_dword_read(struct altera_pcie *pcie, u8 bus, u32 devfn, else headers[0] = TLP_CFG_DW0(TLP_FMTTYPE_CFGRD1); - headers[1] = TLP_CFG_DW1(TLP_REQ_ID(pcie->root_bus_nr, devfn), + headers[1] = TLP_CFG_DW1(TLP_REQ_ID(pcie->root_bus_nr, RP_DEVFN), TLP_READ_TAG, byte_en); headers[2] = TLP_CFG_DW2(bus, devfn, where); @@ -253,7 +254,7 @@ static int tlp_cfg_dword_write(struct altera_pcie *pcie, u8 bus, u32 devfn, else headers[0] = TLP_CFG_DW0(TLP_FMTTYPE_CFGWR1); - headers[1] = TLP_CFG_DW1(TLP_REQ_ID(pcie->root_bus_nr, devfn), + headers[1] = TLP_CFG_DW1(TLP_REQ_ID(pcie->root_bus_nr, RP_DEVFN), TLP_WRITE_TAG, byte_en); headers[2] = TLP_CFG_DW2(bus, devfn, where); -- 1.8.2.1 -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/