From: ranshalit@gmail.com (Ran Shalit)
To: kernelnewbies@lists.kernelnewbies.org
Subject: How to use spi device from another kernel module?
Date: Thu, 8 Dec 2016 12:42:12 +0200 [thread overview]
Message-ID: <CAJ2oMh+TFrS5ztO=jpWeKiySpfGohe05L_ME6VQemVDci0RHZA@mail.gmail.com> (raw)
In-Reply-To: <CAJ2oMh+Mvfoy4Oqp9=ee1Dq4Zu7XU8_GQ_gELj+neL=7X3bhvw@mail.gmail.com>
On Wed, Dec 7, 2016 at 8:21 PM, Ran Shalit <ranshalit@gmail.com> wrote:
> On Wed, Dec 7, 2016 at 7:26 PM, Ran Shalit <ranshalit@gmail.com> wrote:
>> On Wed, Dec 7, 2016 at 6:58 PM, Joel Fernandes <agnel.joel@gmail.com> wrote:
>>> On Tue, Dec 6, 2016 at 11:02 PM, Greg KH <greg@kroah.com> wrote:
>>>> On Tue, Dec 06, 2016 at 09:12:24PM -0800, Joel Fernandes wrote:
>>>>> On Tue, Dec 6, 2016 at 11:42 AM, Ran Shalit <ranshalit@gmail.com> wrote:
>>>>> > Hello,
>>>>> >
>>>>> > I have spi device which is registered using spi_register_board_info(),
>>>>> > and I would like to get a pointer to this device in some other kernel module.
>>>>> >
>>>>> > Is there a simple way to get a pointer to pointer to a device , so
>>>>> > that we can use it from other module ? (something like i2c_get_adapter
>>>>> > for i2c)
>>>>>
>>>>> Find out what's the SPI bus number (for the master) and the chip
>>>>> select on that SPI master (for the SPI device)
>>>>>
>>>>> Then you can use bus_for_each_device on spi_bus_type and find the
>>>>> spi_device you're looking for. See the following code for an example
>>>>> of how to use bus_for_each_device:
>
> Hi,
>
> I did try using this method with the following call:
>
> bus_for_each_dev(&spi_bus_type, NULL, NULL, spi_device_found);
>
> static int spi_device_found(struct device *dev, void *data)
> {
> struct spi_device *spi = container_of(dev, struct spi_device, dev);
>
> printk(": %s %s %dkHz %d bits mode=0x%02X\n",
> spi->modalias, dev_name(dev), spi->max_speed_hz/1000,
> spi->bits_per_word, spi->mode);
>
> return 0;
> }
>
> But for some reason the list is empty, although I do have devices
> registered successfuly with spi_register_driver.
> Using the same method with i2c works well, not sure why it doesn't
> list anything with spi.
>
> Thanks,
> Ran
>
>>>>>
>>>>> http://lxr.free-electrons.com/source/drivers/spi/spi.c#L524
>>>>>
>>>>> In your check function, just make sure your spi->master->bus_num is
>>>>> the bus you want and the spi->chip_select is the chip select
>>>>> corresponding to the device you want. If both these conditions are
>>>>> satisfied, there you have your spi_device.
>>>>
>>>> Eeek, no, please never do that, use the proper spi apis to get your
>>>> needed device. They are there somewhere, using a "raw"
>>>> bus_for_each_device is never the answer unless you are a bus and
>>>> iterating over your own device list.
>>>
>>> Yes I completely agree, maybe I assumed too much and thought he was
>>> trying to do this for some quick debugging from some kernel module,
>>> and was just looking for a quick and dirty way to get to a spi_device.
>>> Was not really suggesting this for production code. :)
>>>
If I may please ask one more thing on this issue, just for my understanding.
Before trying the above suggestions, I made the following trial (which
I know is quick and dirty ):
I copied the pointer to spi device from probe() function into static
variable and than tried to use it later (in proc/sysfs), but I get
exceptions.
I am not going to use this method anyway, yet I am curious why it doesn't work.
Thank you,
Ran
>>
>> You were actually Right... That's exactly what I wanted :) , so I
>> probably will try to use your simple method.
>> I think that for production , spidev shows a good example how to use
>> spi as a char device:
>> https://github.com/Xilinx/linux-xlnx/blob/master/drivers/spi/spidev.c
>>
>> Thanks!
>> Ran
>>
>>> Regards,
>>> Joel
>>>
>>>>
>>>> thanks,
>>>>
>>>> greg k-h
prev parent reply other threads:[~2016-12-08 10:42 UTC|newest]
Thread overview: 8+ messages / expand[flat|nested] mbox.gz Atom feed top
2016-12-06 19:42 How to use spi device from another kernel module? Ran Shalit
2016-12-07 5:12 ` Joel Fernandes
2016-12-07 7:02 ` Greg KH
2016-12-07 15:27 ` Ran Shalit
2016-12-07 16:58 ` Joel Fernandes
2016-12-07 17:26 ` Ran Shalit
2016-12-07 18:21 ` Ran Shalit
2016-12-08 10:42 ` Ran Shalit [this message]
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to='CAJ2oMh+TFrS5ztO=jpWeKiySpfGohe05L_ME6VQemVDci0RHZA@mail.gmail.com' \
--to=ranshalit@gmail.com \
--cc=kernelnewbies@lists.kernelnewbies.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).