cxlflash: Fix async interrupt bypass logic
A bug was introduced earlier in the development cycle when cleaning up logic statements. Instead of skipping bits that are not set, set bits are skipped, causing async interrupts to not be handled correctly. To fix, simply add back in the proper evaluation for an unset bit. Signed-off-by: Matthew R. Ochs <mrochs@linux.vnet.ibm.com> Signed-off-by: Manoj N. Kumar <manoj@linux.vnet.ibm.com> Reviewed-by: Brian King <brking@linux.vnet.ibm.com> Reviewed-by: Andrew Donnellan <andrew.donnellan@au1.ibm.com> Reviewed-by: Tomas Henzl <thenzl@redhat.com> Signed-off-by: James Bottomley <JBottomley@Odin.com>
This commit is contained in:
parent
ef51074a4e
commit
16798d3448
|
@ -1315,7 +1315,7 @@ static irqreturn_t cxlflash_async_err_irq(int irq, void *data)
|
|||
/* check each bit that is on */
|
||||
for (i = 0; reg_unmasked; i++, reg_unmasked = (reg_unmasked >> 1)) {
|
||||
info = find_ainfo(1ULL << i);
|
||||
if ((reg_unmasked & 0x1) || !info)
|
||||
if (((reg_unmasked & 0x1) == 0) || !info)
|
||||
continue;
|
||||
|
||||
port = info->port;
|
||||
|
|
Loading…
Reference in New Issue