From patchwork Wed May 25 13:08:23 2022 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: LI Qingwu X-Patchwork-Id: 576082 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by smtp.lore.kernel.org (Postfix) with ESMTP id 97444C433F5 for ; Wed, 25 May 2022 13:08:47 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229843AbiEYNIq (ORCPT ); Wed, 25 May 2022 09:08:46 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:45834 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231523AbiEYNIp (ORCPT ); Wed, 25 May 2022 09:08:45 -0400 Received: from EUR04-HE1-obe.outbound.protection.outlook.com (mail-eopbgr70098.outbound.protection.outlook.com [40.107.7.98]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 718C9A2062; Wed, 25 May 2022 06:08:42 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=m0S+Oa6KVetd7DRLa+vMfI5AZrnZHcSg4cQGlMllcjuEizUMIpDyejn+7fgMZyR/Y2xbfbTB1K9iuS30V9y91S7Hzr9ONM9wShMxV+vmSqNEtdfsftWj1ROmirKJgL9Fxz/tf3frHim4fKsERnIpNdD5AgkzJX4285IRwN4HQq4V06p8Kf5sZSgZ01okMpP1rxHtcuAGExDh2kmSnYeDOBVqBT3ZNGu7TuTKuiry1WD7zWkfjFi8A/9OZUMqp5+5Tn4A1HAQ5yTkfPmtkXrTnqCm6mjGuUKGVUFVbVEjevULpAtOqIc9vg+KF+SRWuqar6rzUCXaI7T8CWm7dadHDQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-AntiSpam-MessageData-ChunkCount:X-MS-Exchange-AntiSpam-MessageData-0:X-MS-Exchange-AntiSpam-MessageData-1; bh=y9YoyUl4Jwgq9M/1fNZmhEW5S01RQSaiaLfksrOzzJo=; b=MJTW1GnkDfj8vh/ggySOW/NadOWy6gtGB5y05nG6bMTCUp/818BpeRf+H8TsyyLUQ9MFtRxGa8uAwbfrKUR9TT5JpbvTcBkmnzgubGW/H4L8sZvJMwUlndL3JvqrmvjOVFpYw13THj50uk8zdmHivRtJUfm+pAACfPI2bydOhlnW7QZoVeqfWTdPqUzlTX9HS1v/qqMmnHFGxHa1fWRi1SFvZx7Wqpeps3hcpknU3dBa22TnwoNXjK4N8+35tgtx+ihcVd34rwQwdBakoPuiTdvVusZhbmrOZSbPfnmqDWUH5BcBxvl3iSkZqFzG5cXHCVp6qrjPln3uEHSWj56dRw== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass (sender ip is 193.8.40.94) smtp.rcpttodomain=kernel.org smtp.mailfrom=leica-geosystems.com.cn; dmarc=pass (p=quarantine sp=quarantine pct=100) action=none header.from=leica-geosystems.com.cn; dkim=none (message not signed); arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=leica-geosystems.com.cn; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=y9YoyUl4Jwgq9M/1fNZmhEW5S01RQSaiaLfksrOzzJo=; b=KwE+BzCQtbVmY5ei48E3392Sk89IfXI2D7SX+9CnrQ7nqwLVjlxYmOssVa4wpQb3Pq6bkRvVKcMrx2YkF1jvcZAlFynSRflUdk+5SS0H0RjEda9gnFnppm5/4JwTz9sqWgt4Xw+TpjFue+0AqqWxB+8/rrmHJZ7PXiBhUsIE97Y= Received: from AS9PR07CA0017.eurprd07.prod.outlook.com (2603:10a6:20b:46c::13) by AM9PR06MB8052.eurprd06.prod.outlook.com (2603:10a6:20b:3a0::12) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.5273.17; Wed, 25 May 2022 13:08:40 +0000 Received: from HE1EUR02FT051.eop-EUR02.prod.protection.outlook.com (2603:10a6:20b:46c:cafe::38) by AS9PR07CA0017.outlook.office365.com (2603:10a6:20b:46c::13) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.5314.5 via Frontend Transport; Wed, 25 May 2022 13:08:39 +0000 X-MS-Exchange-Authentication-Results: spf=pass (sender IP is 193.8.40.94) smtp.mailfrom=leica-geosystems.com.cn; dkim=none (message not signed) header.d=none;dmarc=pass action=none header.from=leica-geosystems.com.cn; Received-SPF: Pass (protection.outlook.com: domain of leica-geosystems.com.cn designates 193.8.40.94 as permitted sender) receiver=protection.outlook.com; client-ip=193.8.40.94; helo=aherlnxbspsrv01.lgs-net.com; pr=C Received: from aherlnxbspsrv01.lgs-net.com (193.8.40.94) by HE1EUR02FT051.mail.protection.outlook.com (10.152.11.7) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.5293.13 via Frontend Transport; Wed, 25 May 2022 13:08:39 +0000 From: LI Qingwu To: jic23@kernel.org, lars@metafoo.de, mchehab+huawei@kernel.org, ardeleanalex@gmail.com, linux-iio@vger.kernel.org, linux-kernel@vger.kernel.org, Qing-wu.Li@leica-geosystems.com.cn, robh+dt@kernel.org, mike.looijmans@topic.nl, devicetree@vger.kernel.org Cc: thomas.haemmerle@leica-geosystems.com Subject: [PATCH V4 1/6] iio: accel: bmi088: Modified the scale calculate Date: Wed, 25 May 2022 13:08:23 +0000 Message-Id: <20220525130828.2394919-2-Qing-wu.Li@leica-geosystems.com.cn> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20220525130828.2394919-1-Qing-wu.Li@leica-geosystems.com.cn> References: <20220525130828.2394919-1-Qing-wu.Li@leica-geosystems.com.cn> MIME-Version: 1.0 X-EOPAttributedMessage: 0 X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id: 0c4aaac0-2aaf-47a9-4181-08da3e4fafb8 X-MS-TrafficTypeDiagnostic: AM9PR06MB8052:EE_ X-Microsoft-Antispam-PRVS: X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: 870euEi/ecb5RwL52R/o2k5cxIfySJESZa5uGH3KTW8aATKfulDmv/B5vIuuKsZzb1WqkrGlLPGs5ftaRo6TVvVagiJsrCELfC2pf1xFjMONHiblEgQtXkaZCxykoyTXC03IKDJ836tR3jAnabeKzDsX2haN94yFIH6kPEo0QCYnQI+EmVH3NIqRlxFflqhAK27PVkhmPchDt9WRJP6fuPbIyt79xGSjHHaa39lw3EjhAvWwIsKHHkMn8eulZVNjDi9r9eWWNYWvGlpl2XR6dNssmmSb02kdlzYHVZ43KFm8SwYDRm5XhKzQyNHKA0VJlXFADffPAT0Jx//I/+L/piB2Yb2nBUhyIb+dZ/WAaKFrpNNvjg9HxO2ZhZcBXE+UbMyeOl5LdYiJFF/lgjVn9+1YEDUCHyfSbbzI7us23Krh2UvlJKQcRlt0bMDCuxINIAKnkUPSubnOxbx0QGqw2OAlKsmAvKoZsgdkT8TMiGojKpsDEP7K5CcRt7AND0P0Pbz5ApGqfpo8uGuAhb3Mrph0Zmnc0S4FyfyLVp7CIHJCk5gNKKdo3V2Ax+DS0673oKJev5S01GHpamfwPtRJHuDulfoc4/GVTKmEVwlgGKamou+EqcqtwLZoiF8ubyqOQYEv9SnnCah1DdxZ6Qch4svNv/yNucLnXlSD8dXzuLN36vOMAIMJzU0lJk59L+lwtYkbQbkOW1H+WxagetThhQ== X-Forefront-Antispam-Report: CIP:193.8.40.94; CTRY:CH; LANG:en; SCL:1; SRV:; IPV:CAL; SFV:NSPM; H:aherlnxbspsrv01.lgs-net.com; PTR:ahersrvdom50.leica-geosystems.com; CAT:NONE; SFS:(13230001)(4636009)(46966006)(40470700004)(36840700001)(956004)(107886003)(2616005)(316002)(36736006)(356005)(921005)(86362001)(81166007)(6666004)(1076003)(8676002)(70586007)(4326008)(6506007)(70206006)(6512007)(508600001)(26005)(2906002)(36756003)(36860700001)(40460700003)(6486002)(186003)(118246002)(8936002)(82310400005)(83380400001)(336012)(47076005)(5660300002); DIR:OUT; SFP:1102; X-OriginatorOrg: leica-geosystems.com.cn X-MS-Exchange-CrossTenant-OriginalArrivalTime: 25 May 2022 13:08:39.2617 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: 0c4aaac0-2aaf-47a9-4181-08da3e4fafb8 X-MS-Exchange-CrossTenant-Id: 1b16ab3e-b8f6-4fe3-9f3e-2db7fe549f6a X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=1b16ab3e-b8f6-4fe3-9f3e-2db7fe549f6a; Ip=[193.8.40.94]; Helo=[aherlnxbspsrv01.lgs-net.com] X-MS-Exchange-CrossTenant-AuthSource: HE1EUR02FT051.eop-EUR02.prod.protection.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Anonymous X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: AM9PR06MB8052 Precedence: bulk List-ID: X-Mailing-List: devicetree@vger.kernel.org The units after application of scale are 100*m/s^2, The scale calculation is only for the device with the range of 3, 6, 12, and 24g, but some other chips have a range of 2, 4, 6, and 8g. Modified the scales from formula to a list, the scales in the list are calculated as 9.8/32768*pow(2,reg41+1)*1.5, refer to datasheet 5.3.4. The new units after the application of scale are m/s^2. Reviewed-by: Alexandru Ardelean Signed-off-by: LI Qingwu --- drivers/iio/accel/bmi088-accel-core.c | 14 ++++++++++---- 1 file changed, 10 insertions(+), 4 deletions(-) diff --git a/drivers/iio/accel/bmi088-accel-core.c b/drivers/iio/accel/bmi088-accel-core.c index d74465214feb..3f38967c5a0a 100644 --- a/drivers/iio/accel/bmi088-accel-core.c +++ b/drivers/iio/accel/bmi088-accel-core.c @@ -73,6 +73,8 @@ #define BMI088_ACCEL_FIFO_MODE_FIFO 0x40 #define BMI088_ACCEL_FIFO_MODE_STREAM 0x80 +#define BMIO088_ACCEL_ACC_RANGE_MSK GENMASK(1, 0) + enum bmi088_accel_axis { AXIS_X, AXIS_Y, @@ -119,6 +121,7 @@ struct bmi088_accel_chip_info { u8 chip_id; const struct iio_chan_spec *channels; int num_channels; + const int scale_table[4][2]; }; struct bmi088_accel_data { @@ -280,6 +283,7 @@ static int bmi088_accel_read_raw(struct iio_dev *indio_dev, struct bmi088_accel_data *data = iio_priv(indio_dev); struct device *dev = regmap_get_device(data->regmap); int ret; + int reg; switch (mask) { case IIO_CHAN_INFO_RAW: @@ -330,13 +334,14 @@ static int bmi088_accel_read_raw(struct iio_dev *indio_dev, return ret; ret = regmap_read(data->regmap, - BMI088_ACCEL_REG_ACC_RANGE, val); + BMI088_ACCEL_REG_ACC_RANGE, ®); if (ret) goto out_read_raw_pm_put; - *val2 = 15 - (*val & 0x3); - *val = 3 * 980; - ret = IIO_VAL_FRACTIONAL_LOG2; + reg = FIELD_GET(BMIO088_ACCEL_ACC_RANGE_MSK, reg); + *val = data->chip_info->scale_table[reg][0]; + *val2 = data->chip_info->scale_table[reg][1]; + ret = IIO_VAL_INT_PLUS_MICRO; goto out_read_raw_pm_put; default: @@ -432,6 +437,7 @@ static const struct bmi088_accel_chip_info bmi088_accel_chip_info_tbl[] = { .chip_id = 0x1E, .channels = bmi088_accel_channels, .num_channels = ARRAY_SIZE(bmi088_accel_channels), + .scale_table = {{0, 897}, {0, 1794}, {0, 3589}, {0, 7178}}, }, }; From patchwork Wed May 25 13:08:25 2022 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: LI Qingwu X-Patchwork-Id: 576081 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by smtp.lore.kernel.org (Postfix) with ESMTP id A9D44C433F5 for ; Wed, 25 May 2022 13:08:49 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S243857AbiEYNIr (ORCPT ); Wed, 25 May 2022 09:08:47 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:45842 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S243832AbiEYNIq (ORCPT ); Wed, 25 May 2022 09:08:46 -0400 Received: from EUR01-VE1-obe.outbound.protection.outlook.com (mail-eopbgr140102.outbound.protection.outlook.com [40.107.14.102]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id C10DD4BB97; Wed, 25 May 2022 06:08:44 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=g5bHPaxoqlXZUVelWHJOQKCKSQfVhDZ2QCzmJ3Vce/jMxUxRdgfbNE2Dk6zhed6td0i1lrI4YvV+coPOoZvYZ0WZ8TK3clopZA5uX4MBhjkbFzbOvXyw/+H3ut9jxEI+1TCnLUO39plBg92RZ6uC79ZIkiI1mE73Hk63gZyb/hGcbJgkzqZQTXfbjzDGwtFN5ShHqf6SqklbQ4g21ArvacTnd2Qfvqk0WEK7yRFOPY5bcdWZMS8AciDKoBGPVvDaMjBh84GYrj7tm+WOsnf72GdwudWAgZOXmSsjT0cS6/n6D845HFeaggikWXNSgUS1vJLv6twPSORAIi45LtpFgg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-AntiSpam-MessageData-ChunkCount:X-MS-Exchange-AntiSpam-MessageData-0:X-MS-Exchange-AntiSpam-MessageData-1; bh=6XFlk5WFuK2cIX5Ys1DBdTbS/G49IjssPCzOyKESzWE=; b=A+txutBfLC1Z6SrbbHFhuCr/cosbX2IgQxDzAkTFFOqnzTSObkLWPCDzUv0tS1rE83Clo/45qQJRxpL9mUaWIJ4Pj86YDcR+YCKyZN1t/t2pQQbbFSzougS80zj8HRR/jo4j1sCtTTnaLJ0mHGXgQgNNFSl/UgW3x0TW/vIgm97GBIZSHOOlEXizihAvPTzPEBG8+SqbIxjGvVLNUKRAbJyWJJirvyTO45nNbVzleFRGPslC3o6qMrNI+AjzW53Syqowja5pPrFxwtrWJhtL8AQEgBMm7CzTDnR3FBHB5CIrXhAOaiyaeNd0JrXOhgluiFLeiv7uNMep58xyqrHVDg== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass (sender ip is 193.8.40.94) smtp.rcpttodomain=kernel.org smtp.mailfrom=leica-geosystems.com.cn; dmarc=pass (p=quarantine sp=quarantine pct=100) action=none header.from=leica-geosystems.com.cn; dkim=none (message not signed); arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=leica-geosystems.com.cn; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=6XFlk5WFuK2cIX5Ys1DBdTbS/G49IjssPCzOyKESzWE=; b=dSYGEEwY65nvrlf6CmSLd+YqTIOD9j1nxopwJqpbcYf8vsurEAhasCXKmiG9+BT50kZVC4nJzdDIv0L/+JPwPuufc19N4qvq2XzmK+cgr5gXLz9mS31U/NG6KFRxxCsc98Z2xQ7XhSDWfVYZcdLJeRcsUXqFMfV4xH9uTUMExH8= Received: from AS9PR07CA0008.eurprd07.prod.outlook.com (2603:10a6:20b:46c::6) by AM6PR06MB4785.eurprd06.prod.outlook.com (2603:10a6:20b:5b::29) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.5273.14; Wed, 25 May 2022 13:08:42 +0000 Received: from HE1EUR02FT051.eop-EUR02.prod.protection.outlook.com (2603:10a6:20b:46c:cafe::84) by AS9PR07CA0008.outlook.office365.com (2603:10a6:20b:46c::6) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.5293.13 via Frontend Transport; Wed, 25 May 2022 13:08:41 +0000 X-MS-Exchange-Authentication-Results: spf=pass (sender IP is 193.8.40.94) smtp.mailfrom=leica-geosystems.com.cn; dkim=none (message not signed) header.d=none;dmarc=pass action=none header.from=leica-geosystems.com.cn; Received-SPF: Pass (protection.outlook.com: domain of leica-geosystems.com.cn designates 193.8.40.94 as permitted sender) receiver=protection.outlook.com; client-ip=193.8.40.94; helo=aherlnxbspsrv01.lgs-net.com; pr=C Received: from aherlnxbspsrv01.lgs-net.com (193.8.40.94) by HE1EUR02FT051.mail.protection.outlook.com (10.152.11.7) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.5293.13 via Frontend Transport; Wed, 25 May 2022 13:08:41 +0000 From: LI Qingwu To: jic23@kernel.org, lars@metafoo.de, mchehab+huawei@kernel.org, ardeleanalex@gmail.com, linux-iio@vger.kernel.org, linux-kernel@vger.kernel.org, Qing-wu.Li@leica-geosystems.com.cn, robh+dt@kernel.org, mike.looijmans@topic.nl, devicetree@vger.kernel.org Cc: thomas.haemmerle@leica-geosystems.com Subject: [PATCH V4 3/6] iio: accel: bmi088: modified the device name Date: Wed, 25 May 2022 13:08:25 +0000 Message-Id: <20220525130828.2394919-4-Qing-wu.Li@leica-geosystems.com.cn> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20220525130828.2394919-1-Qing-wu.Li@leica-geosystems.com.cn> References: <20220525130828.2394919-1-Qing-wu.Li@leica-geosystems.com.cn> MIME-Version: 1.0 X-EOPAttributedMessage: 0 X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id: 8bc52cca-fc9a-4257-baad-08da3e4fb0f7 X-MS-TrafficTypeDiagnostic: AM6PR06MB4785:EE_ X-Microsoft-Antispam-PRVS: X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: fRESdfyt6eV85kIAIV+L1SlpOiAS7aUHepSrRQ33N7qVNNCG6PkOarJbMDKDw1w1I8X7THlpJ1l9LTE3NIPE2twu1JWrUW3xYxVc1Z42HQlF+o2vdVwChKJANKpoBWkMlh054GNStBnbqlbza68FfG4kZF7qKJWOvlNzX0vfjJNvlzdykB2GF0zjz5OVya3GO05OA3nVBYJT1cROjjhJIO+GEolNpCJJbfchdHdPSnLjnFd665ue4lg7nY5UzcBulOtqmZT7eWOuKkn2vJSTfgpoZW4C0+PmG4LiXGurnO3fHeVjSuaw2NAvSKBIXxzJaT/xwZwypL93VtVblqHIxT8i3ZXCy8CvKe0JaQKucJvBAgt7R+3P0vPOkQAtA4vfj13NaoPx7dg8rATmLDHL8eX8RNon/flRHn6Kb1+MBCVSb2jSYw1D10TzKI3unwlVxnsva7Did487WgAWVPnCFz5LZtQsrmM9xJsGsZTOmXbPxSUJGn/VsCf3caKgHFEkRMU4oGXuyI2uO146B8WGZj3O6bSGbVlW1jptXODkQKUalBdNT/ccb2jqW6awk/Stwx95qEmKn42McAKUllQQQqT/EEl7Ab+WxP2SN6WZpZs6NwFfArU67nvy3cSzeJZXmwa1SmNN5U0dlVadcfH/ZaOw4iYkeXBizTilQI98zJ4lsFOqc3sh27AtWixbtxcxApLdm9plUwJTeKOYHsLBmA== X-Forefront-Antispam-Report: CIP:193.8.40.94; CTRY:CH; LANG:en; SCL:1; SRV:; IPV:CAL; SFV:NSPM; H:aherlnxbspsrv01.lgs-net.com; PTR:ahersrvdom50.leica-geosystems.com; CAT:NONE; SFS:(13230001)(4636009)(46966006)(40470700004)(36840700001)(70586007)(70206006)(6666004)(6512007)(36860700001)(36756003)(118246002)(336012)(6506007)(8936002)(86362001)(82310400005)(508600001)(186003)(83380400001)(6486002)(2616005)(107886003)(81166007)(1076003)(956004)(5660300002)(2906002)(8676002)(4326008)(26005)(921005)(316002)(356005)(36736006)(40460700003)(47076005); DIR:OUT; SFP:1102; X-OriginatorOrg: leica-geosystems.com.cn X-MS-Exchange-CrossTenant-OriginalArrivalTime: 25 May 2022 13:08:41.3554 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: 8bc52cca-fc9a-4257-baad-08da3e4fb0f7 X-MS-Exchange-CrossTenant-Id: 1b16ab3e-b8f6-4fe3-9f3e-2db7fe549f6a X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=1b16ab3e-b8f6-4fe3-9f3e-2db7fe549f6a; Ip=[193.8.40.94]; Helo=[aherlnxbspsrv01.lgs-net.com] X-MS-Exchange-CrossTenant-AuthSource: HE1EUR02FT051.eop-EUR02.prod.protection.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Anonymous X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: AM6PR06MB4785 Precedence: bulk List-ID: X-Mailing-List: devicetree@vger.kernel.org iio: accel: bmi088: modified the device name It is possible to have multiple sensors connected on the same platform. For support of different sensors, making it possible to obtain the device name by reading the chip id. If the device was found in the table but the device tree binding is different, the driver will carry on with a warning. If no matching device was found, the driver load the binding chip info. Tested case, test with bmi085 and bmi090 patches applied: connect 3 bmi090l to the system, and set device tree compatible: spi2.0: compatible = "bosch,bmi090l-accel"; spi2.2: compatible = "bosch,bmi088-accel"; spi2.4: compatible = "bosch,bmi085-accel"; Get a warning for the mismatched devices: bmi088_accel_spi spi2.2: unexpected chip id 0x1A bmi088_accel_spi spi2.4: unexpected chip id 0x1A Get the real present device name: /sys/bus/iio/devices/iio:device1/name:bmi090l-accel /sys/bus/iio/devices/iio:device3/name:bmi090l-accel /sys/bus/iio/devices/iio:device5/name:bmi090l-accel Signed-off-by: LI Qingwu --- drivers/iio/accel/bmi088-accel-core.c | 35 +++++++++++++++------------ drivers/iio/accel/bmi088-accel-spi.c | 13 +++++++--- drivers/iio/accel/bmi088-accel.h | 7 +++++- 3 files changed, 36 insertions(+), 19 deletions(-) diff --git a/drivers/iio/accel/bmi088-accel-core.c b/drivers/iio/accel/bmi088-accel-core.c index 16c95d90f829..fe8db9615d69 100644 --- a/drivers/iio/accel/bmi088-accel-core.c +++ b/drivers/iio/accel/bmi088-accel-core.c @@ -388,6 +388,7 @@ static int bmi088_accel_read_avail(struct iio_dev *indio_dev, long mask) { struct bmi088_accel_data *data = iio_priv(indio_dev); + switch (mask) { case IIO_CHAN_INFO_SCALE: *vals = (const int *)data->chip_info->scale_table; @@ -463,8 +464,8 @@ static const struct iio_chan_spec bmi088_accel_channels[] = { }; static const struct bmi088_accel_chip_info bmi088_accel_chip_info_tbl[] = { - [0] = { - .name = "bmi088a", + [BOSCH_BMI088] = { + .name = "bmi088-accel", .chip_id = 0x1E, .channels = bmi088_accel_channels, .num_channels = ARRAY_SIZE(bmi088_accel_channels), @@ -483,12 +484,15 @@ static const unsigned long bmi088_accel_scan_masks[] = { 0 }; -static int bmi088_accel_chip_init(struct bmi088_accel_data *data) +static int bmi088_accel_chip_init(struct bmi088_accel_data *data, enum bmi_device_type type) { struct device *dev = regmap_get_device(data->regmap); int ret, i; unsigned int val; + if (type >= BOSCH_UNKNOWN) + return -ENODEV; + /* Do a dummy read to enable SPI interface, won't harm I2C */ regmap_read(data->regmap, BMI088_ACCEL_REG_INT_STATUS, &val); @@ -514,22 +518,23 @@ static int bmi088_accel_chip_init(struct bmi088_accel_data *data) } /* Validate chip ID */ - for (i = 0; i < ARRAY_SIZE(bmi088_accel_chip_info_tbl); i++) { - if (bmi088_accel_chip_info_tbl[i].chip_id == val) { - data->chip_info = &bmi088_accel_chip_info_tbl[i]; + for (i = 0; i < ARRAY_SIZE(bmi088_accel_chip_info_tbl); i++) + if (bmi088_accel_chip_info_tbl[i].chip_id == val) break; - } - } - if (i == ARRAY_SIZE(bmi088_accel_chip_info_tbl)) { - dev_err(dev, "Invalid chip %x\n", val); - return -ENODEV; - } + + if (i == ARRAY_SIZE(bmi088_accel_chip_info_tbl)) + data->chip_info = &bmi088_accel_chip_info_tbl[type]; + else + data->chip_info = &bmi088_accel_chip_info_tbl[i]; + + if (i != type) + dev_warn(dev, "unexpected chip id 0x%X\n", val); return 0; } int bmi088_accel_core_probe(struct device *dev, struct regmap *regmap, - int irq, const char *name, bool block_supported) + int irq, enum bmi_device_type type) { struct bmi088_accel_data *data; struct iio_dev *indio_dev; @@ -544,13 +549,13 @@ int bmi088_accel_core_probe(struct device *dev, struct regmap *regmap, data->regmap = regmap; - ret = bmi088_accel_chip_init(data); + ret = bmi088_accel_chip_init(data, type); if (ret) return ret; indio_dev->channels = data->chip_info->channels; indio_dev->num_channels = data->chip_info->num_channels; - indio_dev->name = name ? name : data->chip_info->name; + indio_dev->name = data->chip_info->name; indio_dev->available_scan_masks = bmi088_accel_scan_masks; indio_dev->modes = INDIO_DIRECT_MODE; indio_dev->info = &bmi088_accel_info; diff --git a/drivers/iio/accel/bmi088-accel-spi.c b/drivers/iio/accel/bmi088-accel-spi.c index 06d99d9949f3..c77aec01bc67 100644 --- a/drivers/iio/accel/bmi088-accel-spi.c +++ b/drivers/iio/accel/bmi088-accel-spi.c @@ -52,8 +52,8 @@ static int bmi088_accel_probe(struct spi_device *spi) return PTR_ERR(regmap); } - return bmi088_accel_core_probe(&spi->dev, regmap, spi->irq, id->name, - true); + return bmi088_accel_core_probe(&spi->dev, regmap, spi->irq, + id->driver_data); } static void bmi088_accel_remove(struct spi_device *spi) @@ -61,8 +61,14 @@ static void bmi088_accel_remove(struct spi_device *spi) bmi088_accel_core_remove(&spi->dev); } +static const struct of_device_id bmi088_of_match[] = { + { .compatible = "bosch,bmi088-accel" }, + {} +}; +MODULE_DEVICE_TABLE(of, bmi088_of_match); + static const struct spi_device_id bmi088_accel_id[] = { - {"bmi088-accel", }, + {"bmi088-accel", BOSCH_BMI088}, {} }; MODULE_DEVICE_TABLE(spi, bmi088_accel_id); @@ -71,6 +77,7 @@ static struct spi_driver bmi088_accel_driver = { .driver = { .name = "bmi088_accel_spi", .pm = &bmi088_accel_pm_ops, + .of_match_table = bmi088_of_match, }, .probe = bmi088_accel_probe, .remove = bmi088_accel_remove, diff --git a/drivers/iio/accel/bmi088-accel.h b/drivers/iio/accel/bmi088-accel.h index 5d40c7cf1cbc..65338a1bf97d 100644 --- a/drivers/iio/accel/bmi088-accel.h +++ b/drivers/iio/accel/bmi088-accel.h @@ -8,11 +8,16 @@ struct device; +enum bmi_device_type { + BOSCH_BMI088, + BOSCH_UNKNOWN, +}; + extern const struct regmap_config bmi088_regmap_conf; extern const struct dev_pm_ops bmi088_accel_pm_ops; int bmi088_accel_core_probe(struct device *dev, struct regmap *regmap, int irq, - const char *name, bool block_supported); + enum bmi_device_type type); void bmi088_accel_core_remove(struct device *dev); #endif /* BMI088_ACCEL_H */ From patchwork Wed May 25 13:08:26 2022 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: LI Qingwu X-Patchwork-Id: 576080 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by smtp.lore.kernel.org (Postfix) with ESMTP id 05AC6C433F5 for ; Wed, 25 May 2022 13:09:03 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S244035AbiEYNJA (ORCPT ); Wed, 25 May 2022 09:09:00 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:45898 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S242528AbiEYNIt (ORCPT ); Wed, 25 May 2022 09:08:49 -0400 Received: from EUR02-VE1-obe.outbound.protection.outlook.com (mail-eopbgr20110.outbound.protection.outlook.com [40.107.2.110]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 4FF72A2062; Wed, 25 May 2022 06:08:48 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=W7VdczsEBB3vJrvtLfnxUENSZNaqooaXxzD7RQAV/m+rvi67iUiOjIIu/7E4UCUM5/MtP3R4BqMQHZAaaSv9S3uaFR73c9OBSV91qy39iHAkG2uGdeh2+Z7gKblGjlrTBlS4kQB4JVvCmP41olMJ18UaRnZqwMlQF9FSVmWXU2VCjkk0unvLtIZ6J2+DCI4O3B1nghgsWH5/Txtv0yiUYUnJRfH7sZ9KmyREJrkN78YAlAPc9QqEYcp1mnQa00bvjnwaBSx/tbN/VJzOwEoo5G0AUTMk6bC7CsAkr3ONMc73FDDEv3k1N95p+gWvrjCbhPo5SDCRRgLF074Linx9IA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-AntiSpam-MessageData-ChunkCount:X-MS-Exchange-AntiSpam-MessageData-0:X-MS-Exchange-AntiSpam-MessageData-1; bh=l3jdhWbWEgCxDYxcMZ3yohV5I+65uu+4kU3aTO5Y0s0=; b=VuKwhtyBSqXaDGU6BeTcN72qY3rmV+8+FNy+9mmgU9JX4mbpCNm3a648fhggAjvJFJdEyUj+c5QN+J46AK8Od1JYCgvYeLt/ZnqpbR7CvNGgOgxMtdecVhzUwtGvCUkCjTH6RpSnwLGWbWnhfQVy/pL5GyQ1YXKxlzryHFXRN8NUA94SdGxwxR0FWlO6VLqmhFaevLlvwXVXkMSRqPTu09NRwVx6nQUDCTa3ZO8NxD7LZYd2bodsT6GVKCNFWn2eUYEyXOwLiXaxAvxmCYNTzbQHpHHHYdVaVwdktsTSWvb/hPNUDHH1AXAyES59YFZx9yJX9XxDUrcBIgJs28lYHg== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass (sender ip is 193.8.40.94) smtp.rcpttodomain=kernel.org smtp.mailfrom=leica-geosystems.com.cn; dmarc=pass (p=quarantine sp=quarantine pct=100) action=none header.from=leica-geosystems.com.cn; dkim=none (message not signed); arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=leica-geosystems.com.cn; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=l3jdhWbWEgCxDYxcMZ3yohV5I+65uu+4kU3aTO5Y0s0=; b=bVaVCMrj5rlam9hAZP9BBLydTTUCAI29VmugWMLJlfvMrueJ871pwwnlx/o1zrtWr4GrYVmyqTHUcZ2r98tVM3fb+NqWWk4jKDs7ab0etMc9Nwp375vg+GpKIfkauU2Ci0uwONrh0crSvIP4l0gse+gGZGs43TcbbhAHV3hcd6Y= Received: from AS9PR07CA0002.eurprd07.prod.outlook.com (2603:10a6:20b:46c::20) by VI1PR06MB4014.eurprd06.prod.outlook.com (2603:10a6:802:62::31) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.5273.16; Wed, 25 May 2022 13:08:43 +0000 Received: from HE1EUR02FT051.eop-EUR02.prod.protection.outlook.com (2603:10a6:20b:46c:cafe::b5) by AS9PR07CA0002.outlook.office365.com (2603:10a6:20b:46c::20) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.5293.13 via Frontend Transport; Wed, 25 May 2022 13:08:43 +0000 X-MS-Exchange-Authentication-Results: spf=pass (sender IP is 193.8.40.94) smtp.mailfrom=leica-geosystems.com.cn; dkim=none (message not signed) header.d=none;dmarc=pass action=none header.from=leica-geosystems.com.cn; Received-SPF: Pass (protection.outlook.com: domain of leica-geosystems.com.cn designates 193.8.40.94 as permitted sender) receiver=protection.outlook.com; client-ip=193.8.40.94; helo=aherlnxbspsrv01.lgs-net.com; pr=C Received: from aherlnxbspsrv01.lgs-net.com (193.8.40.94) by HE1EUR02FT051.mail.protection.outlook.com (10.152.11.7) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.5293.13 via Frontend Transport; Wed, 25 May 2022 13:08:42 +0000 From: LI Qingwu To: jic23@kernel.org, lars@metafoo.de, mchehab+huawei@kernel.org, ardeleanalex@gmail.com, linux-iio@vger.kernel.org, linux-kernel@vger.kernel.org, Qing-wu.Li@leica-geosystems.com.cn, robh+dt@kernel.org, mike.looijmans@topic.nl, devicetree@vger.kernel.org Cc: thomas.haemmerle@leica-geosystems.com Subject: [PATCH V4 4/6] iio: accel: bmi088: Add support for bmi085 accel Date: Wed, 25 May 2022 13:08:26 +0000 Message-Id: <20220525130828.2394919-5-Qing-wu.Li@leica-geosystems.com.cn> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20220525130828.2394919-1-Qing-wu.Li@leica-geosystems.com.cn> References: <20220525130828.2394919-1-Qing-wu.Li@leica-geosystems.com.cn> MIME-Version: 1.0 X-EOPAttributedMessage: 0 X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id: 62ee2fd3-af79-4ef2-c53e-08da3e4fb1a5 X-MS-TrafficTypeDiagnostic: VI1PR06MB4014:EE_ X-Microsoft-Antispam-PRVS: X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: uA4X5kuy+sVVLG5IUWk8C+bu6/i7vfXNJA2tR5nZSRHwsQ5hcaJFDZEY/e4dGyNXv5TV0b45QL2baiW9N69wPYVUNUPQD0/Q7p174chhE9ViMxnBMzLIaMNlBLXsqo5pNYebmJvkiy9lA/iNfNt+h9A49H68vtc/cKYhrZaFU6zrXDyho1BOStmzVKzeq8vz7unbg9GfhIRKiBI5y97Y4O8jYmFqCTBCoE6mSeRMLY/KEjI385Bt4/WhiuouC9LmlipQZbXe0uJsriMQdCySBEWutaHdkVSceTTkZF2iLHukEI4F//tjoOBBx2D2lInOq+UhuBQME0qNc/QMoCMLB7+VoY5Z2nkYnb+dnulEypOHpiDo30SF6Rx3544b36T416ZGZO+bX0eTr8iRMC3+hRxySf0Hb0eaeWj+98vQRTvAdXnGoWSdwb1+V9XakwD6LvKKaLXE1t/1ivNCVmcbPyrjrp/3Swk7l1qQN+LZZiO0ZAG/ADsI23wuPjcohVos5Gfe+Drr2f7y8McwGWANGrc1ofitl9pmYgfBkkqflMUcU8mjr3s8ewLB+l2rslnFDLfKarWz1qpZfMeHuDNZ9tkJupXeoWf94BYIbp+k/ea5VM+IFXaoKfJV1LeWQpBWXf4zwAX3lHaBakDlvRY4tIi94cpHb6G3xZ7LP07gBdMzhl11PqwGTwZWSXToAyCw X-Forefront-Antispam-Report: CIP:193.8.40.94; CTRY:CH; LANG:en; SCL:1; SRV:; IPV:CAL; SFV:NSPM; H:aherlnxbspsrv01.lgs-net.com; PTR:ahersrvdom50.leica-geosystems.com; CAT:NONE; SFS:(13230001)(4636009)(40470700004)(46966006)(36840700001)(6666004)(2616005)(47076005)(81166007)(82310400005)(118246002)(356005)(956004)(921005)(107886003)(186003)(70206006)(36736006)(336012)(70586007)(8936002)(4326008)(8676002)(1076003)(36756003)(316002)(36860700001)(86362001)(26005)(6506007)(508600001)(5660300002)(6486002)(6512007)(2906002)(40460700003); DIR:OUT; SFP:1102; X-OriginatorOrg: leica-geosystems.com.cn X-MS-Exchange-CrossTenant-OriginalArrivalTime: 25 May 2022 13:08:42.4960 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: 62ee2fd3-af79-4ef2-c53e-08da3e4fb1a5 X-MS-Exchange-CrossTenant-Id: 1b16ab3e-b8f6-4fe3-9f3e-2db7fe549f6a X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=1b16ab3e-b8f6-4fe3-9f3e-2db7fe549f6a; Ip=[193.8.40.94]; Helo=[aherlnxbspsrv01.lgs-net.com] X-MS-Exchange-CrossTenant-AuthSource: HE1EUR02FT051.eop-EUR02.prod.protection.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Anonymous X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: VI1PR06MB4014 Precedence: bulk List-ID: X-Mailing-List: devicetree@vger.kernel.org Add supports for BMI085, an Inertial Measurement Unit, with an accelerometer and gyroscope. The commit adds the accelerometer driver for the SPI interface. The gyroscope part is already supported by the BMG160 driver. Unlike BMI088, the BMI085 accelerometer ranges are +/-2, 4, 6, and 8g, the scales are calculated as 9.8/32768*pow(2,reg41+1). Reviewed-by: Alexandru Ardelean Signed-off-by: LI Qingwu --- drivers/iio/accel/bmi088-accel-core.c | 7 +++++++ drivers/iio/accel/bmi088-accel-spi.c | 2 ++ drivers/iio/accel/bmi088-accel.h | 1 + 3 files changed, 10 insertions(+) diff --git a/drivers/iio/accel/bmi088-accel-core.c b/drivers/iio/accel/bmi088-accel-core.c index fe8db9615d69..18becc857d49 100644 --- a/drivers/iio/accel/bmi088-accel-core.c +++ b/drivers/iio/accel/bmi088-accel-core.c @@ -464,6 +464,13 @@ static const struct iio_chan_spec bmi088_accel_channels[] = { }; static const struct bmi088_accel_chip_info bmi088_accel_chip_info_tbl[] = { + [BOSCH_BMI085] = { + .name = "bmi085-accel", + .chip_id = 0x1F, + .channels = bmi088_accel_channels, + .num_channels = ARRAY_SIZE(bmi088_accel_channels), + .scale_table = {{0, 598}, {0, 1196}, {0, 2393}, {0, 4785}}, + }, [BOSCH_BMI088] = { .name = "bmi088-accel", .chip_id = 0x1E, diff --git a/drivers/iio/accel/bmi088-accel-spi.c b/drivers/iio/accel/bmi088-accel-spi.c index c77aec01bc67..b14a1e5b986a 100644 --- a/drivers/iio/accel/bmi088-accel-spi.c +++ b/drivers/iio/accel/bmi088-accel-spi.c @@ -62,12 +62,14 @@ static void bmi088_accel_remove(struct spi_device *spi) } static const struct of_device_id bmi088_of_match[] = { + { .compatible = "bosch,bmi085-accel" }, { .compatible = "bosch,bmi088-accel" }, {} }; MODULE_DEVICE_TABLE(of, bmi088_of_match); static const struct spi_device_id bmi088_accel_id[] = { + {"bmi085-accel", BOSCH_BMI085}, {"bmi088-accel", BOSCH_BMI088}, {} }; diff --git a/drivers/iio/accel/bmi088-accel.h b/drivers/iio/accel/bmi088-accel.h index 65338a1bf97d..044999eb4fd6 100644 --- a/drivers/iio/accel/bmi088-accel.h +++ b/drivers/iio/accel/bmi088-accel.h @@ -9,6 +9,7 @@ struct device; enum bmi_device_type { + BOSCH_BMI085, BOSCH_BMI088, BOSCH_UNKNOWN, };