From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from mail-oo1-f47.google.com (mail-oo1-f47.google.com [209.85.161.47]) (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 D58DB3290D1 for ; Wed, 24 Jun 2026 18:26:16 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.161.47 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1782325579; cv=none; b=jYsaRXw9bmStJLVoGgkbW5h6lx9EUwsu43djC4Wjs71K4gFKZDXNxlA4rhQAzY8GXZqsnzJbZDqdg+jKs7vH758i4N+FBqsuwGj0MwRq1aiCXDauAH2wFEKER2Fri6OxzvngPWe8FUBVMW2nDzLW0TmIREISAHrTjvXsjU08f9s= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1782325579; c=relaxed/simple; bh=LaBE5//kvQ8A7+cKYW1tyQKhqQDhLhJidn/QW8U+rMY=; h=From:To:Cc:Subject:Date:Message-ID:MIME-Version; b=JF8Fl0geJe6JvFWA71CndWORJNm2Ph/BgswYIpV26cmg9tiUeCcpiBbg5yCwW8KruaXPuNnflrfdSD/3wD7CTeUgEFc+zGP9UeveJVT0D6IAIk+gPaMS41kFvVMEIOPxdI1Wid0fK/vG4pQ+WDAsssjnQ2l2lplBOb5KDSJ3OqU= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com; spf=pass smtp.mailfrom=gmail.com; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b=jiT7hb93; arc=none smtp.client-ip=209.85.161.47 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=gmail.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b="jiT7hb93" Received: by mail-oo1-f47.google.com with SMTP id 006d021491bc7-69eb8b6bea8so666006eaf.3 for ; Wed, 24 Jun 2026 11:26:16 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20251104; t=1782325576; x=1782930376; darn=vger.kernel.org; h=content-transfer-encoding:mime-version:message-id:date:subject:cc :to:from:from:to:cc:subject:date:message-id:reply-to; bh=5ubuUGTdjA4vxfirxJl+30fGV5ImF8lm+kRdd89Qiyc=; b=jiT7hb93OYcbjNdVmTAMMZoXVdl9/WvxQ7AXzaQs8EdpB8LEUr25REMdIaV4OgODH9 djNj4wZOmO2/pCcwlsbHGVLWAl4FIE7mhmvqaQN0/bPUgbVG7XhDGH6To8H3OzhSiEYK wAoY9RCe1Z+SFCr+bbUAKM4TpV3a2yFG9s5n1NlBdFdSWKxbN+TogBuZIETz9lvQja+B SZppBGKglAPotB6gjsk562vh2A3h0awVhOn/HhqSUoszj8n/oM4MAzBZLURL8KLwDl3L jvEfDal7CESA5DIE42zhoQpxwRzcxHpU3P37BOVrnWMPl5VJ7zUxTmiWcrRHOttN0p9w iBLA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20251104; t=1782325576; x=1782930376; h=content-transfer-encoding:mime-version:message-id:date:subject:cc :to:from:x-gm-gg:x-gm-message-state:from:to:cc:subject:date :message-id:reply-to; bh=5ubuUGTdjA4vxfirxJl+30fGV5ImF8lm+kRdd89Qiyc=; b=ll7H9ND4hu+/NHfJ7/MTz5z29pF5ST3u5msbBqP1CqgyLjq9btd4k0wIpJer3SSryM LQEdHLVyomgEtj9db50BdRsajA0eWnmG93pWq0LuHESMBvyUysTkkJMf16vpYTa/RTm1 APtaaB4OzhDPn1cezxcvY+O/5i5m3aQv/eJz+aSQAus9sStkWpbVZFKyfwuSaxIaXV55 14FFTAIOFG4L40UE1GIH+Ggj+g9cQMTk8+Fb05saIcUIGjL5IWg198yvga4bJU5lgMub vrWf8wu6joEq+PdZE5M9D2g1osSt6+5KKRVu08n1ZqviKhP6m60irrMWRIwVEwY+58+Y lSqg== X-Forwarded-Encrypted: i=1; AFNElJ+OKi93y+UF5oIwRjAN2EBxsDYOj0EIPmIZgJsc9d142TJNclE+0PzI6lNLw75C97VBIoO2pkiUtC9k@vger.kernel.org X-Gm-Message-State: AOJu0YxB12jBqG0uunOxRjxJH2GXhwAhWjJdG4e9xhbOH7qeZNq6lxw3 wCWPnriBly8rJxzx2iVARz1hSQP+62212ie618L5CWjBSFxmzX6vMnQW X-Gm-Gg: AfdE7cnYtp2LhMlPWiYh86SIDKSh3FlueL26C2neLqqO95n22vy5Wd4+NFN0ZJv532g UBzx7NThcrTtrdZENCcqAzpJxzJVvB/CWCE44B0dfVPurYL4wSR028KMux4Cym1/X5mx6xjHxUd mbvYKvNNCKBQmXn76vb1dkfG0c+gKpZZf0zxv2rY0CeyFxWwuTHskK7rWo2rJFGpuwN7ffFIZze Y8gmJV95ugWgRH1WBSbTTlFlyi8yktnAgRSPA4KVKzabFTx6hvBn+q0OC3+BKQgFEAzj+zP2AAt zkop37qin5vCwiNYcgP2iKi75FOuQnQldLMD9/S2UYlRsrwPHuV5cHQ48OBALYYNT2RJ4LjX5dI JUtT/7b/5Tx4trTMwIdYf2tySRSGdXnqH6ao0QhvR9QjieDnwKJjoD/w/Re6CoQUR/DOHU/5Wxh CWlgrzW0yA1mM= X-Received: by 2002:a05:6820:810:b0:6a0:e6f3:bc72 with SMTP id 006d021491bc7-6a122ead741mr3237134eaf.8.1782325575628; Wed, 24 Jun 2026 11:26:15 -0700 (PDT) Received: from localhost.localdomain ([2600:1700:fb0:1bc0::54]) by smtp.gmail.com with ESMTPSA id 586e51a60fabf-4472f042517sm9968060fac.13.2026.06.24.11.26.14 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 24 Jun 2026 11:26:15 -0700 (PDT) From: Chris Morgan To: linux-iio@vger.kernel.org Cc: andy@kernel.org, nuno.sa@analog.com, dlechner@baylibre.com, jic23@kernel.org, jean-baptiste.maneyrol@tdk.com, linux-rockchip@lists.infradead.org, devicetree@vger.kernel.org, heiko@sntech.de, conor+dt@kernel.org, krzk+dt@kernel.org, robh@kernel.org, andriy.shevchenko@intel.com, Chris Morgan Subject: [PATCH V14 0/9] Add Invensense ICM42607 Date: Wed, 24 Jun 2026 13:23:39 -0500 Message-ID: <20260624182350.50467-1-macroalpha82@gmail.com> X-Mailer: git-send-email 2.43.0 Precedence: bulk X-Mailing-List: devicetree@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Transfer-Encoding: 8bit From: Chris Morgan Add support for the ICM42607 IMU. This sensor shares the same functionality but a different register layout with the existing ICM42600. This driver should work with the ICM42607 and ICM42607P over both I2C and SPI, however only the ICM42607P over I2C could be tested. Changes Since V1: - Instead of creating a new driver, merged with the existing inv_icm42600 driver. This necessitated adding some code to the existing driver to permit using a different register layout for the same functionality. - Split changes up a bit more to decrease the size of the individual patches. Note that patch 0004 is still pretty hefty; if I need to split further I may need to create some temporary stub functions. - Used guard() and PM_RUNTIME_ACQUIRE_AUTOSUSPEND() on the new functions per Jonathan's recommendations. Changes Since V2: - Went back to using a new driver on advice from Invensense engineer. - Further split changes up into smaller chunks of functionality. Note still that the largest patch is approximately 900 lines, and that while the driver compiles cleanly at each commit it is not able to drive the hardware until the commit that adds the Interrupt (as it also adds the Makefile). - Change the error to a warning when the devicetree binding does not match the hardware ID. - Dropped the ack on the devicetree bindings, as I am creating a new file (for a new driver) instead of modifying the existing one. Changes Since V3: - Numerous small fixes (too many to list here). Thank you to everyone who provided feedback. - Split power management additions into an additional commit to break things up further. - Consolidated devicetree documentation in existing invensense,icm42600.yaml file. - Removed most of the FIELD_PREP from header file to c files to make code easier to read. - Changed scale values to 2D arrays for Gyro and Accelerometer. - Removed IIO_CHAN_INFO_CALIBBIAS attribute. Changes Since V4: - Additional numerous small fixes, thank you again for all the feedback. - Dropped power control API and instead run device in low noise mode. - Split devicetree bindings into two distinct changes. - Reordered adding of enums and structs to main header file so that they are only brought in when needed. - Stopped using enum for driver data and instead am using pointer to device specific driver data. Changes Since V5: - Corrected use of "dev_warn_probe" to just "dev_warn". - Fixed some return scenarios which would unconditionally return 0 when an error was present. - Corrected use of max() to min() for bounds checking. max() was incorrect. - Fixed using "st->conf.accel.odr" in the gyroscope function. It should have been "st->conf.gyro.odr" which it now is. - Additional small fixes suggested by "sashiko.dev". - Added a regmap cache. I used the datasheet to try and determine which registers might change without explicit writes. Changes Since V6: - Corrected additional errors identified by sashiko.dev, mostly fixing potential deadlocks, missing calls for pm runtime, and potential overflow issues. Changes Since V7: - Dropped Wake on Movement patches, since some of the functionality was only available for a device on which I cannot test. - Dropped support for SPI 3-Wire mode, since it complicated the bus setup (and I lack the hardware to test such features anyway). - Fixed a few additional bugs identified by sashiko.dev bot. Changes Since V8: - Added back IRQ dropped accidentally when dropping wake on movement patches. - Dropped "Reviewed-By" tag on patch 2 because of substantial changes made to devicetree binding documentation. - Additional small fixes as suggested. Changes Since V9: - Removed interrupts (and buffers) from the driver. I previously was unable to detect deadlocks because it turns out my IRQ was not even wired correctly in my device. - Updated devicetree binding commits to make interrupts optional for users of the icm42607 driver. Changes Since V10: - Explicitly specified enum values in header file. - Removed additional dead code for buffer handling. - Cleaned up headers. - Added additional locks as requested by sashiko.dev bot. Changes Since V11: - Since driver has shrunk in size considerably, moved i2c bits into first code commit. This ensures that the very first commit with code can now be compiled. The commit after that adds SPI support as it was in the previous versions. - Used pahole to optimize inv_icm42607_state. Reordering elements reduced size in memory from 384 bytes to 256 bytes. - Added a map of all readable registers and all writeable registers according to the datasheet. - Added back some missing headers pointed out by the maintainers. - Added FIELD_PREP in a few more places to make the code more obvious on what it's doing. - Added a comment to the power management code to note that temperature sensor being enabled doesn't matter as the clocks are off by default when the gyro and accel channels are off. - Removed iio_device_claim_direct() calls since it was no longer needed. - Fixed shared_by_all attributes for temperature sensor. - Additional miscellanous fixes as requested. Changes Since V12: - Removed aligned buffer from inv_icm42607_state struct as we do not currently have the need for it. - Corrected the order of the odr values in the accel and gyro files as the values were out of order (the place in the array corresponds to the register value). - Stopped setting the clock value depending upon the temp config. The datasheet advised to keep using the default value. - Corrected logic when changing between states. We only need to pause when a sensor changes from off to an on state or when the gyro changes from an on state to off. - Added missing includes for several files. Changes Since V13: - Refactored inv_icm42607_set_accel_conf() and inv_icm42607_set_gyro_conf() into a single function. - Refactored inv_icm42607_accel_read_sensor() and inv_icm42607_gyro_read_sensor() into a single function. - Merged inv_icm42607_set_temp_conf() into initial init function since it only really needs to be called once. - Saved adding temp sensor for last and updated inv_icm42607_temp_read() to either confirm other sensors are already enabled or enable the accelerometer so it can get a reading. - Updated inv_icm42607_set_pwr_mgmt0() so that it does not update the sensor mode and forcibly keep the sensor enabled. - Added inv_icm42607_temp_filter_bw enums since it appears to use different values than the accel or gyro sensor. - Set the temp startup time from 77ms to 77us, as I previously misread the datasheet. - Additional minor fixes. Chris Morgan (9): dt-bindings: iio: imu: icm42600: Add mount-matrix dt-bindings: iio: imu: icm42600: Add icm42607 iio: imu: inv_icm42607: Add inv_icm42607 Core Driver iio: imu: inv_icm42607: Add SPI For icm42607 iio: imu: inv_icm42607: Add PM support for icm42607 iio: imu: inv_icm42607: Add Accelerometer for icm42607 iio: imu: inv_icm42607: Add Gyroscope to icm42607 iio: imu: inv_icm42607: Add Temp Support in icm42607 arm64: dts: rockchip: Add icm42607p IMU for RG-DS .../bindings/iio/imu/invensense,icm42600.yaml | 20 +- .../dts/rockchip/rk3568-anbernic-rg-ds.dts | 8 +- drivers/iio/imu/Kconfig | 1 + drivers/iio/imu/Makefile | 1 + drivers/iio/imu/inv_icm42607/Kconfig | 30 + drivers/iio/imu/inv_icm42607/Makefile | 13 + drivers/iio/imu/inv_icm42607/inv_icm42607.h | 423 ++++++++++++ .../iio/imu/inv_icm42607/inv_icm42607_accel.c | 317 +++++++++ .../iio/imu/inv_icm42607/inv_icm42607_core.c | 606 ++++++++++++++++++ .../iio/imu/inv_icm42607/inv_icm42607_gyro.c | 313 +++++++++ .../iio/imu/inv_icm42607/inv_icm42607_i2c.c | 98 +++ .../iio/imu/inv_icm42607/inv_icm42607_spi.c | 108 ++++ .../iio/imu/inv_icm42607/inv_icm42607_temp.c | 99 +++ .../iio/imu/inv_icm42607/inv_icm42607_temp.h | 37 ++ 14 files changed, 2072 insertions(+), 2 deletions(-) create mode 100644 drivers/iio/imu/inv_icm42607/Kconfig create mode 100644 drivers/iio/imu/inv_icm42607/Makefile create mode 100644 drivers/iio/imu/inv_icm42607/inv_icm42607.h create mode 100644 drivers/iio/imu/inv_icm42607/inv_icm42607_accel.c create mode 100644 drivers/iio/imu/inv_icm42607/inv_icm42607_core.c create mode 100644 drivers/iio/imu/inv_icm42607/inv_icm42607_gyro.c create mode 100644 drivers/iio/imu/inv_icm42607/inv_icm42607_i2c.c create mode 100644 drivers/iio/imu/inv_icm42607/inv_icm42607_spi.c create mode 100644 drivers/iio/imu/inv_icm42607/inv_icm42607_temp.c create mode 100644 drivers/iio/imu/inv_icm42607/inv_icm42607_temp.h -- 2.43.0