Message ID | 20241021120313.493371-1-avri.altman@wdc.com |
---|---|
Headers | show |
Series | Untie the host lock entanglement - part 1 | expand |
> On 10/21/24 5:03 AM, Avri Altman wrote: > > Introduce a new host register read/write lock. Use it to protect > > access to the task management doorbell register: UTMRLDBR. This is > > not the UTRLDBR which is already protected by its own outstanding_lock. > > Why is this necessary? I think it is allowed to submit host controller reads > and writes simultaneously from different threads. Only read/modify/writes > have to be serialized. Done. > > Thanks, > > Bart.
> On 10/21/24 5:03 AM, Avri Altman wrote: > > @@ -3100,9 +3100,9 @@ static int ufshcd_clear_cmd(struct ufs_hba *hba, > u32 task_tag) > > mask = 1U << task_tag; > > > > /* clear outstanding transaction before retry */ > > - spin_lock_irqsave(hba->host->host_lock, flags); > > + spin_lock_irqsave(&hba->reg_lock, flags); > > ufshcd_utrl_clear(hba, mask); > > - spin_unlock_irqrestore(hba->host->host_lock, flags); > > + spin_unlock_irqrestore(&hba->reg_lock, flags); > > > > /* > > * wait for h/w to clear corresponding bit in door-bell. > > Hi Avri, > > A similar comment as for the previous patch applies to this patch: > ufshcd_utrl_clear() performs a single MMIO write so I don't think that calls of > this function have to be serialized. Done. Thanks, Avri > > Thanks, > > Bart.