Received: by 2002:ac0:a581:0:0:0:0:0 with SMTP id m1-v6csp3575282imm; Mon, 2 Jul 2018 01:24:36 -0700 (PDT) X-Google-Smtp-Source: AAOMgpefo/bcKLXJd+s9sxeYGjwUVSTDbmXLdyu/SQ5BtkK5jB+qbdRFhGN21TJuXddq4j7EKCAM X-Received: by 2002:aa7:86d7:: with SMTP id h23-v6mr20625306pfo.132.1530519876575; Mon, 02 Jul 2018 01:24:36 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1530519876; cv=none; d=google.com; s=arc-20160816; b=EBgSCxu5pwnL+Fyz5/rymHxSH4nSRP6vWHQYX5BMe8UMbiBwRDCs1fr/FlN3afXarB ewDu5WTp5/vk5onF4b24eBOzBYR6EMkcAJQ3IQafxNg7sX1tulDeO3wLQ/2Siwn6mKXx PuS5lf9wRylGcwoqviXGqtUC3An6XxI8V9aWhGsL1Z3kPjANd/UIMZl0XqoBdvJMoljE 652VoLzPa6XAae+uw5SyAxDonvzu1ansRBSMqlzxJWWyZGI5VBWtgRkF9VM+gkcRmsj4 R+Nx467yRFu9DSi1V1A/s/g7GB9pLw/+ObxQje44fuR09sEaYir/S9OWOMeDHIjVgsQv Vi7Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:date:subject:from:references:in-reply-to :message-id:cc:to:arc-authentication-results; bh=LVWfcktN7kBGlyWD9hYMVTIWvDBwkslFhKHar5b8pPc=; b=Sw35nVceVmec0QZ+pqAicYO0AVQCAac7zxk1/3UvuFZlfAXHwuwx8+KBD6LyXhvPbA KMpTmY4Rg3o02FFy3L+1VGRYhvCqTNZDLuKCNvyJJpTa10+h6l8+Fc5ZFCbRKRQqnv/L 26sqYdMp8QNoJW2ic8Qq1mrNQWEoRt3jpF1myJ8HGalgQWhZTq0XSB8K3RgGDdTJbRFH b871LJH3kz3SVB0/pc6KBMvzoyfdox6j4EFViH3lUNUiKIcVltEdpgUi67jzE5VtaQCv VX+O2eFy3EW4J3MbgBO0TcBifQV80XgPap+uz6qm5XA2cYycMPJ3F/D7vVYSpd4fbfCr 3FTQ== ARC-Authentication-Results: i=1; mx.google.com; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id s184-v6si13755761pgb.123.2018.07.02.01.24.21; Mon, 02 Jul 2018 01:24:36 -0700 (PDT) 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; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S964882AbeGBIWK (ORCPT + 99 others); Mon, 2 Jul 2018 04:22:10 -0400 Received: from kvm5.telegraphics.com.au ([98.124.60.144]:48868 "EHLO kvm5.telegraphics.com.au" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S933657AbeGBIVZ (ORCPT ); Mon, 2 Jul 2018 04:21:25 -0400 Received: by kvm5.telegraphics.com.au (Postfix, from userid 502) id 84A48293A9; Mon, 2 Jul 2018 04:21:19 -0400 (EDT) To: Benjamin Herrenschmidt Cc: Michael Schmitz , , , Message-Id: <4387790ecb4e8aab19582e7560f43500099982d6.1530519301.git.fthain@telegraphics.com.au> In-Reply-To: References: From: Finn Thain Subject: [PATCH v4 11/11] macintosh/via-pmu: Disambiguate interrupt statistics Date: Mon, 2 Jul 2018 04:21:19 -0400 (EDT) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Some of the event counters are overloaded which makes it very difficult to interpret their values. Counter 0 is supposed to report CB1 interrupts but it can also count PMU_INT_WAITING_CHARGER events. Counter 1 is supposed to report GPIO interrupts but it can also count other events (depending upon the value of the PMU_INT_ADB bit). Disambiguate these statistics with dedicated counters for GPIO and CB1 interrupts. Comments in the MkLinux source code say that the type 0 and type 1 interrupts are model-specific. Label them as "unknown". This change to the contents of /proc/pmu/interrupts is by necessity visible in userland. However, packages which interact with the PMU (that is, pbbuttonsd, pmac-utils and pmud) don't open this file. AFAIK, user software has no need to poll these counters. Tested-by: Stan Johnson Signed-off-by: Finn Thain --- The file now looks like this, 0: 0 (Unknown interrupt (type 0)) 1: 0 (Unknown interrupt (type 1)) 2: 0 (PC-Card eject button) 3: 23 (Sound/Brightness button) 4: 74 (ADB message) 5: 0 (Battery state change) 6: 0 (Environment interrupt) 7: 121 (Tick timer) 8: 0 (Ghost interrupt (zero len)) 9: 1 (Empty interrupt (empty mask)) 10: 2 (Max irqs in a row) 11: 194 (Total CB1 triggered events) 12: 0 (Total GPIO1 triggered events) rather than this, 0: 194 (Total CB1 triggered events) 1: 0 (Total GPIO1 triggered events) 2: 0 (PC-Card eject button) 3: 23 (Sound/Brightness button) 4: 74 (ADB message) 5: 0 (Battery state change) 6: 0 (Environment interrupt) 7: 121 (Tick timer) 8: 0 (Ghost interrupt (zero len)) 9: 1 (Empty interrupt (empty mask)) 10: 2 (Max irqs in a row) If some parser exists for this file, and if this change is problematic, we could increment the driver version number in /proc/pmu/info, to correspond with the format change. --- drivers/macintosh/via-pmu.c | 20 ++++++++++++-------- 1 file changed, 12 insertions(+), 8 deletions(-) diff --git a/drivers/macintosh/via-pmu.c b/drivers/macintosh/via-pmu.c index 3da5d40309d4..d72c450aebe5 100644 --- a/drivers/macintosh/via-pmu.c +++ b/drivers/macintosh/via-pmu.c @@ -172,7 +172,9 @@ static int drop_interrupts; static int option_lid_wakeup = 1; #endif /* CONFIG_SUSPEND && CONFIG_PPC32 */ static unsigned long async_req_locks; -static unsigned int pmu_irq_stats[11]; + +#define NUM_IRQ_STATS 13 +static unsigned int pmu_irq_stats[NUM_IRQ_STATS]; static struct proc_dir_entry *proc_pmu_root; static struct proc_dir_entry *proc_pmu_info; @@ -873,9 +875,9 @@ static int pmu_info_proc_show(struct seq_file *m, void *v) static int pmu_irqstats_proc_show(struct seq_file *m, void *v) { int i; - static const char *irq_names[] = { - "Total CB1 triggered events", - "Total GPIO1 triggered events", + static const char *irq_names[NUM_IRQ_STATS] = { + "Unknown interrupt (type 0)", + "Unknown interrupt (type 1)", "PC-Card eject button", "Sound/Brightness button", "ADB message", @@ -884,10 +886,12 @@ static int pmu_irqstats_proc_show(struct seq_file *m, void *v) "Tick timer", "Ghost interrupt (zero len)", "Empty interrupt (empty mask)", - "Max irqs in a row" + "Max irqs in a row", + "Total CB1 triggered events", + "Total GPIO1 triggered events", }; - for (i=0; i<11; i++) { + for (i = 0; i < NUM_IRQ_STATS; i++) { seq_printf(m, " %2u: %10u (%s)\n", i, pmu_irq_stats[i], irq_names[i]); } @@ -1622,7 +1626,7 @@ via_pmu_interrupt(int irq, void *arg) } if (intr & CB1_INT) { adb_int_pending = 1; - pmu_irq_stats[0]++; + pmu_irq_stats[11]++; } if (intr & SR_INT) { req = pmu_sr_intr(); @@ -1709,7 +1713,7 @@ gpio1_interrupt(int irq, void *arg) disable_irq_nosync(gpio_irq); gpio_irq_enabled = 0; } - pmu_irq_stats[1]++; + pmu_irq_stats[12]++; adb_int_pending = 1; spin_unlock_irqrestore(&pmu_lock, flags); via_pmu_interrupt(0, NULL); -- 2.16.4