Re: [PATCH 001 of 6] md: Send online/offline uevents when an md array starts/stops.
From: Kay Sievers <hidden>
Date: 2006-11-08 11:14:46
Also in:
lkml
On Mon, 2006-11-06 at 11:18 +1100, Neil Brown wrote:
On Friday November 3, kay.sievers@vrfy.org wrote:
quoted
The persistent naming rules for /dev/disk/by-* are causing this. Md devices will probably just get their own rules file, which will handle this and which can be packaged and installed along with the md tools.
I'm still a bit concerned about the open->add->open infinite loop. If anyone opens /dev/mdX while it isn't active (e.g. to check if it is active), that will (given a patch that I would like to include) cause and ADD event which will cause udev to start it's loop again. Can we make udev ignore ADD for md and only watch for CHANGE?
Is there a sysfs file or something similar(we could also call a md-tool)
udev could look at, before it tries to open the device? Like:
KERNEL=="md*", ATTR{state}=="active", IMPORT{program}= ...
If we currently ignore the "add" event, then we will not hook into the
coldplug logic, where "add" events are requested for all devices to do
the initial setup after bootup.
If we can't read the state of the md device, to see if it's safe to open
the device, we would need to be smarter with the coldplug logic by
requesting "change" events if necessary, or by passing a "coldplug" flag
with the synthesized event.
Thanks,
Kay