Thu, Aug 27, 2015 at 09:43:54AM CEST, john.fastab...@gmail.com wrote:
>On 15-08-27 12:27 AM, Jiri Pirko wrote:
>> Thu, Aug 27, 2015 at 09:16:44AM CEST, sfel...@gmail.com wrote:
>>> From: Scott Feldman <sfel...@gmail.com>
>>>
>>> In the switchdev model, we use netdevs to represent switchdev ports, but we
>>> have no representation for the switch itself.  So, introduce a new switchdev
>>> device class so we can define semantics and programming interfaces for the
>>> switch itself.  Switchdev device class isn't tied to any particular bus.
>>>
>>> This patch set is just the skeleton to get us started.  It adds the sysfs
>>> object registration for the new class and defines a class-level attr "foo".
>>> With the new class, we could hook PM functions, for example, to handle power
>>> transitions at the switch level.  I registered rocker and get:
>>>
>>>   $ ls /sys/class/switchdev/5254001235010000/
>>>   foo  power  subsystem  uevent
>> 
>> No, please avoid adding anything to sysfs. If we need to add anything,
>> lets make is accesible using Netlink only.
>> 
>> 
>>>
>>> So what next?  I'd rather not build APIs around sysfs, so we need a netlink 
>>> API
>>> we can build on top of this.  It's not really rtnl.  Maybe genl would work?
>>> What ever it is, we'd need to teach iproute2 about a new 'switch' command.
>>>
>>> Netlink API would allow us to represent switch-wide objects such as 
>>> registers,
>>> tables, stats, firmware, and maybe even control.  I think with with netlink
>>> TLVs, we can create a framework for these objects but still allow the switch
>>> driver provide switch-specific info.  For example, a table object:
>>>
>>> [TABLES]
>>>     [TABLE]
>>>             [FIELDS]
>>>                     [FIELD]
>>>                             [ID, TYPE]
>>>             [DATA]
>>>                     [ID, VALUE]
>> 
>> Alert! I feel that someone would like to abuse this iface for writing
>> configuration through. This should be read-only by design. I also think
>> that this should not be something switch-specific. I believe that NIC
>> drivers would benefit from this iface as well when they want to expose
>> something. I think we should use genl for this.
>> 
>
>One place where read-only may not make sense is when the tables can
>be provisioned/configured. Many switches have the ability to be
>configured with "profiles". For a simple example some hardware use a
>single table that can be divided into an IPv4 and an IPv6 section.

Okay. That should be configured via separate configuration Netlink
interface - ConfNetlink. I already spoke with Dave about need for
that one: Netlink based, use PCI-addr (other addr) as a handle,
well-defined config objects. The need to this interface is bigger and bigger.

I can cook-up some RFC patch so you see what I'm talking about.
--
To unsubscribe from this list: send the line "unsubscribe netdev" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to