scds_hasp_check - get status information aboutSUNW.HAStoragePlusresources that are used by a resource
cc [flags…] –I /usr/cluster/include file –L /usr/cluster/lib –l dsdev#include <rgm/libdsdev.h> scha_err_t scds_hasp_check(scds_handle_t handle, scds_hasp_status_t *hasp_status);
The scds_hasp_check()() function retrieves status information about SUNW.HAStoragePlus resources that are used by a resource. This information is obtained from the state, online or otherwise, of all SUNW.HAStoragePlus resources on which the resource depends. This state is obtained by using the Resource_dependencies, Resource_dependencies_weak, Resource_dependencies_restart, or Resource_dependencies_offline_restart properties that are defined for the resource.
If the FileSystemMountPoints property of a SUNW.HAStoragePlus resource is nonempty, the scds_hasp_check()() function considers the resource to be online on a given node, if and only if all the file systems that are listed in the FileSystemMountPoints property are currently mounted on that node. File systems that are mounted globally might be mounted on a node where the SUNW.HAStoragePlus resource is offline. All of the FileSystemMountPoints, whether mounted locally or globally, must be mounted on a node for the SUNW.HAStoragePlus resource to be considered online on that node. The actual state of the resource might be online or offline. If any of these file systems are not mounted on the node, the resource is considered to be offline and its actual state will also be offline.
Resource type implementations can use scds_hasp_check()() in VALIDATE and MONITOR_CHECK method callback implementations to determine whether checks that are specific to any file systems that are managed by SUNW.HAStoragePlus resources should be carried out.
Resource dependencies are only checked within the same cluster context in which the function is executed, either global cluster or zone cluster. Dependencies of the form clustername:resourcename (inter-cluster dependencies) are ignored. For example, if the only HAStoragePlus dependency is an intercluster dependency, the function returns the status code SCDS_HASP_NO_RESOURCE.
When the function succeeds, a status code is stored in the hasp_status parameter. This code can be one of the following values:
Indicates that the resource does not depend on a SUNW.HAStoragePlus resource.
Indicates that a SUNW.HAStoragePlus resource on which the resource depends is not online on any potential primary node.
Indicates that at least one SUNW.HAStoragePlus resource on which the resource depends is not online on the node from which this function is called but is online on another node.
Indicates that all SUNW.HAStoragePlus resources on which the resource depends are online on the node from which this function is called.
The scds_hasp_check()() function ignores SUNW.HAStoragePlus resources for which the FilesystemMountPoints and Zpools properties are both set to an empty list, which is the default, even if the GlobalDevicePaths property is nonempty.
The following parameters are supported:
Handle that is returned from scds_initialize.
Status of SUNW.HAStoragePlus resources that are used by the resource.
The function succeeded.
This value also indicates that the status code that is stored in the hasp_status parameter is valid.
The function failed.
The value that is stored in the hasp_status parameter is undefined. Ignore this undefined value.
See the scha_calls(3HA) man page for a description of other error codes.
Include file
Library
See attributes (5) for descriptions of the following attributes:
|
scds_initialize(3HA), scha_calls(3HA), attributes (5) , SUNW.HAStoragePlus(5)