From patchwork Mon Jul 2 12:44:07 2018 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Amit Kucheria X-Patchwork-Id: 140748 Delivered-To: patch@linaro.org Received: by 2002:a2e:9754:0:0:0:0:0 with SMTP id f20-v6csp3953301ljj; Mon, 2 Jul 2018 05:45:49 -0700 (PDT) X-Google-Smtp-Source: AAOMgpfODzoIC/j6EyF5ACmLprTpBbTKnAmb8y+5kBbyHLPX97hOXrCG+R/bp6hFm4nfqfr3ESxx X-Received: by 2002:a62:b20c:: with SMTP id x12-v6mr16305426pfe.64.1530535549402; Mon, 02 Jul 2018 05:45:49 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1530535549; cv=none; d=google.com; s=arc-20160816; b=WUPYEl/TLJ7lFf9aYu6OFcbU56kK8qcrlxwDNHmBlc/E8Q6zWs/fxIZa3PMPU0rhDV eCutI6G48IzE/6mjviNGG4g5KfgI7U2iY9NYCkraiwe1hw5hEJKPPfJ5OynNe5ozR4Hg LJb2lBNEb+yjLtOukH7obFkFnHKJeATvkAMRRJsVJenThGG8e3t2fYBsRPqQx499YXSi E4JyGx2k/JBEi7jLYfsElGdcI4KSY/Yvhyl2DmxxsjSRB0JTBA/ITwqfcdrz2JeU6XT7 Z7VTRt4LVmZt/6dRSjiJj6EDh7vIhqcwu9I+o8fKN+43yJoMbUGaZBfNEl5hkLte7jqB 34Jw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:references :in-reply-to:message-id:date:subject:cc:to:from:dkim-signature :arc-authentication-results; bh=M1Ao2XwRZv1zWgwTFDVy/i+imQAsiVugIHzOr+xhs5o=; b=H7pJ1lan8w718m+QJgVjVvDOwZ4m46FbArw/WNWSAm8KdVhSJAGwmIuQ2otuOYzkO6 Rbf+yH5K3odftuiz6GRo67128EznS3PEKS31Eylz3nTDytfXUBn1liZaPkYB+UlsColb Z6rMZq/QZ53l3SEKfSUwaQzav09yGTKYWc1fEcqSL+FOLc87HuFBJHoXfzU8f87p/+9U Lvwpk53HTJVBieo6SmFqursFnkXbcj5tLJhCSu1PMXbgYf3Ja96jSfzH0o96oXx7HEU/ fWEIv04tDYYWIxScJBd1B67NyVwRNe42KQObYRHSQewJkDLFrxBZde8xf72UH5TSEela ijHg== ARC-Authentication-Results: i=1; mx.google.com; dkim=neutral (body hash did not verify) header.i=@linaro.org header.s=google header.b=L1QRH4ne; spf=pass (google.com: best guess record for domain of devicetree-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=devicetree-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=linaro.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id 139-v6si13887717pgc.87.2018.07.02.05.45.49; Mon, 02 Jul 2018 05:45:49 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of devicetree-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=neutral (body hash did not verify) header.i=@linaro.org header.s=google header.b=L1QRH4ne; spf=pass (google.com: best guess record for domain of devicetree-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=devicetree-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=linaro.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751909AbeGBMpr (ORCPT + 5 others); Mon, 2 Jul 2018 08:45:47 -0400 Received: from mail-pl0-f68.google.com ([209.85.160.68]:33515 "EHLO mail-pl0-f68.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753070AbeGBMo4 (ORCPT ); Mon, 2 Jul 2018 08:44:56 -0400 Received: by mail-pl0-f68.google.com with SMTP id 6-v6so7919354plb.0 for ; Mon, 02 Jul 2018 05:44:55 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references :in-reply-to:references; bh=2chRnc2W7u7nDJkgcN8SuxEHelsCQc93uFuFBC70dN0=; b=L1QRH4nedVyn8SXsrAlvztQC6tpo4mF/Qj+0PRkN6Y12blWvHG4IRuOurcx+N7fbDC cnDINuQbdoT8W9wGoRj5JWnqHOd3AgotDLfQ3RoosOlTbnXhmmE/P8gcOwSE+gbpoQSY /Jl6xiKBiZZy1/t4m0c0qNoo0Dbx6WpmfH51c= 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:in-reply-to :references:in-reply-to:references; bh=2chRnc2W7u7nDJkgcN8SuxEHelsCQc93uFuFBC70dN0=; b=NTkcVku8oxUBAI31YqIq21QJJxl2i+FQz1StftJ/MAot2G8jmofbhB9nYu/IuXmKQR j4c4UFu1BWqdI9ZdRHuHVTof0nNo7TniAmk+Sh/UmMfsTeg/s7DEmw27bf/3dy5mQ9a2 h2q9pDt5fM4KUSjzMQL1197sfLRHz85Ow3v43a8sgSwaaGHeZILIryZQeKjdVb22zvcZ lmwlo7L8bOnRN8FRL+xZ8eU7G36gaA0NLh0YFhWYjTnHkZA7UVGl3+RrtG10u6mAem9G qIW9pZIOEtiea7celc892ZZDMcVoseI6NJroIYU1rffVoK/67WgYcd7LrAh2K4eEidkv 1Dmg== X-Gm-Message-State: APt69E3Id75Qk+L9cMz84ggGk5/sdN14hb/WNhleu80T2gXOIXNxVVVY +ZTxTz6WhcVO1iRi3BIJ715DYJsVa1c= X-Received: by 2002:a17:902:8e87:: with SMTP id bg7-v6mr25600756plb.129.1530535495526; Mon, 02 Jul 2018 05:44:55 -0700 (PDT) Received: from localhost ([49.248.63.129]) by smtp.gmail.com with ESMTPSA id e10-v6sm20453604pgv.48.2018.07.02.05.44.54 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Mon, 02 Jul 2018 05:44:54 -0700 (PDT) From: Amit Kucheria To: linux-kernel@vger.kernel.org Cc: rnayak@codeaurora.org, linux-arm-msm@vger.kernel.org, bjorn.andersson@linaro.org, edubezval@gmail.com, smohanad@codeaurora.org, vivek.gautam@codeaurora.org, andy.gross@linaro.org, Zhang Rui , Rob Herring , Mark Rutland , Kees Cook , linux-pm@vger.kernel.org, devicetree@vger.kernel.org Subject: [PATCH v4 4/6] thermal: tsens: Add support for SDM845 Date: Mon, 2 Jul 2018 18:14:07 +0530 Message-Id: <43e3ae530334efab3fa0151430879f03731e9daa.1530533998.git.amit.kucheria@linaro.org> X-Mailer: git-send-email 2.7.4 In-Reply-To: References: In-Reply-To: References: Sender: devicetree-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: devicetree@vger.kernel.org SDM845 uses v2.4.0 of the TSENS IP block but the get_temp() function appears to be identical across v2.x.y in code seen so far. We use the generic get_temp() function. Signed-off-by: Amit Kucheria --- Documentation/devicetree/bindings/thermal/qcom-tsens.txt | 2 ++ drivers/thermal/qcom/tsens-v2.c | 6 +++++- drivers/thermal/qcom/tsens.c | 6 ++++++ drivers/thermal/qcom/tsens.h | 5 ++++- 4 files changed, 17 insertions(+), 2 deletions(-) -- 2.7.4 -- To unsubscribe from this list: send the line "unsubscribe devicetree" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html diff --git a/Documentation/devicetree/bindings/thermal/qcom-tsens.txt b/Documentation/devicetree/bindings/thermal/qcom-tsens.txt index 06195e8..075182e 100644 --- a/Documentation/devicetree/bindings/thermal/qcom-tsens.txt +++ b/Documentation/devicetree/bindings/thermal/qcom-tsens.txt @@ -5,6 +5,8 @@ Required properties: - "qcom,msm8916-tsens" : For 8916 Family of SoCs - "qcom,msm8974-tsens" : For 8974 Family of SoCs - "qcom,msm8996-tsens" : For 8996 Family of SoCs + - "qcom,tsens-v2.4.0" : For SDM845 Family of SoCs + - "qcom,tsens-v2" : Generic fallback binding for any Soc using 2.x.y version of the tsens IP - reg: Address range of the thermal registers - #thermal-sensor-cells : Should be 1. See ./thermal.txt for a description. diff --git a/drivers/thermal/qcom/tsens-v2.c b/drivers/thermal/qcom/tsens-v2.c index 2eca7ff..1871945 100644 --- a/drivers/thermal/qcom/tsens-v2.c +++ b/drivers/thermal/qcom/tsens-v2.c @@ -69,8 +69,12 @@ static const struct tsens_ops ops_generic_v2 = { .get_temp = get_temp_tsens_v2, }; +const struct tsens_data data_tsens_v2 = { + .ops = &ops_generic_v2, +}; + +/* Kept around for backward compatibility with old msm8996.dtsi */ const struct tsens_data data_8996 = { .num_sensors = 13, .ops = &ops_generic_v2, }; - diff --git a/drivers/thermal/qcom/tsens.c b/drivers/thermal/qcom/tsens.c index 3440166c..992ed17 100644 --- a/drivers/thermal/qcom/tsens.c +++ b/drivers/thermal/qcom/tsens.c @@ -72,6 +72,12 @@ static const struct of_device_id tsens_table[] = { }, { .compatible = "qcom,msm8996-tsens", .data = &data_8996, + }, { + .compatible = "qcom,tsens-v2.4.0", + .data = &data_tsens_v2, + }, { + .compatible = "qcom,tsens-v2", + .data = &data_tsens_v2, }, {} }; diff --git a/drivers/thermal/qcom/tsens.h b/drivers/thermal/qcom/tsens.h index dc56e1e..69212cb 100644 --- a/drivers/thermal/qcom/tsens.h +++ b/drivers/thermal/qcom/tsens.h @@ -87,6 +87,9 @@ void compute_intercept_slope(struct tsens_device *, u32 *, u32 *, u32); int init_common(struct tsens_device *); int get_temp_common(struct tsens_device *, int, int *); -extern const struct tsens_data data_8916, data_8974, data_8960, data_8996; +/* TSENS v1 targets */ +extern const struct tsens_data data_8916, data_8974, data_8960; +/* TSENS v2 targets */ +extern const struct tsens_data data_8996, data_tsens_v2; #endif /* __QCOM_TSENS_H__ */