Received: by 2002:ac0:946b:0:0:0:0:0 with SMTP id j40csp503721imj; Thu, 7 Feb 2019 07:34:39 -0800 (PST) X-Google-Smtp-Source: AHgI3Ib+q/o5U2sHs1iYqWRTS3M72tuuj1AwDPCt558HrOtXuj72HNNyDpOCIYzeN6bCslGyTeK6 X-Received: by 2002:a17:902:8c8b:: with SMTP id t11mr14678760plo.163.1549553679069; Thu, 07 Feb 2019 07:34:39 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1549553679; cv=none; d=google.com; s=arc-20160816; b=ADzwT5kxUwRCWUetegGlIXQ0DUvQ3r5apenOGwLTdRWYSvCgRtUzt0n03qjXcRnRWs g4IWuTp7mcugfta2jTXGNt78QMox1POBCAEpospfLzJTj54/fmFGrSyPMu9gWLPe6ds7 IpHP+oTR9a22fAze3f9fs90yyM3xC1/VSrW/90jHVxdsKI9p3GB+6GSuUEclszRJq2Kp clA1bEET+Vqpb9bBoJb3PKv34bekqW1P687/IiuiolYJL22fwEjie728fs7HiLArsi1o gvGxa6iT061FW8pTBwOt+7aEahhiZS70C1R2T1ET4KOZAuiAP+T8KL5R1MA9S3f8PUXh nJlA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:to:message-id:date:subject:cc:from :dkim-signature; bh=gnaetUAFn+5YXDNTxlF6/4akDTHRvmy2o7ahSflKzbc=; b=p0la82oKKWowP6bgjSGSTy1EJOm7CSRe3lWNEmLwotwNVtRvyCVb5G08ap3fAWlStv ysDvhGVMbm7tMHuA4q3+KwwJEV4IOdfOLKH35xHFpb0SwrLNTP8aT4sKL7mVoNtUKTSQ oE1wMiTHq9T2SohIAu7bFquQ8g0RqnfxuoVugr4V2A5oEnKHf8z5AYN8Nt3QCUzu1NFN 09fXaskuD7nPIEsqWn5ek1dTU1m9LVH0YZhyJTFwa/j1Box/OK8JUBQbHj4+Sn5SKzCl e0Z38XbDsZ1gFmkmUft2Ppsg0kALVMmL9pl7Na9ChS03zJLJgoNFWnxXs2pZGvV+umJb P3GQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@gmail.com header.s=20161025 header.b=YUWhvCa+; 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; dmarc=fail (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id 38si9013243pln.313.2019.02.07.07.34.23; Thu, 07 Feb 2019 07:34:39 -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; dkim=fail header.i=@gmail.com header.s=20161025 header.b=YUWhvCa+; 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; dmarc=fail (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726796AbfBGPeH (ORCPT + 99 others); Thu, 7 Feb 2019 10:34:07 -0500 Received: from mail-pl1-f196.google.com ([209.85.214.196]:38920 "EHLO mail-pl1-f196.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726048AbfBGPeH (ORCPT ); Thu, 7 Feb 2019 10:34:07 -0500 Received: by mail-pl1-f196.google.com with SMTP id 101so88332pld.6 for ; Thu, 07 Feb 2019 07:34:06 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id; bh=gnaetUAFn+5YXDNTxlF6/4akDTHRvmy2o7ahSflKzbc=; b=YUWhvCa+IWWIHj7ZG+JdsNmBjc1dorQgVphuozqicDGxg1HZ7MyK02kF7Qty9d/Bny oGMz7Rt+SeYzncC8bn1p5y4od2fS6n0GOwnHkNB7tE6C/PBhHcpwwqcv/3v5IanEfi9Q 1N78CDg3Pe3KpU+E+VMQF7NcUnoSCuEUwqrIS1OwT6/EdpyvTqC7aEcDRwd0blSTAy8O /CuljMqw6aGrSHZEfNdUu6Vu0Wal0PJkjP2wHaHuA8e3cjTo/Qm2B0HWomMgMe4pPzIV CnJgJiOSdYejy8/yKQxBfb4FKH511YC2f1/PsG5vU4+osgVvUXIRf3AxMwhqa/hmHs8C ibQw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id; bh=gnaetUAFn+5YXDNTxlF6/4akDTHRvmy2o7ahSflKzbc=; b=Rw7fiu9b1EnP6ru7QZ+LiKYUPAPiAPBe0jQ6NnaOQMicJvviWFVwcX74EBV8ap7PFh I5uOSlZZ9k2g/ldtLtmH14t6gDa+q4qp0iej3/BBYNS1o9LGLhqZkNY78oUD82Vb4GdF zhfq1R02m/8iP3pyOJhEF6cuZAxdvqDZflH+fhOjULhAWD8atTBsjFGz/8poOTgps8Dv eJ9/FtXyXsREp5TfmhioMznMOgsYGSdIBYu00/Yb16T+6NTZN+h8yqlH23Ra4ciqSMon m+OrYX9UXLF1V/rsXU0MafaC9xvlP6PatXu/Llgc/80hR8Fz6nCGlA5gWop0rniN2RvC eWeg== X-Gm-Message-State: AHQUAuaetZy1SC4QVvIftxZ0ZeJWB1AaIUyDJvROl3HYJk2LfYTdebIa gxbmhsK9j3OGASIUaVTYL9c= X-Received: by 2002:a17:902:be03:: with SMTP id r3mr16647718pls.68.1549553646532; Thu, 07 Feb 2019 07:34:06 -0800 (PST) Received: from tianyukernel.corp.microsoft.com ([167.220.255.93]) by smtp.googlemail.com with ESMTPSA id j6sm16493945pfg.126.2019.02.07.07.34.00 (version=TLS1_2 cipher=ECDHE-RSA-AES128-SHA bits=128/128); Thu, 07 Feb 2019 07:34:05 -0800 (PST) From: lantianyu1986@gmail.com X-Google-Original-From: Tianyu.Lan@microsoft.com Cc: Lan Tianyu , arnd@arndb.de, bp@alien8.de, davem@davemloft.net, devel@linuxdriverproject.org, gregkh@linuxfoundation.org, haiyangz@microsoft.com, hpa@zytor.com, iommu@lists.linux-foundation.org, joro@8bytes.org, kys@microsoft.com, linux-kernel@vger.kernel.org, mchehab+samsung@kernel.org, mingo@redhat.com, nicolas.ferre@microchip.com, sashal@kernel.org, sthemmin@microsoft.com, tglx@linutronix.de, x86@kernel.org, michael.h.kelley@microsoft.com, vkuznets@redhat.com, alex.williamson@redhat.com, dan.carpenter@oracle.com Subject: [PATCH V3 0/3] x86/Hyper-V/IOMMU: Add Hyper-V IOMMU driver to support x2apic mode Date: Thu, 7 Feb 2019 23:33:46 +0800 Message-Id: <1549553629-8414-1-git-send-email-Tianyu.Lan@microsoft.com> X-Mailer: git-send-email 2.7.4 To: unlisted-recipients:; (no To-header on input) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Lan Tianyu On the bare metal, enabling X2APIC mode requires interrupt remapping function which helps to deliver irq to cpu with 32-bit APIC ID. Hyper-V doesn't provide interrupt remapping function so far and Hyper-V MSI protocol already supports to deliver interrupt to the CPU whose virtual processor index is more than 255. IO-APIC interrupt still has 8-bit APIC ID limitation. This patchset is to add Hyper-V stub IOMMU driver in order to enable X2APIC mode successfully in Hyper-V Linux guest. The driver returns X2APIC interrupt remapping capability when X2APIC mode is available. X2APIC destination mode is set to physical by PATCH 1 when X2APIC is available. Hyper-V IOMMU driver will scan cpu 0~255 and set cpu into IO-APIC MAX cpu affinity cpumask if its APIC ID is 8-bit. Driver creates a Hyper-V irq domain to limit IO-APIC interrupts' affinity and make sure cpus assigned with IO-APIC interrupt are in the scope of IO-APIC MAX cpu affinity. Lan Tianyu (3): x86/Hyper-V: Set x2apic destination mode to physical when x2apic is available HYPERV/IOMMU: Add Hyper-V stub IOMMU driver MAINTAINERS: Add Hyper-V IOMMU driver into Hyper-V CORE AND DRIVERS scope MAINTAINERS | 1 + arch/x86/kernel/cpu/mshyperv.c | 10 +++ drivers/iommu/Kconfig | 8 ++ drivers/iommu/Makefile | 1 + drivers/iommu/hyperv-iommu.c | 194 +++++++++++++++++++++++++++++++++++++++++ drivers/iommu/irq_remapping.c | 3 + drivers/iommu/irq_remapping.h | 1 + 7 files changed, 218 insertions(+) create mode 100644 drivers/iommu/hyperv-iommu.c -- 2.7.4