On Tue, Aug 16, 2011 at 07:23:52PM +0300, Grumbach, Emmanuel wrote: > > Simply by adding to iwl_priv different struct ops/data for each upper > > layer you will have. You need to have the same thing to clue with > > mac80211, whatever upper layer will be. Otherwise, if mac80211 clue > > have to be different, new hardware probably needs different driver. > > > > I would be reluctant to have all the data / ops needed by all the possible HW > all the time in priv. I don't think it is a good idea to have unallocated pointers > for a bus that don't need the rings... Not sure why there would be any unallocated pointers. > Instead, I think that having a HW specific area that is allocated for each HW is much > nicer and reliable. This is what this patch series is all about. > Furthermore, I don't want the HW layer to dereference iwl_priv, We discussed with Wey upper and lower layer, term HW layer confuse me even more here. > the same way the low level > driver doesn't dereference mac80211's local pointer. This is what the iwl_shared is all about. Yes ieee80211_local is hidden from drivers, but IMHO this is because it is very big structure and we needed separate it logically into smaller structures. Most structures like net_device or Scsi_Host don't do any hiding from lower layers and are just fine. > Are things clearer now ? Unfortunately no. Perhaps you could describe all these layers in same schematic. Explain what for they are, show how they will be clued together and list they particular implementations. Particularly is interesting how do you want to clue driver with mac80211 having different iwl_priv structures. Also, what for are separate iwl_trans_pcie and iwl_bus_pcie instead of one thing that talk to pcie bus. I would not care what you do with iwlwifi driver, but what I learnt from the past you are develop driver in the way that is very hard to debug and support it. On the same time, what is the most disappointing, you are ignoring majority of users bug reports, not leaving other choice that fix bugs by themselves. Hence is important to have driver as clean designed as possible, without any needles layers, abstractions and structures. Stanislaw -- To unsubscribe from this list: send the line "unsubscribe linux-wireless" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html