• Mike Looijmans's avatar
    net: mdiobus: Prevent spike on MDIO bus reset signal · e0183b97
    Mike Looijmans authored
    The mdio_bus reset code first de-asserted the reset by allocating with
    GPIOD_OUT_LOW, then asserted and de-asserted again. In other words, if
    the reset signal defaulted to asserted, there'd be a short "spike"
    before the reset.
    
    Here is what happens depending on the pre-existing state of the reset
    signal:
    Reset (previously asserted):   ~~~|_|~~~~|_______
    Reset (previously deasserted): _____|~~~~|_______
                                      ^ ^    ^
                                      A B    C
    
    At point A, the low going transition is because the reset line is
    requested using GPIOD_OUT_LOW. If the line is successfully requested,
    the first thing we do is set it high _without_ any delay. This is
    point B. So, a glitch occurs between A and B.
    
    We then fsleep() and finally set the GPIO low at point C.
    
    Requesting the line using GPIOD_OUT_HIGH eliminates the A and B
    transitions. Instead we get:
    
    Reset (previously asserted)  : ~~~~~~~~~~|______
    Reset (previously deasserted): ____|~~~~~|______
                                       ^     ^
                                       A     C
    
    Where A and C are the points described above in the code. Point B
    has been eliminated.
    
    The issue was found when we pulled down the reset signal for the
    Marvell 88E1512P PHY (because it requires at least 50ms after POR with
    an active clock). Looking at the reset signal with a scope revealed a
    short spike, point B in the artwork above.
    Signed-off-by: default avatarMike Looijmans <mike.looijmans@topic.nl>
    Reviewed-by: default avatarAndrew Lunn <andrew@lunn.ch>
    Link: https://lore.kernel.org/r/20210202143239.10714-1-mike.looijmans@topic.nlSigned-off-by: default avatarJakub Kicinski <kuba@kernel.org>
    e0183b97
mdio_bus.c 26 KB