From: Jeff Webb <jeff.webb@nta-inc.net>
To: Xenomai <xenomai@xenomai.org>
Subject: Re: [Xenomai] Add cards parameter to rt_e1000e module?
Date: Mon, 15 Dec 2014 09:27:05 -0600 [thread overview]
Message-ID: <548EFDC9.9070008@nta-inc.net> (raw)
In-Reply-To: <20141213051151.GE11058@hermes.click-hack.org>
On 12/12/2014 11:11 PM, Gilles Chanteperdrix wrote:
> On Fri, Dec 12, 2014 at 09:12:23PM -0500, Lennart Sorensen wrote:
>> On Sat, Dec 13, 2014 at 02:03:58AM +0100, Gilles Chanteperdrix wrote:
>>> I understand the need for the "cards" parameter, but...
>>> Is not there another way to solve this issue ? I do not know,
>>> something in /proc or /sys to tell Linux to not load this driver for
>>> that card? I suppose if we tell Linux to not use its driver for some
>>> cards, then later loading the rtnet driver will be used for these
>>> cards? Adding the cards parameter means that the rtnet drivers
>>> diverge from mainline drivers, and so imply a maintenance cost. On
>>> the other hand, maybe that is a cheaper one than trying and solving
>>> the issue globally.
I think the "cards" parameter is a pretty crude solution, too. As you mentioned, this seems like a more general problem that Linux would already have a solution for, but my search for another solution turned up empty.
>> Certainly a well behaved driver would not touch a device already handled
>> by a linux driver. It should be possible to just issue an unbind request
>> to the linux driver for the desired device and then a bind request to
>> the rtnet driver to take over that device.
Thanks for sharing this information. It sounds like that might work.
> The problem with the
> bind/unbind solution is that the driver that will get all the cards
> first depends on the drivers initialization order. With the "cards"
> parameter, you do not have this issue.
Maybe one could create a script that would attempt to unbind both the rt and non-rt drivers (or check to see which one is bound and then unbind it), and then make the desired "bind" calls. It would be better if the incorrect binding were not made in the first place, however. I think the ideal solution would be to have a file that contains device/driver pairs that would keep the kernel from passing the specified devices to any other drivers. I wonder how hard that would be to implement.
For what it's worth, I have these same issues with 16550 serial port drivers. The 8250.nr_uarts parameter is helpful, but doesn't cover all use cases.
-Jeff
next prev parent reply other threads:[~2014-12-15 15:27 UTC|newest]
Thread overview: 11+ messages / expand[flat|nested] mbox.gz Atom feed top
2014-12-12 22:10 [Xenomai] Add cards parameter to rt_e1000e module? Jeff Webb
2014-12-12 23:56 ` Gilles Chanteperdrix
2014-12-15 15:01 ` Jeff Webb
2014-12-15 15:29 ` Jeff Webb
2014-12-13 1:03 ` Gilles Chanteperdrix
2014-12-13 2:12 ` Lennart Sorensen
2014-12-13 5:11 ` Gilles Chanteperdrix
2014-12-13 17:14 ` Lennart Sorensen
2014-12-15 15:27 ` Jeff Webb [this message]
-- strict thread matches above, loose matches on Subject: below --
2014-12-15 20:04 Mariusz Janiak
2014-12-16 21:43 ` Jeff Webb
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=548EFDC9.9070008@nta-inc.net \
--to=jeff.webb@nta-inc.net \
--cc=xenomai@xenomai.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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.