From nobody Sat Mar 28 05:56:25 2026 X-Original-To: dev-commits-src-main@mlmmj.nyi.freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2610:1c1:1:606c::19:1]) by mlmmj.nyi.freebsd.org (Postfix) with ESMTP id 4fjRbF6BR8z6Xb4F for ; Sat, 28 Mar 2026 05:56:25 +0000 (UTC) (envelope-from git@FreeBSD.org) Received: from mxrelay.nyi.freebsd.org (mxrelay.nyi.freebsd.org [IPv6:2610:1c1:1:606c::19:3]) (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 client-signature RSA-PSS (4096 bits) client-digest SHA256) (Client CN "mxrelay.nyi.freebsd.org", Issuer "R12" (not verified)) by mx1.freebsd.org (Postfix) with ESMTPS id 4fjRbF43ktz3qdh for ; Sat, 28 Mar 2026 05:56:25 +0000 (UTC) (envelope-from git@FreeBSD.org) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=freebsd.org; s=dkim; t=1774677385; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding; bh=bOWX3DzgcFcbbqy3wJ8ONU2D6ihqoyi1HgC9HVbPvJ0=; b=rJ55WvNKLZaOA0kqgRKjl3QJIeBL+qTr1hVGcYrRevsWThHj7XI04rnQv2ZzmvkWjdBEQg r9rruL4K3VTyIJtoLose0u9HO90lKL5pIb983OHkIi8KFTPcUXEKQTv8IXmI4L1yG12kN0 wN2i54RYCGULMbue5MLEclKFe5fvAS8ucFgCNFbtXNQ1WhKjwCej527Zpz0tfbUuDSZFKn Uc9QIQaYk+JYcIDSCP3132iyA6gUXRMoNognxqivwPw3eVtsENNQyGaxFbWygsnfniqCAC h+CX82o3NNObH7f52JyU/nAKtH2vOusgb5sIuUPGYfCQGm3PGxeT7utOiu7DYw== ARC-Seal: i=1; s=dkim; d=freebsd.org; t=1774677385; a=rsa-sha256; cv=none; b=kFYwjGVMi/3npCS4g0AA3cqMPaNn/aFR4U2N4KJZqHzlCWna9L3Awv2NkGAJ7dDL+LpRjy 8x2P7FDr0ubAg1bTrXqPubFb6BjUufjDBNJIUqJX8UJmjSv1y+gKcm2D0WdxM2JUWb8sXk yxfVPpoR75S0zeV/ta4BsLTH3yiMHShy/YfsjDwt/KsZ1ME3Tyzh8HHR/Cd6PRD86RRHhM dBFZhjbz3Ud3aX5t6rJTKSb1r7/ayg6X/h5WitNyREt3/QLPbOuyss7OwWogwp/PVmS1eE jreQVOV9iDUHl6coWaN+OXmL6yHb2wBFMW1ACDfykLaDnaYxXNwIlgXGiRnJAg== ARC-Authentication-Results: i=1; mx1.freebsd.org; none ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=freebsd.org; s=dkim; t=1774677385; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding; bh=bOWX3DzgcFcbbqy3wJ8ONU2D6ihqoyi1HgC9HVbPvJ0=; b=VgpzQ3RQ7RzdiFzP6+bQj6ar/IYUPcEFF2wV6g5NjMzAiLhvWIelAIWEKrgwqthcVcCU/K dz1opCfy3Oesk8xyBxFc3h1LRb+6Rr6KRw1Vwnn83qKsEyeBvOoHsaecQKln2KSchLwSGY EvMyO2LR53MheGtlABzpFg4a0/8037SdRLC4WgSwdukUiunQWU7jeFdFWfaz5omXuQJwNd WpKScfbn6YQ7ShnsfIwkXY1Ps5w8Kx6jr+LkyaNZxvnm+8PH/5RxyizKiy0wwm2SDHxgdo LzaXVzRE6Nr0aYL3iC7yvYYcN81ZFhPuMnf1rMYQ0ehcb04Ivk3Q2zwhkLhk3w== Received: from gitrepo.freebsd.org (gitrepo.freebsd.org [IPv6:2610:1c1:1:6068::e6a:5]) by mxrelay.nyi.freebsd.org (Postfix) with ESMTP id 4fjRbF3YC9z1C3Z for ; Sat, 28 Mar 2026 05:56:25 +0000 (UTC) (envelope-from git@FreeBSD.org) Received: from git (uid 1279) (envelope-from git@FreeBSD.org) id 40098 by gitrepo.freebsd.org (DragonFly Mail Agent v0.13+ on gitrepo.freebsd.org); Sat, 28 Mar 2026 05:56:25 +0000 To: src-committers@FreeBSD.org, dev-commits-src-all@FreeBSD.org, dev-commits-src-main@FreeBSD.org From: Colin Percival Subject: git: f350063a251c - main - clapic_handle_intr: KASSERT isrc != NULL List-Id: Commit messages for the main branch of the src repository List-Archive: https://lists.freebsd.org/archives/dev-commits-src-main List-Help: List-Post: List-Subscribe: List-Unsubscribe: X-BeenThere: dev-commits-src-main@freebsd.org Sender: owner-dev-commits-src-main@FreeBSD.org MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: 8bit X-Git-Committer: cperciva X-Git-Repository: src X-Git-Refname: refs/heads/main X-Git-Reftype: branch X-Git-Commit: f350063a251c9da0c5ce437eb4c44a2d716b673e Auto-Submitted: auto-generated Date: Sat, 28 Mar 2026 05:56:25 +0000 Message-Id: <69c76d89.40098.14c72c7b@gitrepo.freebsd.org> The branch main has been updated by cperciva: URL: https://cgit.FreeBSD.org/src/commit/?id=f350063a251c9da0c5ce437eb4c44a2d716b673e commit f350063a251c9da0c5ce437eb4c44a2d716b673e Author: Colin Percival AuthorDate: 2026-03-14 01:03:44 +0000 Commit: Colin Percival CommitDate: 2026-03-28 05:52:44 +0000 clapic_handle_intr: KASSERT isrc != NULL If an interrupt arrives at a CPU which isn't expecting that particular vector, intr_lookup_source will return an isrc of NULL and we'll panic when intr_execute_handlers increments *isrc->is_count. Place a KASSERT a few nanoseconds earlier in order to leave some more breadcrumbs for the next person to trip over this behaviour. Tested on: EC2 r8i.96xlarge MFC after: 3 weeks Sponsored by: Amazon Differential Revision: https://reviews.freebsd.org/D55851 --- sys/x86/x86/local_apic.c | 3 +++ 1 file changed, 3 insertions(+) diff --git a/sys/x86/x86/local_apic.c b/sys/x86/x86/local_apic.c index 8a8fb8ef41f6..888fd266d364 100644 --- a/sys/x86/x86/local_apic.c +++ b/sys/x86/x86/local_apic.c @@ -1445,6 +1445,9 @@ lapic_handle_intr(int vector, struct trapframe *frame) isrc = intr_lookup_source(apic_idt_to_irq(PCPU_GET(apic_id), vector)); + KASSERT(isrc != NULL, + ("lapic_handle_intr: vector %d unrecognized at lapic %u", + vector, PCPU_GET(apic_id))); intr_execute_handlers(isrc, frame); }