Received: by 2002:a05:6902:102b:0:0:0:0 with SMTP id x11csp2224409ybt; Sun, 21 Jun 2020 13:02:34 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzzOu2gWXTH3vtgBSCOxLE/+ddt5n5G92BTpPpItmR5vpTtymIqmH0+fmK+XNTPWqCaW7NL X-Received: by 2002:a17:906:18e1:: with SMTP id e1mr7196654ejf.200.1592769754025; Sun, 21 Jun 2020 13:02:34 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1592769754; cv=none; d=google.com; s=arc-20160816; b=zYgNeK+tjs+p/Zt/gFmbsIHSe25Sxiwtxuu+H1FtoqTyQ+Gh9E0KPTJKP9bq3inSTk HIUnrRVbxUMeO52k2eI/TSaJyCSEm5X7qtz8acLXjTMCVUWsSi+pshxAqvrMJvgV2yGZ Ij7ClM3KjYoBYd54wBaGRvp0Q3eQQ/7nore48ysoySK9x/bgaJuhykbJF9xetmhsTuzv 2QClkoYLPaqI6i++xaptucWdtHEsGpAYEnYdCh74nkFksDeep+0pSVIppDCXISAyovVY xNcymZ8ZMEbD2uSjLIEt9qgT4jpb2QKIi2Qo+zJ044dzRk8WqPtXR/HgcunphdUeDa86 lgfA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from; bh=bGG2fDpv/eZW6z9BWXJyDBxyMNqiSvKqlkAkqX28N8c=; b=AzU5DTPhlBz6PPU3zXcAK/qhN1g6gQw7W2xLw9aWbNokoOba5OZ7SYfetdOpZKYMGi 2xxWMJOMYkuj7eXMddDvma9GHl08rEQCsUzd2ifZblefmmsRs82Js1qlpfrNWS2GbZN2 IVBaTbrAQb/nGbKWAr84RF05gSc8hdUk0KcCzlQ39OrKalmtX2IfYDoXCcNZ3bNhhupF 5daiA0naoNCHr2Sn18yDCMqpGSvb3e7icElKh8aD8/JpeFkS0ry3zXon7yoHW9l1lYWa jdEbcEHa07gnzzXW8+cHhuVH4z9mAMblOlRm5QLRQP3mNpinYXF0pwqFQc3Kq1DqRguD ph0Q== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id o2si8545820edd.477.2020.06.21.13.02.10; Sun, 21 Jun 2020 13:02:34 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1730611AbgFUUAY (ORCPT + 99 others); Sun, 21 Jun 2020 16:00:24 -0400 Received: from smtpout1.mo803.mail-out.ovh.net ([79.137.123.219]:56129 "EHLO smtpout1.mo803.mail-out.ovh.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1730565AbgFUUAY (ORCPT ); Sun, 21 Jun 2020 16:00:24 -0400 Received: from pro2.mail.ovh.net (unknown [10.109.138.102]) by mo803.mail-out.ovh.net (Postfix) with ESMTPS id 435715852A7F; Sun, 21 Jun 2020 22:00:21 +0200 (CEST) Received: from arch.lan (89.70.180.118) by DAG2EX1.emp2.local (172.16.2.11) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.1979.3; Sun, 21 Jun 2020 22:00:20 +0200 From: Tomasz Duszynski To: CC: , , , , Tomasz Duszynski Subject: [PATCH v6 0/4] Add support for SCD30 sensor Date: Sun, 21 Jun 2020 21:56:57 +0200 Message-ID: <20200621195701.97227-1-tomasz.duszynski@octakon.com> X-Mailer: git-send-email 2.27.0 MIME-Version: 1.0 Content-Transfer-Encoding: 7BIT Content-Type: text/plain; charset=US-ASCII X-Originating-IP: [89.70.180.118] X-ClientProxiedBy: CAS1.emp2.local (172.16.1.1) To DAG2EX1.emp2.local (172.16.2.11) X-Ovh-Tracer-Id: 13570753053933198359 X-VR-SPAMSTATE: OK X-VR-SPAMSCORE: 0 X-VR-SPAMCAUSE: gggruggvucftvghtrhhoucdtuddrgeduhedrudektddgudegiecutefuodetggdotefrodftvfcurfhrohhfihhlvgemucfqggfjpdevjffgvefmvefgnecuuegrihhlohhuthemucehtddtnecunecujfgurhephffvufffkffoggfgtghisehtkeertdertddtnecuhfhrohhmpefvohhmrghsiicuffhushiihihnshhkihcuoehtohhmrghsiidrughushiihihnshhkihesohgtthgrkhhonhdrtghomheqnecuggftrfgrthhtvghrnhephedtgefgkeduvdekheeggefghffhteekleetvdekvddtveeutdetueefueehieetnecukfhppedtrddtrddtrddtpdekledrjedtrddukedtrdduudeknecuvehluhhsthgvrhfuihiivgeptdenucfrrghrrghmpehmohguvgepshhmthhpqdhouhhtpdhhvghlohepphhrohdvrdhmrghilhdrohhvhhdrnhgvthdpihhnvghtpedtrddtrddtrddtpdhmrghilhhfrhhomhepthhomhgrshiirdguuhhsiiihnhhskhhisehotghtrghkohhnrdgtohhmpdhrtghpthhtohepphhmvggvrhifsehpmhgvvghrfidrnhgvth Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Following series adds support for Sensirion SCD30 sensor module capable of measuring carbon dioxide, temperature and relative humidity. CO2 measurements base on NDIR principle while temperature and relative humidity are measured by the on board SHT31. As for sensor communication, both I2C and serial interfaces are supported. v6: * fix warnings produced by C=2 build option * fix 0-day warning 'Clarify calculation precedence for '&' and '?'' v5: * set pressure calibration via output channel * use kstrtobool() to read value into _enabled attribute * drop explicit parent asignment as the default one is good enough (seems 'iio: core: pass parent device as parameter during allocation' series was accepted) v4: * improve formatting * improve error handling readability * fix message validity check on serial write v3: * simplify code by scaling temperature & humidity in _read_meas() * update realbits in scan types * s/adjecent/adjacent * drop IIO_CHAN_INFO_RAW from _write_raw_get_fmt because there's no raw output channel * rework locking in _read_raw * fix endianess problem on BE machine * align timestamp properly before pushing to buffers * explain why interrupt gets disabled after registration * add trigger validation * drop SCALE for temperature and humidity channel as they are processed * register action which stops measuring after starting measurements * spit generic calibration attr into two doing specific things * add comment explaining why priv in struct scd30_state is for * rename node in binding example to co2-sensor v2: * move asm/byteorder.h towards the bottom of include list * make channel address names in enum more specific * add postfixes to defines and extra comments * drop unneeded i2c include from scd30 header * break generic command sending function into specialized options * expose automatic calibration and forced calibration via the same attr * use SAMP_FREQ to set frequency instead of meas_interval attr * use CALISCALE to set pressure compensation instead of pressure_comp attr * use CALIBBIAS to set temperature offset instead of temp_offset attr * fix order in MAINTAINERS * drop attribute allowing one to reset sensor * as we have dt probing drop board file based probing (i2c_device_id) * merge patches touching related files * use fwnode API to retrieve interrupt from dt * fix interrupt-parent spelling * change binding license * drop supply from required property Tomasz Duszynski (4): iio: chemical: scd30: add core driver iio: chemical: scd30: add I2C interface driver iio: chemical: scd30: add serial interface driver dt-bindings: iio: scd30: add device binding file Documentation/ABI/testing/sysfs-bus-iio-scd30 | 34 + .../iio/chemical/sensirion,scd30.yaml | 68 ++ MAINTAINERS | 9 + drivers/iio/chemical/Kconfig | 33 + drivers/iio/chemical/Makefile | 3 + drivers/iio/chemical/scd30.h | 78 ++ drivers/iio/chemical/scd30_core.c | 771 ++++++++++++++++++ drivers/iio/chemical/scd30_i2c.c | 139 ++++ drivers/iio/chemical/scd30_serial.c | 263 ++++++ 9 files changed, 1398 insertions(+) create mode 100644 Documentation/ABI/testing/sysfs-bus-iio-scd30 create mode 100644 Documentation/devicetree/bindings/iio/chemical/sensirion,scd30.yaml create mode 100644 drivers/iio/chemical/scd30.h create mode 100644 drivers/iio/chemical/scd30_core.c create mode 100644 drivers/iio/chemical/scd30_i2c.c create mode 100644 drivers/iio/chemical/scd30_serial.c -- 2.27.0