On VAX systems, the value returned is a longword integer. On Alpha systems, the value returned requires a quadword of storage. If the buffer size supplied is not equal to 8 bytes, and the virtual peak exceeds the maximum value that can be represented in a longword, $GETJPI returns the largest positive 32-bit integer: 2147483647.
The Get Job/Process Information service returns information about one or more processes on the system or across the cluster. Using $GETJPI with $PROCESS_SCAN, you can perform selective or clusterwide searches.Getting information about another process is an asynchronous operation because the information might be contained in the virtual address space of the target process, and that process might be running at a lower priority, be outswapped, or be suspended in a miscellaneous or resource wait state. To allow your program to overlap other functions with the time needed to access the data in the other process, $GETJPI returns immediately after it has queued its information-gathering request to the other process. You can use the JPI$_GETJPI item code to control the processing of the $GETJPI call and the information-gathering interprocess request itself.
When performing an asynchronous system service call such as $GETJPI, the specifications of the iosb argument and a unique event flag are used in conjunction with mechanisms such as the $SYNCH system service to synchronize the final completion of the asynchronous system service call.
Required Access or Privileges
The calling process must have GROUP privilege to obtain information about other processes with the same group UIC number as the calling process. The calling process must have WORLD privilege to obtain information about other processes on the system that are not in the same group as the calling process.
Required Quota
Related Services
$GETJPIW, $HIBER, $PROCESS_SCAN, $RESUME, $SYNCH
SS$_NORMAL The service completed successfully. SS$_ACCVIO The item list cannot be read by the caller, or the buffer length or buffer cannot be written by the caller. SS$_BADPARAM The item list contains an invalid identifier. Or, an item list containing both 32-bit and 64-bit item list entries was found. SS$_INCOMPAT The remote node is running an incompatible version of the operating system. SS$_IVLOGNAM The process name string has a length of 0 or has more than 15 characters. SS$_NOMOREPROC In a wildcard operation, $GETJPI found no more processes. SS$_NONEXPR The specified process does not exist, or an invalid process identification was specified. SS$_NOPRIV The process does not have the privilege to obtain information about the specified process. SS$_NOSUCHNODE The specified node is not currently a member of the cluster. SS$_REMRSRC The remote node has insufficient resources to respond to the request. (Bring this error to the attention of your system manager.) SS$_SUSPENDED The specified process is suspended or in a miscellaneous wait state, and the requested information cannot be obtained. SS$_UNREACHABLE The remote node is a member of the cluster but is not accepting requests. This is normal for a brief period early in the system boot process.
Same as those returned in R0.
*/ /* Defining __NEW_STARLET enables the program to benefit from better type checking for prototypes and structures provided by OpenVMS. */ #define __NEW_STARLET 1 #include <efndef> /* No Event Flag Event Flag */ #include <iledef> /* Item List Entry Definitions */ #include <iosbdef> /* I/O Status Block Structure Definition */ #include <jpidef> /* $GETJPI Item Code Definitions */ #include <ssdef> /* SS Message Codes */ #include <starlet> /* Function Prototypes for System Services */ #include <stdio> /* C Standard I/O Functions */ #include <string> /* MEMSET Prototype */ #include <stsdef> /* Status Block Definitions */ #define NUM_ILE 5 #define NAME_LENGTH 16 #define IMAGE_LENGTH 255 /* Macro to initialize a 32-bit item_list_3. */ #define init_ile32(ile, length, code, bufaddr, retlen_addr) \ { (ile)->ile3$w_length = (length); \ (ile)->ile3$w_code = (code); \ (ile)->ile3$ps_bufaddr = (bufaddr); \ (ile)->ile3$ps_retlen_addr = (retlen_addr); } main () { char imagename [IMAGE_LENGTH], procname [NAME_LENGTH], username [NAME_LENGTH]; int count = 0, retpid, status; unsigned int pid = -1; unsigned short imagename_length, procname_length, username_length; ILE3 jpi_ile [NUM_ILE]; IOSB iosb; /* Zeroing the item list has the effect of creating the terminating entry. */ memset (jpi_ile, 0, ILE3$K_LENGTH*NUM_ILE); /* Initialize the item list entries to fetch the user name, the process name, the image name and the PID. */ init_ile32 ( &jpi_ile [0], NAME_LENGTH, JPI$_USERNAME, username, &username_length); init_ile32 ( &jpi_ile [1], NAME_LENGTH, JPI$_PRCNAM, procname, &procname_length); init_ile32 ( &jpi_ile [2], IMAGE_LENGTH, JPI$_IMAGNAME, imagename, &imagename_length); init_ile32 ( &jpi_ile [3], sizeof (int), JPI$_PID, &retpid, NULL); /* Initial wildcard $GETJPI. */ status = sys$getjpiw ( EFN$C_ENF, &pid, NULL, &jpi_ile, &iosb, NULL, 0); /* Loop for all processes on this node. */ while (status != SS$_NOMOREPROC) { if (status & STS$M_SUCCESS) { /* Zero terminate process and image name strings. */ imagename [imagename_length] = '\0'; username [username_length] = '\0'; procname [procname_length] = '\0'; /* Print header if this is the first. */ if (count == 0) printf (" PID User Name Process Name Image\n"); /* Count process and print process data. */ count++; printf ("%08X %-15s %-15s %s\n", retpid, username, procname, imagename); } /* Skip process if suspended or no privilege to see process. Return any other error. */ else if ((status != SS$_NOPRIV) && (status != SS$_SUSPENDED)) return (status); /* Find next process. */ status = sys$getjpiw ( EFN$C_ENF, &pid, NULL, &jpi_ile, &iosb, NULL, 0); } return (SS$_NORMAL); }
This example C program demonstrates how to use$GETJPIW to obtain the PID, process name, and current image being executed for every process for which the caller has the privilege to obtain information.
The Get Job/Process Information and Wait service returns information about one or more processes on the system.The $GETJPIW service completes synchronously; that is, it returns to the caller with the requested information. Digital recommends that you use an IOSB with this service. An IOSB prevents the service from completing prematurely. In addition, the IOSB contains status information.
For asynchronous completion, use the Get Job/Process Information ($GETJPI) service; $GETJPI returns to the caller after queuing the information request, without waiting for the information to be returned.
In all other respects, $GETJPIW is identical to $GETJPI. For all other information about the $GETJPIW service, refer to the description of $GETJPI in this manual.
On Alpha systems, this service accepts 64-bit addresses.
SYS$GETJPIW [efn] ,[pidadr] ,[prcnam] ,itmlst ,[iosb] ,[astadr] ,[astprm]
int sys$getjpiw (unsigned int efn, unsigned int *pidadr, void *prcnam, void *itmlst, struct _iosb *iosb, void (*astadr)(__unknown_params), int astprm);
Returns information about the lock database on a system.The $GETLKI service completes asynchronously; for synchronous completion, use the Get Lock Information and Wait ($GETLKIW) service.
The $GETLKI, $GETLKIW, $ENQ, $ENQW, and $DEQ services together provide the user interface to the Lock Management facility.
SYS$GETLKI [efn] ,lkidadr ,itmlst [,iosb] [,astadr] [,astprm] [,nullarg]
int sys$getlki (unsigned int efn, unsigned int *lkidadr, void *itmlst, struct _iosb *iosb, void (*astadr)(__unknown_params), int astprm, unsigned int reserved);
efn
OpenVMS usage: ef_number type: longword (unsigned) access: read only mechanism: by value
Number of the event flag to be set when $GETLKI completes. The efn argument is a longword containing this number; however, $GETLKI uses only the low-order byte. If you do not specify efn, $GETLKI sets event flag 0.lkidadr
OpenVMS usage: lock_id type: longword (unsigned) access: modify mechanism: by reference
Lock identification (lock ID) for the lock about which information is to be returned. The lock ID is the second longword in the lock status block, which was created when the lock was granted. The lkidadr argument is the address of this longword.If the value specified by lkidadr is 0 or --1, $GETLKI assumes a wildcard operation and returns information about each lock to which the calling process has access, one lock per call.
To use the $GETLKI service, you must have read/write access to the lock ID.
itmlst
OpenVMS usage: item_list_3 type: longword (unsigned) access: read only mechanism: by reference
Item list specifying the lock information that $GETLKI is to return. The itmlst argument is the address of a list of item descriptors, each of which describes an item of information. The list of item descriptors is terminated by a longword of 0.The following diagram depicts the format of a single item descriptor.
![]()
The following table defines the item descriptor fields.
Descriptor Field Definition Buffer length A word containing a user-supplied integer specifying the length (in bytes) of the buffer in which $GETLKI is to write the information. The length of the buffer needed depends upon the item code specified in the item code field of the item descriptor. If the value of the buffer length field is too small, $GETLKI truncates the data and returns the success condition value SS$_NORMAL. Item code A word containing a user-specified symbolic code the item of information that $GETLKI is to return. The $LKIDEF macro defines these codes. Each item code is described in the list of $GETLKI item codes that follows the argument descriptions. Buffer address A longword containing a user-supplied address of the buffer in which $GETLKI is to write the information. Return length address A longword containing the user-supplied address of a longword in which $GETLKI writes return length information. This longword contains the following three bit fields.
Bits 0 to 15 In this, field $GETLKI writes the length in bytes of the data actually written to the buffer specified by the buffer address field in the item descriptor. Bits 16 to 30 $GETLKI uses this field only when the item code field of the item descriptor specifies LKI$_BLOCKEDBY, LKI$_BLOCKING, or LKI$_LOCKS, each of which requests information about a list of locks. $GETLKI writes in this field the length in bytes of the information returned for a single lock on the list. You can divide this length into the total length returned for all locks (bits 0 to 15) to determine the number of locks located by that item code request.
Bit 31 $GETLKI sets this bit if the user-supplied buffer length argument specifies too small a buffer to contain the information returned. Note that in such a case $GETLKI will return the SS$_NORMAL condition value in R0. Therefore, to locate any faulty item descriptor, you need to check the state of bit 31 in the longword specified by the return length field of each item descriptor. iosb
OpenVMS usage: io_status_block type: quadword (unsigned) access: write only mechanism: by reference
I/O status block that is to receive the final completion status. The iosb argument is the address of a quadword.When $GETLKI is called, it sets the I/O status block to 0. When $GETLKI completes, it writes a condition value to the first longword in the quadword. The remaining two words in the quadword are unused.
Although this argument is optional, Digital strongly recommends that you specify it, for the following reasons:
- If you are using an event flag to signal the completion of the service, you can test the I/O status block for a condition value to be sure that the event flag was not set by an event other than service completion.
- If you are using the $SYNCH service to synchronize completion of the service, the I/O status block is a required argument for $SYNCH.
- The condition value returned in R0 and the condition value returned in the I/O status block provide information about different aspects of the call to the $GETLKI service. The condition value returned in R0 gives you information about the success or failure of the service call itself; the condition value returned in the I/O status block gives you information about the success or failure of the service operation. Therefore, to accurately assess the success or failure of the call to $GETLKI, you must check the condition values returned in both R0 and the I/O status block.
astadr
OpenVMS usage: ast_procedure type: procedure value access: call without stack unwinding mechanism: by reference
AST service routine to be executed when the service completes. The astadr argument is the address of this routine.If you specify this argument, the AST routine executes at the same access mode as the caller of the $GETLKI service.
astprm
OpenVMS usage: user_arg type: longword (unsigned) access: read only mechanism: by value
AST parameter to be passed to the AST service routine specified by the astadr argument. The astprm argument is the longword parameter.nullarg
OpenVMS usage: null_arg type: longword (unsigned) access: read only mechanism: by value
Placeholding argument reserved by Digital.
LKI$_BLOCKEDBY
When you specify LKI$_BLOCKEDBY, $GETLKI returns information about all locks that are currently blocked by the lock specified by lkidadr. The $GETLKI service returns eight items of information about each blocked lock.The $LKIDEF macro defines the following symbolic names that refer to the eight items in the buffer.
Symbolic Name Description LKI$L_MSTLKID Lock ID of the blocked lock on the system maintaining the resource (4 bytes) LKI$L_PID Process ID (PID) of the process that took out the blocked lock (4 bytes) LKI$L_MSTCSID OpenVMS Cluster system identifier (CSID) of the node maintaining the resource that is locked by the blocked lock (4 bytes) LKI$B_RQMODE Lock mode requested for the blocked lock; this lock mode was specified by the lkmode argument in the call to $ENQ (1 byte) LKI$B_GRMODE Lock mode granted to the blocked lock; this lock mode is written to the lock value block (1 byte) LKI$B_QUEUE Name of the queue on which the blocked lock currently resides (1 byte) LKI$L_LKID Lock ID of the lock on the system where the lock was requested (4 bytes) LKI$L_CSID OpenVMS Cluster system identifier (CSID) of the system where the lock was requested (4 bytes) The values that $GETLKI can write into the LKI$B_RQMODE, LKI$B_GRMODE, and LKI$B_QUEUE items have symbolic names; these symbolic names specify the six lock modes and the three types of queue in which a lock can reside. The Description section describes these names.
Thus, the buffer specified by the buffer address field in the item descriptor will contain the eight items of information, repeated in sequence, for each blocked lock.
The length of the information returned for each blocked lock is returned in bits 16 to 30 of the longword specified by the return length address field in the item descriptor, while the total length of information returned for all blocked locks is returned in bits 0 to 15. Therefore, to determine the number of blocked locks, you divide the value of bits 16 to 30 into the value of bits 0 to 15.
LKI$_BLOCKING
When you specify LKI$_BLOCKING, $GETLKI returns information about all locks that are currently blocking the lock specified by lkidadr. The $GETLKI service returns eight items of information about each blocking lock.The $LKIDEF macro defines the following symbolic names that refer to the eight items in the buffer.
Symbolic Name Description LKI$L_MSTLKID Lock ID of the blocked lock on the system maintaining the resource (4 bytes) LKI$L_PID Process ID (PID) of the process that took out the blocking lock (4 bytes) LKI$L_MSTCSID OpenVMS Cluster system identifier (CSID) of the node maintaining the resource that is locked by the blocking lock (4 bytes) LKI$B_RQMODE Lock mode requested for the blocking lock; this lock mode was specified by the lkmode argument in the call to $ENQ (1 byte) LKI$B_GRMODE Lock mode granted to the blocking lock; this lock mode is written to the lock value block (1 byte) LKI$B_QUEUE Name of the queue on which the blocking lock currently resides (1 byte) LKI$L_LKID Lock ID of the lock on the system where the lock was requested (4 bytes) LKI$L_CSID OpenVMS Cluster system identifier (CSID) of the system where the lock was requested (4 bytes) The values that $GETLKI can write into the LKI$B_RQMODE, LKI$B_GRMODE, and LKI$B_QUEUE items have symbolic names; these symbolic names specify the six lock modes and the three types of queue in which a lock can reside. The Description section describes these names.
Thus, the buffer specified by the buffer address field in the item descriptor will contain the eight items of information, repeated in sequence, for each blocking lock.
The length of the information returned for each blocking lock is returned in bits 16 to 30 of the longword specified by the return length address field in the item descriptor, while the total length of information returned for all blocking locks is returned in bits 0 to 15. Therefore, to determine the number of blocking locks, you divide the value of bits 16 to 30 into the value of bits 0 to 15.
LKI$_CSID
When you specify LKI$_CSID, $GETLKI returns the Cluster System ID (CSID) of the system where the process owning the lock resides. LKI$_CSID returns the CSID of the node where the $GETLKI system service is issued when the resource is mastered on that node. When the processor is not part of a cluster, LKI$_CSID returns 0.The buffer length field in the item descriptor should specify 4 (bytes).
LKI$_CVTCOUNT
When you specify LKI$_CVTCOUNT, $GETLKI returns the total number of locks that are currently on the conversion queue of the resource associated with the lock. These locks are granted at one mode and are waiting to be converted to another.The buffer length field in the item descriptor should specify 4 (bytes).
LKI$_GRANTCOUNT
When you specify LKI$_GRANTCOUNT, $GETLKI returns the total number of locks that are currently on the grant queue of the resource associated with the lock. Note that the total number of granted locks on the resource is equal to the sum of LKI$_CVTCOUNT and LKI$_GRANTCOUNT.The buffer length field in the item descriptor should specify 4 (bytes).
LKI$_LCKREFCNT
When you specify LKI$_LCKREFCNT, $GETLKI returns the number of locks that have this lock as a parent lock. When these locks were created, the parid argument in the call to $ENQ or $ENQW specified the lock ID of this lock.The buffer length field in the item descriptor should specify 4 (bytes).
LKI$_LKID
When you specify LKI$_LKID, $GETLKI returns the lock ID of the lock on the system where the process owning the lock resides. The lock ID returned by this item code is meaningful only on the system specified in the value returned by the LKI$_CSID item code.The buffer length field in the item descriptor should specify 4 (bytes).
LKI$_LOCKID
When you specify LKI$_LOCKID, $GETLKI returns the lock ID of the current lock. The current lock is the one specified by the lkidadr argument unless lkidadr is specified as --1 or 0, which indicates a wildcard operation. Thus, this item code is usually specified only in wildcard operations where it is useful to know the lock IDs of the locks that $GETLKI has discovered in the wildcard operation.The lock ID is a longword value, so the buffer length field in the item descriptor should specify 4 (bytes).
LKI$_LOCKS
When you specify LKI$_LOCKS, $GETLKI returns information about all locks on the resource associated with the lock specified by lkidadr.The $LKIDEF macro defines the following symbolic names that refer to the eight items in the buffer.
Symbolic Name Description LKI$L_MSTLKID Lock ID of the blocked lock on the system maintaining the resource (4 bytes) LKI$L_PID Process ID (PID) of the process that took out the lock (4 bytes) LKI$L_MSTCSID OpenVMS Cluster system identifier (CSID) of the node maintaining the resource that is locked by the lock (4 bytes) LKI$B_RQMODE Lock mode requested for the lock; this lock mode was specified by the lkmode argument in the call to $ENQ (1 byte) LKI$B_GRMODE Lock mode granted to the lock; this lock mode is written to the lock value block (1 byte) LKI$B_QUEUE Name of the queue on which the lock currently resides (1 byte) LKI$L_LKID Lock ID of the lock on the system where the lock was requested (4 bytes) LKI$L_CSID OpenVMS Cluster system identifier (CSID) of the system where the lock was requested (4 bytes)
Previous | Next | Contents | [Home] | [Comments] | [Ordering info] | [Help]
![]()
4527P039.HTM OSSG Documentation 22-NOV-1996 12:59:47.43Copyright © Digital Equipment Corporation 1996. All Rights Reserved.