On Sat, 02 Dec 2023 11:06:36 +0100 Johannes Berg wrote: > > Would it work if we exposed "linkwatch is pending" / "link is > > transitioning" bit to user space? > > Not sure, not by much or more than what this did? It's basically the > same, I think: I exposed the carrier_up_count at the kernel time, so if > userspace hasn't seen an event with a value >= that it knows the link is > transitioning. The benefit being that it'd work for everyone, without having to add the carrier count in random events? > > Even crazier, would it help if we had rtnl_getlink() run > > linkwatch for the target link if linkwatch is pending? > > Sure, if we were to just synchronize that at the right time (doesn't > even need to be rtnl_getlink, could be a new operation) that'd solve the > issue too, perhaps more easily. I was wondering about the new op, too, but "synchronize things please" op feels a little hacky. rtnl_getlink returns link state, so it feels somewhat natural for it to do the sync, to make sure that what it returns is in fact correct information. No strong feelings, tho. rtnl_getlink does return a lot, so maybe a new rtnl_getcarrier op? Or we can make reading sysfs "carrier" do the sync?