From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from ZR1P278CU001.outbound.protection.outlook.com (mail-switzerlandnorthazon11022124.outbound.protection.outlook.com [40.107.168.124]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 1495C280014 for ; Wed, 4 Mar 2026 13:27:18 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=fail smtp.client-ip=40.107.168.124 ARC-Seal:i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1772630840; cv=fail; b=q9YtY0AXdAk3oiwhMHIAzbwTX2ropsNNVLdlnJO/g3Et7nwUF8+7vmfMNJTbgL+5koZQUUkbE0Kiy6cOEjditlmbPVVc6pF/i1zoqQTjQyQbBagbqpF6MQ0a/aPSv7pT9ZZ5C8wMjXkuGIEnitA8HFiP2OkIHkpeV4t92pVVIwU= ARC-Message-Signature:i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1772630840; c=relaxed/simple; bh=aDC6YhhZfbFqm7RUdnzuG+vWIUT6F8mJeMT2cKQgjro=; h=From:To:Cc:Subject:Date:Message-Id:Content-Type:MIME-Version; b=C1w9BJZ2H40r5zkuRJerI3/muVMN/yo56eMNmsGOerjot01QsnrklKZnux/rjU6E5p5ruJdINkQordZQ9JeNpRf1bNVtwdikXiYcNH9ZhI3MlAqQr6vj0Og0DFCpype6gVKzO5GcIdh8HJzGxhq0ETVZVLJAaBxkFY+iRrKcm2U= ARC-Authentication-Results:i=2; smtp.subspace.kernel.org; dmarc=pass (p=reject dis=none) header.from=duagon.com; spf=pass smtp.mailfrom=duagon.com; dkim=pass (1024-bit key) header.d=duagon.com header.i=@duagon.com header.b=gk8GGeiw; arc=fail smtp.client-ip=40.107.168.124 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=reject dis=none) header.from=duagon.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=duagon.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (1024-bit key) header.d=duagon.com header.i=@duagon.com header.b="gk8GGeiw" ARC-Seal: i=1; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=none; b=nQB7XkozKeEyKd1go2Vj6qqz7zkb+HHYN5mQShGbyoQucaEyosWcU9QNPMJYf8KmBPHSsZDBRXaMXdQ1AJA1B2hf6DU+pSvVpQlgJj1+ROAweIl3p67hmFJIkc9kHiVjcs4GaiZ3y7R0mKfJW6qB+WfF/zTMmuSMZQzgEvRpKOL5i327FFTaepMHJCodjM8dLOB2r125g+rcnoRU/HvBKEfO+FLFDgpb33DnZq1f0R39wTZbFCBRbOwPSaXcBBd1rNDvs/QR69Q3NhkzdyrfQBFUz5VtneVVoBrI5G3zQun6/tvX2ZtPN+MSK/T1SlR85ZzynmGhWaKAjiEasXsrAA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector10001; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-AntiSpam-MessageData-ChunkCount:X-MS-Exchange-AntiSpam-MessageData-0:X-MS-Exchange-AntiSpam-MessageData-1; bh=R+fPpuPKoPkVhGo8aKUeubgUXNO6zLFnNBgtUpau8F4=; b=nHPBmVHefq7yLdyNvgH1AJ366BhliHhZBpbg/Mx35NH7TRn1B1gEkneXNFaBWPmc7OTKvEspEo0IK65e+6v2WNe6r9ZcLXtZaKljJ35yctCJNYlJrwuvX8U3+EJCqkuLdgbJIpfZERjQqqP1mS8Kt8GE2CP9u+LTPtKMhzUD52S5XcduZ5pHOFYm7QbeTXM3Sht+yAaW+n95i3/iDy4j65bATxrjq5CLHDoaueWDvrqGfqfgXb6nUZKfziQlkKMYbXVsmkbhweWIiXIx6QtmllQ49wQQltBngJ7fXsq8MfAtE8DrPWk1UgFZ/Z/b0fPgEhafPBJVOkYmr0F3eEmvHg== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass (sender ip is 40.93.85.27) smtp.rcpttodomain=gmail.com smtp.mailfrom=duagon.com; dmarc=pass (p=reject sp=reject pct=100) action=none header.from=duagon.com; dkim=none (message not signed); arc=none (0) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=duagon.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=R+fPpuPKoPkVhGo8aKUeubgUXNO6zLFnNBgtUpau8F4=; b=gk8GGeiw0nG/LApPfnaqTKCVwDFJv/0sYbRN76uHGjyFQS2FVrhQ6nQU9N27Ky0pyWLJAqb+7XxnZXMcc3Bmsh/rOeKyWyNqmnrSs4bxaNZjRneblcSJoNDZxcrp+/W7CmHDS2q/EY4JhClroLUBdvt+QrgdTx5P6oUtZXqZpXo= Received: from DU2PR04CA0308.eurprd04.prod.outlook.com (2603:10a6:10:2b5::13) by ZRH2PF618BD29AE.CHEP278.PROD.OUTLOOK.COM (2603:10a6:918::213) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.9678.17; Wed, 4 Mar 2026 13:27:14 +0000 Received: from DB5PEPF00014B8E.eurprd02.prod.outlook.com (2603:10a6:10:2b5:cafe::66) by DU2PR04CA0308.outlook.office365.com (2603:10a6:10:2b5::13) with Microsoft SMTP Server (version=TLS1_3, cipher=TLS_AES_256_GCM_SHA384) id 15.20.9654.22 via Frontend Transport; Wed, 4 Mar 2026 13:27:14 +0000 X-MS-Exchange-Authentication-Results: spf=pass (sender IP is 40.93.85.27) smtp.mailfrom=duagon.com; dkim=none (message not signed) header.d=none;dmarc=pass action=none header.from=duagon.com; Received-SPF: Pass (protection.outlook.com: domain of duagon.com designates 40.93.85.27 as permitted sender) receiver=protection.outlook.com; client-ip=40.93.85.27; helo=ZRZP278CU001.outbound.protection.outlook.com; pr=C Received: from hz-deliver01.de.seppmail.cloud (162.55.72.219) by DB5PEPF00014B8E.mail.protection.outlook.com (10.167.8.202) with Microsoft SMTP Server (version=TLS1_3, cipher=TLS_AES_256_GCM_SHA384) id 15.20.9678.18 via Frontend Transport; Wed, 4 Mar 2026 13:27:14 +0000 Received: from hz-glue05.de.seppmail.cloud (unknown [10.11.0.47]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (4096 bits) server-digest SHA256) (No client certificate requested) by hz-deliver01.de.seppmail.cloud (Postfix) with ESMTPS id 4fQtkT3LP6z4x0S; Wed, 4 Mar 2026 14:27:13 +0100 (CET) Received: from hz-glue05.de.seppmail.cloud (unknown [172.18.0.5]) by hz-glue05.de.seppmail.cloud (Postfix) with ESMTP id 4fQtkT35cpz20Df; Wed, 4 Mar 2026 14:27:13 +0100 (CET) X-SEPP-Suspect: 435570f2992348a9a4180382f3631865 Received: from hz-scan01.de.seppmail.cloud (unknown [10.11.0.3]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (4096 bits)) (No client certificate requested) by hz-glue01.de.seppmail.cloud (Postfix) with ESMTPS id 4fQtkT2f6vz20S3; Wed, 4 Mar 2026 14:27:13 +0100 (CET) Received: from hz-scan01 (localhost [127.0.0.1]) by hz-scan01.de.seppmail.cloud (Postfix) with SMTP id 4fQtkT24gyz4J0M; Wed, 04 Mar 2026 14:27:13 +0100 (CET) Received: from hz-m365gate01.de.seppmail.cloud (unknown [10.11.0.27]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange x25519 server-signature RSA-PSS (4096 bits) server-digest SHA256) (No client certificate requested) by hz-scan01.de.seppmail.cloud (Postfix) with ESMTPS; Wed, 04 Mar 2026 14:27:12 +0100 (CET) Received: from ZRZP278CU001.outbound.protection.outlook.com (mail-switzerlandnorthazlp17011027.outbound.protection.outlook.com [40.93.85.27]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange ECDHE (secp384r1) server-signature RSA-PSS (4096 bits) server-digest SHA256 client-signature RSA-PSS (2048 bits) client-digest SHA256) (Client CN "mail.protection.outlook.com", Issuer "DigiCert Cloud Services CA-1" (not verified)) by hz-m365gate01.de.seppmail.cloud (Postfix) with ESMTPS id 4fQtkS0RYMz2wYF; Wed, 4 Mar 2026 14:27:11 +0100 (CET) Received: from ZR0P278MB1218.CHEP278.PROD.OUTLOOK.COM (2603:10a6:910:80::5) by ZR4P278MB1904.CHEP278.PROD.OUTLOOK.COM (2603:10a6:910:b5::19) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.9678.17; Wed, 4 Mar 2026 13:27:08 +0000 Received: from ZR0P278MB1218.CHEP278.PROD.OUTLOOK.COM ([fe80::311:4b5c:48da:9514]) by ZR0P278MB1218.CHEP278.PROD.OUTLOOK.COM ([fe80::311:4b5c:48da:9514%5]) with mapi id 15.20.9678.016; Wed, 4 Mar 2026 13:27:08 +0000 From: Filip Jensen To: morbidrsa@gmail.com Cc: linux-kernel@vger.kernel.org, Filip Jensen , Jose Javier Rodriguez Barbarin Subject: [PATCH v3 0/2] mcb: enable register PCI devices using any BAR Date: Wed, 4 Mar 2026 14:26:48 +0100 Message-Id: <20260304132650.140680-1-dev-Felipe.Jensen@duagon.com> X-Mailer: git-send-email 2.34.1 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-ClientProxiedBy: MA4P292CA0010.ESPP292.PROD.OUTLOOK.COM (2603:10a6:250:2d::13) To ZR0P278MB1218.CHEP278.PROD.OUTLOOK.COM (2603:10a6:910:80::5) Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-MS-TrafficTypeDiagnostic: ZR0P278MB1218:EE_|ZR4P278MB1904:EE_|DB5PEPF00014B8E:EE_|ZRH2PF618BD29AE:EE_ X-MS-Office365-Filtering-Correlation-Id: 7a6842e0-93da-4830-2ac8-08de79f1bf95 X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam-Untrusted: BCL:0;ARA:13230040|52116014|376014|1800799024|366016|38350700014; X-Microsoft-Antispam-Message-Info-Original: DFGe7z6M6RI9VU8TsZdOeokzw1Ndt8ARK6uNmOhSxgLYXuU5HOz0sZzTOWk3eJjWfSHdWjDqMFgZE/wP1dbsLHsI/2hCAnv0Uo+0SBk39fXGgYyPQHF8PRfAJZBc9ySGuPHc8BQaIecKhzNALYVCpy5iXbOl6BC1+gvS83CAn/ZxRJWbf9c/CXIAuiTO7PD9SnVob4sGhRUYlQJ7NcOtosxL9ZMl39AqQ+1LJ0cFVPaFhJXWNN/c8Cx0avjyWPPvHtGSNSTk5GrtwAs1KfiMm9Qz9/drJAYgMEewUeC/uU1F+82QY3l2QCruQDq7v2A2udFyOD/FyBA5JZNvIyRmpKyM1qwZdfpPXPwyiIsQMdY3uTGOBfX+B72Qosxta3SN2UPORMF5o2fe4WZfCEbXmzB8qmRYCWzQkKHxiWrNmC1sQDPHunGxOrEmoCqRl11d2rKnNGs9WIUhycQ2Nl/GbTF/BXejAC5sW0Kt8n5vlU7h5VNLCIrGHwp2Cz/hLW6HqDbM0Jv/8EgvMXWsKPfHfIIiU+2SjwpXP9Mc/EujYfuwz5zrMBSU/hb3FhAhbN3BB4sEwy6K/MNvpZchop89MY4550HJRdOKsgWSZBLfg1r5mXASkR/TAcEx8MjYTUe761xPzA4Qn6kANsDrfPRt4Oa+RFDEUTCtHBUJrVhSmFuY92qK+lfn/0zlXuKuI6UhNiIJDoOCKXv3z8jmLOm+zlnYqY8Ixsa/KoazGhdxOCn+79xO+BqXL6yF4ggTt9Rzfro1LVx9ARYRMnisjOJmNDzjNOEuzhKflFr3Udmyew0= X-Forefront-Antispam-Report-Untrusted: CIP:255.255.255.255;CTRY:;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:ZR0P278MB1218.CHEP278.PROD.OUTLOOK.COM;PTR:;CAT:NONE;SFS:(13230040)(52116014)(376014)(1800799024)(366016)(38350700014);DIR:OUT;SFP:1102; X-MS-Exchange-Transport-CrossTenantHeadersStamped: ZR4P278MB1904 X-SEPP-CCCVersion: 2025-12-11T08:12:51+01:00 9ed91da2 X-EOPAttributedMessage: 0 X-MS-Exchange-SkipListedInternetSender: ip=[40.93.85.27];domain=ZRZP278CU001.outbound.protection.outlook.com X-MS-Exchange-ExternalOriginalInternetSender: ip=[40.93.85.27];domain=ZRZP278CU001.outbound.protection.outlook.com X-MS-Exchange-Transport-CrossTenantHeadersStripped: DB5PEPF00014B8E.eurprd02.prod.outlook.com X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id-Prvs: 04f65a39-8316-4335-de9f-08de79f1bbdf X-SM-ruleversion: 2.1.0 X-Microsoft-Antispam: BCL:0;ARA:13230040|156008|1800799024|82310400026|376014|14060799003|36860700016|35042699022; X-Microsoft-Antispam-Message-Info: =?utf-8?B?TWI0SkkzZm5YdTRxV0FTZFdnVVlSYlc2VlhGOFVCSFMvL2FzOXgwR1UvSVhX?= =?utf-8?B?Qng3ZmFHbzJYTlY5YTJBbkxMb2Q0c1FpdlMrRExQQllxc3p4M3B0d2FkN2No?= =?utf-8?B?SkhCb3BnUy9sWU43WHJOOURnckVmcUYrVjVvTlZYK2ZaMjlQT0tVOWxjeWZ2?= =?utf-8?B?TWVsaXlTNitoNGdwZWVCaGx6cTlUaVlHbjcvUUdySGhOWjBuaDAvMVduNmtp?= =?utf-8?B?VHM4UXVNdEFHQ2hick1Mank0SDJiYlZSVjQ3UC9tM2huTnVtaWZpWG1tS3hP?= =?utf-8?B?S3FDY1FzT3F4MkthSjVCalNRcTJlN2hXQmhaM1I1aWxGT0krbjJwRitGME51?= =?utf-8?B?dmMxZTdOMWQ5cGloakFEWFZYRnFaYk9lSTVrSDUyc1Y2UVhyNzV4bHBla3RJ?= =?utf-8?B?UDR1ZmxmeFp5MUFFVmdxLzhGc1F0UHA4MnlPT2Z5aW8rMTdPUkkveExOQVJT?= =?utf-8?B?RG1TRDJ5YlFpcUM1eWdvZVNRcWtpSnV5eXpqTlJ1NnpMVVJnNDFzVGNuS0pk?= =?utf-8?B?Ny9RRzl5dFRGS3B1NC9ML0JNeEsybmlIQ2ZxZnMvbnJYUVI0eVBPSFIyek1I?= =?utf-8?B?WEM2WFFvM1hGMUdlbno0dy9vK29haytQd2Z4U2RQOWdJUjFkN2ZRYkUxY3hx?= =?utf-8?B?SzRuQms1RnZoZ0IxZ1dhc3dQSWdGTmY5T3FYbkdvSzZjNTU5djc4ajhlY0Fk?= =?utf-8?B?ME5CWHYzWDZyUm9vZEhaNWgwN1hlTHRoRC9sbVVDMzlBam9meHA4dHJMQTRP?= =?utf-8?B?THlTWXpzN0F3eUVNL1dGZmk4ZVJ2YjVPaTB3YTNtRzUxM2Jwb2J6QmMyaWZW?= =?utf-8?B?czJ6NXBibUpLemUvd1o3WFFSVnNmVnYwRlI2L2pRdGwzb3E5TUJuQjRDbXZ5?= =?utf-8?B?SCtHWExQNjltek9ya0ozbmhJc3V6a3FZNGpyMFMrbG9XOXJKT2c0aEFVQmFu?= =?utf-8?B?QmlDbDJ1UnRsV1VXL0x0M1pGZnhjT2Q1a1NWWVdZaTRGS0hHTnNVRGNTa3E5?= =?utf-8?B?Rk9VdnFoOHNSSG1jaEM1SjVvOUNmYm9XUTNtVTE0b2xoVkVheVRMeXNsZ0d6?= =?utf-8?B?QkNRN2tKMmJNMlpKMG1MamMzUEE1KzhBdHZkMGcrbXMyVWg3am5yb09BVEpi?= =?utf-8?B?VGxpQ3hKZkk4YnJDWmJoeC8zUXBLREFLUXFaWExLNllmSDI1aFRTNkZYTVMr?= =?utf-8?B?TmdMNHRqY3cwNFVWd0IzajRhVzNnOWFkTVg4SGo1eWMwUlNYZzlBcEd2ek01?= =?utf-8?B?T2MwWEhQaVA1L1ZnbzAvMHhKQWgzSjlQdDNvei9MM1lIUGZCclBzRjIrd05o?= =?utf-8?B?b0NyTWlYcFhSZWUrOVBxeUxPZXhZT3p2ZTNtTTFUQ051NE8wYXEwd2VGV2ZN?= =?utf-8?B?ZURHSkg3K1NUNUlwcUdIQkYrZWJYYmFMOHUxVStZSVR6NFdNNmFVUWREWGNx?= =?utf-8?Q?HUrNYQPq?= X-Forefront-Antispam-Report: CIP:162.55.72.219;CTRY:CH;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:ZRZP278CU001.outbound.protection.outlook.com;PTR:mail-switzerlandnorthazlp17011027.outbound.protection.outlook.com;CAT:NONE;SFS:(13230040)(156008)(1800799024)(82310400026)(376014)(14060799003)(36860700016)(35042699022);DIR:OUT;SFP:1102; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: Z0V8hTmWbBlSwXsK3wUIk8ZzBUfM/3Qkg9VekJw7uX/NbxkN0yk78hE0oAiZ96NuRG1iCQGgxG6TMeU0MOdlLhMqcJnjP3B6xQHf91UxZRivbgJWA2/ZMe8kDKZq1BLeMdyha82i4I7RxvKJEdfAt11gnrA0oUFNV6R4kS61WTnnWroSnO1mNyRRQmBjnn/cMEl9wi/A9/GEOh4Me7VKn8d4yRzDYeOu/f/vaVxv18AygbikKOMj38Qrbr2qXXRk1Uq2zVAVLe8naWInE9uEO/aJCYG0roPC06Yn9Cpcs2V44NNUoJIQduY/KuZh0guqk015bT4RDsJYnO4slCQqNMB63kFZ69uXksWjUZW2fqaGBGXITTwf6BgZlcdC9tlxsZbhVwaKFyV0m8rcUdISzIsHBpksZMBP2keDbOPSzsX51sO5T/rmaPoyKUvtCFs4 X-OriginatorOrg: duagon.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 04 Mar 2026 13:27:14.0289 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: 7a6842e0-93da-4830-2ac8-08de79f1bf95 X-MS-Exchange-CrossTenant-Id: e5e7e96e-8a28-45d6-9093-a40dd5b51a57 X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=e5e7e96e-8a28-45d6-9093-a40dd5b51a57;Ip=[162.55.72.219];Helo=[hz-deliver01.de.seppmail.cloud] X-MS-Exchange-CrossTenant-AuthSource: DB5PEPF00014B8E.eurprd02.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Anonymous X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: ZRH2PF618BD29AE V2 -> V3: Thanks for second review. Fixed declaring pci_dev outside of the only block where it is needed in patch 1/2. V1 -> V2: Thanks to the review from Johannes Thumshirn, the patch 2/3 of the first version has been removed and the cleaner solution from patch 3/3 is then kept. The PCI mcb driver is currently only able to register devices that use the first PCI BAR. That is hardcoded in mcb-parse.c in lines 156-161: c = kzalloc_obj(struct chameleon_bar); if (!c) return -ENOMEM; bar_count = 1; c->addr = mapbase; However, mcb devices can use other indexes of the 6 PCI BARs. This serie of patches allows to use these devices by adding the relevant PCI BAR info to the chameleon table. As this code must also work for lpc devices, it has been done a refactoring in order to keep the two buses dependent operations regarding bars (get_bar and is_io_mapped_bar) outside of the common parsing code. These callback operations are stored in a structure and passed over to the parser, thus rendering each module, the mcb-lpc and mcb-pci, only with their own bus relevant logic. This patch depends on the previously accepted patch: Link: https://lore.kernel.org/lkml/20260217075124.10052-1-dev-Felipe.Jensen@duagon.com/ Reviewed-by: Jose Javier Rodriguez Barbarin Filip Jensen (2): mcb: Use more than the first bar in pci devices mcb: refactor bus operations out of common code drivers/mcb/mcb-internal.h | 10 ++++- drivers/mcb/mcb-lpc.c | 56 ++++++++++++++++++++++++++- drivers/mcb/mcb-parse.c | 77 +++++--------------------------------- drivers/mcb/mcb-pci.c | 40 +++++++++++++++++++- 4 files changed, 111 insertions(+), 72 deletions(-) -- 2.34.1