On 2023-04-10 23:26, Song Liu wrote: > On Mon, Apr 10, 2023 at 6:34 PM Yu Kuai <yukuai1@xxxxxxxxxxxxxxx> wrote: >> >> Hi, >> >> 在 2023/04/11 9:15, Song Liu 写道: >>> On Mon, Apr 10, 2023 at 4:37 AM Yu Kuai <yukuai1@xxxxxxxxxxxxxxx> wrote: >>>> >>>> From: Yu Kuai <yukuai3@xxxxxxxxxx> >>>> >>>> Prepare to protect md_thread with rcu, there are no functional changes. >>> >>> Why do we need this change? To add __rcu later? >> >> Add __rcu is one reason, more importantly is to assign md_thread inside >> md_register_thread in patch 6: >> >> rcu_assign_pointer(*threadp, thread); > > Got it. > >>> >>> Can we do something like: >>> >>> struct md_thread __rcu *md_register_thread(void (*run) (struct md_thread *), >>> struct mddev *mddev, const char *name) >> >> I think this is not necessary, if we don't want to change api, we must >> use rcu_assign_pointer for each caller to set md_thread. > > I think it is better to use rcu_assign_pointer at the caller side. I agree. Logan