Message ID | 20231213181554.4741-1-ansuelsmth@gmail.com (mailing list archive) |
---|---|
Headers | show |
Series | net: add define to describe link speed modes | expand |
On Wed, Dec 13, 2023 at 07:15:52PM +0100, Christian Marangi wrote: > This is a simple series to add define to describe link speed modes. > > Hope the proposed way is acceptable with the enum and define. > > This is also needed in the upcoming changes in the netdev trigger for LEDs > where phy_speeds functions is used to declare a more compact array instead > of using a "big enough" approach. I'm trying to figure out the 'big picture' here. The LED trigger will call ksetting_get to get a list of supported link modes. You can then use the table struct phy_setting settings[] in phy-core.c to translate the link mode to a speed. You are likely to get a lot of duplicate speeds, but you can remove them. For each speed you need to create a sysfs file. Why not just create a linked list, rather than an array? Or just walk the table and find out how many different speeds there are and allocate an array of that size. Its currently 15, which is not that big. And then just use the is_visible method to hide the ones which are not relevant. I don't see any need for new enums or tables here, just a function to look up a link mode in that table and return the speed. Andrew
On Thu, Dec 14, 2023 at 12:05:52AM +0100, Andrew Lunn wrote: > On Wed, Dec 13, 2023 at 07:15:52PM +0100, Christian Marangi wrote: > > This is a simple series to add define to describe link speed modes. > > > > Hope the proposed way is acceptable with the enum and define. > > > > This is also needed in the upcoming changes in the netdev trigger for LEDs > > where phy_speeds functions is used to declare a more compact array instead > > of using a "big enough" approach. > > I'm trying to figure out the 'big picture' here. > > The LED trigger will call ksetting_get to get a list of supported link > modes. You can then use the table struct phy_setting settings[] in > phy-core.c to translate the link mode to a speed. You are likely to > get a lot of duplicate speeds, but you can remove them. For each speed > you need to create a sysfs file. Why not just create a linked list, > rather than an array? Or just walk the table and find out how many > different speeds there are and allocate an array of that size. Its > currently 15, which is not that big. And then just use the is_visible > method to hide the ones which are not relevant. > > I don't see any need for new enums or tables here, just a function to > look up a link mode in that table and return the speed. > The big picture was to have an handy define and statically allocate the array with the max amount of link modes possible without having to allocate kernel memory at runtime. With the current way of allocating only the needed space, I have to parse the settings table 2 times (one to get the number and the second time to compose the actual array) Not a problem since these are called only on LED register or when the device name is called... Just extra code and the fact that kmalloc can fail with ENOMEM. (but that is almost imposible and would be in an OOM condition)