/********************************************************************************************************************************/ /* Created: 15-MAR-2001 23:38:00 by OpenVMS SDL EV1-33 */ /* Source: 15-MAR-2001 23:34:09 _$11$DUA933:[BUILD.SDL]STARDEFFL.SDI;1 */ /********************************************************************************************************************************/ /*** MODULE $LKIDEF ***/ #ifndef __LKIDEF_LOADED #define __LKIDEF_LOADED 1 #pragma nostandard #ifdef __cplusplus extern "C" { #define __unknown_params ... #else #define __unknown_params #endif #if !defined(__VAXC) && !defined(VAXC) #define __struct struct #define __union union #else #define __struct variant_struct #define __union variant_union #endif /*+ */ /* */ /* Get Lock Information Data Identifier Definitions */ /* */ /* **** NOTE **** */ /* */ /* New items must always be added to the END of each item list */ /* (preceeding the ENDlistname item) so that users will not have */ /* to relink. */ /*- */ /* ITEM LIST BLOCKS */ #define LKI$K_LENGTH 24 /*LENGTH OF LIST BLOCK WITHOUT BYTE RANGE INFO */ #define LKI$C_LENGTH 24 /*LENGTH OF LIST BLOCK WITHOUT BYTE RANGE INFO */ #define LKI$K_BR_LENGTH 56 /*LENGTH OF LIST BLOCK WITH BYTE RANGE INFO */ #define LKI$C_BR_LENGTH 56 /*LENGTH OF LIST BLOCK WITH BYTE RANGE INFO */ /* WITH MULTITASK INFO. */ struct lkidef { __union { unsigned int lki$l_mstlkid; /*LOCK ID ON MASTER */ unsigned int lki$l_lockid; /*OLD SYMBOL */ } lki$r_u1; unsigned int lki$l_pid; /*PROCESS ID */ __union { unsigned int lki$l_mstcsid; /*CSID OF MASTER */ unsigned int lki$l_sysid; /*OLD SYMBOL */ } lki$r_u2; unsigned char lki$b_rqmode; /*REQUEST MODE */ unsigned char lki$b_grmode; /*GRANTED MODE */ char lki$b_queue; /*LOCK QUEUE */ char lki$$$_spare; /*SPARE BYTE */ __union { unsigned int lki$l_lkid; /*LOCK ID ON PROCESS NODE */ unsigned int lki$l_remlkid; /*OLD SYMBOL */ } lki$r_u3; __union { unsigned int lki$l_csid; /*CSID OF PROCESS NODE */ unsigned int lki$l_remsysid; /*OLD SYMBOL */ } lki$r_u4; unsigned int lki$q_rqstart [2]; /* REQUEST RANGE START */ unsigned int lki$q_rqlength [2]; /* REQUEST RANGE LENGTH */ unsigned int lki$q_grstart [2]; /* GRANTED RANGE START */ unsigned int lki$q_grlength [2]; /* GRANTED RANGE LENGTH */ } ; #if !defined(__VAXC) && !defined(VAXC) #define lki$l_mstlkid lki$r_u1.lki$l_mstlkid #define lki$l_lockid lki$r_u1.lki$l_lockid #define lki$l_mstcsid lki$r_u2.lki$l_mstcsid #define lki$l_sysid lki$r_u2.lki$l_sysid #define lki$l_lkid lki$r_u3.lki$l_lkid #define lki$l_remlkid lki$r_u3.lki$l_remlkid #define lki$l_csid lki$r_u4.lki$l_csid #define lki$l_remsysid lki$r_u4.lki$l_remsysid #endif /* #if !defined(__VAXC) && !defined(VAXC) */ /* DEFINE NAMSPACE FIELDS */ #define LKI$M_SYSNAM 0x80000000 struct namspace { __union { __struct { unsigned short int lki$w_group; /*GROUP OF OWNER UIC */ unsigned char lki$b_rmod; /*ACCESS MODE OF REQUEST */ unsigned char lki$b_status; /*STATUS OF RESOURCE */ } lki$r_namspace_fields; __struct { unsigned lki$$_fill : 31; /* SPARE */ unsigned lki$v_sysnam : 1; /* SYSTEM WIDE RSB */ } lki$r_status_bits; } lki$r_namspace_union; } ; #if !defined(__VAXC) && !defined(VAXC) #define lki$w_group lki$r_namspace_union.lki$r_namspace_fields.lki$w_group #define lki$b_rmod lki$r_namspace_union.lki$r_namspace_fields.lki$b_rmod #define lki$b_status lki$r_namspace_union.lki$r_namspace_fields.lki$b_status #define lki$v_sysnam lki$r_namspace_union.lki$r_status_bits.lki$v_sysnam #endif /* #if !defined(__VAXC) && !defined(VAXC) */ /* DEFINE STATE FIELDS */ struct statef { unsigned char lki$b_state_rqmode; /*REQUEST MODE */ unsigned char lki$b_state_grmode; /*GRANTED MODE */ char lki$b_state_queue; /*LOCK STATE CODE */ } ; #define LKIUSR$K_LENGTH 20 #define LKIUSR$C_LENGTH 20 #define LKIUSR$K_BLOCKER_START 20 /* OFFSET TO THE START OF THE RETURNED INFORMATION */ struct lkiusrdef { unsigned int lkiusr$q_start [2]; /* START OF THE REQUESTED RANGE */ unsigned int lkiusr$q_length [2]; /* LENGTH OF THE REQUESTED RANGE */ unsigned char lkiusr$b_rqmode; /* REQUESTED MODE */ unsigned char lkiusr$b_ignore_own; /* FLAG TO IGNORE LOCKS OWNED BY THE CALLING PROCESS */ short int lki$$_fill_1; /* reserved */ } ; struct rngdef { unsigned int lki$_rng_q_rqstart [2]; /* REQUEST RANGE START */ unsigned int lki$_rng_q_rqlength [2]; /* REQUEST RANGE LENGTH */ unsigned int lki$_rng_q_grstart [2]; /* GRANTED RANGE START */ unsigned int lki$_rng_q_grlength [2]; /* GRANTED RANGE LENGTH */ } ; /*LOCK STATE CODE VALUES */ #define LKI$C_GRANTED 1 /* GRANTED */ #define LKI$C_CONVERT 0 /* CONVERSION */ #define LKI$C_WAITING -1 /* WAITING */ #define LKI$C_RETRY -2 /* RETRY REQUEST */ #define LKI$C_SCSWAIT -3 /* SCS WAIT */ #define LKI$C_RSPNOTQED -4 /* RESPONSE NOT QUEUED */ #define LKI$C_RSPQUEUED -5 /* RESPONSE QUEUED */ #define LKI$C_RSPGRANTD -6 /* RESPONSE GRANTED */ #define LKI$C_RSPDOLOCL -7 /* RESPONSE DO LOCALLY */ #define LKI$C_RSPRESEND -8 /* RESPONSE RESEND */ /* DEFINE TABLE NUMBERS */ /* STRUCTURE CODES MUST START AT 1 */ #define LKI$C_LKBTYPE 1 /* ITEM IN LKB */ #define LKI$C_RSBTYPE 2 /* ITEM IN RSB */ #define LKI$C_LISTEND 0 /* DEFINE ITMLST TERMINATOR */ /* ITEM IDENTIFIERS FOR LKB */ #define LKI$_PID 256 /* PROCESS ID */ #define LKI$_STATE 257 /* CURRENT LOCK STATE */ #define LKI$_PARENT 258 /* ID OF PARENT LOCK */ #define LKI$_LCKREFCNT 259 /* SUB-LOCK REFERENCE COUNT */ #define LKI$_LOCKID 260 /* LOCK ID */ #define LKI$_REMLKID 261 /* REMOTE LOCK ID */ #define LKI$_MSTLKID 262 /* LOCK ID ON RESOURCE MASTER */ #define LKI$_LKID 263 /* LOCK ID ON PROCESS NODE */ #define LKI$_CSID 264 /* CSID OF PROCESS NODE */ #define LKI$_BRL 265 /* IS THE LOCK A BYTE RANGE LOCK */ #define LKI$_RANGE 266 /* Range of request */ #define LKI$_LASTLKB 267 /* MAX INDEX IN LKB TABLE */ /* ITEM IDENTIFIERS FOR RSB */ #define LKI$_NAMSPACE 512 /* RESOURCE NAME SPACE */ #define LKI$_RESNAM 513 /* RESOURCE NAME */ #define LKI$_RSBREFCNT 514 /* SUB-RESOURCE REFERENCE COUNT */ #define LKI$_VALBLK 515 /* VALUE BLOCK */ #define LKI$_SYSTEM 516 /* SYSTEM ID OF SYSTEM WITH RESOURCE */ #define LKI$_LCKCOUNT 517 /* COUNT OF LOCKS ON RESOURCE */ #define LKI$_BLOCKEDBY 518 /* LIST OF LOCKS BLOCKED BY CURRENT LOCK */ #define LKI$_BLOCKING 519 /* LIST OF LOCKS BLOCKING CURRENT LOCK */ #define LKI$_LOCKS 520 /* LIST OF ALL LOCKS ON RESOURCE */ #define LKI$_CVTCOUNT 521 /* COUNT OF LOCKS ON CONVERSION QUEUE */ #define LKI$_WAITCOUNT 522 /* COUNT OF LOCKS ON WAIT QUEUE */ #define LKI$_GRANTCOUNT 523 /* COUNT OF LOCKS ON GRANT QUEUE */ #define LKI$_MSTCSID 524 /* CSID OF RESOURCE MASTER */ #define LKI$_VALBLKST 525 /* VALUE BLOCK STATUS */ #define LKI$_BLOCKEDBY_BR 526 /* LIST OF LOCKS BLOCKED BY CURRENT LOCK WITH BYTE RANGES */ #define LKI$_BLOCKING_BR 527 /* LIST OF LOCKS BLOCKING THE CURRENT LOCK WITH BYTE RANGES */ #define LKI$_LOCKS_BR 528 /* LIST OF LOCKS ALL LOCKS ON A RESOURCE WITH BYTE RANGES */ #define LKI$_BLOCKER_BR 529 /* LOCK THAT WILL BLOCK THE REQUESTED RANGE AND MODE */ #define LKI$_LASTRSB 530 /* MAX INDEX IN RSB */ #define LKISND$K_HDRLEN 16 /*LENGTH OF HEADER */ #define LKISND$C_HDRLEN 16 /*LENGTH OF HEADER */ struct lkisnddef { /* Format for local system buffer header when sending an information request */ /* to a remote system. */ unsigned short int lkisnd$w_retsize; /* size of return info */ unsigned short int lkisnd$w_status; /* status of operation */ unsigned short int lkisnd$w_flags; /* flags */ unsigned short int lkisnd$w_seqnum; /* rebuild seqnm */ unsigned short int lkisnd$w_size; /* size of structure */ unsigned char lkisnd$b_type; /* type of stucture */ unsigned char lkisnd$b_fill_2; /* */ unsigned char lkisnd$b_item_length; /* len of item info */ unsigned char lkisnd$b_fill_3; /* */ unsigned short int lkisnd$w_fill_4; /* */ } ; #ifdef __cplusplus } #endif #pragma standard #endif /* __LKIDEF_LOADED */