Received: by 2002:ac0:a679:0:0:0:0:0 with SMTP id p54csp680975imp; Thu, 21 Feb 2019 09:04:21 -0800 (PST) X-Google-Smtp-Source: AHgI3IYin3UdtpAN+GT4nUii0HMJDX9niaL5OteNlqHlfbxDvumLxuiKAtOgO2FgsUsaGx6LF017 X-Received: by 2002:a63:65c7:: with SMTP id z190mr35380395pgb.249.1550768661387; Thu, 21 Feb 2019 09:04:21 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1550768661; cv=none; d=google.com; s=arc-20160816; b=M/JBoNCXD982a2Td+M/5D2GWAq69mmAm7cm/mzveuspOM/2JUC64UnoutsR8fACU5c gSOUflDNPE7f1BODwDIsJBqYAQup6G+6In2/OBH6NqSTFqGy/EezLp2I1cHgescA7F6o +DOTKP3iceUZpn4FazipefeBmqy3dynFrc4y/SONDAabmDeIWrvoCuQ+W/8cc/R6qNmw C7FSwFF6afmNvdT1L4fx/m5uhIFtyS0L72Hv2iQa3pbQzfF+1b1Ap4ErbAbb9Q6arn01 U5FCb49g/DlGLaQ6OPAYWQKurX3Mo9r4/LCHL4Xsa2evRHs3+yAlb8C5Y418K8iTVPoA vPWA== 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 :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=yL5GvNyfXfc5QJRF7NpJkIoJuarqFd1g+366bCn7ypY=; b=M7ilgCps1SKzA2rps5HIBEWAh1jjFZPYiG1/ZAHAIGFP4GpDJf3x9fbVKawifRvHwG wSa+MovhCIQRB+WuqDjevqY+ZithIt9ANQO98TCDP8le3w26pP6RaPnLpVS/Se/utE6v RxfYBsUUmcrucUVm5e/qnHWr0UKKoTrfHz5QXWHsOaAjFFkf5n6RyxstYPirp3AjMsZQ JsYfiHMcWHfSUeotzz6A8odljttVUpJpdZMjmUPeMGr9HAsrvQ3VyveDV43PAoPghDLN OgwCLfHalh+YMh4/zFkCx9B//fJt9eBLwhEtM72MJV5MSbvucM631JkCieq1UoMFnzEx z5/g== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@goldelico.com header.s=strato-dkim-0002 header.b="PjKKP/Rh"; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id f11si16826869plt.133.2019.02.21.09.04.05; Thu, 21 Feb 2019 09:04:21 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=fail header.i=@goldelico.com header.s=strato-dkim-0002 header.b="PjKKP/Rh"; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728663AbfBURDY (ORCPT + 99 others); Thu, 21 Feb 2019 12:03:24 -0500 Received: from mo4-p04-ob.smtp.rzone.de ([85.215.255.122]:34454 "EHLO mo4-p04-ob.smtp.rzone.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728414AbfBURDG (ORCPT ); Thu, 21 Feb 2019 12:03:06 -0500 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; t=1550768582; s=strato-dkim-0002; d=goldelico.com; h=References:In-Reply-To:Message-Id:Date:Subject:Cc:To:From: X-RZG-CLASS-ID:X-RZG-AUTH:From:Subject:Sender; bh=yL5GvNyfXfc5QJRF7NpJkIoJuarqFd1g+366bCn7ypY=; b=PjKKP/RhMJ6Q1niA7pjReNLY7GK9KdocNVAwJuKvVAvVDmtVKW7AZMwRKq12rXIzyG cRpAJspD6vXQZhFw5sqD0AC1xYTKImp+a5cvs0I4w09znyevy6YoOKzD1cuZJg91NZNe gxCFpjeuts/VfpKeTZOzYvNyBE1IeE7293w1tMHt2Rkn3hsPWS5lPXKzn3HhONPjxrlm VKH0x6TDC9aPp744o9fsswPhe02ekGdtgYCmUtuJrjkIw5CGFX7y1GqSV8qmuHHCz3gd NBG1xrTBqTQNTvVRpNwNuNoe4cHBVduXuV0OvN3pv2ZYFinzSXpl+9bKJgJziGqBIkpb 4P8A== X-RZG-AUTH: ":JGIXVUS7cutRB/49FwqZ7WcJeFKiMhflhwDubTJ9o1OAA2UNf2MzNl43D1ri" X-RZG-CLASS-ID: mo00 Received: from iMac.fritz.box by smtp.strato.de (RZmta 44.9 DYNA|AUTH) with ESMTPSA id 608499v1LH31LXJ (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (curve secp521r1 with 521 ECDH bits, eq. 15360 bits RSA)) (Client did not present a certificate); Thu, 21 Feb 2019 18:03:01 +0100 (CET) From: "H. Nikolaus Schaller" To: Linus Walleij , Jonathan Cameron , Rob Herring , Mark Rutland , "H. Nikolaus Schaller" , Andy Shevchenko , Charles Keepax , Song Qiang , Jean-Baptiste Maneyrol , Martin Kelly , Jonathan Marek , Brian Masney , Stephan Gerhold Cc: letux-kernel@openphoenux.org, Hartmut Knaack , Lars-Peter Clausen , Peter Meerwald-Stadler , linux-iio@vger.kernel.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org Subject: [PATCH v2 08/10] iio: magnetometer: hmc5843: add mount matrix support Date: Thu, 21 Feb 2019 18:02:53 +0100 Message-Id: X-Mailer: git-send-email 2.19.1 In-Reply-To: References: MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org This patch allows to read a mount-matrix device tree property and report to user-space or in-kernel iio clients. Signed-off-by: H. Nikolaus Schaller --- drivers/iio/magnetometer/hmc5843.h | 1 + drivers/iio/magnetometer/hmc5843_core.c | 20 ++++++++++++++++++-- 2 files changed, 19 insertions(+), 2 deletions(-) diff --git a/drivers/iio/magnetometer/hmc5843.h b/drivers/iio/magnetometer/hmc5843.h index a75224cf99df..e3e22d2508d3 100644 --- a/drivers/iio/magnetometer/hmc5843.h +++ b/drivers/iio/magnetometer/hmc5843.h @@ -43,6 +43,7 @@ struct hmc5843_data { struct mutex lock; struct regmap *regmap; const struct hmc5843_chip_info *variant; + struct iio_mount_matrix orientation; __be16 buffer[8]; }; diff --git a/drivers/iio/magnetometer/hmc5843_core.c b/drivers/iio/magnetometer/hmc5843_core.c index ada142fb7aa3..05629ec56d80 100644 --- a/drivers/iio/magnetometer/hmc5843_core.c +++ b/drivers/iio/magnetometer/hmc5843_core.c @@ -237,6 +237,15 @@ int hmc5843_set_measurement_configuration(struct iio_dev *indio_dev, return hmc5843_set_meas_conf(data, meas_conf); } +static const struct iio_mount_matrix * +hmc5843_get_mount_matrix(const struct iio_dev *indio_dev, + const struct iio_chan_spec *chan) +{ + struct hmc5843_data *data = iio_priv(indio_dev); + + return &data->orientation; +} + static const struct iio_enum hmc5843_meas_conf_enum = { .items = hmc5843_meas_conf_modes, .num_items = ARRAY_SIZE(hmc5843_meas_conf_modes), @@ -247,7 +256,8 @@ static const struct iio_enum hmc5843_meas_conf_enum = { static const struct iio_chan_spec_ext_info hmc5843_ext_info[] = { IIO_ENUM("meas_conf", true, &hmc5843_meas_conf_enum), IIO_ENUM_AVAILABLE("meas_conf", &hmc5843_meas_conf_enum), - { }, + IIO_MOUNT_MATRIX(IIO_SHARED_BY_DIR, hmc5843_get_mount_matrix), + { } }; static const struct iio_enum hmc5983_meas_conf_enum = { @@ -260,7 +270,8 @@ static const struct iio_enum hmc5983_meas_conf_enum = { static const struct iio_chan_spec_ext_info hmc5983_ext_info[] = { IIO_ENUM("meas_conf", true, &hmc5983_meas_conf_enum), IIO_ENUM_AVAILABLE("meas_conf", &hmc5983_meas_conf_enum), - { }, + IIO_MOUNT_MATRIX(IIO_SHARED_BY_DIR, hmc5843_get_mount_matrix), + { } }; static @@ -635,6 +646,11 @@ int hmc5843_common_probe(struct device *dev, struct regmap *regmap, data->variant = &hmc5843_chip_info_tbl[id]; mutex_init(&data->lock); + ret = iio_read_mount_matrix(dev, "mount-matrix", + &data->orientation); + if (ret) + return ret; + indio_dev->dev.parent = dev; indio_dev->name = name; indio_dev->info = &hmc5843_info; -- 2.19.1