Received: by 2002:a25:868d:0:0:0:0:0 with SMTP id z13csp2141800ybk; Mon, 11 May 2020 12:59:19 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxfj1L8w87ns0P69wBxfE3ROJdutgDmm2QmdIYwBQPA1N2SHMYY51b8BooSgceEnql5SQOb X-Received: by 2002:a17:906:eb1a:: with SMTP id mb26mr1400753ejb.362.1589227158897; Mon, 11 May 2020 12:59:18 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1589227158; cv=none; d=google.com; s=arc-20160816; b=IWTpLmMrx9q5MoyZ04VB3a07ziZ+fg2/Z/xXVZLnABoVlr/vZ9OTdU0hBaQHjmewhF VNXSAD/g/L7baWPiCN2+qvjxykm87NnpLnzAt12OtEaD8Q2Hw8dvN7EqNs4IS9K+ctkg BYThXi63YwjKW48Jl27NAp52z5BRxfT2xaRvrj9XnBrTJ/aDqjlo6KAFcijcPpeIac6H pRmPNxTfT8ogK57hMZOPAcXB+ADcZPb8w/ULPpxaQ3uRiKE3m1lwbdPoJAXVDTBhKxEG I4Ca/eMhEOhby1D+yS7rp5oLj6rmwn7MwGwekKXdT851kzGJ1SQAFzpEBKEiSsm4L97F RkBw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-language :content-transfer-encoding:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:dkim-signature; bh=1UwqtZKMBfGFgyFnK3JlTll7tSdmM/BdA7mHFZYsJzI=; b=FpYhHpa5NTjlysJur+MzAtP2nng7VoplxH7L0DPVjePUiCYxhOBm6QVG52jrb5soaw gwgPBCijGvm2bjrbllIGj+X/3OGaPk2dxh4pX1smMMKz9SqBbd7+ipwgWZFLXQT86Xmy 1BoYY85mHwRtfuOUzj5Jq0QSOSF0zNfgngoBgF4J30LmlPtfnmpLPK5TXKnKWhr8uYU/ L+VJNOTydN8ItGrctm0/rH63e4ZrcdMTj4UPrsBUhsgqLQ0p+3E8aL8Ee9hdqoiHOHx1 7IdLH5FD91LyWD2xkxQQWbI76Q4OFRa2JlL4Kp7j54mItsrlMjQpbbC1v+z5FHGsmcis 87vA== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@metafoo.de header.s=default2002 header.b="j+JUn/Mh"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=metafoo.de Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id p21si6856549edm.75.2020.05.11.12.58.55; Mon, 11 May 2020 12:59:18 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=fail header.i=@metafoo.de header.s=default2002 header.b="j+JUn/Mh"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=metafoo.de Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1731427AbgEKT4s (ORCPT + 99 others); Mon, 11 May 2020 15:56:48 -0400 Received: from www381.your-server.de ([78.46.137.84]:35182 "EHLO www381.your-server.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729049AbgEKT4r (ORCPT ); Mon, 11 May 2020 15:56:47 -0400 DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=metafoo.de; s=default2002; h=Content-Transfer-Encoding:Content-Type:In-Reply-To: MIME-Version:Date:Message-ID:From:References:Cc:To:Subject:Sender:Reply-To: Content-ID:Content-Description:Resent-Date:Resent-From:Resent-Sender: Resent-To:Resent-Cc:Resent-Message-ID:List-Id:List-Help:List-Unsubscribe: List-Subscribe:List-Post:List-Owner:List-Archive; bh=1UwqtZKMBfGFgyFnK3JlTll7tSdmM/BdA7mHFZYsJzI=; b=j+JUn/MhgUkPqExsnrfkzGZ8BG eVFmHbN8APctUYEBnzp9XGlrVk+G+tQt2oS39gjja0IVzfuywUuZ3emonIQ6cG+nJp7z3nMqXnf6N bD4BxGbezLl8nbZWgLUZH9B+kAj2LJBEjrzSJlL0/OL5KNShbohfHJn9Egz1FXDagzrRr5M11AaOb apNK3cZR0HAkew4h3tk7Jv1jkL1TXfOsFYwEGXNasg/LQYluqKmqc/C/kdZNVNTskZzuz+nKPvyJc I5+7E1IzrFqlnsbZQkV9CM/1AVXOTLJnFBCzv9VM2QNked2mI+PyjMATjJvNboQtV9n430Xp/7lWr FWrVja+w==; Received: from sslproxy05.your-server.de ([78.46.172.2]) by www381.your-server.de with esmtpsa (TLSv1.2:DHE-RSA-AES256-GCM-SHA384:256) (Exim 4.89_1) (envelope-from ) id 1jYEXZ-00039o-G6; Mon, 11 May 2020 21:56:41 +0200 Received: from [82.135.66.51] (helo=[192.168.178.20]) by sslproxy05.your-server.de with esmtpsa (TLSv1.3:TLS_AES_256_GCM_SHA384:256) (Exim 4.92) (envelope-from ) id 1jYEXZ-000Cev-6U; Mon, 11 May 2020 21:56:41 +0200 Subject: Re: [RFC PATCH 00/14] iio: buffer: add support for multiple buffers To: "Ardelean, Alexandru" , "jic23@kernel.org" Cc: "linux-kernel@vger.kernel.org" , "linux-iio@vger.kernel.org" References: <20200508135348.15229-1-alexandru.ardelean@analog.com> <20200510110958.29046a18@archlinux> <8c5d9ef5ed4ea9037c5459daa2044d1cd7c5db7a.camel@analog.com> <554fe46f0cdd1cafb313f534c0edd93f5686b806.camel@analog.com> <7d2c8174e345bf8e241d48de65066d2606143503.camel@analog.com> <9ae7e69b-f4ce-dd2b-d70b-2aac66b19814@metafoo.de> <04fda2eb89244dd2bf8e024d4b4405eceffd016c.camel@analog.com> From: Lars-Peter Clausen Message-ID: Date: Mon, 11 May 2020 21:56:40 +0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:68.0) Gecko/20100101 Thunderbird/68.7.0 MIME-Version: 1.0 In-Reply-To: <04fda2eb89244dd2bf8e024d4b4405eceffd016c.camel@analog.com> Content-Type: text/plain; charset=utf-8; format=flowed Content-Transfer-Encoding: 7bit Content-Language: en-US X-Authenticated-Sender: lars@metafoo.de X-Virus-Scanned: Clear (ClamAV 0.102.2/25809/Mon May 11 14:16:55 2020) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 5/11/20 4:56 PM, Ardelean, Alexandru wrote: > On Mon, 2020-05-11 at 15:58 +0200, Lars-Peter Clausen wrote: >> [External] >> >> On 5/11/20 3:24 PM, Ardelean, Alexandru wrote: >>> On Mon, 2020-05-11 at 13:03 +0000, Ardelean, Alexandru wrote: >>>> [External] >>>> >>>> On Mon, 2020-05-11 at 12:37 +0200, Lars-Peter Clausen wrote: >>>>> [External] >>>>> >>>>> On 5/11/20 12:33 PM, Ardelean, Alexandru wrote: >>>>>> On Sun, 2020-05-10 at 11:09 +0100, Jonathan Cameron wrote: >>>>>>> [External] >>>>>>> >>>>>>> On Sat, 9 May 2020 10:52:14 +0200 >>>>>>> Lars-Peter Clausen wrote: >>>>>>> >>>>>>>> On 5/8/20 3:53 PM, Alexandru Ardelean wrote: >>>>>>>>> [...] >>>>>>>>> What I don't like, is that iio:device3 has iio:buffer3:0 (to 3). >>>>>>>>> This is because the 'buffer->dev.parent = &indio_dev->dev'. >>>>>>>>> But I do feel this is correct. >>>>>>>>> So, now I don't know whether to leave it like that or symlink to >>>>>>>>> shorter >>>>>>>>> versions like 'iio:buffer3:Y' -> 'iio:device3/bufferY'. >>>>>>>>> The reason for naming the IIO buffer devices to 'iio:bufferX:Y' >>>>>>>>> is >>>>>>>>> mostly to make the names unique. It would have looked weird to >>>>>>>>> do >>>>>>>>> '/dev/buffer1' if I would have named the buffer devices >>>>>>>>> 'bufferX'. >>>>>>>>> >>>>>>>>> So, now I'm thinking of whether all this is acceptable. >>>>>>>>> Or what is acceptable? >>>>>>>>> Should I symlink 'iio:device3/iio:buffer3:0' -> >>>>>>>>> 'iio:device3/buffer0'? >>>>>>>>> What else should I consider moving forward? >>>>>>>>> What means forward? >>>>>>>>> Where did I leave my beer? >>>>>>>> Looking at how the /dev/ devices are named I think we can provide >>>>>>>> a >>>>>>>> name >>>>>>>> that is different from the dev_name() of the device. Have a look >>>>>>>> at >>>>>>>> device_get_devnode() in drivers/base/core.c. We should be able to >>>>>>>> provide the name for the chardev through the devnode() callback. >>>>>>>> >>>>>>>> While we are at this, do we want to move the new devices into an >>>>>>>> iio >>>>>>>> subfolder? So iio/buffer0:0 instead of iio:buffer0:0? >>>>>>> Possibly on the folder. I can't for the life of me remember why I >>>>>>> decided >>>>>>> not to do that the first time around - I'll leave it at the >>>>>>> mysterious "it may turn out to be harder than you'd think..." >>>>>>> Hopefully not ;) >>>>>> I was also thinking about the /dev/iio subfolder while doing this. >>>>>> I can copy that from /dev/input >>>>>> They seem to do it already. >>>>>> I don't know how difficult it would be. But it looks like a good >>>>>> precedent. >>>>> All you have to do is return "iio/..." from the devnode() callback. >>>> I admit I did not look closely into drivers/input/input.c before >>>> mentioning >>>> this >>>> as as good precedent. >>>> >>>> But, I looks like /dev/inpput is a class. >>>> While IIO devices are a bus_type devices. >>>> Should we start implementing an IIO class? or? >>> What I should have highlighted [before] with this, is that there is no >>> devnode() >>> callback for the bus_type [type]. >> But there is one in device_type :) > Many thanks :) > That worked nicely. > > I now have: > > root@analog:~# ls /dev/iio/* > /dev/iio/iio:device0 /dev/iio/iio:device1 > > /dev/iio/device3: > buffer0 buffer1 buffer2 buffer3 > > /dev/iio/device4: > buffer0 > > > It looks like I can shift these around as needed. > This is just an experiment. > I managed to move the iio devices under /dev/iio, though probably the IIO > devices will still be around as /dev/iio:deviceX for legacy reasons. > > Two things remain unresolved. > 1. The name of the IIO buffer device. > > root@analog:/sys/bus/iio/devices# ls iio\:device3/ > buffer in_voltage0_test_mode name > events in_voltage1_test_mode of_node > iio:buffer:3:0 in_voltage_sampling_frequency power > iio:buffer:3:1 in_voltage_scale scan_elements > iio:buffer:3:2 in_voltage_scale_available subsystem > iio:buffer:3:3 in_voltage_test_mode_available uevent > > > Right now, each buffer device is named 'iio:buffer:X:Y'. > One suggesttion was 'iio:deviceX:bufferY' > I'm suspecting the latter is preferred as when you sort the folders, buffers > come right after the iio:deviceX folders in /sys/bus/iio/devices. > > I don't feel it matters much the device name of the IIO buffer if we symlink it > to a shorter form. > > I'm guessing, we symlink these devices to short-hand 'bufferY' folders in each > 'iio:deviceX'? I think that would be a bit excessive. Only for the legacy buffer we need to have a symlink. > [...] > 2. I know this is [still] stupid now; but any suggestions one how to symlink > /dev/iio:device3 -> /dev/iio/device3/buffer0 ? > Does not seem to be possible. Userspace will have to take care of it. This means we need to keep legacy devices in /dev/ and only new buffers in /dev/iio/.