From nobody Thu Apr 16 02:01:54 2026 Received: from mail-pg1-f181.google.com (mail-pg1-f181.google.com [209.85.215.181]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id ED039389452 for ; Tue, 3 Mar 2026 09:04:23 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.215.181 ARC-Seal: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1772528665; cv=none; b=oChRxE9VSrjMSSLwOMsykbncJd/H2wq4zJDvP5fssvqP2/dMiUEWj/y03F8k4u3F/qb9y9pmwv4SgjSfCOi6wVASRqnmlNQ5GXO3k6wMGZAptAUfhTfnv56/FtN2ojNd0LjNzg/Y3FGvrqdevuSkhiQym4H389mSISE0bBy0cpk= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1772528665; c=relaxed/simple; bh=HMWLi5YF4lA0CxQ8/r7Lh7BOhSJi3O7f2hDG4tWEiRE=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version; b=mfXsvYdUZlGlBVdrQbnf8ihK5a9ymmvQL4xW3GewVUI91G41zHpcP7sU5qYUJe4pFrutMNRoaj1hTc39KDKUejC+jZ1+zjdiXEg7BvPEHHYs+s48tm/Bh/2Q1SXf8Av6C3VeOvlBp5VBH0HL9sWAfqiNq0nKLeAu4Hf1YuiDA4E= ARC-Authentication-Results: i=1; smtp.subspace.kernel.org; dmarc=none (p=none dis=none) header.from=sirat.me; spf=pass smtp.mailfrom=gmail.com; arc=none smtp.client-ip=209.85.215.181 Authentication-Results: smtp.subspace.kernel.org; dmarc=none (p=none dis=none) header.from=sirat.me Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=gmail.com Received: by mail-pg1-f181.google.com with SMTP id 41be03b00d2f7-c70ef340a02so3105949a12.2 for ; Tue, 03 Mar 2026 01:04:23 -0800 (PST) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1772528663; x=1773133463; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-gg:x-gm-message-state:from :to:cc:subject:date:message-id:reply-to; bh=41EUXMaXVnuo7cK8Z5CD58qbq04Mb1iyKiHB70SkViA=; b=J6pOQYvCiDjGhnjJVS5qAQe1aywPhMNPHCK1CH0zCzeH9Xx4B657AvTlWRzgPqfCdC 17yAwxmQxFXUFJxsQYJuxpUzM9E3e+aoBNbuadrZ1a8NbwmR1GuPf2Ze5i1T/ghfOVOV DZmrW8Xb1Zpvxsx4/JJbejI9YZUOdaex3aHXTmi7lB8BvzahutvBQDr1wUi1b5lWNXZD rA+3feA9pPKVgZ1mZQimOUVRlF1qllosA1t++KwB1qQdSy2kXvX7+uGSp5Fq0N1z1L0h /NKxGnZhTJkSSKylpVE/h8OK5CtdgyUZztkPmIu0Kz1zbdbA7PeHzSQFKq65VumqeuVP TSDg== X-Forwarded-Encrypted: i=1; AJvYcCU8RnD6kGrrgy5NOnb6tZs23v3Up+ciIGAk8Jvm7UP/zgL/QdsXS8xN/4+HIF2UjyGJq16aphlbX/foFzE=@vger.kernel.org X-Gm-Message-State: AOJu0Yw7tlqeR5R1C11Ju+3Mmmk+Yw+wDdXDvXLycJYSUV6wQZF53EJa orz0ecbba+vsuwOmjkXvyXwOu6p7ZDQPzYa1nRkUeCBhpG4oM3Hy3FMm X-Gm-Gg: ATEYQzzgrdfd3L1YwPkvKXY0d82uhb/tuaz0d3roAncZ2SUryLAD2dJ2lBenz/V4nUJ tVt3EEX5GMNyEj0caaoDEdXK82j6ebGWtuBQciW23Kasq5p4yVPXLXnmwbpzd1OhO15wajqPRjI x4ZxG3/fE8G1VDzdgbkpDE1zMy1TGWhXU2ALa805Wskles2h6gSRCNHIVipiGqCTd1y2iVi+5Z0 MzMzf2tl+O0B5FqXFZFeTCRwNbjGtgMLekZKgrtKa8OYMFXrzpZmQYVeX1b1eO1cHeW7jLMd4r+ 7R78+c42hX1IV4XHdiHkeV/fueMl/02dmRjN6Qm4i/HUjFV9l3qQllb2oqSXpqhixW6AxHGyM7T 1WNJqJ8Egyh9eG+Dxz1tm1geCgos331uIwOeaZb1l8prHCBmr5pWGNHztSW0vK3BjskpTBpA+a8 +ycYp5nGFXZ39wcwW4 X-Received: by 2002:a05:6a21:110:b0:38e:676a:f31 with SMTP id adf61e73a8af0-395c3a4a18bmr12885122637.25.1772528662985; Tue, 03 Mar 2026 01:04:22 -0800 (PST) Received: from archlinux ([59.152.111.50]) by smtp.gmail.com with ESMTPSA id 98e67ed59e1d1-3599c4c0792sm1638259a91.14.2026.03.03.01.04.18 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 03 Mar 2026 01:04:22 -0800 (PST) From: Siratul Islam To: linux-iio@vger.kernel.org, devicetree@vger.kernel.org Cc: jic23@kernel.org, dlechner@baylibre.com, nuno.sa@analog.com, andy@kernel.org, robh@kernel.org, krzk+dt@kernel.org, conor+dt@kernel.org, linux-kernel@vger.kernel.org, Siratul Islam Subject: [PATCH 1/3] dt-bindings: iio: proximity: add ST VL53L1X ToF sensor Date: Tue, 3 Mar 2026 15:02:40 +0600 Message-ID: <20260303090253.42076-2-email@sirat.me> X-Mailer: git-send-email 2.53.0 In-Reply-To: <20260303090253.42076-1-email@sirat.me> References: <20260303090253.42076-1-email@sirat.me> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable Content-Type: text/plain; charset="utf-8" Add device tree binding documentation for the STMicroelectronics VL53L1X Time-of-Flight ranging sensor connected via I2C. Signed-off-by: Siratul Islam --- .../bindings/iio/proximity/st,vl53l1x.yaml | 49 +++++++++++++++++++ 1 file changed, 49 insertions(+) create mode 100644 Documentation/devicetree/bindings/iio/proximity/st,vl53= l1x.yaml diff --git a/Documentation/devicetree/bindings/iio/proximity/st,vl53l1x.yam= l b/Documentation/devicetree/bindings/iio/proximity/st,vl53l1x.yaml new file mode 100644 index 000000000000..1b14063ba344 --- /dev/null +++ b/Documentation/devicetree/bindings/iio/proximity/st,vl53l1x.yaml @@ -0,0 +1,49 @@ +# SPDX-License-Identifier: (GPL-2.0 OR BSD-2-Clause) +%YAML 1.2 +--- +$id: http://devicetree.org/schemas/iio/proximity/st,vl53l1x.yaml# +$schema: http://devicetree.org/meta-schemas/core.yaml# + +title: ST VL53L1X ToF ranging sensor + +maintainers: + - Siratul Islam + +properties: + compatible: + const: st,vl53l1x + + reg: + maxItems: 1 + + interrupts: + maxItems: 1 + + reset-gpios: + maxItems: 1 + + vdd-supply: true + +required: + - compatible + - reg + +additionalProperties: false + +examples: + - | + #include + i2c { + #address-cells =3D <1>; + #size-cells =3D <0>; + + proximity@29 { + compatible =3D "st,vl53l1x"; + reg =3D <0x29>; + interrupt-parent =3D <&gpio>; + interrupts =3D <23 IRQ_TYPE_EDGE_FALLING>; + reset-gpios =3D <&gpio 5 1>; + vdd-supply =3D <&vdd_3v3>; + }; + }; +... --=20 2.53.0 From nobody Thu Apr 16 02:01:54 2026 Received: from mail-pj1-f42.google.com (mail-pj1-f42.google.com [209.85.216.42]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id C9E107263B for ; Tue, 3 Mar 2026 09:04:28 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.216.42 ARC-Seal: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1772528670; cv=none; b=KCS/rZgSi1Re26KxPf/x0LMxy+qSlTANni6invPNOs7HWRXv9YLh6Hf8ZjqNIE6PLi9urkCvrhvETg0Cat7oDQDNXCTRf7SBW5jcLFOqz8DZ77DETBp/Rez242xRjys2zXk+4WP782mr8+ac6Ffbm125R5/cQJYMhk+S+t4Nw2Y= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1772528670; c=relaxed/simple; bh=0PJwd7XF+9xOUJ0yDG1vq71b40VT/pWF78WQPKC8jQY=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version; b=ibqljUhnfjmWhFPYKzhsEO4rVcS9LPQ0/wfe2ZUfLYA/23uzrGN4UWrfui8ik0ZGHwGpvE+abllWZEUnm3mat5Ihkwq28zH1xaZ4kcosInOzL0y8FsHSVEyKiH/v366UZ+TV8eRoqAIzhz6VWkUy/xbj59MTQbMzjti+fIWRLTU= ARC-Authentication-Results: i=1; smtp.subspace.kernel.org; dmarc=none (p=none dis=none) header.from=sirat.me; spf=pass smtp.mailfrom=gmail.com; arc=none smtp.client-ip=209.85.216.42 Authentication-Results: smtp.subspace.kernel.org; dmarc=none (p=none dis=none) header.from=sirat.me Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=gmail.com Received: by mail-pj1-f42.google.com with SMTP id 98e67ed59e1d1-3598cab697eso1184842a91.1 for ; Tue, 03 Mar 2026 01:04:28 -0800 (PST) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1772528668; x=1773133468; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-gg:x-gm-message-state:from :to:cc:subject:date:message-id:reply-to; bh=Yl+V5WYYhYV9wtbd+MR+5r+/F6CswJHJAfl/LtgJ5FE=; b=uQNZ1cq2c4uY1E3zAcb7HsmK5l3Y3skZa2FOIbWHkU8jNGz3+5PSE40kJG6Wo2FJwn ZFV5QS57FSlDfqvrdan4cZHhhEQbgfQxy/xt3PhscoNFB/ogwI/GZehxO4HMaoU7m1s4 DQYmIqV7A6w0sRoHfGpNP+KqKafDaM+4QFx9i+9o6q5IzNyCDpCLT9Q3CVNKPM8imh5W ZjT6hi4qmcaSJ0kfNHgjBdMegvMMdj7m5ZjlnCdLSWZ6ku+OubFkGRapYxdqqlFmGLZi croKZSyayiSHL9d3awJuNhCKgzcUyi4RUac2j9ED+osaEcWzQPRvjWtVNUtgcQeKZjQF ZSAg== X-Forwarded-Encrypted: i=1; AJvYcCW2u/NjbhztdYOdtvVe0CQ3WqZeNgJoezhgbwKxHGgPyBVNGGC96+ueECwK0MTnh+O7LRUSoCFDGXyCTb0=@vger.kernel.org X-Gm-Message-State: AOJu0YwS53ce8lWCJv274nRs3LVxCrCQhO0ujBsg+w5RDqcZkH7E+l5J RQSWd7NjgvxvmcxPsNCTDIsu/NQ2pFUS9nPG6w5NsfabxuYFax1FcMFq X-Gm-Gg: ATEYQzyZdTsGkJQeyyUHKtIOebSLXLwc71gxcnBmaXy+w0kN+tI5ozaHPZglbRHwjPH R/9T5qsrhROiuhMD9V49zQftxxIUPYMvTE2oSxNw/iDLoYipbBACdIxA7UdYYfRV1pFBLqb/Iwq kaHR/L+p/MhK0xust6YceiOjSR6NZE5drTkDgyBVPO2LdnDFuHvF1Gj8INNaHK/saKjYaky1Rvi I9Ug1Wpx4p2cTvqHAXPR/hAQTactiruEEf3XMc3uqFlYEfEKtv8fekDJeAP9wii/VQZiQXgmjN8 T4W2NlaU47v5uAuA5Q0/BlnsGJnTMJeA3kjKgQSKrQS1b9ahyI6wTD7Qaj7kVLtvmiOG5oZAlN7 399X7lRlTm3APqycrBQeb4ZAgLp/x288D3JcplBGxWwLk2/3TzPnCn3FGm/h6IDzVfcevCgsnH6 dhI6WSPJA8cGPja0QU X-Received: by 2002:a17:90b:48ce:b0:359:86f4:bc7a with SMTP id 98e67ed59e1d1-3599ce32c37mr1283054a91.5.1772528667842; Tue, 03 Mar 2026 01:04:27 -0800 (PST) Received: from archlinux ([59.152.111.50]) by smtp.gmail.com with ESMTPSA id 98e67ed59e1d1-3599c4c0792sm1638259a91.14.2026.03.03.01.04.23 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 03 Mar 2026 01:04:27 -0800 (PST) From: Siratul Islam To: linux-iio@vger.kernel.org, devicetree@vger.kernel.org Cc: jic23@kernel.org, dlechner@baylibre.com, nuno.sa@analog.com, andy@kernel.org, robh@kernel.org, krzk+dt@kernel.org, conor+dt@kernel.org, linux-kernel@vger.kernel.org, Siratul Islam Subject: [PATCH 2/3] iio: proximity: add driver for ST VL53L1X ToF sensor Date: Tue, 3 Mar 2026 15:02:41 +0600 Message-ID: <20260303090253.42076-3-email@sirat.me> X-Mailer: git-send-email 2.53.0 In-Reply-To: <20260303090253.42076-1-email@sirat.me> References: <20260303090253.42076-1-email@sirat.me> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable Content-Type: text/plain; charset="utf-8" Add support for the STMicroelectronics VL53L1X Time-of-Flight ranging sensor with I2C interface. Signed-off-by: Siratul Islam --- drivers/iio/proximity/Kconfig | 14 + drivers/iio/proximity/Makefile | 1 + drivers/iio/proximity/vl53l1x-i2c.c | 901 ++++++++++++++++++++++++++++ 3 files changed, 916 insertions(+) create mode 100644 drivers/iio/proximity/vl53l1x-i2c.c diff --git a/drivers/iio/proximity/Kconfig b/drivers/iio/proximity/Kconfig index 6070974c2c85..3b0fdeb03ecd 100644 --- a/drivers/iio/proximity/Kconfig +++ b/drivers/iio/proximity/Kconfig @@ -244,6 +244,20 @@ config VL53L0X_I2C To compile this driver as a module, choose M here: the module will be called vl53l0x-i2c. =20 +config VL53L1X_I2C + tristate "STMicroelectronics VL53L1X ToF ranger sensor (I2C)" + depends on I2C + select IIO_BUFFER + select IIO_TRIGGERED_BUFFER + select REGMAP_I2C + help + Say Y here to build a driver for STMicroelectronics VL53L1X + ToF ranger sensors with i2c interface. + This driver can be used to measure the distance of objects. + + To compile this driver as a module, choose M here: the + module will be called vl53l1x-i2c. + config AW96103 tristate "AW96103/AW96105 Awinic proximity sensor" select REGMAP_I2C diff --git a/drivers/iio/proximity/Makefile b/drivers/iio/proximity/Makefile index 152034d38c49..4352833dd8a4 100644 --- a/drivers/iio/proximity/Makefile +++ b/drivers/iio/proximity/Makefile @@ -23,5 +23,6 @@ obj-$(CONFIG_SX_COMMON) +=3D sx_common.o obj-$(CONFIG_SX9500) +=3D sx9500.o obj-$(CONFIG_VCNL3020) +=3D vcnl3020.o obj-$(CONFIG_VL53L0X_I2C) +=3D vl53l0x-i2c.o +obj-$(CONFIG_VL53L1X_I2C) +=3D vl53l1x-i2c.o obj-$(CONFIG_AW96103) +=3D aw96103.o =20 diff --git a/drivers/iio/proximity/vl53l1x-i2c.c b/drivers/iio/proximity/vl= 53l1x-i2c.c new file mode 100644 index 000000000000..b4122fce0de1 --- /dev/null +++ b/drivers/iio/proximity/vl53l1x-i2c.c @@ -0,0 +1,901 @@ +// SPDX-License-Identifier: GPL-2.0 OR BSD-2-Clause +/* + * Support for ST VL53L1X FlightSense ToF Ranging Sensor on a i2c bus. + * + * Copyright (C) 2026 Siratul Islam + * + * Datasheet available at + * + * + * Default 7-bit i2c slave address 0x29. + * + * The VL53L1X requires a firmware configuration blob to be loaded at boot. + * Register values for the default configuration are taken from + * ST's VL53L1X Ultra Lite Driver (STSW-IMG009). + */ + +#include +#include +#include +#include +#include +#include +#include +#include +#include + +#include +#include +#include +#include +#include + +#define VL53L1X_SOFT_RESET 0x0000 +#define VL53L1X_VHV_CONFIG__TIMEOUT_MACROP_LOOP_BOUND 0x0008 +#define VL53L1X_VHV_CONFIG__INIT 0x000B +#define VL53L1X_GPIO_HV_MUX__CTRL 0x0030 +#define VL53L1X_GPIO__TIO_HV_STATUS 0x0031 +#define VL53L1X_SYSTEM__INTERRUPT_CONFIG_GPIO 0x0046 +#define VL53L1X_PHASECAL_CONFIG__TIMEOUT_MACROP 0x004B +#define VL53L1X_RANGE_CONFIG__TIMEOUT_MACROP_A 0x005E +#define VL53L1X_RANGE_CONFIG__VCSEL_PERIOD_A 0x0060 +#define VL53L1X_RANGE_CONFIG__TIMEOUT_MACROP_B 0x0061 +#define VL53L1X_RANGE_CONFIG__VCSEL_PERIOD_B 0x0063 +#define VL53L1X_RANGE_CONFIG__VALID_PHASE_HIGH 0x0069 +#define VL53L1X_SYSTEM__INTERMEASUREMENT_PERIOD 0x006C +#define VL53L1X_SD_CONFIG__WOI_SD0 0x0078 +#define VL53L1X_SD_CONFIG__WOI_SD1 0x0079 +#define VL53L1X_SD_CONFIG__INITIAL_PHASE_SD0 0x007A +#define VL53L1X_SD_CONFIG__INITIAL_PHASE_SD1 0x007B +#define VL53L1X_SYSTEM__INTERRUPT_CLEAR 0x0086 +#define VL53L1X_SYSTEM__MODE_START 0x0087 +#define VL53L1X_RESULT__RANGE_STATUS 0x0089 +#define VL53L1X_RESULT__FINAL_CROSSTALK_CORRECTED_RANGE_MM_SD0 0x0096 +#define VL53L1X_RESULT__OSC_CALIBRATE_VAL 0x00DE +#define VL53L1X_FIRMWARE__SYSTEM_STATUS 0x00E5 +#define VL53L1X_IDENTIFICATION__MODEL_ID 0x010F + +#define VL53L1X_MODEL_ID_VAL 0xEACC + +#define VL53L1X_DEFAULT_CONFIG_ADDR 0x2D + +#define VL53L1X_MODE_START_TIMED 0x40 +#define VL53L1X_MODE_START_STOP 0x00 + +#define VL53L1X_INT_NEW_SAMPLE_READY 0x02 + +#define VL53L1X_GPIO_HV_MUX_POLARITY BIT(4) + +#define VL53L1X_VHV_LOOP_BOUND_TWO 0x09 + +#define VL53L1X_RANGE_STATUS_MASK GENMASK(4, 0) +#define VL53L1X_RANGE_STATUS_VALID 9 + +/* Inter-measurement period uses PLL divider with 1.075 oscillator correct= ion */ +#define VL53L1X_OSC_CALIBRATE_MASK GENMASK(9, 0) +#define VL53L1X_OSC_CORRECTION_FACTOR 1075 +#define VL53L1X_OSC_CORRECTION_DIVISOR 1000 + +enum vl53l1x_distance_mode { + VL53L1X_SHORT, + VL53L1X_LONG, +}; + +struct vl53l1x_data { + struct i2c_client *client; + struct regmap *regmap; + struct completion completion; + struct regulator *vdd_supply; + struct gpio_desc *reset_gpio; + struct iio_trigger *trig; + enum vl53l1x_distance_mode distance_mode; + u16 osc_calibrate_val; + u8 gpio_polarity; +}; + +static const struct regmap_config vl53l1x_regmap_config =3D { + .reg_bits =3D 16, + .val_bits =3D 8, + .reg_format_endian =3D REGMAP_ENDIAN_BIG, +}; + +static int vl53l1x_read_u16(struct vl53l1x_data *data, u16 reg, u16 *val) +{ + __be16 buf; + int ret; + + ret =3D regmap_bulk_read(data->regmap, reg, &buf, 2); + if (ret) + return ret; + + *val =3D be16_to_cpu(buf); + return 0; +} + +static int vl53l1x_write_u16(struct vl53l1x_data *data, u16 reg, u16 val) +{ + __be16 buf =3D cpu_to_be16(val); + + return regmap_bulk_write(data->regmap, reg, &buf, 2); +} + +static int vl53l1x_write_u32(struct vl53l1x_data *data, u16 reg, u32 val) +{ + __be32 buf =3D cpu_to_be32(val); + + return regmap_bulk_write(data->regmap, reg, &buf, 4); +} + +static int vl53l1x_clear_irq(struct vl53l1x_data *data) +{ + return regmap_write(data->regmap, VL53L1X_SYSTEM__INTERRUPT_CLEAR, + 0x01); +} + +static int vl53l1x_start_ranging(struct vl53l1x_data *data) +{ + int ret; + + ret =3D vl53l1x_clear_irq(data); + if (ret) + return ret; + + return regmap_write(data->regmap, VL53L1X_SYSTEM__MODE_START, + VL53L1X_MODE_START_TIMED); +} + +static int vl53l1x_stop_ranging(struct vl53l1x_data *data) +{ + return regmap_write(data->regmap, VL53L1X_SYSTEM__MODE_START, + VL53L1X_MODE_START_STOP); +} + +static int vl53l1x_data_ready(struct vl53l1x_data *data, bool *ready) +{ + unsigned int status; + int ret; + + ret =3D regmap_read(data->regmap, VL53L1X_GPIO__TIO_HV_STATUS, &status); + if (ret) + return ret; + + *ready =3D (status & 0x01) =3D=3D (!data->gpio_polarity); + return 0; +} + +/* + * Default configuration blob from ST's VL53L1X ULD (STSW-IMG009). + */ +static const u8 vl53l1x_default_config[] =3D { + 0x00, /* 0x2D */ + 0x00, /* 0x2E */ + 0x00, /* 0x2F */ + 0x01, /* 0x30 */ + 0x02, /* 0x31 */ + 0x00, /* 0x32 */ + 0x02, /* 0x33 */ + 0x08, /* 0x34 */ + 0x00, /* 0x35 */ + 0x08, /* 0x36 */ + 0x10, /* 0x37 */ + 0x01, /* 0x38 */ + 0x01, /* 0x39 */ + 0x00, /* 0x3A */ + 0x00, /* 0x3B */ + 0x00, /* 0x3C */ + 0x00, /* 0x3D */ + 0xFF, /* 0x3E */ + 0x00, /* 0x3F */ + 0x0F, /* 0x40 */ + 0x00, /* 0x41 */ + 0x00, /* 0x42 */ + 0x00, /* 0x43 */ + 0x00, /* 0x44 */ + 0x00, /* 0x45 */ + 0x20, /* 0x46 */ + 0x0B, /* 0x47 */ + 0x00, /* 0x48 */ + 0x00, /* 0x49 */ + 0x02, /* 0x4A */ + 0x0A, /* 0x4B */ + 0x21, /* 0x4C */ + 0x00, /* 0x4D */ + 0x00, /* 0x4E */ + 0x05, /* 0x4F */ + 0x00, /* 0x50 */ + 0x00, /* 0x51 */ + 0x00, /* 0x52 */ + 0x00, /* 0x53 */ + 0xC8, /* 0x54 */ + 0x00, /* 0x55 */ + 0x00, /* 0x56 */ + 0x38, /* 0x57 */ + 0xFF, /* 0x58 */ + 0x01, /* 0x59 */ + 0x00, /* 0x5A */ + 0x08, /* 0x5B */ + 0x00, /* 0x5C */ + 0x00, /* 0x5D */ + 0x01, /* 0x5E */ + 0xCC, /* 0x5F */ + 0x0F, /* 0x60 */ + 0x01, /* 0x61 */ + 0xF1, /* 0x62 */ + 0x0D, /* 0x63 */ + 0x01, /* 0x64 */ + 0x68, /* 0x65 */ + 0x00, /* 0x66 */ + 0x80, /* 0x67 */ + 0x08, /* 0x68 */ + 0xB8, /* 0x69 */ + 0x00, /* 0x6A */ + 0x00, /* 0x6B */ + 0x00, /* 0x6C */ + 0x00, /* 0x6D */ + 0x0F, /* 0x6E */ + 0x89, /* 0x6F */ + 0x00, /* 0x70 */ + 0x00, /* 0x71 */ + 0x00, /* 0x72 */ + 0x00, /* 0x73 */ + 0x00, /* 0x74 */ + 0x00, /* 0x75 */ + 0x00, /* 0x76 */ + 0x01, /* 0x77 */ + 0x0F, /* 0x78 */ + 0x0D, /* 0x79 */ + 0x0E, /* 0x7A */ + 0x0E, /* 0x7B */ + 0x00, /* 0x7C */ + 0x00, /* 0x7D */ + 0x02, /* 0x7E */ + 0xC7, /* 0x7F */ + 0xFF, /* 0x80 */ + 0x9B, /* 0x81 */ + 0x00, /* 0x82 */ + 0x00, /* 0x83 */ + 0x00, /* 0x84 */ + 0x01, /* 0x85 */ + 0x00, /* 0x86 */ + 0x00, /* 0x87 */ +}; + +static int vl53l1x_chip_init(struct vl53l1x_data *data) +{ + struct device *dev =3D &data->client->dev; + unsigned int val; + u16 model_id; + int tries =3D 200; + bool ready; + int ret; + + ret =3D regmap_write(data->regmap, VL53L1X_SOFT_RESET, 0x00); + if (ret) + return ret; + usleep_range(100, 200); + + ret =3D regmap_write(data->regmap, VL53L1X_SOFT_RESET, 0x01); + if (ret) + return ret; + usleep_range(1000, 2000); + + ret =3D regmap_read_poll_timeout(data->regmap, + VL53L1X_FIRMWARE__SYSTEM_STATUS, val, + val & BIT(0), 1000, 100000); + if (ret) { + dev_err(dev, "firmware boot timeout\n"); + return ret; + } + + ret =3D vl53l1x_read_u16(data, VL53L1X_IDENTIFICATION__MODEL_ID, + &model_id); + if (ret) + return ret; + + if (model_id !=3D VL53L1X_MODEL_ID_VAL) { + dev_err(dev, "unknown model id: 0x%04x\n", model_id); + return -ENODEV; + } + + ret =3D vl53l1x_read_u16(data, VL53L1X_RESULT__OSC_CALIBRATE_VAL, + &data->osc_calibrate_val); + if (ret) + return ret; + + ret =3D regmap_bulk_write(data->regmap, VL53L1X_DEFAULT_CONFIG_ADDR, + vl53l1x_default_config, + sizeof(vl53l1x_default_config)); + if (ret) + return ret; + + ret =3D regmap_read(data->regmap, VL53L1X_GPIO_HV_MUX__CTRL, &val); + if (ret) + return ret; + data->gpio_polarity =3D !!(val & VL53L1X_GPIO_HV_MUX_POLARITY); + + /* Initial ranging cycle for VHV calibration */ + ret =3D vl53l1x_start_ranging(data); + if (ret) + return ret; + + do { + ret =3D vl53l1x_data_ready(data, &ready); + if (ret) + return ret; + if (ready) + break; + usleep_range(1000, 5000); + } while (--tries); + + if (!tries) + return -ETIMEDOUT; + + ret =3D vl53l1x_clear_irq(data); + if (ret) + return ret; + + ret =3D vl53l1x_stop_ranging(data); + if (ret) + return ret; + + ret =3D regmap_write(data->regmap, + VL53L1X_VHV_CONFIG__TIMEOUT_MACROP_LOOP_BOUND, + VL53L1X_VHV_LOOP_BOUND_TWO); + if (ret) + return ret; + + return regmap_write(data->regmap, VL53L1X_VHV_CONFIG__INIT, 0x00); +} + +static int vl53l1x_set_distance_mode(struct vl53l1x_data *data, + enum vl53l1x_distance_mode mode) +{ + int ret; + + switch (mode) { + case VL53L1X_SHORT: + ret =3D regmap_write(data->regmap, + VL53L1X_PHASECAL_CONFIG__TIMEOUT_MACROP, + 0x14); + if (ret) + return ret; + ret =3D regmap_write(data->regmap, + VL53L1X_RANGE_CONFIG__VCSEL_PERIOD_A, 0x07); + if (ret) + return ret; + ret =3D regmap_write(data->regmap, + VL53L1X_RANGE_CONFIG__VCSEL_PERIOD_B, 0x05); + if (ret) + return ret; + ret =3D regmap_write(data->regmap, + VL53L1X_RANGE_CONFIG__VALID_PHASE_HIGH, + 0x38); + if (ret) + return ret; + ret =3D regmap_write(data->regmap, VL53L1X_SD_CONFIG__WOI_SD0, + 0x07); + if (ret) + return ret; + ret =3D regmap_write(data->regmap, VL53L1X_SD_CONFIG__WOI_SD1, + 0x05); + if (ret) + return ret; + ret =3D regmap_write(data->regmap, + VL53L1X_SD_CONFIG__INITIAL_PHASE_SD0, 6); + if (ret) + return ret; + ret =3D regmap_write(data->regmap, + VL53L1X_SD_CONFIG__INITIAL_PHASE_SD1, 6); + break; + case VL53L1X_LONG: + ret =3D regmap_write(data->regmap, + VL53L1X_PHASECAL_CONFIG__TIMEOUT_MACROP, + 0x0A); + if (ret) + return ret; + ret =3D regmap_write(data->regmap, + VL53L1X_RANGE_CONFIG__VCSEL_PERIOD_A, 0x0F); + if (ret) + return ret; + ret =3D regmap_write(data->regmap, + VL53L1X_RANGE_CONFIG__VCSEL_PERIOD_B, 0x0D); + if (ret) + return ret; + ret =3D regmap_write(data->regmap, + VL53L1X_RANGE_CONFIG__VALID_PHASE_HIGH, + 0xB8); + if (ret) + return ret; + ret =3D regmap_write(data->regmap, VL53L1X_SD_CONFIG__WOI_SD0, + 0x0F); + if (ret) + return ret; + ret =3D regmap_write(data->regmap, VL53L1X_SD_CONFIG__WOI_SD1, + 0x0D); + if (ret) + return ret; + ret =3D regmap_write(data->regmap, + VL53L1X_SD_CONFIG__INITIAL_PHASE_SD0, 14); + if (ret) + return ret; + ret =3D regmap_write(data->regmap, + VL53L1X_SD_CONFIG__INITIAL_PHASE_SD1, 14); + break; + default: + return -EINVAL; + } + + if (ret) + return ret; + + data->distance_mode =3D mode; + return 0; +} + +static int vl53l1x_set_timing_budget(struct vl53l1x_data *data, u16 budget= _ms) +{ + u16 timeout_a, timeout_b; + int ret; + + switch (data->distance_mode) { + case VL53L1X_SHORT: + switch (budget_ms) { + case 15: + timeout_a =3D 0x001D; + timeout_b =3D 0x0027; + break; + case 20: + timeout_a =3D 0x0051; + timeout_b =3D 0x006E; + break; + case 33: + timeout_a =3D 0x00D6; + timeout_b =3D 0x006E; + break; + case 50: + timeout_a =3D 0x01AE; + timeout_b =3D 0x01E8; + break; + case 100: + timeout_a =3D 0x02E1; + timeout_b =3D 0x0388; + break; + case 200: + timeout_a =3D 0x03E1; + timeout_b =3D 0x0496; + break; + case 500: + timeout_a =3D 0x0591; + timeout_b =3D 0x05C1; + break; + default: + return -EINVAL; + } + break; + case VL53L1X_LONG: + switch (budget_ms) { + case 20: + timeout_a =3D 0x001E; + timeout_b =3D 0x0022; + break; + case 33: + timeout_a =3D 0x0060; + timeout_b =3D 0x006E; + break; + case 50: + timeout_a =3D 0x00AD; + timeout_b =3D 0x00C6; + break; + case 100: + timeout_a =3D 0x01CC; + timeout_b =3D 0x01EA; + break; + case 200: + timeout_a =3D 0x02D9; + timeout_b =3D 0x02F8; + break; + case 500: + timeout_a =3D 0x048F; + timeout_b =3D 0x04A4; + break; + default: + return -EINVAL; + } + break; + default: + return -EINVAL; + } + + ret =3D vl53l1x_write_u16(data, VL53L1X_RANGE_CONFIG__TIMEOUT_MACROP_A, + timeout_a); + if (ret) + return ret; + + return vl53l1x_write_u16(data, VL53L1X_RANGE_CONFIG__TIMEOUT_MACROP_B, + timeout_b); +} + +static int vl53l1x_set_inter_measurement_ms(struct vl53l1x_data *data, + u16 period_ms) +{ + u16 clock_pll =3D data->osc_calibrate_val & VL53L1X_OSC_CALIBRATE_MASK; + u32 inter_meas; + + inter_meas =3D (u32)clock_pll * (u32)period_ms; + inter_meas =3D (inter_meas * VL53L1X_OSC_CORRECTION_FACTOR) / + VL53L1X_OSC_CORRECTION_DIVISOR; + + return vl53l1x_write_u32(data, VL53L1X_SYSTEM__INTERMEASUREMENT_PERIOD, + inter_meas); +} + +static int vl53l1x_read_proximity(struct vl53l1x_data *data, int *val) +{ + unsigned long time_left; + unsigned int range_status; + u16 distance; + int tries =3D 200; + bool ready; + int ret; + + if (data->client->irq) { + reinit_completion(&data->completion); + + ret =3D vl53l1x_clear_irq(data); + if (ret) + return ret; + + time_left =3D wait_for_completion_timeout(&data->completion, HZ); + if (time_left =3D=3D 0) + return -ETIMEDOUT; + } else { + do { + ret =3D vl53l1x_data_ready(data, &ready); + if (ret) + return ret; + + if (ready) + break; + + usleep_range(1000, 5000); + } while (--tries); + + if (!tries) + return -ETIMEDOUT; + } + + ret =3D regmap_read(data->regmap, VL53L1X_RESULT__RANGE_STATUS, + &range_status); + if (ret) + goto clear_irq; + + range_status &=3D VL53L1X_RANGE_STATUS_MASK; + + ret =3D vl53l1x_read_u16(data, + VL53L1X_RESULT__FINAL_CROSSTALK_CORRECTED_RANGE_MM_SD0, + &distance); + if (ret) + goto clear_irq; + + dev_dbg(&data->client->dev, "distance=3D%u status=3D%u\n", distance, + range_status); + + if (range_status !=3D VL53L1X_RANGE_STATUS_VALID) { + ret =3D -EIO; + goto clear_irq; + } + + *val =3D distance; + +clear_irq: + vl53l1x_clear_irq(data); + return ret; +} + +static const struct iio_chan_spec vl53l1x_channels[] =3D { + { + .type =3D IIO_DISTANCE, + .info_mask_separate =3D BIT(IIO_CHAN_INFO_RAW) | + BIT(IIO_CHAN_INFO_SCALE), + .scan_index =3D 0, + .scan_type =3D { + .sign =3D 'u', + .realbits =3D 16, + .storagebits =3D 16, + }, + }, + IIO_CHAN_SOFT_TIMESTAMP(1), +}; + +static int vl53l1x_read_raw(struct iio_dev *indio_dev, + const struct iio_chan_spec *chan, int *val, + int *val2, long mask) +{ + struct vl53l1x_data *data =3D iio_priv(indio_dev); + int ret; + + if (chan->type !=3D IIO_DISTANCE) + return -EINVAL; + + switch (mask) { + case IIO_CHAN_INFO_RAW: + if (!iio_device_claim_direct(indio_dev)) + return -EBUSY; + ret =3D vl53l1x_read_proximity(data, val); + iio_device_release_direct(indio_dev); + if (ret) + return ret; + return IIO_VAL_INT; + case IIO_CHAN_INFO_SCALE: + *val =3D 0; + *val2 =3D 1000; + return IIO_VAL_INT_PLUS_MICRO; + default: + return -EINVAL; + } +} + +static int vl53l1x_validate_trigger(struct iio_dev *indio_dev, + struct iio_trigger *trig) +{ + struct vl53l1x_data *data =3D iio_priv(indio_dev); + + return data->trig =3D=3D trig ? 0 : -EINVAL; +} + +static const struct iio_info vl53l1x_info =3D { + .read_raw =3D vl53l1x_read_raw, + .validate_trigger =3D vl53l1x_validate_trigger, +}; + +static irqreturn_t vl53l1x_trigger_handler(int irq, void *priv) +{ + struct iio_poll_func *pf =3D priv; + struct iio_dev *indio_dev =3D pf->indio_dev; + struct vl53l1x_data *data =3D iio_priv(indio_dev); + struct { + u16 distance; + aligned_s64 timestamp; + } scan =3D {}; + unsigned int range_status; + int ret; + + ret =3D regmap_read(data->regmap, VL53L1X_RESULT__RANGE_STATUS, + &range_status); + if (ret || (range_status & VL53L1X_RANGE_STATUS_MASK) !=3D + VL53L1X_RANGE_STATUS_VALID) + goto done; + + ret =3D vl53l1x_read_u16(data, + VL53L1X_RESULT__FINAL_CROSSTALK_CORRECTED_RANGE_MM_SD0, + &scan.distance); + if (ret) + goto done; + + iio_push_to_buffers_with_timestamp(indio_dev, &scan, + iio_get_time_ns(indio_dev)); + +done: + iio_trigger_notify_done(indio_dev->trig); + vl53l1x_clear_irq(data); + + return IRQ_HANDLED; +} + +static irqreturn_t vl53l1x_threaded_irq(int irq, void *priv) +{ + struct iio_dev *indio_dev =3D priv; + struct vl53l1x_data *data =3D iio_priv(indio_dev); + + if (iio_buffer_enabled(indio_dev)) + iio_trigger_poll_nested(indio_dev->trig); + else + complete(&data->completion); + + return IRQ_HANDLED; +} + +static int vl53l1x_configure_irq(struct i2c_client *client, + struct iio_dev *indio_dev) +{ + struct vl53l1x_data *data =3D iio_priv(indio_dev); + int irq_flags =3D irq_get_trigger_type(client->irq); + int ret; + + if (!irq_flags) + irq_flags =3D IRQF_TRIGGER_FALLING; + + ret =3D devm_request_threaded_irq(&client->dev, client->irq, NULL, + vl53l1x_threaded_irq, + irq_flags | IRQF_ONESHOT, + indio_dev->name, indio_dev); + if (ret) { + dev_err(&client->dev, "devm_request_irq error: %d\n", ret); + return ret; + } + + ret =3D regmap_write(data->regmap, VL53L1X_SYSTEM__INTERRUPT_CONFIG_GPIO, + VL53L1X_INT_NEW_SAMPLE_READY); + if (ret) + dev_err(&client->dev, "failed to configure IRQ: %d\n", ret); + + return ret; +} + +static int vl53l1x_buffer_postenable(struct iio_dev *indio_dev) +{ + struct vl53l1x_data *data =3D iio_priv(indio_dev); + + return vl53l1x_start_ranging(data); +} + +static int vl53l1x_buffer_postdisable(struct iio_dev *indio_dev) +{ + struct vl53l1x_data *data =3D iio_priv(indio_dev); + int ret; + + ret =3D vl53l1x_stop_ranging(data); + if (ret) + return ret; + + reinit_completion(&data->completion); + wait_for_completion_timeout(&data->completion, HZ / 10); + + return vl53l1x_clear_irq(data); +} + +static const struct iio_buffer_setup_ops vl53l1x_buffer_setup_ops =3D { + .postenable =3D &vl53l1x_buffer_postenable, + .postdisable =3D &vl53l1x_buffer_postdisable, +}; + +static const struct iio_trigger_ops vl53l1x_trigger_ops =3D { + .validate_device =3D iio_trigger_validate_own_device, +}; + +static void vl53l1x_power_off(void *_data) +{ + struct vl53l1x_data *data =3D _data; + + vl53l1x_stop_ranging(data); + gpiod_set_value_cansleep(data->reset_gpio, 1); + regulator_disable(data->vdd_supply); +} + +static int vl53l1x_power_on(struct vl53l1x_data *data) +{ + int ret; + + ret =3D regulator_enable(data->vdd_supply); + if (ret) + return ret; + + gpiod_set_value_cansleep(data->reset_gpio, 0); + usleep_range(3200, 5000); + + return 0; +} + +static int vl53l1x_probe(struct i2c_client *client) +{ + struct vl53l1x_data *data; + struct iio_dev *indio_dev; + int ret; + + indio_dev =3D devm_iio_device_alloc(&client->dev, sizeof(*data)); + if (!indio_dev) + return -ENOMEM; + + data =3D iio_priv(indio_dev); + data->client =3D client; + + if (!i2c_check_functionality(client->adapter, + I2C_FUNC_SMBUS_READ_I2C_BLOCK | + I2C_FUNC_SMBUS_BYTE_DATA)) + return -EOPNOTSUPP; + + data->regmap =3D devm_regmap_init_i2c(client, &vl53l1x_regmap_config); + if (IS_ERR(data->regmap)) + return dev_err_probe(&client->dev, PTR_ERR(data->regmap), + "regmap initialization failed\n"); + + data->vdd_supply =3D devm_regulator_get(&client->dev, "vdd"); + if (IS_ERR(data->vdd_supply)) + return dev_err_probe(&client->dev, PTR_ERR(data->vdd_supply), + "Unable to get VDD regulator\n"); + + data->reset_gpio =3D + devm_gpiod_get_optional(&client->dev, "reset", GPIOD_OUT_HIGH); + if (IS_ERR(data->reset_gpio)) + return dev_err_probe(&client->dev, PTR_ERR(data->reset_gpio), + "Cannot get reset GPIO\n"); + + ret =3D vl53l1x_power_on(data); + if (ret) + return dev_err_probe(&client->dev, ret, + "Failed to power on the chip\n"); + + ret =3D devm_add_action_or_reset(&client->dev, vl53l1x_power_off, data); + if (ret) + return ret; + + ret =3D vl53l1x_chip_init(data); + if (ret) + return ret; + + ret =3D vl53l1x_set_distance_mode(data, VL53L1X_LONG); + if (ret) + return ret; + + ret =3D vl53l1x_set_timing_budget(data, 50); + if (ret) + return ret; + + ret =3D vl53l1x_set_inter_measurement_ms(data, 50); + if (ret) + return ret; + + ret =3D vl53l1x_start_ranging(data); + if (ret) + return ret; + + indio_dev->name =3D "vl53l1x"; + indio_dev->info =3D &vl53l1x_info; + indio_dev->channels =3D vl53l1x_channels; + indio_dev->num_channels =3D ARRAY_SIZE(vl53l1x_channels); + indio_dev->modes =3D INDIO_DIRECT_MODE; + + if (client->irq) { + init_completion(&data->completion); + + data->trig =3D devm_iio_trigger_alloc(&client->dev, "%s-dev%d", + indio_dev->name, + iio_device_id(indio_dev)); + if (!data->trig) + return -ENOMEM; + + data->trig->ops =3D &vl53l1x_trigger_ops; + iio_trigger_set_drvdata(data->trig, indio_dev); + ret =3D devm_iio_trigger_register(&client->dev, data->trig); + if (ret) + return ret; + + indio_dev->trig =3D iio_trigger_get(data->trig); + + ret =3D vl53l1x_configure_irq(client, indio_dev); + if (ret) + return ret; + + ret =3D devm_iio_triggered_buffer_setup(&client->dev, + indio_dev, NULL, + &vl53l1x_trigger_handler, + &vl53l1x_buffer_setup_ops); + if (ret) + return ret; + } + + return devm_iio_device_register(&client->dev, indio_dev); +} + +static const struct i2c_device_id vl53l1x_id[] =3D { { "vl53l1x" }, { } }; +MODULE_DEVICE_TABLE(i2c, vl53l1x_id); + +static const struct of_device_id st_vl53l1x_dt_match[] =3D { + { .compatible =3D "st,vl53l1x" }, + { } +}; +MODULE_DEVICE_TABLE(of, st_vl53l1x_dt_match); + +static struct i2c_driver vl53l1x_driver =3D { + .driver =3D { + .name =3D "vl53l1x-i2c", + .of_match_table =3D st_vl53l1x_dt_match, + }, + .probe =3D vl53l1x_probe, + .id_table =3D vl53l1x_id, +}; +module_i2c_driver(vl53l1x_driver); + +MODULE_AUTHOR("Siratul Islam "); +MODULE_DESCRIPTION("ST VL53L1X ToF ranging sensor driver"); +MODULE_LICENSE("Dual BSD/GPL"); --=20 2.53.0 From nobody Thu Apr 16 02:01:54 2026 Received: from mail-pg1-f177.google.com (mail-pg1-f177.google.com [209.85.215.177]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id C024B38C2C5 for ; Tue, 3 Mar 2026 09:04:33 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.215.177 ARC-Seal: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1772528674; cv=none; b=tdD5E0rQyQ9M7ZvZmvKVsrHdTT6He+XGK1bqGdMd0pKqeBrx1SjbJJrg5l0fPghbwyoV/YAGsOSHRSQsHoqkBNInJIx+78xG3do/MXWAiwaOWHMh9TQO9bIxnYV34YDf7/jZp1ysqgpOlLaAep8zu6PjND5FUf5CwY388S96TIM= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1772528674; c=relaxed/simple; bh=+SjfXXKp3c0wc8KEdqgR9dPREkkj2LhhEMz0XvYDYRI=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version; b=IH0PSivs7W209TtkXvQDzLQw2B126E3FVUb2Y5ccCxjr+M5G3QkkMk8j5g5z1XQDaE4xGp2e7g2e5y7GFjdPymrmaI9n9foeN9vWjRN9MubldGcTPdXB8B01YfnIkkcfwr/FDqwyQgkBxguWHQcbXbX8gIgx63/Wo/YczyAgV+4= ARC-Authentication-Results: i=1; smtp.subspace.kernel.org; dmarc=none (p=none dis=none) header.from=sirat.me; spf=pass smtp.mailfrom=gmail.com; arc=none smtp.client-ip=209.85.215.177 Authentication-Results: smtp.subspace.kernel.org; dmarc=none (p=none dis=none) header.from=sirat.me Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=gmail.com Received: by mail-pg1-f177.google.com with SMTP id 41be03b00d2f7-c6e191c4b8fso1868175a12.0 for ; Tue, 03 Mar 2026 01:04:33 -0800 (PST) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1772528673; x=1773133473; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-gg:x-gm-message-state:from :to:cc:subject:date:message-id:reply-to; bh=0L3t5+5v1063qWjRief/SwRioE8DmiEkQhc2hG7+TeI=; b=RhH01bdT1G3bS/B0lEeL2SVz7r5NeYQV7Q3H81/GvzIINS7Ag0wXz9R+nrq8EjG58p kh6Oa+m5TtS0jjLEn9sNkbC+0knDNIVgEsQXfARNTsVOpuzh8fq3KVUD7CyQfDnBr/xF fFWf7l0tjr+9Cx7LUosWwnUvXx4v9RCoeHLpeWVZEmMNwtjpM0unmqj/JbQUcxbvr5Po 6/ubz8hn4v6xpHMyXkSvNj83p1vuN8AzbNKEtH319Zaq8nQkNrro1sDLUe61kPpjnsJn IYgnD8rpYzTAalP4Tcn9y2oxMCx6nt538tCOG1RkBEWmFh+mZ6tuQs7K6RzS1ZqSmNbG T18g== X-Forwarded-Encrypted: i=1; AJvYcCXFOsgs1D8aRW5Nv5nagD13sIFHK4t22VGKZ1wXpG5Bmk1C/MtPaI4cPnZAG/eZlnSiOZt1J6pSk2VeAk8=@vger.kernel.org X-Gm-Message-State: AOJu0YwBZ4xZmMRct/9NRM7zK4CFbi8U9Qzn2YlzrMoNXKmHoT/rbBvY 9ijjZZdm80Syz4Qz/g8KopbkMSKG1+kGckjF+vUjZ1wtAiHxkywTJAJZ X-Gm-Gg: ATEYQzwMj4GXEZrKfn0cK3doiEGGXgY9Hm9GF2BSwigf38yisLUL0mnz+Da++F/hDXe I/bC6nvT4NKkBaL1oAf8BKzvaWq+wlVT1cMNdafxRBubDJaVWoQ5uiEvbl+X70IF6YWtsW2pujd QsbEbVarCvp4+dIqu2O+6ze6KBFqnpLyRJp9cBjxGkzkk5NaL8VhSCEdtxwd3wOUGASPm6t/hrj MXdgNTP+MI21bt8Pz0GsIvcotFvKs2ODKEjXFKc9oCiJ2sN7keeaKWGp6BV2DQwCH+HAhWBQ6No eMP3Vw+q6JdDDVLYQUwXtHt2fSx92QWtjFki0cU936Ngnaflrhes1QCMAOw5wjL1oj1JKmRu4c4 Mx6Cew8RfWXGVCLRY1hrB+qNPaIE+9sVDGdUgzzqAwqDKzhJkdQXwfsPiymT2zeXHbKxtFJp125 xaI0EGcrAwvK/lQOuQ X-Received: by 2002:a17:90a:d40b:b0:359:8f4b:6ed5 with SMTP id 98e67ed59e1d1-3598f4b6fecmr4980226a91.15.1772528672828; Tue, 03 Mar 2026 01:04:32 -0800 (PST) Received: from archlinux ([59.152.111.50]) by smtp.gmail.com with ESMTPSA id 98e67ed59e1d1-3599c4c0792sm1638259a91.14.2026.03.03.01.04.28 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 03 Mar 2026 01:04:32 -0800 (PST) From: Siratul Islam To: linux-iio@vger.kernel.org, devicetree@vger.kernel.org Cc: jic23@kernel.org, dlechner@baylibre.com, nuno.sa@analog.com, andy@kernel.org, robh@kernel.org, krzk+dt@kernel.org, conor+dt@kernel.org, linux-kernel@vger.kernel.org, Siratul Islam Subject: [PATCH 3/3] MAINTAINERS: add entry for ST VL53L1X ToF sensor driver Date: Tue, 3 Mar 2026 15:02:42 +0600 Message-ID: <20260303090253.42076-4-email@sirat.me> X-Mailer: git-send-email 2.53.0 In-Reply-To: <20260303090253.42076-1-email@sirat.me> References: <20260303090253.42076-1-email@sirat.me> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable Content-Type: text/plain; charset="utf-8" Add maintainer entry for the STMicroelectronics VL53L1X Time-of-Flight ranging sensor IIO driver. Signed-off-by: Siratul Islam --- MAINTAINERS | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/MAINTAINERS b/MAINTAINERS index 61bf550fd37c..cb8ee607fda1 100644 --- a/MAINTAINERS +++ b/MAINTAINERS @@ -25093,6 +25093,13 @@ S: Maintained F: Documentation/devicetree/bindings/iio/proximity/st,vl53l0x.yaml F: drivers/iio/proximity/vl53l0x-i2c.c =20 +ST VL53L1X ToF RANGER(I2C) IIO DRIVER +M: Siratul Islam +L: linux-iio@vger.kernel.org +S: Maintained +F: Documentation/devicetree/bindings/iio/proximity/st,vl53l1x.yaml +F: drivers/iio/proximity/vl53l1x-i2c.c + STABLE BRANCH M: Greg Kroah-Hartman M: Sasha Levin --=20 2.53.0