• William A. Kennington III's avatar
    powerpc/opal: Fix EBUSY bug in acquiring tokens · 71e24d77
    William A. Kennington III authored
    The current code checks the completion map to look for the first token
    that is complete. In some cases, a completion can come in but the
    token can still be on lease to the caller processing the completion.
    If this completed but unreleased token is the first token found in the
    bitmap by another tasks trying to acquire a token, then the
    __test_and_set_bit call will fail since the token will still be on
    lease. The acquisition will then fail with an EBUSY.
    
    This patch reorganizes the acquisition code to look at the
    opal_async_token_map for an unleased token. If the token has no lease
    it must have no outstanding completions so we should never see an
    EBUSY, unless we have leased out too many tokens. Since
    opal_async_get_token_inrerruptible is protected by a semaphore, we
    will practically never see EBUSY anymore.
    
    Fixes: 8d724823 ("powerpc/powernv: Infrastructure to support OPAL async completion")
    Signed-off-by: default avatarWilliam A. Kennington III <wak@google.com>
    Signed-off-by: default avatarMichael Ellerman <mpe@ellerman.id.au>
    71e24d77
opal-async.c 4.99 KB