• J
    bus: mhi: core: Remove link_status() callback · 85a087df
    Jeffrey Hugo 提交于
    If the MHI core detects invalid data due to a PCI read, it calls into
    the controller via link_status() to double check that the link is infact
    down.  All in all, this is pretty pointless, and racy.  There are no good
    reasons for this, and only drawbacks.
    
    Its pointless because chances are, the controller is going to do the same
    thing to determine if the link is down - attempt a PCI access and compare
    the result.  This does not make the link status decision any smarter.
    
    Its racy because its possible that the link was down at the time of the
    MHI core access, but then recovered before the controller access.  In this
    case, the controller will indicate the link is not down, and the MHI core
    will precede to use a bad value as the MHI core does not attempt to retry
    the access.
    
    Retrying the access in the MHI core is a bad idea because again, it is
    racy - what if the link is down again?  Furthermore, there may be some
    higher level state associated with the link status, that is now invalid
    because the link went down.
    
    The only reason why the MHI core could see "invalid" data when doing a PCI
    access, that is actually valid, is if the register actually contained the
    PCI spec defined sentinel for an invalid access.  In this case, it is
    arguable that the MHI implementation broken, and should be fixed, not
    worked around.
    
    Therefore, remove the link_status() callback before anyone attempts to
    implement it.
    Signed-off-by: NJeffrey Hugo <jhugo@codeaurora.org>
    Reviewed-by: NManivannan Sadhasivam <manivannan.sadhasivam@linaro.org>
    Reviewed-by: NHemant Kumar <hemantk@codeaurora.org>
    Signed-off-by: NManivannan Sadhasivam <manivannan.sadhasivam@linaro.org>
    Link: https://lore.kernel.org/r/20200430190555.32741-4-manivannan.sadhasivam@linaro.orgSigned-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
    85a087df
init.c 32.6 KB