Re: [PATCH v4] md: generate CHANGE uevents for md device

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hi,

在 2024/05/09 23:33, Mariusz Tkaczyk 写道:
On Thu, 9 May 2024 21:09:12 +0800
Yu Kuai <yukuai1@xxxxxxxxxxxxxxx> wrote:

   static DECLARE_WAIT_QUEUE_HEAD(md_event_waiters);
   static atomic_t md_event_count;
-void md_new_event(void)
+void md_new_event(struct mddev *mddev)
   {
   	atomic_inc(&md_event_count);
   	wake_up(&md_event_waiters);
+	schedule_work(&mddev->uevent_work);

This doesn't look correct, if uevent_work is queued already and not
running yet, this will do nothing, which means uevent will be missing.
Looks like you want to generate as much uevent as md_new_event() is
called, or you maybe don't care about this?

I think we don't need to care. I meant that we don't need perfect mechanism.
If there will be two events queued then probably userspace will be busy
handling first one so the second one will be unnoticed anyway. Perhaps, we
should left comment?

I'm not sure, for example:

1) user remove a device, wait for uevent;
2) a event is triggered by other context, while the device is not
removed yet;
3) user receive a event, then how do user side handle this case?

And if we really don't care about this case, comment will be good.



By the way, since we're here, will it be better to add some uevent
description in detail as well? for example:

After add a new disk by mdadm, use kobject_uevent_env() and pass in
additional string like "add <disk> to array/conf".

And many other events.


Could you please elaborate more? I don't understand why this comment is
connected to new disk, potentially CHANGE uevent can be generated in more
scenarios, like rebuild/resync/reshape end, level change, starting raid array,
stopping raid array (I just briefly looked where md_new_event() is called). I
think that it is correct because those changes are real CHANGE of mddevice
state. Also, there is a comment below md_new_event():

Yes, this is just an example for add device. I mean all other events
should be attached with proper string as well. So that if user just remove a disk, it can wait for the CHANGE event with the additional
string like "remove xxx".

Thanks,
Kuai


  * Events are:
  *  start array, stop array, error, add device, remove device,
  *  start build, activate spare

Thanks,
Mariusz

.






[Index of Archives]     [Linux RAID Wiki]     [ATA RAID]     [Linux SCSI Target Infrastructure]     [Linux Block]     [Linux IDE]     [Linux SCSI]     [Linux Hams]     [Device Mapper]     [Device Mapper Cryptographics]     [Kernel]     [Linux Admin]     [Linux Net]     [GFS]     [RPM]     [git]     [Yosemite Forum]


  Powered by Linux