Received: by 2002:ac0:946b:0:0:0:0:0 with SMTP id j40csp2373167imj; Mon, 11 Feb 2019 01:32:24 -0800 (PST) X-Google-Smtp-Source: AHgI3IbaacjtgU7ajG1shIjaNjbDaM1uVItuLuWUK3onCaEVz4bY2hvrP6Xaem8myjcaJtklNpOk X-Received: by 2002:a65:5c02:: with SMTP id u2mr32536321pgr.13.1549877544049; Mon, 11 Feb 2019 01:32:24 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1549877544; cv=none; d=google.com; s=arc-20160816; b=dJJORj2z5493odU5efQoy7sXUHlCAtKZKJX0hGPENts8qzZ8EEzSEbLPt/IQ3Q7XWc JuhrdQRDz0uqJSP4/ajyv4FIcEo5sGdDB+o6/uEQWVaB+lVCkaMBbJGswf3wbqLRPrDj R/n3vvA0bRYXJp1OzE4ZjxmOwX6Bw7X0OcMdrkv9ME3KD2M+RATG1quR6NHFKZ0TVvxv csylEtnFikStH8BxiZCZMEjPmkU1eALiAXyxmCLa9RBe7bDEyEOsBO3NTY2ZfyH77Ajk 4kpsCXocUHtIsYLsCPCEXpLz/YJEL8buaEKuHTEKTVpg4xbewq8yT1pJ2IBBc/OrdHlM Kc8A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:to:content-transfer-encoding:mime-version :message-id:date:subject:cc:from:dkim-signature; bh=VtN5TpTq4iwM1pPfzvGUrEDcplUZre+748yHJSDQqI4=; b=0Klti1aqTduHg0TCMDiQEhEo/VusUlewVCD1Fgu/r5XW/+GyNOZ/PeByqlvcS+e4Xo 7fPB89cMSasV8KIom/27jojwVW1on9+kKhDvaGrbCuKGaSfCKuHY3cDMWYmiP32jB2Y2 0JqBeydg6l6Hzrd/+Cg6V9SEP1a1oVBPcanzSC1N4T5agmklpvrLGIOgZ6uCktKpo9Zo IRGbWvwGWulE/gjkj5m88SVkmO48+d8MgrFxzZfhk/eKawdnPt8e+1F8u9HF0NC3WNAd 8lEyG07WDmJMGFSGME/PGomszsJZaKfcHBk3tzLdYXe8zOZf4CfoO5OaktNkjjWWQZ0k ucRA== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@gmail.com header.s=20161025 header.b=VU0H4rt1; 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 m187si10026533pfm.51.2019.02.11.01.32.08; Mon, 11 Feb 2019 01:32:24 -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=VU0H4rt1; 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 S1726756AbfBKJbv (ORCPT + 99 others); Mon, 11 Feb 2019 04:31:51 -0500 Received: from mail-wm1-f66.google.com ([209.85.128.66]:37219 "EHLO mail-wm1-f66.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725986AbfBKJbu (ORCPT ); Mon, 11 Feb 2019 04:31:50 -0500 Received: by mail-wm1-f66.google.com with SMTP id x10so10405655wmg.2; Mon, 11 Feb 2019 01:31:49 -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:mime-version :content-transfer-encoding; bh=VtN5TpTq4iwM1pPfzvGUrEDcplUZre+748yHJSDQqI4=; b=VU0H4rt18sHwL+e0dAbnD4mb04s6ZG0pOri7Mh7q5esVgWy+AFg5RqYlvOQG5OEROY fcobB+7jHz49XLhtV6VmNMtEz2fco0qnEEjtzABDOTmPUVbUoZOHpR+0nUkN/hpU1XcI 9+7xxF6CkrOApQ6KDOSAXVCD1jxbgt7VFQSOBZ8SQNeHqapkWnJpEVdGh1XkW9gGvAu7 OujDJMWyy/DydBNxAvOG+bgQcIGgAoi0m6qkrTuZj6nkeMDZc3cjtd0jNUcA3u/JN9TD G5WbXys54Fe0J79Auo6Ltl4W6AGPkPdfVW78wfnLyKlV/jPdY7Xnbgq294IJudnD8z2Q Ge/Q== 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:mime-version :content-transfer-encoding; bh=VtN5TpTq4iwM1pPfzvGUrEDcplUZre+748yHJSDQqI4=; b=pJC+my7CWERP0eE7oXWU7kZikr9Icrlv+y0WLxdSZ4jrT4F/0cnRA3tQJYj7hoPd9w RBuLllPD6SZMGHTrb1nHnpN2Hxp128KbAyWRq1LHSUQif6q+73pG7H+/fgadnzNH6zQv Iq75GIi+74Mh+z9WS45G8t5w0KBA09NptBFMzt7BCA1BoZMJ0EMFbeXQz8FyFZ9SqOB0 Y38vJb9/rOHVyOV85ubXvDblChoE2DSUtoIQ436TqpCuH+hMi0DYmHQ/18b2kLfvB1nP oEg6JU70fdZt31z+Cb9ZUVDrJtx65hFiGToDSRXfssBT5NGVc8TIS72czxwLvMuqxRJG muQQ== X-Gm-Message-State: AHQUAuZfRhRtbKjVF1lAAOQ7Xz2LiM5Ip2DXN+kJEZytBXlNE9jvin6q QI+Xok5qvARbGXO2X9d0/ww= X-Received: by 2002:a1c:c303:: with SMTP id t3mr7721825wmf.94.1549877508629; Mon, 11 Feb 2019 01:31:48 -0800 (PST) Received: from laptop.criteois.lan ([91.199.242.236]) by smtp.gmail.com with ESMTPSA id v4sm9362447wme.6.2019.02.11.01.31.47 (version=TLS1_2 cipher=ECDHE-RSA-CHACHA20-POLY1305 bits=256/256); Mon, 11 Feb 2019 01:31:47 -0800 (PST) From: Erwan Velu X-Google-Original-From: Erwan Velu Cc: e.velu@criteo.com, Liam.Howlett@oracle.com, Srinivas Pandruvada , Len Brown , "Rafael J. Wysocki" , Viresh Kumar , linux-pm@vger.kernel.org (open list:INTEL PSTATE DRIVER), linux-kernel@vger.kernel.org (open list) Subject: [PATCH v3] cpufreq: intel_pstate: Reporting reasons why driver prematurely exit Date: Mon, 11 Feb 2019 10:31:40 +0100 Message-Id: <20190211093140.23608-1-e.velu@criteo.com> X-Mailer: git-send-email 2.20.1 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit 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 The init code path have several execeptions where the module can decide not to load. As CONFIG_X86_INTEL_PSTATE is generally set to Y, the return code is not reachable. The initialisation code is neither verbose of the reason why it did choose to prematurely exit. This situation leads to situation where its difficult for a user to determine, on a given platform, why the driver didn't loaded properly. This patch is about reporting to the user the reason/context why the driver failed to load. That is a precious hint when debugging a platform. Signed-off-by: Erwan Velu --- drivers/cpufreq/intel_pstate.c | 36 ++++++++++++++++++++++++++-------- 1 file changed, 28 insertions(+), 8 deletions(-) diff --git a/drivers/cpufreq/intel_pstate.c b/drivers/cpufreq/intel_pstate.c index dd66decf2087..ba2e2aee6c20 100644 --- a/drivers/cpufreq/intel_pstate.c +++ b/drivers/cpufreq/intel_pstate.c @@ -2475,6 +2475,7 @@ static bool __init intel_pstate_no_acpi_pss(void) kfree(pss); } + pr_info("Cannot detect ACPI PSS"); return true; } @@ -2484,10 +2485,16 @@ static bool __init intel_pstate_no_acpi_pcch(void) acpi_handle handle; status = acpi_get_handle(NULL, "\\_SB", &handle); - if (ACPI_FAILURE(status)) + if (ACPI_FAILURE(status)) { + pr_info("Cannot detect ACPI SB"); return true; + } - return !acpi_has_method(handle, "PCCH"); + status = acpi_has_method(handle, "PCCH"); + if (!status) { + pr_info("Cannot detect ACPI PCCH"); + } + return !status; } static bool __init intel_pstate_has_acpi_ppc(void) @@ -2502,6 +2509,7 @@ static bool __init intel_pstate_has_acpi_ppc(void) if (acpi_has_method(pr->handle, "_PPC")) return true; } + pr_info("Cannot detect ACPI PPC"); return false; } @@ -2592,8 +2600,10 @@ static int __init intel_pstate_init(void) const struct x86_cpu_id *id; int rc; - if (no_load) + if (no_load) { + pr_info("disabling as per user-request\n"); return -ENODEV; + } id = x86_match_cpu(hwp_support_ids); if (id) { @@ -2606,31 +2616,41 @@ static int __init intel_pstate_init(void) } } else { id = x86_match_cpu(intel_pstate_cpu_ids); - if (!id) + if (!id) { + pr_warn("CPU ID is not in the list of supported devices\n"); return -ENODEV; + } copy_cpu_funcs((struct pstate_funcs *)id->driver_data); } - if (intel_pstate_msrs_not_valid()) + if (intel_pstate_msrs_not_valid()) { + pr_warn("Cannot enable driver as per invalid MSRs\n"); return -ENODEV; + } hwp_cpu_matched: /* * The Intel pstate driver will be ignored if the platform * firmware has its own power management modes. */ - if (intel_pstate_platform_pwr_mgmt_exists()) + if (intel_pstate_platform_pwr_mgmt_exists()) { + pr_warn("Platform already taking care of power management\n"); return -ENODEV; + } - if (!hwp_active && hwp_only) + if (!hwp_active && hwp_only) { + pr_warn("HWP not present\n"); return -ENOTSUPP; + } pr_info("Intel P-state driver initializing\n"); all_cpu_data = vzalloc(array_size(sizeof(void *), num_possible_cpus())); - if (!all_cpu_data) + if (!all_cpu_data) { + pr_warn("Cannot allocate memory\n"); return -ENOMEM; + } intel_pstate_request_control_from_smm(); -- 2.20.1