/**/ /******************************************************************************/ /** **/ /** Copyright (c) 2001 **/ /** by DIGITAL Equipment Corporation, Maynard, Mass. **/ /** **/ /** This software is furnished under a license and may be used and copied **/ /** only in accordance with the terms of such license and with the **/ /** inclusion of the above copyright notice. This software or any other **/ /** copies thereof may not be provided or otherwise made available to any **/ /** other person. No title to and ownership of the software is hereby **/ /** transferred. **/ /** **/ /** The information in this software is subject to change without notice **/ /** and should not be construed as a commitment by DIGITAL Equipment **/ /** Corporation. **/ /** **/ /** DIGITAL assumes no responsibility for the use or reliability of its **/ /** software on equipment which is not supplied by DIGITAL. **/ /** **/ /******************************************************************************/ /********************************************************************************************************************************/ /* Created 15-MAR-2001 22:56:46 by VAX SDL T3.2-8 Source: 25-AUG-2000 09:05:37 $11$DUA933:[BACKUP.SRC]BACKSTRUC.SDL;1 */ /********************************************************************************************************************************/ /*** MODULE $BCKCOMMON ***/ #define BACKUP$VERSION "V7.3" /* Version number of BACKUP */ #define BACKUP$K_OPSYS_VAX 1024 /* Operating system ID */ #define BACKUP$K_OPSYS_ALPHA 2048 /* Operating system ID */ #define BACKUP$K_BACKUP 1 /* Subsystem ID */ #define BACKUP$K_DATABLOCK 1 /* Application ID normal blocks */ #define BACKUP$K_XORBLOCK 2 /* Application ID XOR blocks */ #define FILESCAN_LOGGING 1 /* Turn on (1) or off (0) internal */ #define TRUE 1 #define FALSE 0 #define ANSI_LBLSZ 6 /* ANSI Standard MT label name size */ #define ANSI_BLKSZ 80 /* ANSI Standard header size */ #define COPY_BUFF_COUNT 2 /* Default buffer count for disk-to-disk */ #define COPY_BUFF_SIZE 33040 /* Default buffer size for disk-to-disk */ #define SMALL_DISK 4096 /* Largest disk with no bad block data */ #define LIST_SIZE 512 /* Size of listing line */ #define JOUR_SIZE 512 /* Size of journal line */ #define MAX_RECORD 2048 /* Maximum length attribute record */ #define MAX_ATTRS 18 /* Maximum number of attributes in list */ #define STA_IN_CHAN 131071 /* Pseudo-channel for input */ #define STA_OUT_CHAN 196607 /* Pseudo-channel for output */ #define MAX_DCL_STRING_SIZE 1024 /* Max DCL command string size */ #define STD_PAGE_SIZE 512 /* Standard [VAX] page size (bytes) */ #define MIN_BUFFER_SPACE 6144 /* Minimum reasonable buffer size */ #define NEXT_TRY_BUFF_FACTOR 2 /* multiply factor for new buffer size */ #define D_K_SCANLVLS 8 /* ODS-1 directory levels supported */ #define MAX_CTRL_STRING_SIZE 256 /* Max. FAO control string size */ #define PFL_M_DIR 1 #define PFL_M_DESELECT 2 #define PFL_M_OPEN 4 #define PFL_M_IGNO_INTE 8 #define PFL_M_ERROR 16 #define PFL_M_HEADONLY 32 #define PFL_M_NOPOST 64 #define PFL_M_SAVE_ALL 128 #define PFL_M_F64DIR 256 #define PFL_M_ALIAS 512 #define PFL_K_LENGTH 56 /* length of PFL block */ #define PFL_C_LENGTH 56 /* length of PFL block */ struct PFL { char *PFL_A_RSA; /* Resultant name pointer */ char *PFL_A_DIRNAME; /* Directory name pointer */ /**** Note: Old overlay form must be used in FID & DID due to SDL bug */ /**** that omits the field size symbol in a structured field. */ union { /* File ID overlay. */ unsigned short int PFL_W_FID [3]; /* File's FID. */ struct { unsigned short int PFL_W_FID_NUM; /* File ID NUM. */ unsigned short int PFL_W_FID_SEQ; /* File ID SEQ. */ union { /* File RVN overlay. */ unsigned short int PFL_W_FID_RVNW; /* File ID RVN & NMX. */ struct { /* File ID RVN. */ unsigned char PFL_B_FID_RVN; /* FID RVN. */ unsigned char PFL_B_FID_NMX; /* FID NMX. */ } PFL_R_FID_RVN_FIELDS; } PFL_R_FID_RVN_OVERLAY; } PFL_R_FID_FIELDS; } PFL_R_FID_OVERLAY; union { unsigned short int PFL_W_DID [3]; /* Directory ID. */ struct { unsigned short int PFL_W_DID_NUM; /* File ID of directory. */ unsigned short int PFL_W_DID_SEQ; /* DID sequence number. */ union { unsigned short int PFL_W_DID_RVNW; /* RVN. */ struct { unsigned char PFL_B_DID_RVN; /* RVN byte. */ unsigned char PFL_B_DID_NMX; /* NMX for DID. */ } PFL_R_DID_RVN_FIELDS; } PFL_R_DID_RVN_OVERLAY; } PFL_R_DID_FIELDS; } PFL_R_DID_OVERLAY; unsigned short int PFL_W_S_RSA; /* Resultant name length */ unsigned short int PFL_W_S_DIRNAME; /* Directory name length */ unsigned long int PFL_L_CHANNEL; /* Channel for access to file. */ unsigned long int PFL_L_FILESIZE; /* Size of this file. */ unsigned short int PFL_W_REVISION; /* FI2$W_REVCNT (for access conflict check) */ unsigned short int PFL_W_S_DATA; unsigned long int PFL_L_D_UIC; /* Directory UIC. */ unsigned short int PFL_W_D_FPRO; /* Directory file protection. */ unsigned short int PFL_W_D_VERLIM; /* Directory version limit. */ unsigned long int PFL_L_DIR_STATUS; /* Copy of DIR_STATUS at time of scan. */ union { unsigned long int PFL_L_FLAGS; /* PFL flags. */ struct { unsigned PFL_V_DIR : 1; /* True for directories. */ unsigned PFL_V_DESELECT : 1; /* File removed from selection. */ unsigned PFL_V_OPEN : 1; /* Set if file is open. */ unsigned PFL_V_IGNO_INTE : 1; /* Set if we are to ignore conflicts. */ unsigned PFL_V_ERROR : 1; /* Set if there was a read error for the file. */ unsigned PFL_V_HEADONLY : 1; /* Set if the file's data isn't to be copied. */ unsigned PFL_V_NOPOST : 1; /* Set if error occurred, do not post-process this file. */ unsigned PFL_V_SAVE_ALL : 1; /* Set if [INCR] saving new/renamed dir's files. */ unsigned PFL_V_F64DIR : 1; /* Set if file is a Files-64 directory */ unsigned PFL_V_ALIAS : 1; /* Set if file is an ALIAS file entry. */ unsigned PFL_V_fill_2 : 6; } PFL_r_fill_1; } PFL_r_fill_0; int *PFL_A_CHKPT_BUF; /* Pointer to checkpoint data */ } ; #define DIRSTAT_M_VALID 1 #define DIRSTAT_M_DIR_SEL 2 #define DIRSTAT_M_SCANNED 4 #define DIRSTAT_M_FILE_SEL 8 struct PFLDIRSTAT { unsigned DIRSTAT_V_VALID : 1; /* DIR_STATUS is valid */ unsigned DIRSTAT_V_DIR_SEL : 1; /* Directory is selected */ unsigned DIRSTAT_V_SCANNED : 1; /* Directory was scanned */ unsigned DIRSTAT_V_FILE_SEL : 1; /* Files in directory are selected */ unsigned DIRSTAT_V_fill_3 : 4; } ; #define VVM_M_EOF 1 #define VVM_M_EOB 2 #define VVM_M_ERROR 4 #define VVM_M_COMPLETE 8 #define VVM_M_ISSUED 16 #define VVM_M_F64DIR 32 #define VVM_K_LENGTH 40 /* length of VVM block */ #define VVM_C_LENGTH 40 /* length of VVM block */ struct VVM { struct VVM *VVM_A_VBN_FLINK; /* Pointer to next VVM, VBN order. */ struct VVM *VVM_A_LBN_FLINK; /* Pointer to next VVM, LBN order. */ unsigned long int VVM_L_START_LBN; /* Starting LBN for read. */ unsigned long int VVM_L_START_VBN; /* Starting VBN for this extent/read. */ int *VVM_A_VA; /* Destination VA of read. */ struct PFL *VVM_A_PFL_PTR; /* Pointer back to PFL for file data. */ union { /* IOSB accessible as address or long. */ unsigned long int VVM_L_IOSB [2]; struct { unsigned long int VVM_L_IOSB1; unsigned long int VVM_L_IOSB2; } VVM_R_IOSB_FIELDS; } VVM_R_IOSB_OVERLAY; unsigned long int VVM_L_READ_SIZE; /* Size of this read. */ union { unsigned long int VVM_L_FLAGS; /* Flags for the read status. */ struct { unsigned VVM_V_EOF : 1; /* Set if this is the last read for the file. */ unsigned VVM_V_EOB : 1; /* Set if this read ends a buffer. */ unsigned VVM_V_ERROR : 1; /* Set if the read incurred an error. */ unsigned VVM_V_COMPLETE : 1; /* Set if the QIO completed. */ unsigned VVM_V_ISSUED : 1; /* Set when the QIO is issued. */ unsigned VVM_V_F64DIR : 1; /* Set if file is a Files-64 directory */ unsigned VVM_V_fill_6 : 2; } VVM_r_fill_5; } VVM_r_fill_4; } ; #define CPD_K_LENGTH 68 /* length of CPD block */ #define CPD_C_LENGTH 68 /* length of CPD block */ struct CPD { struct CPD *CPD_A_FLINK; /* Pointer to next CPD buffer. */ struct CPD *CPD_A_BLINK; /* Pointer to last CPD buffer. */ unsigned long int CPD_L_INPUT_CHAN; /* Current input channel */ int *CPD_A_PROC_LIST; /* Ptr to INPUT_PROC_LIST */ unsigned long int CPD_L_DIR_SCANLIMIT [8]; /* Directory queue context */ int *CPD_A_INPUT_QUAL; /* Pointer to input qualifier list */ unsigned long int CPD_L_FASTBUF_SIZE; /* Fast buffer size */ unsigned short int CPD_W_COM_FLAGS; /* Current common flags */ unsigned short int CPD_W_INPUT_FLAGS; /* Current input file flags */ unsigned char CPD_B_FAST_STRUCLEV; /* Structure level for fast backup */ unsigned char CPD_B_FAST_RVN; /* Current RVN */ unsigned char CPD_B_SETCOUNT; /* Number of volumes in set */ unsigned char CPD_B_LOST_RVN; /* Current RVN of lost file processing */ unsigned long int CPD_L_LOST_FILENUM; /* File number of lost file processing */ } ; #define FC_S_AREA 852 struct BCK$FC { unsigned char FC_FAB [80]; unsigned char FC_RAB [68]; unsigned char FC_NAM [96]; unsigned char FC_RLF [96]; unsigned char FC_ESA [256]; unsigned char FC_RSA [256]; } ; /* */ /* Qualifier Parameter Value Block */ /* */ #define QUAL_S_OUTP 44 /* Output Parameter Block size */ #define QUAL_S_INPU 60 /* Input Parameter Block size */ struct QUALPVB { struct QUALPVB *QUAL_NEXT; /* Pointer to next parameter block (common to all) */ int *QUAL_PARA_FC; /* Parameter file context */ struct dsc$descriptor QUAL_EXP_DESC; /* Descriptor for expanded string */ struct dsc$descriptor QUAL_DEV_DESC; /* Descriptor for device portion only */ struct dsc$descriptor QUAL_DVI_DESC; /* Descriptor for NAM$T_DVI string */ struct dsc$descriptor QUAL_LNM_DESC; /* Descriptor for volume logical name */ unsigned long int QUAL_ALLOC_CHAN; /* Device allocation channel */ unsigned long int QUAL_DEVCHAR2; /* Second longword for device char */ unsigned long int QUAL_USE_COUNT; /* Count of input files from this spec */ unsigned long int QUAL_USE_CHKPT; /* Cell to checkpoint QUAL_USE_COUNT */ unsigned QUAL_PAR_FLAGS : 32; /* Input/Output Parameter Flags */ } ; #define PFLAGS_M_DEV_MOU 1 union fill_7 { unsigned long int PFLAGS_L_PFLAGS; struct { unsigned PFLAGS_V_DEV_MOU : 1; /* [STABACKUP] device mounted */ /* (Used for /LIST of *.* tape savesets.) */ unsigned PFLAGS_V_fill_9 : 7; } PFLAGS_r_fill_8; } ; /* */ /* Encrypt Key [Parameter] Value Block */ /* */ #define QUAL_S_ENCV 12 /* Encrypt value list item */ struct ENCPVB { struct ENCPVB *QUAL_ENVA_LINK; /* Link word - Encrypt key value */ struct dsc$descriptor QUAL_ENVA_DESC; /* Value string descriptor - Encrypt key value */ } ; /* */ /* Exclude Parameter Value Block */ /* */ #define QUAL_S_EXCL 12 /* Exclude value list item size */ struct EXCLPVB { struct EXCLPVB *QUAL_EXCL_NEXT; /* Pointer to next parameter block (common to all) */ struct dsc$descriptor QUAL_EXCL_DESC; /* /EXCLUDE value */ } ; /* */ /* Select Parameter Value Block */ /* */ #define QUAL_S_SELE 12 /* Select value list item size */ struct SELEPVB { struct SELEPVB *QUAL_SELE_NEXT; /* Pointer to next parameter block (common to all) */ struct dsc$descriptor QUAL_SELE_DESC; /* /SELECT value */ } ; /* */ /* Label Parameter Value Block */ /* */ #define QUAL_S_LABE 16 /* Label value list item size */ struct LABEPVB { struct LABEPVB *QUAL_LABE_NEXT; /* Pointer to next parameter block (common to all) */ struct dsc$descriptor QUAL_LABE_VALUE; /* /LABEL value */ } ; /* */ /* Format of Bad Block Descriptor [Header] returned by routine GET_BADBLOCKS. */ /* */ #define BAD_S_HEADER 8 struct BADBLK { unsigned long int BAD_NUMDESC; /* Number of descriptors */ unsigned long int BAD_SERIAL; /* Pack serial number */ unsigned int BAD_DESC [2]; /* Origin of descriptors */ } ; /* */ /* Bad Block Descriptor */ /* */ #define BAD_S_DESC 8 struct BADBDSC { unsigned long int BAD_LBN; /* LBN */ unsigned long int BAD_COUNT; /* Count */ } ; /* */ /* MAX Number of FID/DID entries in an input_proc_list block. */ /* */ #define REC_MAX_COUNT 64 /* */ /* PROCESSED FILE ID LIST ( INPUT_PROC_LIST ) Entry */ /* */ #define REC_M_BADVER 1 #define REC_M_NOBACK 2 #define REC_M_FOPEN 4 #define REC_M_ACCESS 8 #define REC_S_PROC_FILE 13 /* The length of a FID/DID/FLAGS entry */ struct INPROCBLK { union { unsigned char REC_B_FLAGS; struct { unsigned REC_V_BADVER : 1; /* Flag to say verification pass failed */ unsigned REC_V_NOBACK : 1; /* Flag to say file marked NOBACKUP */ unsigned REC_V_FOPEN : 1; /* Flag to say file open (write access) */ unsigned REC_V_ACCESS : 1; /* Flag to say file access conflict */ unsigned REC_V_fill_12 : 4; } REC_r_fill_11; } fill_10; unsigned short int REC_RECFID [3]; /* File ID */ unsigned short int REC_RECDID [3]; /* Directory ID */ } ; /* */ /* PROCESSED FILE ID LIST ( INPUT_PROC_LIST ) */ /* */ #define REC_S_ENTRY 844 struct INPROCLST { struct INPROCLST *REC_NEXT; /* Pointer to next block */ struct QUALPVB *REC_QUAL; /* Value of INPUT_QUAL for this block */ unsigned short int REC_USED; /* Count of used entries in this block */ unsigned short int REC_VOLUME; /* Volume number */ unsigned short int (*(*REC_FID_BASE)); /* Base of FID/DID entries */ } ; /* */ /* Processed Volume ID (LABEL) List */ /* */ /* Field definitions for structure pointed to by OUTPUT_VID_LIST. */ /* */ /* The Volume ID list (VID) maintains the label/name of each volume in */ /* an output saveset (or tape volume set if you prefer) as it is */ /* processed. This allows MME routines to lookup a file's volume Id */ /* based on the volume's number as stored in the FID structures defined */ /* in the Processed File ID List (i.e. REC_VOLUME). The VID consists of */ /* a singly-linked list of VID blocks. Each block contains several */ /* slots of 12 characters, each containing a volume Id string (except */ /* for the last slot which is used as a header/control entry). */ /* */ /* Additional details about the use of the VID list can be found in */ /* module SAVE.B32. */ /* */ /* VID_ENTRY is the normal, 12 character volume (label) Id. The other */ /* fields define a remapping of VID_ENTRY as the header/control entry. */ /* */ struct VIDENT { unsigned char VID_ENTRY [12]; /* normal VID entry (12 bytes) */ } ; #define VID_S_ENTRY 12 /* size, in bytes, of an entry/slot */ struct VIDHDR { struct VIDHDR *VID_NEXT; /* pointer to next VID block */ unsigned char VID_BLKN; /* VID block number (0-255) */ unsigned char VID_MBZ_1 [3]; /* reserved...mbz (padding) */ unsigned long int VID_MBZ_2; /* reserved...mbz (padding) */ } ; #define VID_K_BASIS 16 /* modulo base */ #define VID_K_SLOTS 17 /* number of slots per VID block */ #define VID_S_BLOCK 204 /* size, in bytes, of a VID block */ #define BCB_S_IDLE 0 /* idle */ #define BCB_S_READ 1 /* read operation pending */ #define BCB_S_WRITE 2 /* write operation pending */ #define BCB_S_DATA 3 /* holding data, no I/O pending */ #define BCB_S_REREAD 4 /* read on alternate channel */ #define BCB_DATA_TYPE 0 /* Data (normal) type */ #define BCB_XOR_TYPE 1 /* XOR type */ #define BCB_FLAGS_START 44 /* offset used to init. flags */ #define BCB_M_WRITE_ISSUED 1 #define BCB_M_WRITE_REISSUED 2 #define BCB_M_WRITE_SYNCH 4 #define BCB_M_EIP_EOV 8 #define BCB_M_ASSOC_VREAD 16 #define BCB_M_FINAL_XOR 32 #define BCB_M_NEW_PASS 64 #define BCB_FLAGS_K_LENGTH 4 #define BCB_LENGTH 64 /* length of buffer control block */ struct BCBBLK { struct BCBBLK *BCB_FLINK; /* queue forward link */ struct BCBBLK *BCB_BLINK; /* queue back link */ unsigned short int BCB_SIZE; /* buffer size */ unsigned char BCB_STATE; /* buffer state */ unsigned char BCB_TYPE; /* Purpose (XOR, data) */ int *BCB_BUFFER; /* buffer address */ int *BCB_RECORD; /* current record pointer */ unsigned long int BCB_BLOCKNUM; /* disk block number */ union { unsigned short int BCB_IOSB [4]; /* I/O status block (base) */ struct { unsigned long int BCB_STATUS; /* I/O status longword */ unsigned long int BCB_STATUS2; /* second I/O status longword */ } IOSBLBLK; struct { unsigned short int BCB_IO_STATUS; /* I/O status word */ unsigned short int BCB_IO_BCOUNT; /* I/O status byte count */ unsigned long int BCB_IOSBWBLK_filler; } IOSBWBLK; } IOSBLKU; unsigned long int BCB_WRITE_FUNC; /* Write function for */ /* asynch writes */ int *BCB_SUCC_ACT; /* success action routine */ int *BCB_FAIL_ACT; /* failure action routine */ union { unsigned long int BCB_L_FLAGS; /* flags */ struct { unsigned BCB_V_WRITE_ISSUED : 1; /* Flag to indicate write was successfully issued */ unsigned BCB_V_WRITE_REISSUED : 1; /* Error write reissued */ unsigned BCB_V_WRITE_SYNCH : 1; /* Perform the write synchronously */ unsigned BCB_V_EIP_EOV : 1; /* Do not reissue from ast level during error processing */ unsigned BCB_V_ASSOC_VREAD : 1; /* At least one virtual read is associated with this buffer */ unsigned BCB_V_FINAL_XOR : 1; /* This is the final XOR BCB for the volume */ unsigned BCB_V_NEW_PASS : 1; /* Start of a new file scan pass */ unsigned BCB_V_fill_15 : 1; } BCB_r_fill_14; } fill_13; /* The following constant definition is required because the FLAGS structure */ /* and its length are not otherwise declared by SDL. */ /* */ struct PFL *BCB_FIRST_PFL; /* Pointer to first associated PFL */ struct PFL *BCB_LAST_PFL; /* Pointer to last associated PFL */ unsigned long int BCB_START_VBN; /* Starting VBN of first file represented in buffer */ unsigned long int BCB_NEXT_VBN; /* VBN of first file in next buffer */ } ; #define BSR_LENGTH 136 /* Length of BSR area */ struct BSRBLK { struct dsc$descriptor BSR_SSNAME; /* Descriptor for SSNAME */ struct dsc$descriptor BSR_COMMAND; /* Descriptor for COMMAND */ struct dsc$descriptor BSR_COMMENT; /* Descriptor for COMMENT */ struct dsc$descriptor BSR_USERNAME; /* Descriptor for USERNAME */ unsigned int BSR_DATE [2]; /* Value of DATE */ struct dsc$descriptor BSR_SYSVER; /* Descriptor for SYSVER */ struct dsc$descriptor BSR_NODENAME; /* Descriptor for NODENAME */ struct dsc$descriptor BSR_DRIVEID; /* Descriptor for DRIVEID */ struct dsc$descriptor BSR_BACKVER; /* Descriptor for BACKVER */ struct dsc$descriptor BSR_VOLSETNAM; /* Descriptor for VOLSETNAM */ unsigned int BSR_BACKSIZE [2]; /* Value of BACKSIZE */ unsigned long int BSR_USERUIC; /* Value of USERUIC */ unsigned long int BSR_SIR; /* Value of SIR */ unsigned long int BSR_BLOCKSIZE; /* Value of BLOCKSIZE */ unsigned long int BSR_BACKFILES; /* Value of BACKFILES */ unsigned short int BSR_OPSYS; /* Value of OPSYS */ unsigned short int BSR_XORSIZE; /* Value of XORSIZE */ unsigned short int BSR_BUFFERS; /* Value of BUFFERS */ unsigned short int BSR_NVOLS; /* Value of NVOLS */ unsigned char BSR_CRYPTDATA [24]; /* Value of CRYPTDATA */ } ; #define VSR_LENGTH 114 /* Length of VSR area */ struct VSRBLK { struct dsc$descriptor VSR_VSRVOLNAME; /* Descriptor for VOLNAME */ struct dsc$descriptor VSR_OWNERNAME; /* Descriptor for OWNERNAME */ struct dsc$descriptor VSR_FORMAT; /* Descriptor for FORMAT */ unsigned int VSR_VOLDATE [2]; /* Value of VOLDATE */ unsigned int VSR_TOTSIZE [2]; /* Value of TOTSIZE */ unsigned long int VSR_VOLOWNER; /* Value of VOLOWNER */ unsigned long int VSR_VOLSIZE; /* Value of VOLSIZE */ unsigned long int VSR_TOTFILES; /* Value of TOTFILES */ unsigned long int VSR_MAXFILES; /* Value of MAXFILES */ unsigned long int VSR_MAXFILNUM; /* Value of MAXFILNUM */ unsigned long int VSR_SERIALNUM; /* Value of SERIALNUM */ union { unsigned short int VSR_VOLSTRUCT; /* Value of VOLSTRUCT */ struct { unsigned char VOLSTRUCT_FILL1; /* dummy item to maintain offset */ unsigned char VSR_STRUCLEV; /* Structure level part of VOLSTRUCT */ } fill_17; } fill_16; unsigned short int VSR_RVN; /* Value of RVN */ unsigned short int VSR_PROTECT; /* Value of PROTECT */ unsigned short int VSR_FILEPROT; /* Value of FILEPROT */ unsigned short int VSR_RECPROT; /* Value of RECPROT */ unsigned short int VSR_VOLCHAR; /* Value of VOLCHAR */ unsigned short int VSR_EXTEND; /* Value of EXTEND */ unsigned short int VSR_CLUSTER; /* Value of CLUSTER */ unsigned short int VSR_RESFILES; /* Value of RESFILES */ unsigned char VSR_WINDOW; /* Value of WINDOW */ unsigned char VSR_LRU_LIM; /* Value of LRU_LIM */ unsigned long int VSR_INDEXLBN; /* Value of INDEXLBN */ struct dsc$descriptor VSR_BOOTBLOCK; /* Descriptor for BOOTBLOCK */ unsigned int VSR_RETAINMIN [2]; /* Value of RETAINMIN */ unsigned int VSR_RETAINMAX [2]; /* Value of RETAINMAX */ unsigned short int VSR_BACKREV; /* Value of BACKREV. */ } ; #define PVA_LENGTH 40 /* Length of PVA area */ struct PVABLK { struct dsc$descriptor PVA_DEVNAM; /* Descriptor for DEVNAM */ struct dsc$descriptor PVA_LABEL; /* Descriptor for LABEL */ struct dsc$descriptor PVA_BADBLOCK; /* Descriptor for BADBLOCK */ unsigned long int PVA_MAXBLOCK; /* Value of MAXBLOCK */ unsigned long int PVA_SERIAL; /* Value of SERIAL */ unsigned short int PVA_CYLINDERS; /* Value of CYLINDERS */ unsigned char PVA_SECTORS; /* Value of SECTORS */ unsigned char PVA_TRACKS; /* Value of TRACKS */ unsigned long int PVA_DEVTYP; /* Value of DEVTYP */ } ; #define FAR_M_HEADONLY 1 #define FAR_LENGTH 188 /* Length of FAR area */ struct FARBLK { struct dsc$descriptor FAR_FILENAME; /* Descriptor for FILENAME */ struct dsc$descriptor FAR_PLACEMENT; /* Descriptor for PLACEMENT */ unsigned char FAR_RECATTR [32]; /* Value of RECATTR */ unsigned int FAR_CREDATE [2]; /* Value of CREDATE */ unsigned int FAR_REVDATE [2]; /* Value of REVDATE */ unsigned int FAR_EXPDATE [2]; /* Value of EXPDATE */ unsigned int FAR_BAKDATE [2]; /* Value of BAKDATE */ union { unsigned short int FAR_FARFID [3]; /* Value of FID */ struct { unsigned short int FAR_FID_NUM; unsigned short int FAR_FID_SEQ; union { unsigned short int FAR_FID_RVNW; struct { unsigned char FAR_FID_RVN; unsigned char FAR_FID_NMX; } fill_21; } fill_20; } fill_19; } fill_18; union { unsigned short int FAR_BACKLINK [3]; /* Value of BACKLINK */ struct { unsigned short int FAR_DID_NUM; unsigned short int FAR_DID_SEQ; unsigned short int FAR_DID_RVNW; } fill_23; } fill_22; unsigned long int FAR_FILESIZE; /* Value of FILESIZE */ union { unsigned long int FAR_UIC; /* Value of UIC */ struct { unsigned short int FAR_UICMEMBER; /* Member part of UIC */ unsigned short int FAR_UICGROUP; /* Group part of UIC */ } fill_25; } fill_24; unsigned long int FAR_UCHAR; /* Value of UCHAR */ unsigned long int FAR_BOOTVBN; /* Value of BOOTVBN for 1st boot image */ union { unsigned short int FAR_STRUCLEV; /* Value of STRUCLEV */ struct { unsigned char FAR_STRUCLEV_FILL1; /* dummy item to maintain offset */ unsigned char FAR_STRUCLEVB; /* Structure level part of STRUCLEV */ } fill_27; } fill_26; unsigned short int FAR_FPRO; /* Value of FPRO */ unsigned short int FAR_RPRO; /* Value of RPRO */ unsigned short int FAR_REVISION; /* Value of REVISION */ unsigned long int FAR_DIR_UIC; /* Value of DIR_UIC */ unsigned short int FAR_DIR_FPRO; /* Value of DIR_FPRO */ unsigned char FAR_ACLEVEL; /* Value of ACLEVEL */ unsigned char FAR_DIR_STATUS; /* Value of DIR_STATUS */ unsigned short int FAR_DIR_VERLIM; /* Value of DIR_VERLIM */ unsigned short int FAR_VERLIMIT; /* Value of VERLIMIT */ struct dsc$descriptor FAR_ACLSEGMENT; /* ACL segment descriptor */ unsigned long int FAR_HIGHWATER; /* Value of HIGHWATER */ unsigned char FAR_JNL_FLAGS; /* Value of JNL_FLAGS */ unsigned char FAR_RU_ACTIVE; /* Value of RU_ACTIVE */ union { unsigned short int FAR_W_FLAGS; struct { unsigned FAR_V_HEADONLY : 1; /* Only the HEADER was saved */ unsigned FAR_V_FILL_1 : 15; } BIT_FLAGS; } FLAGS_OVERLAY; unsigned long int FAR_BOOTVBN2; /* Value of BOOTVBN for 2nd boot image */ unsigned int FAR_ACCDATE [2]; /* ODS5, Access date */ unsigned int FAR_ATTDATE [2]; /* ODS5, Attribute change date */ unsigned char FAR_LENGTH_HINT [16]; /* ODS5, File length hint */ unsigned char FAR_EX_RECATTR [8]; /* ODS5, Extended RMS record attributes */ } ; #define ATTBUF_LENGTH 188 #define ACB_S_ENTRY 16 /* Size of entry */ struct STABCKACB { struct STABCKACB *ACB_FLINK; /* Forward link */ struct STABCKACB *ACB_BLINK; /* Backward link */ unsigned long int ACB_COUNT; /* Block count */ unsigned long int ACB_LBN; /* Logical block number */ } ; #define WCB_M_BLACKHOLE 1 #define WCB_S_HEADER 20 /* Size of header */ struct STABWCBHD { struct STABWCBHD *WCB_LINK; /* Link to next block */ unsigned long int WCB_VBN; /* In first block only, starting VBN of window */ unsigned char WCB_SIZE; /* Number of entries in window block */ unsigned char WCB_FREE; /* Number of free entries in window */ unsigned char WCB_RVN; /* RVN */ union { unsigned char WCB_B_FLAGS; /* Flag byte */ struct { unsigned WCB_V_BLACKHOLE : 1; /* Flush write I/Os into this window */ unsigned WCB_V_fill_30 : 7; } WCB_r_fill_29; } fill_28; unsigned long int WCB_CUR_HWM; /* Current highwater mark for open file */ unsigned long int WCB_SET_HWM; /* Highwater mark written for open file */ } ; #define WCB_S_ENTRY 8 /* Size of each entry */ struct STABWCBENT { unsigned long int WCB_COUNT; /* Count of blocks */ unsigned long int WCB_LBN; /* LBN of blocks */ } ; #define VCB_M_OUTPUT 1 #define VCB_M_ODS_2 2 #define VCB_M_INIT_DONE 4 #define VCB_M_SAVESET 8 #define VCB_M_NOTVOLSET 16 #define VCB_M_ODS_5 32 #define VCB_S_ENTRY 68 /* Size of entry */ struct STABCKVCB { int *VCB_INDEXF; /* Pointer to index file window */ unsigned short int VCB_CLUSTER; /* Cluster factor */ unsigned char VCB_RVN; /* Relative volume number */ union { unsigned char VCB_B_FLAGS; struct { unsigned VCB_V_OUTPUT : 1; /* True if output volume */ unsigned VCB_V_ODS_2 : 1; /* True if ODS-2 volume */ unsigned VCB_V_INIT_DONE : 1; /* True if initialization has been done */ unsigned VCB_V_SAVESET : 1; /* True if saveset volume */ unsigned VCB_V_NOTVOLSET : 1; /* Sequential disk volume is not in a set */ unsigned VCB_V_ODS_5 : 1; /* True if ODS-5 volume */ unsigned VCB_V_fill_33 : 2; } VCB_r_fill_32; } fill_31; unsigned short int VCB_CHAN; /* Channel number assigned to this RVN */ unsigned short int VCB_IOCOUNT; /* Count of pending read/write QIOs */ unsigned long int VCB_BITMAP_LBN; /* LBN of storage bitmap */ int *VCB_IMAP; /* Pointer to index file bitmap image */ unsigned long int VCB_IMAP_LBN; /* LBN of index file bitmap */ unsigned short int VCB_INIT_HDRS; /* Bit mask of initialized headers */ unsigned short int VCB_HDR_OFFSET; /* VBN offset to file headers */ unsigned long int VCB_MAXFILIDX; /* Number of bits in index file bitmap */ struct dsc$descriptor VCB_DEVICE; /* Descriptor for device name */ struct STABCKACB *VCB_ACB_FLINK; /* Queue header for ACB queue */ struct STABCKACB *VCB_ACB_BLINK; /* */ int *VCB_FAB; /* Pointer to FAB with filespec */ unsigned short int VCB_BITMAP_SIZE; /* Storage bitmap size in blocks */ unsigned short int VCB_FILLER1_VCB; /* dummy item to maintain offsets */ unsigned char VCB_VCBVOLNAME [12]; /* Volume label */ } ; #define MTL_M_SEQ_DISK 1 #define MTL_M_NEW_ACL 2 #define MTL_M_NOHWM 4 #define MTL_S_ENTRY 52 /* Size of entry, less VCB pointers */ /* MTL_VCB(n)= 52+4*(n),0,32,0 %; ! Pointer to VCB for RVN n */ struct STABCKMTL { struct STABCKVCB *MTL_CHAN_1; /* Pointer to VCB to which each of 2 */ struct STABCKVCB *MTL_CHAN_2; /* channels is assigned */ struct STABWCBHD *MTL_WINDOW; /* Pointer to WCB for accessed file */ int *MTL_HEADER; /* Pointer to header for accessed file */ int *MTL_ACLFL; /* ACL queue */ int *MTL_ACLBL; /* head */ union { unsigned short int MTL_MTLFID [3]; /* File ID of accessed file */ struct { unsigned short int MTL_FID_NUM; /* */ unsigned short int MTL_FID_SEQ; /* */ union { unsigned short int MTL_FID_RVNW; /* */ struct { unsigned char MTL_FID_RVN; /* */ unsigned char MTL_FID_NMX; /* */ } fill_37; } fill_36; } fill_35; } fill_34; unsigned char MTL_STRUCLEV; /* Structure level of volume set */ unsigned char MTL_SETCOUNT; /* Count of volumes in volume set */ unsigned long int MTL_FILESIZE; /* Size of accessed file */ unsigned char MTL_STRUCNAME [12]; /* Volume set name */ unsigned char MTL_RVN_BASE; /* RVN mounted on first VCB */ union { unsigned char MTL_B_FLAGS [3]; struct { unsigned MTL_V_SEQ_DISK : 1; /* Set if sequential disk volume set */ unsigned MTL_V_NEW_ACL : 1; /* Set if ACL must be written */ unsigned MTL_V_NOHWM : 1; /* Highwater marking disabled for volume set */ unsigned MTL_V_fill_40 : 5; } MTL_r_fill_39; } fill_38; } ; #define D_M_DIR_SCAN 1 #define D_M_DIR_MATCHES 2 #define D_M_WILD_TERM 4 #define D_M_NON_TERM 8 #define DQE_S_ENTRY 84 /* Size of directory queue entry in bytes */ struct DIRQUEUE { struct DIRQUEUE *D_DQE_FLINK; /* Pointer to next directory queue entry */ struct DIRQUEUE *D_DQE_BLINK; /* Pointer to prior directory queue entry */ int *D_REC; /* Pointer to current record */ int *D_VER; /* Pointer to current version if ODS-2 */ unsigned long int D_BUF_LEN; /* Length of buffer in bytes */ int *D_BUF_ADDR; /* Pointer to buffer */ unsigned long int D_BUF_LIM; /* Limit of significant part of buffer */ unsigned long int D_VBN; /* Next VBN to be read */ unsigned long int D_DIR_LEN; /* Length of directory in blocks */ unsigned short int D_DIRFID [3]; /* File ID of directory */ unsigned short int D_SAV_LEN; /* Saved length of directory string */ union { unsigned long int D_L_FLAGS; /* Directory entry flags */ struct { unsigned D_V_DIR_SCAN : 1; /* True if directory file to be scanned */ unsigned D_V_DIR_MATCHES : 1; /* True if current directory matches */ unsigned D_V_WILD_TERM : 1; /* True if terminator contains wildcard */ unsigned D_V_NON_TERM : 1; /* True if terminator is "*" */ unsigned D_V_fill_43 : 4; } D_r_fill_42; } fill_41; struct dsc$descriptor D_TERM_DESC; /* Termination string descriptor */ struct dsc$descriptor D_NAME_DESC; /* Current filename string descriptor */ unsigned short int D_TERM_VER; /* Termination version number */ unsigned short int D_FPRO; /* Directory file protection */ unsigned long int D_UIC; /* Directory file owner */ unsigned short int D_VERLIM; /* Directory default version limit */ short int D_VER_COUNT; /* File version counter (0, -1, ...) */ int *D_F64DIRBUF; /* Pointer to Files-64 directory buffer */ unsigned long int D_F64DIRBUFLEN; /* Length in bytes of F64DIRBUF */ } ; #define DQF_S_ENTRY 24 /* Size of entry in bytes */ struct DSKQUOTA { struct DSKQUOTA *DQF_LLINK; /* Pointer to entry with lesser UIC */ struct DSKQUOTA *DQF_RLINK; /* Pointer to entry with greater UIC */ unsigned long int DQF_UIC; /* UIC */ unsigned long int DQF_USAGE; /* Usage in blocks */ unsigned long int DQF_PERMQUOTA; /* Permanent disk quota */ unsigned long int DQF_OVERDRAFT; /* Overdraft limit */ } ; #define PLC_S_HDR 10 /* Length of placement block header */ struct PLCBLK { struct PLCBLK *PLC_FLINK; /* Forward link */ struct PLCBLK *PLC_BLINK; /* Backward link */ unsigned char PLC_TYPE; /* Type code */ unsigned char PLC_SIZE; /* Size of block */ unsigned char (*(*PLC_DATA_START)); /* Data portion */ } ; #define VBN_S_ENTRY 18 /* Length of VBN data block */ struct VBNBLK { struct VBNBLK *VBN_FLINK; /* Forward link */ struct VBNBLK *VBN_BLINK; /* Backward link */ unsigned char VBN_TYPE; /* Type code */ unsigned char VBN_SIZE; /* Size of block */ unsigned long int VBN_FIRST; /* First VBN in range */ unsigned long int VBN_LAST; /* Last VBN in range */ } ; /* Max. label string size (disk/tape) */ #define VOL_LABEL_STRING_MAX_SIZE 12 #define VOL_LABEL_MAX_LIST 20 /* Max. (initial) number of labels */ /* (20*12 bytes) Blockvector size */ /* (Initial dynamic size) */ /* */ #define VOL_LABEL_LIST_SIZE 240 #define VOLLBL_BLOCK_SIZE 12 /* Label Block Size */ struct VOLLBLBLK { struct { char VOL_LABEL_STRING [12]; /* Label string */ } LblVector [99]; } ; #define TAPEQ_M_EXPI 1 #define TAPEQ_M_LABE 2 #define TAPEQ_M_PROT 4 #define TAPEQ_M_WREN 8 #define TAPEQ_M_MOUN 16 #define TAPEQ_M_WRIT 32 #define TAPEQ_M_NOVR 64 #define TAPEQ_M_VOOO 128 #define TAPEQ_M_RVL 256 #define TAPEQ_M_NOUSE 512 union fill_44 { unsigned long int TAPEQ_L_TAPERRQ; struct { unsigned TAPEQ_V_EXPI : 1; /* Has tape expiration date been met */ unsigned TAPEQ_V_LABE : 1; /* Is the tape label correct */ unsigned TAPEQ_V_PROT : 1; /* Is tape protected from access */ unsigned TAPEQ_V_WREN : 1; /* Should tape be write enabled */ unsigned TAPEQ_V_MOUN : 1; /* Should we issue tape mount request */ unsigned TAPEQ_V_WRIT : 1; /* Do we want to write onto the tape */ unsigned TAPEQ_V_NOVR : 1; /* We want to prevent overwrite of tape */ unsigned TAPEQ_V_VOOO : 1; /* Volume was found to be Out Of Order */ unsigned TAPEQ_V_RVL : 1; /* Ask for unspecified volume label */ unsigned TAPEQ_V_NOUSE : 1; /* Don't use the loaded tape label */ unsigned TAPEQ_V_fill_46 : 6; } TAPEQ_r_fill_45; } ; #define CLEAR_ASTLM_EFN 5 /* Wait for $SETIMR */ #define OUTSTANDING_WRITE_EFN 6 /* For non-TMSCP support */ #define V_READ_EFN 20 /* Event flag for vvm reads */ #define BUFFER_FREED_EFN 21 /* Event flag set when a buffer is freed */ #define MISC_VM_BLOCK_HDR_SIZE 16 /* VM Block Header Size */ struct MISCVMBLK { struct MISCVMBLK *MISC_VM_FLINK; /* Misc. VM queue forward link */ struct MISCVMBLK *MISC_VM_BLINK; /* Misc. VM queue backward link */ int *MISC_VM_ADDR; /* start of block (includes QUAD alignment space) */ unsigned long int MISC_VM_SIZE; /* Misc. VM block size (bytes) */ unsigned char (*(*MISC_VM_USE_VM)); /* Start of Misc. VM usable data */ } ; struct EVNTCALBCK { unsigned long int Event_Callback_addr [44]; /* (each) Event Type Callback */ } ; #define QUAL_S_AREA 220 /* Length of the qualifiers block */ #define COM_FLAGS_START 666 /* defined for COM_FLAGS init. */ #define COM_M_EOV 1 #define COM_M_STANDALONE 2 #define COM_M_FILESEEN 4 #define COM_M_VERIFYING 8 #define COM_M_FAIL_RSTRT 16 #define COM_M_CONTINUE 32 #define COM_M_DSBL_CHKPT 64 #define COM_M_DSBL_RSTRT 128 #define COM_M_INTERACT 256 #define COM_M_TAPE_CACHE 512 #define COM_M_SEEN_FILE_OR_VBN 1024 #define COM_M_SAV_SAV 2048 #define COM_M_ERROR_IN_PROG 4096 #define COM_M_MME_EXISTS 8192 #define COM_M_LABEL_OVERWRITE 16384 #define COM_M_SS_EOV 32768 #define COM_FLAGS_K_LENGTH 2 /* defined for COM_FLAGS init. */ #define COM_M_CVT_ODS5_ODS2 1 #define COM_M_SNAPDISK 2 #define COM_M_DO_MME_END 4 #define INPUT_BEG 860 /* Beginning of input context */ #define INPUT_FLAGS_START 864 /* defined for COM_FLAGS init. */ #define INPUT_M_OPEN 1 #define INPUT_M_EOV_IN_PROG 2 #define INPUT_M_EOV_SAVING 4 #define INPUT_M_ON_RVN 8 #define INPUT_M_IGNO_INTE 16 #define INPUT_M_SAVE_OK 32 #define INPUT_M_WILDSAVE 64 #define INPUT_M_REWOUND 128 #define INPUT_M_SSFOUND 256 #define INPUT_M_ALIAS 512 #define INPUT_FLAGS_K_LENGTH 4 /* defined for COM_FLAGS init. */ #define INPUT_HDR_BEG 912 /* Beginning of header data */ #define INPUTCTX_HDR_SIZE 116 #define INPUTCTX_SIZE 168 #define OUTPUT_BEG 1052 /* Beginning of output context */ #define OUTPUT_M_OPEN 1 #define OUTPUT_M_FIRST 2 #define OUTPUT_M_LAST 4 #define OUTPUT_M_INCR_DIR 8 #define OUTPUT_M_IMPLICIT 16 #define OUTPUT_M_ACL_ERROR 32 #define OUTPUT_M_ACL_FIRST_TIME 64 #define OUTPUT_M_DIR_OPEN 128 #define OUTPUT_M_NONSEQ_IN 256 #define OUTPUT_M_SKIP_ALIAS 512 #define OUTPUT_M_ALIAS_OPEN 1024 #define OUTPUTCTX_SIZE 232 /* End of output context */ #define FASTCTX_VOL_BEG 1328 /* Beginning of per-volume information */ #define FASTCTX_VOL_SIZE 20 /* End of per-volume information */ #define MAP_M_JOURNAL_ENTRY 1 #define MAP_M_LOST_FILES 2 #define RESTART_M_RESTARTING 1 #define RESTART_M_ON_RVN 2 #define RESTART_M_CLEAR_AST 4 #define DIR_BEG 1464 /* Beginning of context */ #define DIR_M_IMAGE_SCAN 1 #define DIR_M_SCAN_FAILED 2 #define DIR_M_HARD_STOP 4 #define DIR_M_SCANNED_DIRS 8 #define DIR_M_INITIAL 16 #define DIR_M_ROOT_MFD 32 #define D_STAT_M_VALID 1 #define D_STAT_M_DIR_SEL 2 #define D_STAT_M_SCANNED 4 #define D_STAT_M_FILE_SEL 8 #define DIRCTX_SIZE 104 /* End of context */ #define INCR_M_SKIP_DIR 1 #define INCR_M_SAVE_ALL_DIR 2 #define INCR_M_DISABLE_SAVE_ALL 4 #define CHK_FLAGS_START 2488 /* define an offset for clearing the following structure */ #define CHK_FLAGS_M_F11 65536 #define CHK_FLAGS_M_SAV 131072 #define CHK_FLAGS_M_SAVE_SET 262144 #define CHK_FLAGS_M_SRCH_LIST 524288 #define CHK_FLAGS_M_SMFS 1048576 #define CHK_FLAGS_M_DRVCLS_MISUSED 16777216 #define CHK_FLAGS_K_LENGTH 4 /* define a length for clearing the above structure */ #define BCK$$_S_COMMON_AREA 2532 /* Size of the Common Area */ struct BCK_COMMON_DATA { /* OBSOLETE (BASE POINTER NO LONGER NEEDED). */ /* */ /* ! Marker for base of area. */ /* */ /* GLOBAL_BASE address dimension *; */ /* */ int *FREE_LIST [2]; /* Free queue header */ int *INPUT_WAIT [2]; /* Input pending queue header */ int *REREAD_WAIT [2]; /* Re-read pending queue header */ int *OUTPUT_WAIT [2]; /* Output ready for issue queue header */ int *OUTPUT_ISSUED [2]; /* Output issued queue header */ int *XOR_LIST [2]; /* Q header of buffers for XOR. */ int *ASYNCH_WORK [2]; /* Asynch work queue header */ struct MISCVMBLK *MISC_VM_LIST [2]; /* Q header of misc. VM (must be free'd) */ unsigned long int JPI_PID; /* JPI$_PID */ unsigned long int JPI_UIC; /* JPI$_UIC */ unsigned int JPI_DATE [2]; /* $GETTIM */ struct dsc$descriptor JPI_NODE_DESC; /* Translation of SYS$NODE */ unsigned int JPI_CURPRIV [2]; /* Current process privileges */ unsigned char JPI_USERNAME [12]; /* JPI$_USERNAME */ unsigned long int JPI_ASTLM; /* AST limit from GETJPI. */ unsigned long int JPI_BIOLM; /* Buffered IO limit. */ unsigned long int JPI_FILCNT; /* Open file limit. */ unsigned long int JPI_WSQUOTA; /* Working set quota. */ unsigned long int JPI_WSSIZE; /* Current working set size. */ unsigned long int ADJ_WSSIZE; /* Adjusted working set size (after $ADJWSL) */ unsigned long int SYI_VERSION; /* SYI$_VERSION */ unsigned long int SYI_SID; /* SYI$_SID */ unsigned long int SYI_CHANNELCNT; /* SYI$_CHANNELCNT */ unsigned long int SYI_PAGE_SIZE; /* SYI$_PAGE_SIZE */ unsigned long int CTRL_T_CHAN; /* Channel to trap ^T. */ unsigned long int SACT_PF; /* Page faults. */ unsigned long int SACT_IO; /* Direct IO and total IO. */ unsigned long int SACT_BIO; /* Buffered IO. */ unsigned long int SACT_PPGCNT; /* Pages in working set. */ unsigned long int SACT_GPGCNT; /* Global pages in working set. */ unsigned long int SACT_CPU; /* CPU time (mSec). */ int *RWSV_HOLD_LIST [2]; /* Queue header for error rewrites or held I/Os for volume switches */ int *RWSV_ERRORS_LIST [2]; /* Queue header for output error rewrites */ unsigned long int RWSV_CRC16 [16]; /* CRC-16 polynomial table */ unsigned long int RWSV_AUTODIN [16]; /* AUTODIN-II polynomial table */ unsigned char RWSV_FILESET_ID [8]; /* File set identifier */ unsigned char RWSV_VOLUME_ID [12]; /* Volume identifier */ unsigned short int RWSV_VOL_NUMBER; /* Save set volume number */ unsigned short int RWSV_SEG_NUMBER; /* File section number */ unsigned long int RWSV_FILE_NUMBER; /* File sequence number */ int *RWSV_SAVE_QUAL; /* Pointer to save set qualifiers block */ int *RWSV_SAVE_FAB; /* Pointer to saveset File Context (FC) */ unsigned long int RWSV_CHAN; /* Channel assigned to save set medium */ int *RWSV_XOR_BCB; /* Pointer to BCB for XOR block */ unsigned long int RWSV_IN_SEQ; /* Input block sequence number */ unsigned long int RWSV_IN_SEQ_0; /* RWSV_IN_SEQ at start of reel */ unsigned long int RWSV_IN_XOR_SEQ; /* Sequence number of last XOR block */ unsigned char RWSV_IN_XOR_RFA [6]; /* RFA of last XOR block */ unsigned char RWSV_LOOKAHEAD; /* Buffer count from summary record */ unsigned char RWSV_XORSIZE; /* XOR group size from summary record */ unsigned long int RWSV_IN_GROUP_SIZE; /* XOR group size of save set */ unsigned short int RWSV_IN_ERRORS; /* Count of input errors */ unsigned short int RWSV_IN_XORUSE; /* Count of XOR recoveries performed */ int *RWSV_IN_ORGERR [2]; /* Original STS/STV of a train of loses */ unsigned long int RWSV_IN_VBN; /* Current VBN in save set file */ unsigned long int RWSV_IN_VBN_0; /* Saved input VBN */ unsigned long int RWSV_ALLOC; /* Number of blocks available in save set file */ unsigned long int RWSV_EOF; /* End of file VBN if save set file */ unsigned long int RWSV_OUT_SEQ; /* Output block sequence number */ unsigned long int RWSV_OUT_VBN; /* Output VBN */ unsigned long int RWSV_OUT_BLOCK_COUNT; /* Count of blocks on output tape */ unsigned short int RWSV_OUT_ERRORS; /* Count of output errors */ unsigned short int RWSV_SEQ_ERRORS; /* Count of consecutive input errors */ unsigned char RWSV_OUT_GROUP_COUNT; /* Count of blocks in output XOR group */ unsigned short int RWSV_HOLD_COUNT; /* Count of blocks on rwsv_hold_list */ unsigned char rwsv_end_filler; /* quadword align the start of next block */ /* */ /* Qualifier block structure (database) */ /* */ struct { struct QUALPVB *QUAL_A_INPU_LIST; /* Input parameters */ struct QUALPVB *QUAL_A_OUTP_LIST; /* Output parameters */ unsigned QUAL_V_ALIAS : 1; /* /ALIAS */ unsigned QUAL_V_ANAL : 1; /* /ANALYZE */ unsigned QUAL_V_ASSI : 1; /* /ASSIST for mounts */ unsigned QUAL_V_BACK : 1; /* /BACKUP */ unsigned QUAL_V_BEFO : 1; /* /BEFORE */ unsigned QUAL_V_BEFO_BACK : 1; /* /BEFORE=BACKUP */ unsigned QUAL_V_BLOC : 1; /* /BLOCK_SIZE */ unsigned QUAL_V_BUFF : 1; /* /BUFFER_COUNT */ unsigned QUAL_V_COMM : 1; /* /COMMENT */ unsigned QUAL_V_COMP : 1; /* /COMPARE */ unsigned QUAL_V_CONF : 1; /* /CONFIRM */ unsigned QUAL_V_CRC : 1; /* /CRC */ unsigned QUAL_V_CREA : 1; /* /CREATED */ unsigned QUAL_V_DCL_INTERFACE : 1; /* API invoked from DCL main */ unsigned QUAL_V_DELE : 1; /* /DELETE */ unsigned QUAL_V_DENS : 1; /* /DENSITY */ unsigned QUAL_V_DISP_KEEP : 1; /* /DISPOSITION=KEEP (MME) */ unsigned QUAL_V_DISP_RELE : 1; /* /DISPOSITION=RELEASE (MME) */ unsigned QUAL_V_EXACT : 1; /* /EXACT_ORDER */ unsigned QUAL_V_EXCL : 1; /* /EXCLUDE */ unsigned QUAL_V_EXPI : 1; /* /EXPIRED */ unsigned QUAL_V_FAST : 1; /* /FAST */ unsigned QUAL_V_FILEMERGE : 1; /* Standalone file merge */ unsigned QUAL_V_FULL : 1; /* /FULL */ unsigned QUAL_V_GROU : 1; /* /GROUP_SIZE */ unsigned QUAL_V_IDRVCLS_VALID : 1; /* Drive class processed/valid (input) */ unsigned QUAL_V_IF11 : 1; /* Input is Files-11 or physical */ unsigned QUAL_V_IGNO_ACCESS : 1; /* /IGNORE=ACCESSIBILITY */ unsigned QUAL_V_IGNO_INTE : 1; /* /IGNORE=INTERLOCK */ unsigned QUAL_V_IGNO_LABE : 1; /* /IGNORE=LABEL_PROCESSING. */ unsigned QUAL_V_IGNO_NOBA : 1; /* /IGNORE=NOBACKUP */ unsigned QUAL_V_IGNO_STRUCTURE : 1; /* /IGNORE=STRUCTURE (allow ODS5 conversions) */ unsigned QUAL_V_IMAG : 1; /* /IMAGE */ unsigned QUAL_V_INCR : 1; /* /INCREMENTAL */ unsigned QUAL_V_INIT : 1; /* /INITIALIZE */ unsigned QUAL_V_INTE : 1; /* /INTERCHANGE */ unsigned QUAL_V_ISAV : 1; /* Input is save set */ unsigned QUAL_V_I_CART : 1; /* /CARTRIDGE on input (MME) */ unsigned QUAL_V_I_CAR_CARTMED : 1; /* MEDIA_NAME specified on input */ unsigned QUAL_V_I_CAR_CARTNAM : 1; /* NAME specified on input */ unsigned QUAL_V_I_CAR_CARTSID : 1; /* SIDE specified on input */ unsigned QUAL_V_I_DRVCLS : 1; /* /DRIVE_CLASS on input (MME) */ unsigned QUAL_V_I_OWNE : 1; /* /OWNER_UIC on input (MME) */ unsigned QUAL_V_I_OWN_WGRP : 1; /* Wildcard group */ unsigned QUAL_V_I_OWN_WMEM : 1; /* Wildcard member */ unsigned QUAL_V_I_SAVE : 1; /* /SAVE_SET on input */ unsigned QUAL_V_I_SMFS : 1; /* SMFS Device on Input */ unsigned QUAL_V_JOUR : 1; /* /JOURNAL */ unsigned QUAL_V_LABE : 1; /* /LABEL */ unsigned QUAL_V_LIST : 1; /* /LIST */ unsigned QUAL_V_LOG : 1; /* /LOG */ unsigned QUAL_V_MEDIA_COMPACTN : 1; /* /MEDIA_FORMAT=COMPACTION (MME) */ unsigned QUAL_V_MEDIA_FORMAT : 1; /* /MEDIA_FORMAT (MME) */ unsigned QUAL_V_MODI : 1; /* /MODIFIED */ unsigned QUAL_V_NEWV : 1; /* /NEW_VERSION */ unsigned QUAL_V_ODRVCLS_VALID : 1; /* Drive class processed/valid (output) */ unsigned QUAL_V_OF11 : 1; /* Output is Files-11 or physical */ unsigned QUAL_V_OSAV : 1; /* Output is save set */ unsigned QUAL_V_OVER : 1; /* /OVERLAY */ unsigned QUAL_V_O_CART : 1; /* /CARTRIDGE on output (MME) */ unsigned QUAL_V_O_CAR_CARTMED : 1; /* MEDIA_NAME specified on output */ unsigned QUAL_V_O_CAR_CARTNAM : 1; /* NAME specified on output */ unsigned QUAL_V_O_CAR_CARTSID : 1; /* SIDE specified on output */ unsigned QUAL_V_O_DRVCLS : 1; /* /DRIVE_CLASS on output (MME) */ unsigned QUAL_V_O_OWNE : 1; /* /OWNER_UIC on output */ unsigned QUAL_V_O_OWN_DEFA : 1; /* =DEFAULT */ unsigned QUAL_V_O_OWN_ORIG : 1; /* =ORIGINAL */ unsigned QUAL_V_O_OWN_PARE : 1; /* =PARENT */ unsigned QUAL_V_O_OWN_UIC : 1; /* =[g,m] */ unsigned QUAL_V_O_SAVE : 1; /* /SAVE_SET on output */ unsigned QUAL_V_O_SMFS : 1; /* SMFS Device on Output */ unsigned QUAL_V_PHYS : 1; /* /PHYSICAL */ unsigned QUAL_V_PROT : 1; /* /PROTECTION on output */ unsigned QUAL_V_RECO : 1; /* /RECORD */ unsigned QUAL_V_RELEASE_TAPE : 1; /* /RELEASE_TAPE */ unsigned QUAL_V_REPL : 1; /* /REPLACE */ unsigned QUAL_V_REWI : 1; /* /REWIND */ unsigned QUAL_V_SCRA : 1; /* /SCRATCH specified (MME) */ unsigned QUAL_V_SCR_ASGN_BASE : 1; /* ASSIGNMENT_UNIT=BASE_CARTRIDGE */ unsigned QUAL_V_SCR_ASGN_COMP : 1; /* =COMPOUND_CARTRIDGE */ unsigned QUAL_V_SCR_ASGN_PRES : 1; /* =PREASSIGNED_SIDE */ unsigned QUAL_V_SCR_ASGN_SIDE : 1; /* =SIDE */ unsigned QUAL_V_SCR_COLL : 1; /* COLLECTION name specified */ unsigned QUAL_V_SCR_LOCA : 1; /* LOCATION name specified */ unsigned QUAL_V_SCR_MEDI : 1; /* MEDIA_NAME specified */ unsigned QUAL_V_SELE : 1; /* /SELECT */ unsigned QUAL_V_SINC : 1; /* /SINCE */ unsigned QUAL_V_SINC_BACK : 1; /* /SINCE=BACKUP */ unsigned QUAL_V_SNAPSHOT : 1; /* /SNAPSHOT (SnapDisk) */ unsigned QUAL_V_SLS : 1; /* /STORAGE_LIBRARY */ unsigned QUAL_V_SS_ENCRYP : 1; /* /ENCRYPT save set */ unsigned QUAL_V_SS_FILE : 1; /* Save set is a disk file */ unsigned QUAL_V_TAPE_EXPI : 1; /* Expiration date present */ unsigned QUAL_V_TRUN : 1; /* /TRUNCATE */ unsigned QUAL_V_UNSHELVE : 1; /* /UNSHELVE (File Shelving support) */ unsigned QUAL_V_VERI : 1; /* /VERIFY */ unsigned QUAL_V_VOLU : 1; /* /VOLUME */ unsigned QUAL_V_RELEASE_NOUNLOAD : 1; /* /RELEASE_TAPE=NOUNLOAD */ unsigned QUAL_v_qualflags_filler : 29; /* longword alignment for following fields */ unsigned long int QUAL_l_qualblock_filler1; /* quadword-alignment for BEFO_VALUE */ /* (the following date-time field) */ unsigned int QUAL_Q_BEFO_VALUE [2]; /* /BEFORE quadword time value */ struct dsc$descriptor QUAL_R_COMM_DESC; /* /COMMENT descriptor */ unsigned int QUAL_Q_SINC_VALUE [2]; /* /SINCE quadword time value */ struct dsc$descriptor QUAL_R_CMD_DESC; /* Command line descriptor */ struct EXCLPVB *QUAL_A_EXCL_LIST; /* /EXCLUDE list head */ int *QUAL_A_JOUR_FC; /* /JOURNAL file context */ int *QUAL_A_LIST_FC; /* /LIST file context */ union { unsigned long int QUAL_I_OWN_VALU; /* /OWNER_UIC value on input */ struct { unsigned short int QUAL_I_OWN_MEM; /* Member portion */ unsigned short int QUAL_I_OWN_GRP; /* Group portion */ } QUAL_R_I_OWNUIC_FLDS; } QUAL_R_I_OWNER_UIC; union { unsigned long int QUAL_O_OWN_VALU; /* /OWNER_UIC value on output */ struct { unsigned short int QUAL_O_OWN_MEM; /* Member portion */ unsigned short int QUAL_O_OWN_GRP; /* Group portion */ } QUAL_R_O_OWNUIC_FLDS; } QUAL_R_O_OWNER_UIC; struct SELEPVB *QUAL_A_SELE_LIST; /* /SELECT list head */ unsigned short int QUAL_W_BLOC_VALUE; /* /BLOCK_SIZE value */ unsigned short int QUAL_w_fill_bloc_val2; /* dummy item to maintain offsets */ unsigned char QUAL_B_DENS_VALUE; /* /DENSITY value */ unsigned char QUAL_B_GROU_VALUE; /* /GROUP_SIZE value */ unsigned char QUAL_B_VOLU_VALUE; /* /VOLUME value */ unsigned char QUAL_B_OPERATION_TYPE; /* Current BACKUP operation type */ struct VOLLBLBLK *QUAL_A_LABEL_LIST; /* /LABEL vector pointer - was list head */ unsigned char QUAL_B_LABEL_LIST_SIZE; /* number of labels in the label vector */ unsigned char QUAL_B_LABEL_LIST_MAX_SIZE; /* max. items the label vector holds */ unsigned char QUAL_b_fill_label_val2 [2]; /* filler, longword alignment */ unsigned short int QUAL_W_PROT_VALUE; /* /PROTECTION value */ unsigned short int QUAL_w_fill_prot_val2; /* dummy item to maintain offsets */ struct ENCPVB *QUAL_A_CRYP_VLIST; /* Pointer to list of key values */ struct dsc$descriptor QUAL_R_CRYP_USERKEY; /* Descriptor for user specified key */ struct dsc$descriptor QUAL_R_CRYP_USERALG; /* Descriptor for user specified algorithn */ unsigned int QUAL_Q_TAPE_VALUE [2]; /* /TAPE_EXPIRATION value */ struct dsc$descriptor QUAL_R_COLL_NAME; /* /SCRATCH=COLLECTION descriptor */ struct dsc$descriptor QUAL_R_MEDI_NAME; /* /SCRATCH=MEDIA_NAME descriptor */ struct dsc$descriptor QUAL_R_LOCA_NAME; /* /SCRATCH=LOCATION descriptor */ struct dsc$descriptor QUAL_R_ICART_NAME; /* /CARTRIDGE=NAME descriptor (input) */ struct dsc$descriptor QUAL_R_ICART_MEDI; /* /CARTRIDGE=MEDIA_NAME descriptor (input) */ struct dsc$descriptor QUAL_R_OCART_NAME; /* /CARTRIDGE=NAME descriptor (output) */ struct dsc$descriptor QUAL_R_OCART_MEDI; /* /CARTRIDGE=MEDIA_NAME descriptor (output) */ struct dsc$descriptor QUAL_R_IDRVCLS_NM; /* /DRIVE_CLASS descriptor (input) */ struct dsc$descriptor QUAL_R_ODRVCLS_NM; /* /DRIVE_CLASS descriptor (output) */ unsigned long int QUAL_L_ICART_VALU; /* /CARTRIDGE=SIDE value (input) */ unsigned long int QUAL_L_OCART_VALU; /* /CARTRIDGE=SIDE value (output) */ struct EVNTCALBCK *QUAL_A_CALLBACK_ADR; /* routine for handling messages, errors, etc. */ unsigned long int QUAL_L_CTX_HANDLE; /* BACKUP operation instance identifier */ } qual_block; /* Qualifier database */ struct dsc$descriptor COM_SSNAME; /* Descriptor for save set name */ unsigned short int COM_VALID_TYPES; /* BITVECTOR[16], Bit mask of valid input record types */ struct { /* Common flags */ unsigned COM_V_EOV : 1; /* Output save medium is at end */ unsigned COM_V_STANDALONE : 1; /* This is the standalone version */ unsigned COM_V_FILESEEN : 1; /* At least one file processed */ unsigned COM_V_VERIFYING : 1; /* Verify pass in progress */ unsigned COM_V_FAIL_RSTRT : 1; /* Reel restart failed to find file */ unsigned COM_V_CONTINUE : 1; /* Continue despite high error rate */ unsigned COM_V_DSBL_CHKPT : 1; /* Checkpoint can not be requested */ /* since operation is not restartable */ unsigned COM_V_DSBL_RSTRT : 1; /* Checkpoint was requested while */ /* DSBL_CHKPT was set */ unsigned COM_V_INTERACT : 1; /* SYS$COMMAND is a terminal */ unsigned COM_V_TAPE_CACHE : 1; /* Caching tape drive */ unsigned COM_V_SEEN_FILE_OR_VBN : 1; /* Flag to say that we have built a file-header. */ unsigned COM_V_SAV_SAV : 1; /* Save-set to save-set copy requested */ unsigned COM_V_ERROR_IN_PROG : 1; /* Note that error recovery is in progress */ unsigned COM_V_MME_EXISTS : 1; /* An MME subsystem is defined/running */ unsigned COM_V_LABEL_OVERWRITE : 1; /* First tape_volume label overwrite needed. */ unsigned COM_V_SS_EOV : 1; /* Started Saveset in EOT/EOV region. */ } FLAGS; unsigned short int COM_BUFF_COUNT; /* Count of buffers in pool */ unsigned short int COM_TOTAL_BUFF; /* Count of buffers allowed. */ unsigned short int COM_SIMULT_BUFF; /* Number of buffers in read pass. */ unsigned char COM_I_SETCOUNT; /* Input volume set count */ unsigned char COM_O_SETCOUNT; /* Output volume set count */ unsigned char COM_I_STRUCNAME [12]; /* Input volume set name */ unsigned int COM_O_BSRDATE [2]; /* Date of backup from summary record */ unsigned char COM_O_STRUCNAME [12]; /* Output volume set name */ unsigned char ALT_SSNAME [32]; /* Storage for alternate save set name */ unsigned char INPUT_FUNC; /* IO$_READVBLK or IO$_READLBLK */ unsigned char INPUT_RTYPE; /* BRH$K_VBN or BRH$K_LBN */ unsigned char OUTPUT_FUNC; /* IO$_WRITEVBLK or IO$_WRITELBLK */ unsigned char FAST_STRUCLEV; /* Structure level of input volume set */ unsigned char SEARCH_BI_ACE [50]; /*BBLOCK[ACE$S_RMSJNL], */ /* Block to hold the rms BI journal ACE. */ unsigned char SEARCH_AI_ACE [50]; /*BBLOCK[ACE$S_RMSJNL], */ /* Block to hold the rms AI journal ACE. */ union { unsigned long int COM_L_FLAGS2; /* Common flags 2 */ struct { unsigned COM_V_CVT_ODS5_ODS2 : 1; /* Convert ODS-5 Filenames to ODS-2 */ unsigned COM_V_SNAPDISK : 1; /* Input device is SnapDisk [SD$] */ /* (use [SD$] BACKUP date for comparisions) */ unsigned COM_V_DO_MME_END : 1; /* Must do MME clean-up */ unsigned COM_V_fill_49 : 5; } COM_r_fill_48; } fill_47; int *FIRST_BCB; /* First BCB after EOV is detected. */ unsigned long int PHYS_EOV_IN_PROG; /* INITIAL(0), ! Indate end of volume on physical save */ unsigned long int EXH_FINAL_STATUS; /* INITIAL(0), ! Exit handler's final status value */ unsigned long int INPUT_CHAN; /* Input channel */ union { unsigned long int INPUT_L_FLAGS; /* Input flag bits */ struct { unsigned INPUT_V_OPEN : 1; /* Input file is open */ unsigned INPUT_V_EOV_IN_PROG : 1; /* EOV processing in progress */ unsigned INPUT_V_EOV_SAVING : 1; /* SAVE_BLOCKS in progress */ unsigned INPUT_V_ON_RVN : 1; /* Blocks exist on RVN selected by */ /* /VOLUME qualifier */ unsigned INPUT_V_IGNO_INTE : 1; /* Ignore file access conflict */ unsigned INPUT_V_SAVE_OK : 1; /* No errors occurred during save */ unsigned INPUT_V_WILDSAVE : 1; /* Wild card save set given */ unsigned INPUT_V_REWOUND : 1; /* Input tape rewound for wildcards */ unsigned INPUT_V_SSFOUND : 1; /* Input save set found (only for wildcards) */ unsigned INPUT_V_ALIAS : 1; /* Input file is an alias entry */ unsigned INPUT_V_fill_52 : 6; } INPUT_r_fill_51; } fill_50; int *INPUT_FAB; /* Pointer to input FAB */ int *INPUT_NAM; /* Pointer to input NAM block */ struct BCBBLK *INPUT_BCB; /* Pointer to input BCB */ struct QUALPVB *INPUT_QUAL; /* Pointer to input qualifiers block */ struct BADBLK *INPUT_BAD; /* Pointer to input bad block data */ unsigned long int INPUT_BLOCK; /* Current input block number */ unsigned long int INPUT_MAXBLOCK; /* Maximum input block number */ struct dsc$descriptor INPUT_NAMEDESC; /* Descriptor for input file name */ unsigned char INPUT_STATBLK [8]; /* Statistics block */ unsigned int INPUT_CREDATE [2]; /* Creation date */ unsigned int INPUT_REVDATE [2]; /* Revision date */ unsigned int INPUT_EXPDATE [2]; /* Expiration date */ unsigned int INPUT_BAKDATE [2]; /* Backup date */ unsigned int INPUT_ACCDATE [2]; /* ODS5, Access date */ unsigned int INPUT_ATTDATE [2]; /* ODS5, Attribute change date */ unsigned char INPUT_EX_RECATTR [8]; /* ODS5, Extended RMS record attributes */ unsigned char INPUT_LENGTH_HINT [16]; /* (NT/FAT) File length hint */ unsigned long int INPUT_MEDIA_ID; /* Media id of input device */ unsigned char INPUT_FILEOWNER [4]; /* File owner UIC */ unsigned char INPUT_FILECHAR [4]; /* File characteristics */ unsigned char INPUT_RECATTR [32]; /* Record attributes */ struct INPROCBLK *INPUT_PROC_LIST; /* List of processed file ID's */ struct PLCBLK *INPUT_PLACEMENT [2]; /* List head for placement data */ struct VBNBLK *INPUT_VBN_LIST [2]; /* List head for VBN data */ unsigned short int INPUT_PLACE_LEN; /* Length of placement data as attribute */ unsigned short int fill_input_blk; /* Filler, longword alignment */ unsigned long int OUTPUT_CHAN; /* Output channel */ union { unsigned short int OUTPUT_W_OUTPUT_FLAGS; /* Output flag bits */ struct { unsigned OUTPUT_V_OPEN : 1; /* Output file is open */ unsigned OUTPUT_V_FIRST : 1; /* Verifying first block */ unsigned OUTPUT_V_LAST : 1; /* Verifying last block */ unsigned OUTPUT_V_INCR_DIR : 1; /* Special /INCREMENTAL directory scan */ unsigned OUTPUT_V_IMPLICIT : 1; /* Output file implicitly opened */ unsigned OUTPUT_V_ACL_ERROR : 1; /* Error occurred processing ACL */ unsigned OUTPUT_V_ACL_FIRST_TIME : 1; /* First time through processing ACL */ unsigned OUTPUT_V_DIR_OPEN : 1; /* An output directory is open */ unsigned OUTPUT_V_NONSEQ_IN : 1; /* Input saveset is not sequential */ unsigned OUTPUT_V_SKIP_ALIAS : 1; /* Skip current [alias] file for output */ unsigned OUTPUT_V_ALIAS_OPEN : 1; /* Skip current [alias] file for output */ unsigned OUTPUT_V_fill_55 : 5; } OUTPUT_r_fill_54; } fill_53; unsigned short int fill_output_flgs2; /* Filler, longword alignment */ int *OUTPUT_FAB; /* Pointer to output FAB */ int *OUTPUT_NAM; /* Pointer to output NAM block */ struct BCBBLK *OUTPUT_BCB; /* Pointer to output BCB */ struct QUALPVB *OUTPUT_QUAL; /* Pointer to output qualifiers block */ struct BADBLK *OUTPUT_BAD; /* Pointer to output bad block data */ unsigned long int OUTPUT_BLOCK; /* Current output block number */ unsigned long int OUTPUT_MAXBLOCK; /* Maximum output block number */ union { unsigned int DGMQ_OUTPUT_DEVGEOM [2]; /* Output device geometry */ struct { unsigned char DGM_SECTORS; /* DIB$B_SECTORS */ unsigned char DGM_TRACKS; /* DIB$B_TRACKS */ unsigned short int DGM_CYLINDERS; /* DIB$W_CYLINDER */ unsigned long int DGM_MAXBLOCK; /* DIB$L_MAXBLOCK */ } DGMr_fill_57; } fill_56; unsigned char OUTPUT_ATTBUF [188]; /*BBLOCK[ATTBUF_LENGTH], ! Values from attribute record */ struct VIDHDR *OUTPUT_VID_LIST; /* List of processed volume ID's */ unsigned long int OUTPUT_INDEX_EFBLK; /* Where in INDEXF the EFBLK should be, if /NOINIT was selected */ unsigned long int LIST_TOTFILES; /* Listing -- total files */ unsigned long int LIST_TOTSIZE; /* Listing -- total size */ int *VERIFY_FAB; /* Pointer to verification File Context (FC) */ unsigned long int VERIFY_USE_COUNT; /* Use count for current VERIFY_QUAL */ struct QUALPVB *VERIFY_QUAL; /* Corresponding input qualifier block */ struct BCBBLK *COMPARE_BCB; /* BCB for compare buffer */ int *FAST_BUFFER; /* Pointer to index file buffer */ unsigned long int FAST_BUFFER_SIZE; /* Size of index file buffer */ unsigned char FAST_RVN; /* RVN of current MFD */ unsigned char FAST_SCANNING; /* */ unsigned short int DIR_VERLIMIT; /* File version limit */ int *FAST_IMAP_SIZE; /* Number of blocks in index file bitmap */ int *FAST_IMAP; /* Bitmap of valid and selected files */ int *FAST_HDR_OFFSET; /* VBN offset to file header */ int *FAST_BOOT_LBN; /* LBN of 1st boot file */ int *FAST_BOOT_LBN2; /* LBN OF 2nd boot file */ struct PFL *CURRENT_PFL; /* Current PFL for file scan/map. */ struct PFL *PFL_LIST; /* Header for file data. */ union { unsigned char MAP_B_PHASE; /* Bit mask to indicate start of mapping phase */ struct { unsigned MAP_V_JOURNAL_ENTRY : 1; /* Offset into NEW_MAP_PHASE */ unsigned MAP_V_LOST_FILES : 1; /* Processing lost files - NEW_MAP_PHASE */ unsigned MAP_V_fill_60 : 6; } MAP_r_fill_59; } fill_58; unsigned char fill_phase_flgs2 [3]; /* Filler, longword alignment */ struct VVM *VVM_LIST [2]; /* VVM listhead. */ struct VVM *VVM_FREE_LIST [2]; /* Listhead of free VVMs. */ unsigned long int VVM_LBN_HEADER; /* VVM list - LBN pointer. */ unsigned long int MEGA_BUFFER_SUPPORT; /* The output device is capable of */ unsigned int CLEAR_ASTLM_DELTA [2]; /* handling the new buffer scheme. */ unsigned char *JOUR_BUFFER; /* Journal buffer */ char *JOUR_DIR; /* Current directory string */ unsigned long int JOUR_HIBLK; /* Highest allocated block */ unsigned long int JOUR_EFBLK; /* End of file block */ unsigned long int JOUR_INBLK; /* Current input block */ unsigned short int JOUR_FFBYTE; /* End of file byte */ unsigned short int JOUR_INBYTE; /* Current input byte */ unsigned short int JOUR_STRUCT_LEV; /* Current journal struture level */ unsigned char JOUR_COUNT; /* XOR byte count context */ unsigned char JOUR_REVERSE; /* True if reading backward */ unsigned short int JOUR_EXSZ; /* Default file extention size. */ unsigned short int fill_jour_blk2; /* Filler, longword alignment */ int *CHKPT_HIGH_SP; /* High value of SP for saved portion */ int *CHKPT_LOW_SP; /* Low value of SP for saved portion */ int *CHKPT_STACK; /* Pointer to save area for stack */ int *CHKPT_VARS; /* Pointer to save area for variables */ unsigned long int CHKPT_STATUS; /* Failure status of a re-access */ int *CHKPT_LIST [2]; /* Q header of buffers for checkpoint data. */ int *CHKPT_EOV_DATA [2]; /* Storage for EOV checkpoint context */ union { unsigned char RESTART_B_IN_PROGRESS; /*BITVECTOR[8], ! Indicates a restart has taken place */ struct { unsigned RESTART_V_RESTARTING : 1; /* Restart is taking place */ unsigned RESTART_V_ON_RVN : 1; /* Restart took place on the RVN */ unsigned RESTART_V_CLEAR_AST : 1; /* Restarting - must clear AST */ unsigned RESTART_V_fill_63 : 5; } RESTART_r_fill_62; } fill_61; unsigned char PARTIAL_MAPPING; /* Signal partial mapping after restart */ unsigned short int fill_pmap_flg2; /* Filler, longword alignment */ unsigned long int DIR_CHAN; /* Channel assigned to device */ int *DIR_NAM; /* Pointer to name block */ struct dsc$descriptor DIR_SEL_DIR; /* Descriptor for selection directory */ struct dsc$descriptor DIR_SEL_NTV; /* Descriptor for selection n.t;v */ struct dsc$descriptor *DIR_DEV_DESC; /* Descriptor for device */ unsigned char DIR_STRUCLEV; /* Structure level of directory */ unsigned short int DIR_LEVELS; /* Current number of active levels */ union { unsigned char DIR_B_FLAGS; /* Flag bits */ struct { unsigned DIR_V_IMAGE_SCAN : 1; /* Image mode scan */ unsigned DIR_V_SCAN_FAILED : 1; /* Previous scan failed */ unsigned DIR_V_HARD_STOP : 1; /* Immediate return on terminator */ unsigned DIR_V_SCANNED_DIRS : 1; /* Return scanned directories */ unsigned DIR_V_INITIAL : 1; /* Initial call */ unsigned DIR_V_ROOT_MFD : 1; /* Scan root MFD only */ unsigned DIR_V_fill_66 : 2; } DIR_r_fill_65; } fill_64; union { unsigned char D_STAT_B_STATUS; /* DIR_STATUS - Directory status flags */ struct { unsigned D_STAT_V_VALID : 1; /* DIR_STATUS is valid */ unsigned D_STAT_V_DIR_SEL : 1; /* Directory is selected */ unsigned D_STAT_V_SCANNED : 1; /* Directory was scanned */ unsigned D_STAT_V_FILE_SEL : 1; /* Files in directory are selected */ unsigned D_STAT_V_fill_69 : 4; } D_STAT_r_fill_68; } fill_67; unsigned char DIR_FILLER_01 [7]; /* Filler for Quadword Alignment */ struct dsc$descriptor DIR_PATH_DESC; /* Current directory path descriptor */ struct DIRQUEUE *DQE_LIVE_HDR [2]; /* Live directory queue entry list */ struct DIRQUEUE *DQE_FREE_HDR [2]; /* Free directory queue entry list */ struct DIRQUEUE *DQE_SAVE_PTR; /* Saved directory queue entry pointer */ unsigned long int DIR_SEL_LATEST; /* Latest version selector */ unsigned long int DIR_SCANLIMIT [8]; /* ODS-1 directory scan limits */ struct STABCKMTL *INPUT_MTL; /* Pointer to input MTL entry */ struct STABCKMTL *OUTPUT_MTL; /* Pointer to output MTL entry */ struct STABCKMTL *CURRENT_MTL; /* Pointer to MTL for current operation */ struct STABCKVCB *CURRENT_VCB; /* Pointer to VCB for current operation */ struct STABWCBHD *CURRENT_WCB; /* Pointer to WCB for current operation */ struct dsc$descriptor RSA_DESC; /* Descriptor for RSA in STA_DISMOUNT_OU */ unsigned short int DQF_QUOTA_FID [3]; /* File ID of quota file */ unsigned short int fill_dqfquotafid; /* maintain longword alignment */ int *DQF_ROOT; /* Root of quota table */ unsigned long int DQF_COUNT; /* Count of entries in quota table */ int *QUEUE_HEADERS [6]; /* Queue headers for: */ /* Allocated disk extents */ /* Required extents */ /* Used extension file IDs */ unsigned long int SYSDISK_CHAN; /* Standalone backup system disk channel. */ int *LOCK_RANGE [2]; /* Pair of addresses for WS lock. */ int *ACL_BUFFER; /* Pointer to the ACL to save */ struct dsc$descriptor ACL_FIB_DESCR; /* FIB descriptor */ unsigned long int ACL_LENGTH; /* Size of the entire ACL */ unsigned char ACL_FIB [96]; /*BBLOCK [FIB$C_LENGTH], FIB storage */ unsigned long int SAVESET_ENCR; /* flag(s) */ int *CRYP_IN_CONTEXT; /* Pointer to encrypt context for input ss */ int *CRYP_OU_CONTEXT; /* Pointer to output encrypt context */ int *CRYP_DA_CONTEXT; /* Pointer to datakey encryption context */ unsigned char CRYP_DATA_ENCIV [8]; /* Copy of IV for encryption of savesets */ unsigned char CRYP_DATA_CODE [4]; /*BBLOCK [4], ! Saveset encryption algorithm code */ unsigned char CRYP_DATA_KEY [8]; /*BBLOCK [8] ! Saveset data key */ unsigned char CRYP_DATA_IV [8]; /*BBLOCK [8] ! Saveset encryption IV */ unsigned long int CRYP_DATA_CKSM; /* Checksum for code,key, and iv */ unsigned char LOST_FILES_RVN; /* Current RVN for lost files processing */ unsigned char fill_lostfilervn [3]; /* Maintain longword alignment */ unsigned long int LOST_FILES_FNUM; /* Current file number for lost files processing */ unsigned char INCR_FIB [96]; /*BBLOCK [FIB$C_LENGTH], FIB for wildcarding */ unsigned char INCR_RSA [252]; /*VECTOR[ATR$S_ASCNAME,BYTE], Resultant String */ unsigned char fill_incrresname [2]; /* Maintain longword alignment */ unsigned long int INCR_RSS; /* Size of entire resultant string */ unsigned long int INCR_NTS; /* Size of "name.type" portion */ unsigned long int INCR_VER; /* Binary version number */ unsigned short int INCR_BACKLINK [3]; /* Backlink */ unsigned short int fill_incrbacklink; /* Maintain longword alignment */ unsigned long int INCR_FILECHAR; /* Characteristics of disk file */ unsigned int INCR_BAKDATE [2]; /* Backup date */ struct dsc$descriptor INCR_DIR_DEV_DESC; /* Descriptor for special dir. dev. */ struct dsc$descriptor INCR_DIR_PATH_DESC; /* Descriptor for special dir. */ unsigned char INCR_HEADER_FILENAME [252]; /*VECTOR[ATR$S_ASCNAME,BYTE], Filename in the header */ struct { /* Incremental processing flags (save and restore) */ unsigned INCR_V_SKIP_DIR : 1; /* Skip saveset dir/files */ unsigned INCR_V_SAVE_ALL_DIR : 1; /* Save all subdir's/related files of a dir. */ unsigned INCR_V_DISABLE_SAVE_ALL : 1; /* DISABLE the above flag. */ unsigned INCR_v_incr_flags_filler1 : 13; /* longword-align next field */ } INCR_FLAGS; struct VIDHDR *CURRENT_VID; /* Pointer to VID block being processed */ unsigned long int EXH_CTRL_BLK [4]; /* Exit handler control block */ struct { unsigned short int CHK_FLAGS_W_COUNT; unsigned CHK_FLAGS_V_F11 : 1; unsigned CHK_FLAGS_V_SAV : 1; unsigned CHK_FLAGS_V_SAVE_SET : 1; unsigned CHK_FLAGS_V_SRCH_LIST : 1; unsigned CHK_FLAGS_V_SMFS : 1; /* True if SMFS device found */ unsigned CHK_FLAGS_v_fill_chkflags1 : 3; /* BYTE-align next bit/flag */ unsigned CHK_FLAGS_V_DRVCLS_MISUSED : 1; /* (formerly CHK_QUALS[CHK_DRVCLS_MISUSED] */ unsigned CHK_FLAGS_v_fill_chkquals1 : 7; /* Maintain longword alignment */ } CMDCHKFLG; unsigned long int MAPPING_NEW_FILE; /* Begin mapping a new file */ unsigned long int EXTENT_VBN; /* Starting VBN of this extent */ unsigned long int STILL_ADJUSTING; /* Indicate first pass through mapping pointers */ unsigned long int EXIT_STATUS; /* Image exit status */ unsigned long int EOV_XOR_WRITTEN; /* Note that an XOR block has */ /* already been written at the */ /* end of volume. */ unsigned long int OUTSTANDING_WRITE_COUNT; /* INITIAL(0), */ /* Count of outstanding writes for non-TMSCP support */ unsigned long int UCB_ADDR; /* address of saveset device's UCB */ unsigned long int MCB_ADDR; /* address of MCB for saveset device */ unsigned int SNAPDISK_BACKUP [2]; /* BACKUP date (returned from sd$getdisk routine) */ } ; #define BTC_K_CONSIDER 1 /* Consider a file */ #define BTC_K_REJECT 2 /* Reject a file */ #define BTC_K_ALRFAST 3 /* Already chosen on bitmap. */ #define BTC_K_MAPPED 4 /* Mapped by scanner. */ #define BTC_K_CHOSEN 5 /* File is now chosen. */ #define BCK_K_BLOCK_SIZE_MIN 2048 #define BCK_K_BLOCK_SIZE_MAX 65535 #define BCK_K_GROUP_SIZE_MIN 0 #define BCK_K_GROUP_SIZE_MAX 100 #define BCK_K_TAPE_DENS_800 800 #define BCK_K_TAPE_DENS_833 833 #define BCK_K_TAPE_DENS_1600 1600 #define BCK_K_TAPE_DENS_62500 6250 #define BCK_K_VOLUME_NUM_MIN 1 #define BCK_K_VOLUME_NUM_MAX 255