| ==================== | 
| device-mapper uevent | 
| ==================== | 
|   | 
| The device-mapper uevent code adds the capability to device-mapper to create | 
| and send kobject uevents (uevents).  Previously device-mapper events were only | 
| available through the ioctl interface.  The advantage of the uevents interface | 
| is the event contains environment attributes providing increased context for | 
| the event avoiding the need to query the state of the device-mapper device after | 
| the event is received. | 
|   | 
| There are two functions currently for device-mapper events.  The first function | 
| listed creates the event and the second function sends the event(s):: | 
|   | 
|   void dm_path_uevent(enum dm_uevent_type event_type, struct dm_target *ti, | 
|                       const char *path, unsigned nr_valid_paths) | 
|   | 
|   void dm_send_uevents(struct list_head *events, struct kobject *kobj) | 
|   | 
|   | 
| The variables added to the uevent environment are: | 
|   | 
| Variable Name: DM_TARGET | 
| ------------------------ | 
| :Uevent Action(s): KOBJ_CHANGE | 
| :Type: string | 
| :Description: | 
| :Value: Name of device-mapper target that generated the event. | 
|   | 
| Variable Name: DM_ACTION | 
| ------------------------ | 
| :Uevent Action(s): KOBJ_CHANGE | 
| :Type: string | 
| :Description: | 
| :Value: Device-mapper specific action that caused the uevent action. | 
|     PATH_FAILED - A path has failed; | 
|     PATH_REINSTATED - A path has been reinstated. | 
|   | 
| Variable Name: DM_SEQNUM | 
| ------------------------ | 
| :Uevent Action(s): KOBJ_CHANGE | 
| :Type: unsigned integer | 
| :Description: A sequence number for this specific device-mapper device. | 
| :Value: Valid unsigned integer range. | 
|   | 
| Variable Name: DM_PATH | 
| ---------------------- | 
| :Uevent Action(s): KOBJ_CHANGE | 
| :Type: string | 
| :Description: Major and minor number of the path device pertaining to this | 
|           event. | 
| :Value: Path name in the form of "Major:Minor" | 
|   | 
| Variable Name: DM_NR_VALID_PATHS | 
| -------------------------------- | 
| :Uevent Action(s): KOBJ_CHANGE | 
| :Type: unsigned integer | 
| :Description: | 
| :Value: Valid unsigned integer range. | 
|   | 
| Variable Name: DM_NAME | 
| ---------------------- | 
| :Uevent Action(s): KOBJ_CHANGE | 
| :Type: string | 
| :Description: Name of the device-mapper device. | 
| :Value: Name | 
|   | 
| Variable Name: DM_UUID | 
| ---------------------- | 
| :Uevent Action(s): KOBJ_CHANGE | 
| :Type: string | 
| :Description: UUID of the device-mapper device. | 
| :Value: UUID. (Empty string if there isn't one.) | 
|   | 
| An example of the uevents generated as captured by udevmonitor is shown | 
| below | 
|   | 
| 1.) Path failure:: | 
|   | 
|     UEVENT[1192521009.711215] change@/block/dm-3 | 
|     ACTION=change | 
|     DEVPATH=/block/dm-3 | 
|     SUBSYSTEM=block | 
|     DM_TARGET=multipath | 
|     DM_ACTION=PATH_FAILED | 
|     DM_SEQNUM=1 | 
|     DM_PATH=8:32 | 
|     DM_NR_VALID_PATHS=0 | 
|     DM_NAME=mpath2 | 
|     DM_UUID=mpath-35333333000002328 | 
|     MINOR=3 | 
|     MAJOR=253 | 
|     SEQNUM=1130 | 
|   | 
| 2.) Path reinstate:: | 
|   | 
|     UEVENT[1192521132.989927] change@/block/dm-3 | 
|     ACTION=change | 
|     DEVPATH=/block/dm-3 | 
|     SUBSYSTEM=block | 
|     DM_TARGET=multipath | 
|     DM_ACTION=PATH_REINSTATED | 
|     DM_SEQNUM=2 | 
|     DM_PATH=8:32 | 
|     DM_NR_VALID_PATHS=1 | 
|     DM_NAME=mpath2 | 
|     DM_UUID=mpath-35333333000002328 | 
|     MINOR=3 | 
|     MAJOR=253 | 
|     SEQNUM=1131 |