Received: by 10.192.165.148 with SMTP id m20csp3666558imm; Mon, 7 May 2018 16:55:51 -0700 (PDT) X-Google-Smtp-Source: AB8JxZp8H40uins1JxpbzJS0V7Q4/E5hvc1kCnU9BINUd2Z9HXM0dhe1A3P+wOPBi/M8CX0khw+K X-Received: by 2002:a65:61ad:: with SMTP id i13-v6mr30743928pgv.449.1525737351622; Mon, 07 May 2018 16:55:51 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1525737351; cv=none; d=google.com; s=arc-20160816; b=wcRAidRc2UNybvOJ5DH8MqQpKt+29diB9to5th/9kvKn9NmYUt/7vv1XN85pJVFzbR iFu0ZLs/mQlGsr/4LVnKc2lHyGp+VcPk048GJRFlIiARtL2mmLCAa55etHWr70HpgkfC DiTh69TrmElXQnX4mhHLQ/J1IeKofzQcOzgEKQwX1y5oUjWzz+mVSbDsv473uTHenUEh d15mNheq07SuotMFrD5rfjYDdI8OcwoqL/oL+N7cSmKW/7UknveHo7LqLzeqKmN3l292 beh4QQnvkc3CNI82SYzkb9oWt4rKygEEPRMks5XT7rdCF4PIwjhS+FoR4MZTrgVYSebK ErKg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:date:subject:cc:to:from :dkim-signature:arc-authentication-results; bh=snwJmaUHYckrcQq2GSiPTJUbAsv9VzZH9Cn0DvCECZ0=; b=K8J3/IbqjMxR3Bid0UsxUFmXkSpu8Jh1IJZ42ymUWD84FxO/g+lkEiy/geSjiBA/Hk IcyQ/EMYUYVqABSF+tLUt6sSwXdiddMkcBVNcSEwsOKyMqeLfWq2HsQ3Z12iHnqX+vv/ KUhvzCtBdaOi9OYrzyulMyislOLd/02txBM91hdFrvqmnEV3f2I2c6XzFr+Dq/LuUasj Ww97eXz5Z3jvpGTcxU1VAnyhS5hlzKIwwZOlNG4cjZZVG7bn4GUcKueSmj/du3X/hKJt CHkYQcKpl3su51GO/t+1tQQqLtJjHrJ/sAbFgD+ART7Oupg17QGp9/XGwqUWydn8yRd9 zP9g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=Mdq5BlrE; 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=pass (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 e29-v6si22994273plj.518.2018.05.07.16.55.35; Mon, 07 May 2018 16:55:51 -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; dkim=pass header.i=@linaro.org header.s=google header.b=Mdq5BlrE; 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=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753585AbeEGXx5 (ORCPT + 99 others); Mon, 7 May 2018 19:53:57 -0400 Received: from mail-pl0-f67.google.com ([209.85.160.67]:45735 "EHLO mail-pl0-f67.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753546AbeEGXxm (ORCPT ); Mon, 7 May 2018 19:53:42 -0400 Received: by mail-pl0-f67.google.com with SMTP id bi12-v6so1073254plb.12 for ; Mon, 07 May 2018 16:53:42 -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; bh=snwJmaUHYckrcQq2GSiPTJUbAsv9VzZH9Cn0DvCECZ0=; b=Mdq5BlrEShn3c/WYlyk98dUOXM2SCkCmoG/4BRkrmdz3cPlLKrMXwTZAPLKaqolHtj aw4xpbGJPxeK5jX+w0+4XMwreBqblnP+SfV1J2uAglPbMe35rB/2TKG4k9X+CYa7P+uK YhjJZFstozNDerfiUZeAE8DRfXx7pmJPn6tmY= 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; bh=snwJmaUHYckrcQq2GSiPTJUbAsv9VzZH9Cn0DvCECZ0=; b=J2J62hT1D2pQVAWl6E4kAye7ZWi9oULTUplRSCRp6WhUzvAEhXVK+dRGPj1ZVqq7wY eUnZQnE4ZvtO7R1Xto6Im5sA4Oc7bJL6dqqZ/3SRyw4cKCE8RXxcuoMgXuQ44gAKwMft r7WFpJpkn98N77RgF386SkLOALGRlmpNgM95Wc+Nx990gdhSWKl1KjUj9oJtTTO+cGDf ZUzqVo7iZQRHcE/abz/KxlABUw1/UNE1lK5HAXD05b+2BGvrigUxTVfyz1N4CKq994r/ SPt9M5KeGhF7xJkcTHBO8eg6Q4e56hWpOw3TElRltWpxG7emc4aqeMTx0Zcoul10YYpg 11mQ== X-Gm-Message-State: ALQs6tApF950d6mTSOm4WTYR4gWqd5VNKYUGyy8KxDeg5IDu4x5E2k1z lfHhgQuDbLh6aucDw6vjnARLeQ== X-Received: by 2002:a17:902:6b09:: with SMTP id o9-v6mr40120364plk.256.1525737222173; Mon, 07 May 2018 16:53:42 -0700 (PDT) Received: from localhost.localdomain (104-188-17-28.lightspeed.sndgca.sbcglobal.net. [104.188.17.28]) by smtp.gmail.com with ESMTPSA id i127sm43891680pfc.154.2018.05.07.16.53.41 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Mon, 07 May 2018 16:53:41 -0700 (PDT) From: Bjorn Andersson To: Zhang Rui , Eduardo Valentin , Rob Herring , Mark Rutland , Rajendra Nayak Cc: linux-pm@vger.kernel.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, linux-arm-msm@vger.kernel.org Subject: [PATCH] thermal: qcom: tsens: Allow number of sensors to come from DT Date: Mon, 7 May 2018 16:53:39 -0700 Message-Id: <20180507235339.8836-1-bjorn.andersson@linaro.org> X-Mailer: git-send-email 2.17.0 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org For platforms that has multiple copies of the TSENS hardware block it's necessary to be able to specify the number of sensors per block in DeviceTree. Signed-off-by: Bjorn Andersson --- .../devicetree/bindings/thermal/qcom-tsens.txt | 1 + drivers/thermal/qcom/tsens.c | 12 +++++++++--- 2 files changed, 10 insertions(+), 3 deletions(-) diff --git a/Documentation/devicetree/bindings/thermal/qcom-tsens.txt b/Documentation/devicetree/bindings/thermal/qcom-tsens.txt index 292ed89d900b..06195e8f35e2 100644 --- a/Documentation/devicetree/bindings/thermal/qcom-tsens.txt +++ b/Documentation/devicetree/bindings/thermal/qcom-tsens.txt @@ -8,6 +8,7 @@ Required properties: - reg: Address range of the thermal registers - #thermal-sensor-cells : Should be 1. See ./thermal.txt for a description. +- #qcom,sensors: Number of sensors in tsens block - Refer to Documentation/devicetree/bindings/nvmem/nvmem.txt to know how to specify nvmem cells diff --git a/drivers/thermal/qcom/tsens.c b/drivers/thermal/qcom/tsens.c index 3f9fe6aa51cc..20f3b87d7667 100644 --- a/drivers/thermal/qcom/tsens.c +++ b/drivers/thermal/qcom/tsens.c @@ -116,6 +116,7 @@ static int tsens_probe(struct platform_device *pdev) struct tsens_device *tmdev; const struct tsens_data *data; const struct of_device_id *id; + u32 num_sensors; if (pdev->dev.of_node) dev = &pdev->dev; @@ -130,18 +131,23 @@ static int tsens_probe(struct platform_device *pdev) else data = &data_8960; - if (data->num_sensors <= 0) { + num_sensors = data->num_sensors; + + if (np) + of_property_read_u32(np, "#qcom,sensors", &num_sensors); + + if (num_sensors <= 0) { dev_err(dev, "invalid number of sensors\n"); return -EINVAL; } tmdev = devm_kzalloc(dev, sizeof(*tmdev) + - data->num_sensors * sizeof(*s), GFP_KERNEL); + num_sensors * sizeof(*s), GFP_KERNEL); if (!tmdev) return -ENOMEM; tmdev->dev = dev; - tmdev->num_sensors = data->num_sensors; + tmdev->num_sensors = num_sensors; tmdev->ops = data->ops; for (i = 0; i < tmdev->num_sensors; i++) { if (data->hw_ids) -- 2.17.0