netdev.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
From: Chris Snook <csnook@redhat.com>
To: Ben Hutchings <bhutchings@solarflare.com>
Cc: Stephen Hemminger <shemminger@vyatta.com>,
	Brice Goglin <brice@myri.com>,
	netdev@vger.kernel.org
Subject: Re: [RFC] per-nic module parameters
Date: Sat, 25 Oct 2008 07:06:23 -0400	[thread overview]
Message-ID: <4902FDAF.5060305@redhat.com> (raw)
In-Reply-To: <20081024210128.GS7331@solarflare.com>

Ben Hutchings wrote:
> Stephen Hemminger wrote:
>> On Fri, 24 Oct 2008 22:09:35 +0200
>> Brice Goglin <brice@myri.com> wrote:
>>
>>> Hello,
>>>
>>> We're working on making myri10ge module parameters per-nic. It looks
>>> like ixgb already does so with the following macro in ixgb_param.c:
>>>
>>> #define IXGB_PARAM_INIT { [0 ... IXGB_MAX_NIC] = OPTION_UNSET }
>>> #define IXGB_PARAM(X, desc)                                     \
>>>         static int __devinitdata X[IXGB_MAX_NIC+1]              \
>>>                 = IXGB_PARAM_INIT;                              \
>>>         static unsigned int num_##X = 0;                        \
>>>         module_param_array_named(X, X, int, &num_##X, 0);       \
>>>         MODULE_PARM_DESC(X, desc);
>>>
>>> Is this the recommended way to implement per-nic module params? Or
>>> should we do something else?
>> Module parameters are bad. They are device specific and awkward for
>> any general configuration system to deal with. As much as possible,
>> please convert any module parameters to real interfaces like netlink,
>> ethtool, or sysfs.
> 
> I agree in principle.  However, every distribution uses modutils and allows
> default module parameters to be set in the same way.  So it's easy to tell
> customers how to configure module parameters persistently.  The same cannot
> be said for ethtool, unfortunately.

That makes it a distribution problem, maybe something LSB should address.  ixgb 
inherits this code from e1000, which has been around a very, very long time. 
It's still a sin that they didn't strip it out when they derived ixgb from 
e1000, but it's a less severe sin than writing new module parameter code from 
scratch.

Sometimes there are legitimate reasons to use module parameters, but duplicating 
ethtool functionality doesn't qualify.  Those parameters that e1000 still 
carries are there because now that they've documented it and customers are using 
it, they can't ever remove it.  Telling your customers to use ETHTOOL_OPTS if 
their distro has /etc/sysconfig/network-scripts/ifcfg-eth* files, or pre-up if 
their distro has /etc/network/interfaces is not difficult.

Interface consistency is a worthwhile goal, but you're creating a bigger 
consistency problem in the kernel than you're solving in the distributions if 
you do this, and you make it very difficult to ever go back once you realize the 
mistake.

-- Chris

      reply	other threads:[~2008-10-25 11:07 UTC|newest]

Thread overview: 4+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2008-10-24 20:09 [RFC] per-nic module parameters Brice Goglin
2008-10-24 20:39 ` Stephen Hemminger
2008-10-24 21:01   ` Ben Hutchings
2008-10-25 11:06     ` Chris Snook [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=4902FDAF.5060305@redhat.com \
    --to=csnook@redhat.com \
    --cc=bhutchings@solarflare.com \
    --cc=brice@myri.com \
    --cc=netdev@vger.kernel.org \
    --cc=shemminger@vyatta.com \
    /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).