From patchwork Tue Jan 19 05:48:43 2021 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Dmitry Baryshkov X-Patchwork-Id: 366119 Delivered-To: patch@linaro.org Received: by 2002:a02:a60d:0:0:0:0:0 with SMTP id c13csp468509jam; Mon, 18 Jan 2021 22:23:09 -0800 (PST) X-Google-Smtp-Source: ABdhPJxpc84AVpCA3bTgm8QTfE8wCAGjUOKktJPydkD6SQVkzAM9ybHTD4k443QfGtZH1uboelDm X-Received: by 2002:a05:6402:20e:: with SMTP id t14mr2217237edv.178.1611037389132; Mon, 18 Jan 2021 22:23:09 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1611037389; cv=none; d=google.com; s=arc-20160816; b=fXnFdoZQo4hjyGQaZ7LI5m4CrT1GfGfSmG/z66qqeFr2EKJSAoC/wbgKFs38a88ngN vWqyQfroin7+5ZG7xl0N+0ORhEjdV2Z6TTtkt7sa0zVyvVLU5DDbTZx4M+2OO6TJTj1y +Bo76IuuaP5jgeivdZv5SjcFX6n/cvhXzZpBWKHCkeOERR9cLa2q9OeYQ0/sESDRqbqS mM5EcOgnBavXLqzCEKnRkK2fa3u67ZAYg/w/OoyxHeg09yKLmfBXbN6Z79uedY4rAcYZ 6j/IAeA16Cn5Upm6qa3HTt0VIfXntZd2mnNyVBM6RyXpcRCotGZOv+A1H8JiGH3VxiuM bC6g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from:dkim-signature; bh=BaDAnz5PWlBb3FvhcqwZjvy+ViqKXKxtEUXuyfVUfG0=; b=nWxd9cPNgAV/paZ7/W4pMtYNkJVbkz6G+oEKZFG6ehIxZAfTsMVqjtNGfJV2qjRdQ4 tn+jtol1lPaaQ1gwltZUfY4rP+L0wNoI3v9ddVuMUaJfd/m8ieyFlFH5Xd1pZOyp3zpp GXEPLCLJKQ9/Zc3Olh4PpzqkvoYOMeP6mTnpVmRQ6Wp1NEJiyKaEVmApaCyRMp0Lqo7n vvsb9Xl/Z9Bh27q0D12uoEjJXAQCbcS4HAQqQqro/69qKayFI5Pm/u93kx47ah5/4eiu Ni2emi0yfv5Y6yQPz0856YpLsnaFQLaFmvf0VYfK88bpOobw0IxtuP4JSdoTsIxLSHIr TKDA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=qGROhCgS; spf=pass (google.com: domain of linux-arm-msm-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-arm-msm-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. [23.128.96.18]) by mx.google.com with ESMTP id s21si3615300edd.135.2021.01.18.22.23.08; Mon, 18 Jan 2021 22:23:09 -0800 (PST) Received-SPF: pass (google.com: domain of linux-arm-msm-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=qGROhCgS; spf=pass (google.com: domain of linux-arm-msm-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-arm-msm-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 S1726515AbhASGW1 (ORCPT + 15 others); Tue, 19 Jan 2021 01:22:27 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:53826 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2391316AbhASFtf (ORCPT ); Tue, 19 Jan 2021 00:49:35 -0500 Received: from mail-lj1-x232.google.com (mail-lj1-x232.google.com [IPv6:2a00:1450:4864:20::232]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id CA5A9C061575 for ; Mon, 18 Jan 2021 21:48:54 -0800 (PST) Received: by mail-lj1-x232.google.com with SMTP id n11so20586738lji.5 for ; Mon, 18 Jan 2021 21:48:54 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=BaDAnz5PWlBb3FvhcqwZjvy+ViqKXKxtEUXuyfVUfG0=; b=qGROhCgSdGzhZsNXSPaDyyoY6c8nRMnGYynnd1NPmCMGf8MWrc9+z7jJRYietSod5v Snkh4Nf8Z9dt/m5G2oPEQr6AwPgKR7AVgv0VbTKRTvBuvlcbXdi/qNJVGBmU0TgpOKIM COWa+4zGLbkNGGo+htqIpH8jr9dxUk20sIgO41FsyHjUzVfvjhieK5qLmI1PSL/ElNMF a/Uukm4BmE1VTSJuD5PxkxJ0hRDoOLUTDalZI2ew5VHX3AQc/1UY61vyDk+hGQs1JFg/ O3DoPdlPpciL7SJD6/7wkyl4R0o5O+UkvNNFGnvEnB1Sp6b6ScuH1g8hKnuGL/99m3ng EkSw== 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=BaDAnz5PWlBb3FvhcqwZjvy+ViqKXKxtEUXuyfVUfG0=; b=E4QGrq4Vm028v1BLKebA0Ucgj7pZ1mOIyQlClIEgjjf0GGjYGk/ya2+QtqUgGkQwTY +svGeh0ypUYEAq8drXGpWPSyxXfAvUDPjfeDLJ5yudrTVPzov7mTnBjpoaLhGCG8C4d+ fIJT4RNR6ix1wLC+XDqspfadX9A5C7S3RpBCHWLWafI7WIyeVoKij+teLK1jzgdjPZ7r iQCerXqgVpIBedKR35hLAnOrgXEdd/lsvuYHJJ58AOA+QKDJZ041hQq0fvJRTzBzqv8P 57+265HZ5QxgHw3uEJPd1lxieHoDslqYObiEpaKCqyFklSQjSAvNuFrPcEsNw9nW/AoF /Cvw== X-Gm-Message-State: AOAM533cvTT8SmA54StOnI9pu3B/eKCphJ70i25u6oMb19e43j4nomUM Q2z59IiBLHNbi4y+NLNG4+nZfddeZUgm5za0 X-Received: by 2002:a2e:8691:: with SMTP id l17mr572169lji.408.1611035332781; Mon, 18 Jan 2021 21:48:52 -0800 (PST) Received: from eriador.lumag.spb.ru ([188.162.65.64]) by smtp.gmail.com with ESMTPSA id j3sm2168207lfb.29.2021.01.18.21.48.50 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 18 Jan 2021 21:48:52 -0800 (PST) From: Dmitry Baryshkov To: Andy Gross , Bjorn Andersson , Rob Herring , Zhang Rui , Daniel Lezcano , Amit Kucheria , Jonathan Cameron , Hartmut Knaack , Lars-Peter Clausen , Peter Meerwald-Stadler Cc: linux-arm-msm@vger.kernel.org, linux-pm@vger.kernel.org, devicetree@vger.kernel.org, linux-iio@vger.kernel.org, Manivannan Sadhasivam , Jishnu Prakash Subject: [PATCH v12 0/5] qcom: pm8150: add support for thermal monitoring Date: Tue, 19 Jan 2021 08:48:43 +0300 Message-Id: <20210119054848.592329-1-dmitry.baryshkov@linaro.org> X-Mailer: git-send-email 2.29.2 MIME-Version: 1.0 Precedence: bulk List-ID: X-Mailing-List: linux-arm-msm@vger.kernel.org This patch serie adds support for thermal monitoring block on Qualcomm's PMIC5 chips. PM8150{,b,l}, qrb5165-rb5 board and sm8250-mtp board device trees are extended to support thermal zones provided by this thermal monitoring block. Unlike the rest of PMIC thermal senses, these thermal zones describe particular thermistors, which differ between from board to board. Dependencies: https://git.kernel.org/pub/scm/linux/kernel/git/jic23/iio.git/log/?h=ib-iio-thermal-5.11-rc1 Changes since v11: - Drop io-channel-ranges from dts example. Changes since v10: - Rebased on top of ib-iio-thermal-5.11-rc1 immutable branch, with IIO-related patches picked up by Jonathan. - Changed thermal zone device tree nodes to use -thermal suffix following the schema. - Reordered device tree nodes to keep the alphanumeric sorting order. Changes since v9: - In patch 12 add comments to the code as requested by Daniel Lezcano. - Change copyright comment in qcom-spmi-adc-tm5.c to clearly note driver history. Changes since v8: - Simplified qcom_vadc_map_voltage_temp() code by removing ascending tables support - Simplified qcom-vadc-common volt/temp mapping code - Implement suggestions by Matthias Kaehlcke: message formatting, rewrite comments, remove unused variable initialization. Changes since v7: - Move qcom-vadc-common.h header to include/linux/iio/adc/ dir. - Use explicit sizeof(var) instead of hand-coding 1 when accessing adc-tm registers. - Remove buffer read from adc_tm5_init(). - Remove extra on-stack var from adc_tm5_get_temp(). - Minor formatting changes as suggested Daniel. Changes since v6: - Added include as noted by Jishnu Prakash. Changes since v5: - Reworked DT bindings: * Removed qcom,adc-channel, instead it is parsed from io-channels * Renamed qcom,hw-settle-time to include -us suffix - Re-added monitor enabling which got lost during refactored. Noted by Jishnu Prakash. - Use threaded IRQ handler as susggested by Jishnu. Changes since v4: - Added kernel-doc comments to ADC-TM structures - Used several sizeof(buf) instead of hand-conding register size Changes since v3: - Fix DT description to spell "thermal monitoring" instead of just TM - Fix warnings in DT example - Add EXPORT_SYMBOL_GPL(of_iio_channel_get_by_name) - Fixed whitespace chanes in qcom-vadc-common.c - Removed error message if IIO chanel get returns -EPROBE_DEFER Changes since v2: - IIO: export of_iio_channel_get_by_name() function - dt-bindings: move individual io-channels to each thermal monitoring channel rather than listing them all in device node - added fallback defaults to of_device_get_match_data calls in qcom-spmi-adc5 and qcom-spmi-adc-tm5 drivers - minor typo fixes Changes since v1: - Introduce fixp_linear_interpolate() by Craig Tatlor - Lots of syntax/whitespace changes - Cleaned up register definitions per Jonathan's suggestion - Implemented most of the suggestions from Bjorn's and Jonathan's review