Page MenuHomeFreeBSD

al_eth: Finish conversion to IfAPI
ClosedPublic

Authored by jhibbits on Mar 7 2023, 7:18 PM.
Tags
None
Referenced Files
Unknown Object (File)
Wed, Jan 1, 1:08 AM
Unknown Object (File)
Sat, Dec 28, 11:11 PM
Unknown Object (File)
Sat, Dec 28, 7:35 AM
Unknown Object (File)
Fri, Dec 27, 9:53 AM
Unknown Object (File)
Nov 27 2024, 7:20 PM
Unknown Object (File)
Nov 7 2024, 10:00 PM
Unknown Object (File)
Nov 2 2024, 3:14 AM
Unknown Object (File)
Nov 2 2024, 3:10 AM
Subscribers

Details

Summary

One gotcha with this is I don't know if the if_link_state_change() calls
are correct, so need further review.

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Skipped
Unit
Tests Skipped
Build Status
Buildable 50202
Build 47094: arc lint + arc unit

Event Timeline

zlei requested changes to this revision.Mar 8 2023, 3:41 AM
zlei added a subscriber: zlei.
zlei added inline comments.
sys/dev/al_eth/al_eth.c
342

I dont think this should be changed.
This LINK_STATE_DOWN is the initial state of ifp, and the ifp should not be exposed until fully constructed.

3518

I think this is correct usage of if_link_state_change().

This revision now requires changes to proceed.Mar 8 2023, 3:41 AM
sys/dev/al_eth/al_eth.c
342

There's currently no way to just set the link state. I could add the API, but it would be used only by this driver. The initial state is LINK_STATE_UNKNOWN.

@wma would it be possible for you to test the driver with the if_link_state setting removed? No other driver explicitly sets the link state.

Drop the initial link state. Nothing else sets initial link state.

I do not have al_eth devices. It is ideally someone can test this.

Generally looks good to me, except the concurrency of device_detach and miibus_statchg event.

sys/dev/al_eth/al_eth.c
342

I do not see any logic checking adapter->netdev->if_link_state. So an initial state LINK_STATE_UNKNOWN should be OK.

3521

I'm a little worried about this LINK_STATE_DOWN event.

if_link_state_change(struct ifnet *ifp, int link_state)
{
        /* Return if state hasn't changed. */
        if (ifp->if_link_state == link_state)
                return;

        ifp->if_link_state = link_state;

        /* XXXGL: reference ifp? */
        taskqueue_enqueue(taskqueue_swi, &ifp->if_linktask);
}

I'm not familiar with MII bus.
Is it possible that we get concurrent device_detach / al_detach() and miibus_statchg / al_miibus_statchg() ?
If yes then the above LINK_STATE_DOWN may lead use-after-free.
See also D39614 .

This revision is now accepted and ready to land.Apr 25 2023, 3:31 AM
sys/dev/al_eth/al_eth.c
3521

I think al_detach() probably needs a bus_generic_detach() to detach its child miibus. This seems common across at least several drivers I've looked at.

This revision was automatically updated to reflect the committed changes.