[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <a916f016-5d8b-3f56-0a84-95d1712bec4c@cumulusnetworks.com>
Date: Thu, 5 Apr 2018 14:10:29 -0600
From: David Ahern <dsa@...ulusnetworks.com>
To: Jiri Pirko <jiri@...nulli.us>
Cc: netdev@...r.kernel.org, davem@...emloft.net,
roopa@...ulusnetworks.com, shm@...ulusnetworks.com,
jiri@...lanox.com, idosch@...lanox.com,
jakub.kicinski@...ronome.com, andy.roulin@...il.com
Subject: Re: [PATCH net-next 6/6] netdevsim: Add simple FIB resource
controller via devlink
On 4/5/18 11:27 AM, Jiri Pirko wrote:
> Wed, Mar 28, 2018 at 03:22:00AM CEST, dsa@...ulusnetworks.com wrote:
>> Add devlink support to netdevsim and use it to implement a simple,
>> profile based resource controller. Only one controller is needed
>> per namespace, so the first netdevsim netdevice in a namespace
>> registers with devlink. If that device is deleted, the resource
>> settings are deleted.
>
> I don't understand why you add 1:1 fixed relationship between
> netnamespace and devlink instance. That is highly misleading and reader
> might think that those 2 are somehow related. They are not. You can have
> multiple devlink instances for many ports in a single namespace.
The netdevsim devlink instance is an example of limiting the number of
FIB entries and FIB rules for a namespace. It is currently limited to
the init_net based on past discussion.
It does not make sense to have multiple resource controllers for the
same network namespace, hence the limit of only registering with devlink
on the first device create.
>
> Could you please clarify?
>
> Also, to see the relationship between individual netdevsim netdevices
> and the parent devlink instance, we should use devlink_port
> instances, like this:
>
> devlink1 devlink2
> | | | |
> dl_port1_1 dlport1_2 dlport2_1 dlport2_2
> | | | |
> eth0 eth1 eth2 eth3
>
> Note that "devlink instance" reprensents one ASIC.
> The address of the devlink instance is the bus address of the ASIC.
> Here, you use address of some/first netdevsim netdev instance.
The ASIC here is the kernel tables in a namespace. It does not make
sense to have 2 devlink instances for a single namespace.
>
> The way it is implemented in netdevsim by this patch is wrong on
> so many levels :(
>
> Could you please fix this? I'm more than happy to help you with this,
> please say so. Thanks!
What is there to fix?
Not creating a netdevsim device per netdevsim netdevice? That is
completely unrelated to the devlink change.
Powered by blists - more mailing lists