Johannes Berg <johannes@xxxxxxxxxxxxxxxx> wrote: > On Mon, 2015-03-02 at 18:40 +0100, Florian Westphal wrote: > > to make it fit into (future) 44-byte sized skb->cb[]. > > > > This works, since flags is only used to store values > > from mac80211_tx_control_flags enum, and these are just 2 bits. > > We can thus move this to the padding hole inside the union. > > > > Also add BUILD_BUG_ON magic to make sure that the new flags > > field doesn't share storage w. other members of the union. > > This is really ugly - what's the point of this? Eventually reducing skb size to make it fit into 3 cachelines again even on 64bit architectures. For that 40 bytes need to go. > Mind you - we are actually acutely out of space and would rather have > *more*, not less. :-( I'm not familiar with mac80211, aside from that it seemed to me that 40 byte cb would be doable, given enough work. Where are to main problems, exactly? I known that pushing something into ->cb is a lot easier than e.g. keeping extra state on stack, but, IMO cb should really only be used when you need to associate data strictly with an skb so that this data is still availabe even when skb gets queued somewehere. Is there a document somewhere that lists all of the per-skb data that mac80211 needs to store (or wants to store)? Thanks, Florian -- 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