From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from mail-ed1-f42.google.com (mail-ed1-f42.google.com [209.85.208.42]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id F195F36BCCA for ; Wed, 14 Jan 2026 06:17:57 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.208.42 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1768371481; cv=none; b=d8hQl2oggZw3nk4v8VUx0zZfFNCziUcRkt5e9BZr0gqTXKqwdV+YX6+ZurqpRXUDRHMSuczME/k4A+pLC/qGdRwIt5ICdKohfNcm1BJTjKu8AGgxtr0hE+MoLpD6fRZWnaBALn5eGcQS2Wh/N5858HQUZiTyu0xmDjNtBXbON74= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1768371481; c=relaxed/simple; bh=yau+4rlRtbk+Hkl4uAzYetCD2LZ9ZvKbRGUV1gwIuDw=; h=Message-ID:Date:MIME-Version:Subject:To:Cc:References:From: In-Reply-To:Content-Type; b=eDzx92M+V672j9B4gDKY04UE8JLOQXib4crBak5mQattCRFDous3LdPtlSqsaNhcxMvTH2Sp0fhMWRFedwhoxP88inEWebeTYTw0tW96LAchNwX4irebtZY0lF6pM7rJlxR2rgWv7a6i/1yAK/h3+bgTVtvSDnfObtwvgNJzXy0= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=pass (p=quarantine dis=none) header.from=suse.com; spf=pass smtp.mailfrom=suse.com; dkim=pass (2048-bit key) header.d=suse.com header.i=@suse.com header.b=R4ILbbxy; arc=none smtp.client-ip=209.85.208.42 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=quarantine dis=none) header.from=suse.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=suse.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=suse.com header.i=@suse.com header.b="R4ILbbxy" Received: by mail-ed1-f42.google.com with SMTP id 4fb4d7f45d1cf-64dfb22c7e4so921592a12.1 for ; Tue, 13 Jan 2026 22:17:56 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=suse.com; s=google; t=1768371473; x=1768976273; darn=vger.kernel.org; h=content-transfer-encoding:in-reply-to:autocrypt:content-language :from:references:cc:to:subject:user-agent:mime-version:date :message-id:from:to:cc:subject:date:message-id:reply-to; bh=ospkGk8mNG8iLzTlo0V1f4uk0KSl1JOaEVfqVAzbrRw=; b=R4ILbbxykmwLRryNfMJkHD0Uu1jTHObY+2h383fkY6yIqoO+3SFDbUzMvvzi7vGVLw S1+2bmI60PbpcCKKje/uCof2KdlnZOxb4xf2xELkQ6t+V57DRDXW5Nynd+82fUBCsXIz /1qWC1GVSAdS/qDM3WQzLsoVZ/0DuF+ed7MQYbjzHPCF8HWsKVXD8AHBSNYCijFstLGZ t5zpRiftZmYsHilK4PdqqkhXevl48wptrHckf41TOltRm+fYQw5AQGSL4JDqsbLBLAS2 KncgMJ3WtMbA8n5Bgsnk4rpAw2u9QHoxR4vHbUnNSHcXVMWvlZo+aQxjRr2XjsFGLyIM pknA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1768371473; x=1768976273; h=content-transfer-encoding:in-reply-to:autocrypt:content-language :from:references:cc:to:subject:user-agent:mime-version:date :message-id:x-gm-gg:x-gm-message-state:from:to:cc:subject:date :message-id:reply-to; bh=ospkGk8mNG8iLzTlo0V1f4uk0KSl1JOaEVfqVAzbrRw=; b=iVjkDGiA03aH9O5sfLTGJt6ciMXYOQxJnLPeK9Fj/1LB+MkaV5kAtB1WU0pWJ2EGzv Z21YTqsatWex54q2RI1hikgfA/xEpWV8egWWxb6XaQO/TaWu9wPOhE5OHwM0zIb+uEJp vJ39sc9MkTdkH5yKpWWADJiXUON7QC0i7jm8DFdWKM0AS0rzhi/qFGT+kehDo+++uXVK 8AUjITtBYGljHtvwrkYOJkxS1z4/VP53YgACiDzwq57CkHEt63SEqzFJUsYyzChKn7Ai /7CRNaj+1hAc5VpsGirupyZ2I2OjlU9JTmsYD0dcxxEi9e9TvPCNGWVJAQFB/WLfotoG uqwA== X-Forwarded-Encrypted: i=1; AJvYcCWMYui4yyau1I6UCGJIai8cR7cZN8J24sVjYledQHCuDaigXcd+XIe4Nu64ILFxmVO8KRUEE/Wjv6fFaCI=@vger.kernel.org X-Gm-Message-State: AOJu0YxANuGJFsnndsyhYrnWPbj3N+sILSVfUfTazXNkAw2U5jRTZ0IQ VUAoS9S02p3pM/lpXxYp0TFNClsoy5URHd3uITVnhuXKMUjwUIFal6KuIZs8/8OHYfE= X-Gm-Gg: AY/fxX7rHmWnQRwJ9FdjlJ8rPXCJlMCd4uDBf6iXT6Nadi5koeVZkPVFNnuGlJHq2iX 2+7A1CxgdLbFRuVvpUeGXI29moGy1NL6C7M07s25Q4m5Gj3fHbqUPSkD4tER4FYWjnUNpYUiS6A 7NRNdV4rKTdICqOpAnzKAd8wmx4V2fPwsMMeCkDAKZLFWgW5p3o/jIR4LIlkZGkzrU6wuS9YCqw nyGrrsTSLjgn+nz+4HdUatLuEy+eXskIdwO9Z9GFPJwtucLp+SnPQ2SG3y8h2UoGjL6ph7UOqp2 7BtM3vCdOYcjUpHDf7JNz3W1ScIKvAkZ6Y+VBi5zpigQW5dy/OsKwB27NNUYZCUNxC9qu+E5Xk/ XsfZ7v7CxO5xfzT9jOsy1SgIZFadvwmzL76ct6FtQvLii7JqrwGWjZGI1NfgKK8EotJPqDcWMUU zbT3V5fN10JgSuWKhU1Cn3W4uIYCN2UuSVFV6s X-Received: by 2002:a17:906:d553:b0:b87:1755:99da with SMTP id a640c23a62f3a-b87357db944mr440741266b.9.1768371472835; Tue, 13 Jan 2026 22:17:52 -0800 (PST) Received: from [192.168.0.20] (nborisov.ddns.nbis.net. [85.187.217.240]) by smtp.gmail.com with ESMTPSA id a640c23a62f3a-b876c599391sm33571066b.58.2026.01.13.22.17.51 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Tue, 13 Jan 2026 22:17:52 -0800 (PST) Message-ID: Date: Wed, 14 Jan 2026 08:17:50 +0200 Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 User-Agent: Mozilla Thunderbird Subject: Re: [PATCH] x86/mce: Fix timer interval adjustment after logging a MCE event To: Borislav Petkov , "Luck, Tony" Cc: "Li, Rongqing" , Thomas Gleixner , Ingo Molnar , Dave Hansen , "x86@kernel.org" , "H . Peter Anvin" , Yazen Ghannam , "Zhuo, Qiuxu" , Avadhut Naik , "linux-kernel@vger.kernel.org" , "linux-edac@vger.kernel.org" References: <56d12335986e41da81581ef724742319@baidu.com> <20260112095118.GAaWTEFkUFHMlu0W-A@fat_crate.local> <268e2f0512db435685af987a2ba6893c@baidu.com> <20260113095111.GHaWYVj4Crd2z8oLp-@fat_crate.local> <39cfb093256f4da78fe0bc9e814ce5d0@baidu.com> <20260113124837.GHaWY_JVdFi53mh6oO@fat_crate.local> <20260113205654.GTaWaxllyfJLHsl0YX@fat_crate.local> <20260113213158.GUaWa5zunSfuAzra0n@fat_crate.local> <20260113224152.GVaWbKMMzManQ5WwlT@fat_crate.local> From: Nikolay Borisov Content-Language: en-US Autocrypt: addr=nik.borisov@suse.com; keydata= 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 In-Reply-To: <20260113224152.GVaWbKMMzManQ5WwlT@fat_crate.local> Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 8bit On 14.01.26 г. 0:41 ч., Borislav Petkov wrote: > On Tue, Jan 13, 2026 at 10:31:58PM +0100, Borislav Petkov wrote: >> Ufff, how silly and overengineered we've made it. I need to think about >> a cleaner solution tomorrow... > > One idea I just thought of: > > those two steps: > > 1. setting mce_need_notify, and > > 2. testing and clearing it > > are basically logically a one query: do we have logged errors, or, IOW, is the > gen pool not empty? > > IOW, this below. > > That'll get rid of that gunk of when should we test and when set and will > JustWork(tm) for what we want it to do. > > But let's see how it all really works tomorrow... > > diff --git a/arch/x86/kernel/cpu/mce/core.c b/arch/x86/kernel/cpu/mce/core.c > index 34440021e8cf..c378d4d450b6 100644 > --- a/arch/x86/kernel/cpu/mce/core.c > +++ b/arch/x86/kernel/cpu/mce/core.c > @@ -595,7 +595,7 @@ static bool mce_notify_irq(void) > /* Not more than two messages every minute */ > static DEFINE_RATELIMIT_STATE(ratelimit, 60*HZ, 2); > > - if (test_and_clear_bit(0, &mce_need_notify)) { > + if (!mce_gen_pool_empty()) { > mce_work_trigger(); > > if (__ratelimit(&ratelimit)) > @@ -618,10 +618,6 @@ static int mce_early_notifier(struct notifier_block *nb, unsigned long val, > /* Emit the trace record: */ > trace_mce_record(err); > > - set_bit(0, &mce_need_notify); > - > - mce_notify_irq(); > - so now mce_notify_irq() is not being called from the early notifier, i.e the callchain mc_poll_banks -> machine_check_poll -> mce_log no longer call mce_notify_irq() in the early notifier chain. > return NOTIFY_DONE; > } >