• Frank Li's avatar
    i3c: master: svc: fix wrong data return when IBI happen during start frame · 5e5e3c92
    Frank Li authored
         ┌─────┐     ┏──┐  ┏──┐  ┏──┐  ┏──┐  ┏──┐  ┏──┐  ┏──┐  ┏──┐  ┌─────
    SCL: ┘     └─────┛  └──┛  └──┛  └──┛  └──┛  └──┛  └──┛  └──┛  └──┘
         ───┐                       ┌─────┐     ┌─────┐     ┌───────────┐
    SDA:    └───────────────────────┘     └─────┘     └─────┘           └─────
         xxx╱    ╲╱                                        ╲╱    ╲╱    ╲╱    ╲
       : xxx╲IBI ╱╲               Addr(0x0a)               ╱╲ RW ╱╲NACK╱╲ S  ╱
    
    If an In-Band Interrupt (IBI) occurs and IBI work thread is not immediately
    scheduled, when svc_i3c_master_priv_xfers() initiates the I3C transfer and
    attempts to send address 0x7e, the target interprets it as an
    IBI handler and returns the target address 0x0a.
    
    However, svc_i3c_master_priv_xfers() does not handle this case and proceeds
    with other transfers, resulting in incorrect data being returned.
    
    Add IBIWON check in svc_i3c_master_xfer(). In case this situation occurs,
    return a failure to the driver.
    
    Fixes: dd3c5284 ("i3c: master: svc: Add Silvaco I3C master driver")
    Cc:  <stable@vger.kernel.org>
    Reviewed-by: default avatarMiquel Raynal <miquel.raynal@bootlin.com>
    Signed-off-by: default avatarFrank Li <Frank.Li@nxp.com>
    Link: https://lore.kernel.org/r/20231023161658.3890811-3-Frank.Li@nxp.comSigned-off-by: default avatarAlexandre Belloni <alexandre.belloni@bootlin.com>
    5e5e3c92
svc-i3c-master.c 45.1 KB