Received: by 2002:a05:6a10:16a7:0:0:0:0 with SMTP id gp39csp4366042pxb; Tue, 10 Nov 2020 14:50:07 -0800 (PST) X-Google-Smtp-Source: ABdhPJwAxv5AWh2Buz5lq7JvzqSUZRwTdFr/0KTOsdZEXyBy6/wcFCdUMBo+fogwFXY8s0d5IPwQ X-Received: by 2002:a05:6402:3056:: with SMTP id bu22mr1759766edb.252.1605048606963; Tue, 10 Nov 2020 14:50:06 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1605048606; cv=none; d=google.com; s=arc-20160816; b=p8kp/Z0zvMtFK8sue09zANf3o+QPH1HuQ9vMevoiZporoGUw3F9tqLAhK1PZj5VFuU M6APwo8jSQqMAhLkFYla05RLmY3e3vuhQEhOTsjv6Hy6Cozf40gN1lzITBxBLjqkoftV LzQUAy+Y3OA1KPmBcMe6kYCClG5wy3kAcLwPmmS9iafYRSaF1GFmoohsPwogvroTR+0+ l453Xqi0wwCoPwpYxFARbGosbJLPnTlnSHhHsNFm8uGzE8cTgKOccXKgIRD1C3tb+qOx IcGTIIYzlGl+ubrYQt3rNLA3oIJwtEgWVa8q/JHT5UwBSVTmlXacPz1DSnqCZvXCG+dc SF/A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:mime-version:message-id:date:references :in-reply-to:subject:cc:to:dkim-signature:dkim-signature:from; bh=qGDOcaUuccXX4HJHlpwgmk95YzzPlwTmVqFSpCljX28=; b=yc3G4hrqfHe8mw0K+wcNWyhOxvN3M0kz0ckR/zIqpztUsnC6DRklYpbu4PqiD/5JUc S2w9kXuvPXI7GAz95vnx7zboISFw2QtgKVa3xrwKUKPaADxMz8Q88KaqB9vYV6TmePgs F636p/HTV8OxMCRUI37sgNy9mfApTTrnnUZKRZkISLQ/TRncv15tKkIAcRfQ/hjuY2qx VHjOPkfPlKOrw+sgJGIR9uajy42Ch8PRMHIHHKqq0fPkwlGMegKLiVF1NQoYnfaWAOdo BXO7EsRsUYL77pjYiCH/CZ+Ml25hpVhEEQqt/vH+Rpw1bnNo2ji0iKyTaSuqDPF0r/o8 Hdzw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linutronix.de header.s=2020 header.b=rB+TkqVC; dkim=neutral (no key) header.i=@linutronix.de header.b="MT/t6jQt"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=linutronix.de Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id uz28si11970ejb.599.2020.11.10.14.49.41; Tue, 10 Nov 2020 14:50:06 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@linutronix.de header.s=2020 header.b=rB+TkqVC; dkim=neutral (no key) header.i=@linutronix.de header.b="MT/t6jQt"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=linutronix.de Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1732175AbgKJWsM (ORCPT + 99 others); Tue, 10 Nov 2020 17:48:12 -0500 Received: from Galois.linutronix.de ([193.142.43.55]:33232 "EHLO galois.linutronix.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726688AbgKJWsM (ORCPT ); Tue, 10 Nov 2020 17:48:12 -0500 From: Thomas Gleixner DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linutronix.de; s=2020; t=1605048489; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: in-reply-to:in-reply-to:references:references; bh=qGDOcaUuccXX4HJHlpwgmk95YzzPlwTmVqFSpCljX28=; b=rB+TkqVCsOvjutZGJnjP66ThUL/jCgKi39wAnpriYKBRbXSkcQVb602p9p7rKMhH3MEe92 gU0gclpZH/ohiaaObuXWg+DM1MtnvlwaUewUVxNhHqVASS8VvV2q8J0MEWNFVrTeTQ3NgF YQd5GgyZYa96EAb4FdJ1myrL6nkXCAynf6zRHSm2moYJMOHj5dHTfp4ll19aXB/gsiKhoZ bEBtHBYqJDad1P4ic7v4jB4CyRuisGZipnFhSp+7605S/BsbMT+3Nb96tAwl3LB9MmXBHk Xd7pkDbilZJYCmIHs+4Gz4RSiWBiQ99IXRM8ty16+WQLH/hql/IePTx0WR/Esw== DKIM-Signature: v=1; a=ed25519-sha256; c=relaxed/relaxed; d=linutronix.de; s=2020e; t=1605048489; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: in-reply-to:in-reply-to:references:references; bh=qGDOcaUuccXX4HJHlpwgmk95YzzPlwTmVqFSpCljX28=; b=MT/t6jQtgQLLcJs6gD6ugCxz9OTgBoQ1o0sqd39RRGNpgoWHdXEmIemSZuc0/xFv/hfQE6 mCGdnfNoCQLWZ9Bg== To: Tom Lendacky , David Woodhouse , Borislav Petkov Cc: linux-kernel@vger.kernel.org, x86 , Qian Cai , Joerg Roedel Subject: Re: [EXTERNAL] [tip: x86/apic] x86/io_apic: Cleanup trigger/polarity helpers In-Reply-To: References: <20201024213535.443185-20-dwmw2@infradead.org> <160397373817.397.3191135882528008704.tip-bot2@tip-bot2> <20201110061046.GA7290@nazgul.tnic> <87d00lgu13.fsf@nanos.tec.linutronix.de> <9a003c2f-f59a-43ab-bbd5-861b14436d29@amd.com> <87a6vpgqbt.fsf@nanos.tec.linutronix.de> <82d54a74-af90-39a4-e483-b3cd73e2ef03@amd.com> <78be575e10034e546cc349d65fac2fcfc6f486b2.camel@infradead.org> <877dqtgkzb.fsf@nanos.tec.linutronix.de> <874klxghwu.fsf@nanos.tec.linutronix.de> <45B3C20C-3BBB-40F3-8A7B-EB20EDD0706F@infradead.org> <87y2j9exk2.fsf@nanos.tec.linutronix.de> <8C2E184C-D069-4C60-96B5-0758FBC6E402@infradead.org> Date: Tue, 10 Nov 2020 23:48:04 +0100 Message-ID: <87tutwg76j.fsf@nanos.tec.linutronix.de> MIME-Version: 1.0 Content-Type: text/plain Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue, Nov 10 2020 at 16:00, Tom Lendacky wrote: > On 11/10/20 3:30 PM, David Woodhouse wrote: > [ 15.581115] WARNING: CPU: 6 PID: 1 at arch/x86/kernel/apic/apic.c:2527 __irq_msi_compose_msg+0x9f/0xb0 > [ 15.581115] Call Trace: > [ 15.581115] irq_msi_update_msg+0x4d/0x80 > [ 15.581115] msi_set_affinity+0x160/0x190 Duh. Yes, that want's some love as well. Delta patch below. Thanks, tglx --- --- a/arch/x86/kernel/apic/msi.c +++ b/arch/x86/kernel/apic/msi.c @@ -24,10 +24,11 @@ struct irq_domain *x86_pci_msi_default_d static void irq_msi_update_msg(struct irq_data *irqd, struct irq_cfg *cfg) { + struct irq_chip *chip = irq_data_get_irq_chip(irqd); struct msi_msg msg[2] = { [1] = { }, }; - __irq_msi_compose_msg(cfg, msg, false); - irq_data_get_irq_chip(irqd)->irq_write_msi_msg(irqd, msg); + __irq_msi_compose_msg(cfg, msg, chip->flags & IRQCHIP_MSI_EXTID); + chip->irq_write_msi_msg(irqd, msg); } static int @@ -271,7 +272,7 @@ static struct irq_chip iommu_msi_control .irq_retrigger = irq_chip_retrigger_hierarchy, .irq_set_affinity = msi_set_affinity, .irq_compose_msi_msg = iommu_msi_compose_msg, - .flags = IRQCHIP_SKIP_SET_WAKE, + .flags = IRQCHIP_SKIP_SET_WAKE | IRQCHIP_MSI_EXTID, }; static struct msi_domain_info iommu_msi_domain_info = { @@ -310,7 +311,7 @@ static struct irq_chip dmar_msi_controll .irq_retrigger = irq_chip_retrigger_hierarchy, .irq_compose_msi_msg = iommu_msi_compose_msg, .irq_write_msi_msg = dmar_msi_write_msg, - .flags = IRQCHIP_SKIP_SET_WAKE, + .flags = IRQCHIP_SKIP_SET_WAKE | IRQCHIP_MSI_EXTID, }; static int dmar_msi_init(struct irq_domain *domain, --- a/include/linux/irq.h +++ b/include/linux/irq.h @@ -567,6 +567,8 @@ struct irq_chip { * IRQCHIP_SUPPORTS_NMI: Chip can deliver NMIs, only for root irqchips * IRQCHIP_ENABLE_WAKEUP_ON_SUSPEND: Invokes __enable_irq()/__disable_irq() for wake irqs * in the suspend path if they are in disabled state + * IRQCHIP_MSI_EXTID The MSI message created for this chip can + * have an otherwise forbidden extended ID */ enum { IRQCHIP_SET_TYPE_MASKED = (1 << 0), @@ -579,6 +581,7 @@ enum { IRQCHIP_SUPPORTS_LEVEL_MSI = (1 << 7), IRQCHIP_SUPPORTS_NMI = (1 << 8), IRQCHIP_ENABLE_WAKEUP_ON_SUSPEND = (1 << 9), + IRQCHIP_MSI_EXTID = (1 << 10), }; #include