net: dsa: Fix use after free in dsa_switch_remove()
authorFlorian Fainelli <f.fainelli@gmail.com>
Sun, 3 Nov 2019 03:13:26 +0000 (20:13 -0700)
committerDavid S. Miller <davem@davemloft.net>
Wed, 6 Nov 2019 01:53:58 +0000 (17:53 -0800)
commitc058f6dfeb1c645e77dc89d1690848ca06f45735
treea3da3bf333e70412ca42f2bcc1fb58318cc8e2af
parent2bceefbe557f4b4e875ca6db19a9f8a8bb3d557d
net: dsa: Fix use after free in dsa_switch_remove()

The order in which the ports are deleted from the list and freed and the
call to dsa_switch_remove() is done is reversed, which leads to an
use after free condition. Reverse the two: first tear down the ports and
switch from the fabric, then free the ports associated with that switch
fabric.

Fixes: 05f294a85235 ("net: dsa: allocate ports on touch")
Signed-off-by: Florian Fainelli <f.fainelli@gmail.com>
Reviewed-by: Vivien Didelot <vivien.didelot@gmail.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
net/dsa/dsa2.c