Received: by 2002:ac0:a679:0:0:0:0:0 with SMTP id p54csp683215imp; Thu, 21 Feb 2019 09:06:28 -0800 (PST) X-Google-Smtp-Source: AHgI3IZNFW6QYjRIEhcqDbQD/57Pl4LcdPhLUFTY68Xz5wWaZiay+HA4vgX4uNaqGIiByY5wei57 X-Received: by 2002:a17:902:728f:: with SMTP id d15mr2643520pll.156.1550768788616; Thu, 21 Feb 2019 09:06:28 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1550768788; cv=none; d=google.com; s=arc-20160816; b=Rqsov3sPPHAhxEkUHXr19PyhEgPoTnJ5i6a4jB47kgHHxfBrSK/Z7zfk6LNUaLzmWp b9CcKiBdoPiZ/W5BUFEHlrNAjmjPoR1ZxkarbU7KbIqpnew2cHJKZTnf07sLlUvlc0jD /uqpXe86f8UPga9Q6IKfOW7Syw1x3j519tPZApkNmEv2Zctix9KAGublXf9GqwltHicU Ci4i6xGmfmILEm7sOy+zRfc8Jznpr9EN1tyCB3oAAA8yWYak5BJMSeIWpXSksT/r3iy6 kPQhHiufKT7CEooIgS0mL1IZQ8p0AAoiTnLhqGMOY+X/LufxsuVyFCOIOq/VPTBAVab2 JCKw== 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=Bb4qNjnoSsFX6gssQVbJgzru/6GuCa9xGr0eyLH83FA=; b=vgQ/V5asBCrvFHSY7ZqYiR2EBS5/dl+t961A50Y+iQKl2ffzz73nIHWdsFWwFe70BA uKs0Qi1TjMcmNnUdZ9rakjBb7TqXSN3G5VGWwPL3Grb2BXlEKatKvt7wGTOve4CkDWmi godexPrGj0LgRt+f2CVNrbQqM8Ya6kydP3Tj7hVCZr/W9kLySnta8yOcrzVFe0jVmYuy AG6oIhrOIQNjOfMCBlvH4ayEYCLIWdo6quvvrWCNSp2KB9pAFRlftxGTUndvdCTnQF/X BZVPjP1iEQCb2s+NKosoR9lwfqTzu5dj2z12sBZLGnJiZ4mHQOKRfiYbqENyaFa5daXL WDtA== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@goldelico.com header.s=strato-dkim-0002 header.b=ffPPfWLk; 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 g1si8279118plp.406.2019.02.21.09.06.12; Thu, 21 Feb 2019 09:06:28 -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=ffPPfWLk; 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 S1728730AbfBURD4 (ORCPT + 99 others); Thu, 21 Feb 2019 12:03:56 -0500 Received: from mo4-p03-ob.smtp.rzone.de ([85.215.255.103]:20738 "EHLO mo4-p03-ob.smtp.rzone.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726371AbfBURDE (ORCPT ); Thu, 21 Feb 2019 12:03:04 -0500 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; t=1550768581; 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=Bb4qNjnoSsFX6gssQVbJgzru/6GuCa9xGr0eyLH83FA=; b=ffPPfWLkotfHb3HpVXEnLTUKKW1atQgrt81VYDHS8sg3k/psMPjP9/WJPnbjTkhaKs WDLwtlh85wN1XZ14A4S6IkqOuD67/lq6D4xEo11lnQQO57tEksxi3E6Rlv/B8MgCl8aT RgHM5nAjE/UEcVeDVSlcbI5SiQSHkOxkcK5xI1NZIVI5GuNVBdzqVR1An3cDceFncseE 2dBEDdoVXOH9mL4mQtZPhyr0POtN+4wMhdaAikoxHbso5RCO0hHsUKRe74gqtkZFD2sv k7eMvZ4bFCIlU3lHpCAeJt20PexaEwNIYuoKKGwDECn6oyKnDPCmZO3wUf5ahRG7LT2h tszw== 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 608499v1LH31LXI (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 07/10] iio: magnetometer: bmc150: add mount matrix support Date: Thu, 21 Feb 2019 18:02:52 +0100 Message-Id: <92f9b04e6540612b8bb8450803df1fcda21e364b.1550768574.git.hns@goldelico.com> 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/bmc150_magn.c | 21 +++++++++++++++++++++ 1 file changed, 21 insertions(+) diff --git a/drivers/iio/magnetometer/bmc150_magn.c b/drivers/iio/magnetometer/bmc150_magn.c index d91cb845e3d6..b0d8b036d9bb 100644 --- a/drivers/iio/magnetometer/bmc150_magn.c +++ b/drivers/iio/magnetometer/bmc150_magn.c @@ -143,6 +143,7 @@ struct bmc150_magn_data { */ struct mutex mutex; struct regmap *regmap; + struct iio_mount_matrix orientation; /* 4 x 32 bits for x, y z, 4 bytes align, 64 bits timestamp */ s32 buffer[6]; struct iio_trigger *dready_trig; @@ -612,6 +613,20 @@ static ssize_t bmc150_magn_show_samp_freq_avail(struct device *dev, return len; } +static const struct iio_mount_matrix * +bmc150_magn_get_mount_matrix(const struct iio_dev *indio_dev, + const struct iio_chan_spec *chan) +{ + struct bmc150_magn_data *data = iio_priv(indio_dev); + + return &data->orientation; +} + +static const struct iio_chan_spec_ext_info bmc150_magn_ext_info[] = { + IIO_MOUNT_MATRIX(IIO_SHARED_BY_DIR, bmc150_magn_get_mount_matrix), + { } +}; + static IIO_DEV_ATTR_SAMP_FREQ_AVAIL(bmc150_magn_show_samp_freq_avail); static struct attribute *bmc150_magn_attributes[] = { @@ -638,6 +653,7 @@ static const struct attribute_group bmc150_magn_attrs_group = { .storagebits = 32, \ .endianness = IIO_LE \ }, \ + .ext_info = bmc150_magn_ext_info, \ } static const struct iio_chan_spec bmc150_magn_channels[] = { @@ -861,6 +877,11 @@ int bmc150_magn_probe(struct device *dev, struct regmap *regmap, data->irq = irq; data->dev = dev; + ret = iio_read_mount_matrix(dev, "mount-matrix", + &data->orientation); + if (ret) + return ret; + if (!name && ACPI_HANDLE(dev)) name = bmc150_magn_match_acpi_device(dev); -- 2.19.1