MP_REGISTERFOROBJECTPROPERTYCHANGES(3MPAPI)
Common Multipath Management Library Functions

NAME


MP_RegisterForObjectPropertyChanges - register a client function to
be called

SYNOPSIS


cc [ flag... ] file... -lMPAPI [ library... ]
#include <mpapi.h>

MP_STATUS MP_RegisterForObjectPropertyChanges(
MP_OBJECT_PROPERTY_FN pClientFn, MP_OBJECT_TYPE objectType,
void *pCallerData, MP_OID pluginOid);


PARAMETERS


pClientFn
A pointer to an object ID that has type
MP_OBJECT_PROPERTY_FN function defined by the client.
With a successful return, this function is called to
inform the client of objects that have had one or more
properties changed.


objectType
The type of object the client wishes to register for
property change callbacks.


pCallerData
A pointer that is passed to the callback routine with
each event. This might be used by the caller to
correlate the event to the source of the registration.


pluginOid
If this is a valid plugin object ID, then registration
is limited to that plugin. If this is zero, then the
registration is for all plugins.


DESCRIPTION


The MP_RegisterForObjectPropertyChanges() function registers a client
function to be called whenever the property of an object changes.


The function specified by pClientFn is called whenever the property
of an object changes. For the purposes of this function, a
property is defined to be a field in an object's property structure
and the object's status. Therefore, the client function is not called
if a statistic of the associated object changes. But, it is called
when the status changes (e.g., from working to failed) or when a name
or other field in a property structure changes.


It is not an error to re-register a client function. However, a
client function has only one registration. The first call to
deregister a client function will deregister it no matter how many
calls to register the function have been made.


If multiple properties of an object change simultaneously, a client
function can be called only once to be notified that all the changes
have occurred.

RETURN VALUES


MP_STATUS_INVALID_OBJECT_TYPE

The pluginOid or objectType does not specify any valid object
type. This is most likely to happen if an uninitialized object
ID is passed to the API.


MP_STATUS_OBJECT_NOT_FOUND

The pluginOid owner ID or object sequence number is invalid.


MP_STATUS_INVALID_PARAMETER

The pCallerData is null or if the pluginOid has a type subfield
other than MP_OBJECT_TYPE_PLUGIN, or when objectType is invalid.


MP_STATUS_SUCCESS

The operation is successful.


MP_STATUS_FN_REPLACED

An existing client function is replaced with the one specified in
pClientFn.


ATTRIBUTES


See attributes(7) for descriptions of the following attributes:


+--------------------+---------------------------+
| ATTRIBUTE TYPE | ATTRIBUTE VALUE |
+--------------------+---------------------------+
|Interface Stability | Standard: ANSI INCITS 412 |
| | Multipath Management API |
+--------------------+---------------------------+
|MT-Level | Safe |
+--------------------+---------------------------+

SEE ALSO


libMPAPI(3LIB), MP_DeregisterForObjectPropertyChanges(3MPAPI),
attributes(7)


Multipath Management API Version 1.0

February 15, 2006
MP_REGISTERFOROBJECTPROPERTYCHANGES(3MPAPI)

tribblix@gmail.com :: GitHub :: Privacy