F$GETDVI is the UCL wrapper for the SYS_GETDVI system call. We briefly introduced this
system call back in article 62.
Here is the definition:
F$GETDVI returns a specific piece of information about the specified device.
Item | Information returned |
ACCESSTIME_RECORDED | TRUE if volume supports recording of access times. FALSE otherwise. |
ACPPID | Ancilllary control process (ACP) identification. |
ACPTYPE | ACP type code: F11V1, F11V12, F11V3, F11V4, F11V5, F64, HBS, JNL, MTA, NET, REM, UCX, or ILLEGAL. ILLEGAL is returned if the device is not mounted, mounted using /FOREIGN, or the ACPTYPE is not defined. |
ALL | TRUE if the device is allocated. FALSE otherwise. |
ALLDEVNAM | Allocation class device name |
ALLOCLASS | Allocation class of the host. |
ALT_HOST_AVAIL | TRUE if host serving the alternate path is available. FALSE otherwise. |
ALT_HOST_NAME | Name of the host serving the alternate path |
ALT_HOST_TYPE | Hardware type of the host serving the alternate path. |
AVAILABLE_PATH_COUNT | Number of available working paths for a multipath-capable device. |
AVL | TRUE if device is available for use. FALSE otherwise. |
CCL | TRUE if the device is a carriage control device. FALSE otherwise. |
CLUSTER | Volume cluser size. |
CONCEALED | TRUE if the logical device name translates to a concealed device. FALSE otherwise. |
CYLINDERS | Number of cylinders on the volume (local disks only). |
DEVBUFSIZ | Device buffer size. |
DEVCHAR | Device characteristics. |
DEVCHAR2 | Additional device characteristics. |
DEVCLASS | Device class. |
DEVDEPEND | Device dependent information. |
DEVDEPEND2 | Additional device dependent information. |
DEVICE_MAX_IO_SIZE | The maximum contiguous transfer size supported by the device driver. Note that other software layers, such as RMS, may impose a smaller size. |
DEVICE_TYPE_NAME | Device type name. For some hardware, such as SCSI, the device type is retrieved from the hardware device itself. |
DEVLOCKNAM | A unique lock name for the device. |
DEVNAM | Device name. |
DEVSTS | Device status. |
DEVTYPE | Device type. |
DFS_ACCESS | TRUE to indicate a remote virtual disk. FALSE otherwise. |
DIR | TRUE if the device is file structured. FALSE otherwise. |
DMT | TRUE if device is marked for dismount. FALSE otherwise. |
DUA | TRUE if device is generic. FALSE otherwise. |
ELG | TRUE if device has error logging enabled. |
ERASE_ON_DELETE | TRUE if files are zeroed upon deletion on the volume. FALSE otherwise. |
ERRCNT | Error count on device. If pathname is specified, the count is only for that pathname, otherwise it is the aggregate for all paths. |
ERROR_RESET_TIME | Time at which the error count was reset |
EXISTS | TRUE if the device exists on the system. FALSE otherwise. |
EXPSIZE | Current expansion limit on the volume. |
FC_HBA_FIRMWARE_REV | Same as FIRMWARE. |
FC_NODE_NAME | Fibre Channel host bus adapter node name. |
FC_PORT_NAME | Fibre Channel host bus adapter port name. |
FIRMWARE_REV | Hardware firmware revision information. If hardware doesn't support this, a null string is returned. |
FOD | TRUE if the device is a files-oriented device. FALSE otherwise. |
FOR | TRUE if the device is mounted using /FOREIGN. FALSE otherwise. |
FREEBLOCKS | Number of free space on the volume (disks only). |
FULLDEVNAM | Fully qualified device name. |
GEN | TRUE If device is generic. FALSE otherwise. |
HARDLINKS_SUPPORTED | TRUE if volume's file system supports POSIX hardlinks. FALSE otherwise. |
HOST_AVAIL | TRUE if host serving the primary path is available. FALSE otherwise. |
HOST_COUNT | Number of hosts that make the device available to a UOS Cluster. |
HOST_NAME | Name of the host serving the primary path. |
HOST_TYPE | Hardware type of the host serving the primary path. |
IDV | TRUE if the device is capable of producing input. FALSE otherwise. |
LAN_ALL_MULTICAST_MODE | TRUE if the device is enabled to receive all multicast packets rather than only packets addressed to the enabled multicast addresses. FALSE otherwise. |
LAN_AUTONEG_ENABLED | TRUE if device is set to autonegotiate the speed and duplex settings. FALSE otherwise. |
LAN_DEFAULT_MAC_ADDRESS | The default MAC address of the device. Null is returned for non-network devices. |
LAN_FULL_DUPLEX | TRUE if the device is operating in full-duplex mode. FALSE otherwise. |
LAN_JUMBO_FRAMES_ENABLED | TRUE if jumbo frames are enabled. FALSE otherwise. |
LAN_LINK_STATE_VALID | TRUE if the device driver correctly maintains the link status. FALSE otherwise. |
LAN_LINK_UP | TRUE if the link is up. FALSE otherwise. |
LAN_MAC_ADDRESS | Current MAC address of the device. Null is returned for non-network devices. |
LAN_PROMISCUOUS_MODE | TRUE if device is enabled to receive all packets rather than those matching its MAC. FALSE otherwise. |
LAN_PROTOCOL_NAME | Name of the LAN protocol running on the device. Null is returned for non-network devices. |
LAN_PROTOCOL_TYPE | Type of LAN protocol running on the device. Null is returned for non-network devices. |
LAN_SPEED | Speed of the LAN device in megabits per second. Null is returned for non-network devices. |
LOCKID | Clusterwise lock identification. |
LOGVOLNAM | Logical volume name. |
MAILBOX_BUFFER_QUOTA | Current mailbox quota. |
MAILBOX_INITIAL_QUOTA | Initial mailbox quota. |
MAXBLOCK | Size of volume in bytes. |
MAXFILES | Maximum number of files on volume (disks only). 0 if no limit. |
MBX | TRUE if device is a mailbox. FALSE otherwise. |
MEDIA_ID | Non-decoded media ID. Null if no media on device. |
MEDIA_NAME | Name of media type. |
MEDIA_TYPE | Device name prefix. |
MNT | TRUE if the device is mounted. FALSE otherwise. |
MOUNT_TIME | Time at which the device was mounted. |
MOUNTCNT | Number of times the device has been mounted on the local system. |
MOUNTVER_ELIGIBLE | TRUE if the volume is eligible to udnergo mount verification. FALSE otherwise. |
MPDEV_AUTO_PATH_SW_CNT | Number of times a multipath device has autmatically switched paths due to I/O errors or due to falling back to a local path from a remote path. |
MPDEV_CURRENT_PATH | Current path name for multipath devices. If the device is not part of a multipath set, this returnes the name of the device path. Returns null string if device doesn't support multipathing. |
MPDEV_MAN_PATH_SW_CNT | Number of times a multipath device has manually switched paths. |
MT3_DENSITY | Current density of the tape. |
MT3_SUPPORTED | TRUE if device supports densities. FALSE otherwise. |
MULTIPATH | TRUE if the device is a member of a multipath set. FALSE otherwise. |
MVSUPMSG | TRUE if mount verification OPCOM messages are currently supressed on this device. FALSE otherwise. |
NET | TRUE if device is a network device. FALSE otherwise. |
NEXTDEVNAM | Device name of the next volume in a volume set (disks only). |
NOCACHE_ON_VOLUME | TRUE if device is mounted with no caching. FALSE otherwise. |
NOHIGHWATER | TRUE if high-water marking is disabled on the device. FALSE otherwise. |
NOSHARE_MOUNTED | TRUE if the volume is mounted with /NOSHARE. FALSE otherwise. |
ODS2_SUBSET0 | TRUE if volume mounted on the device only supports a subset of the ODS-2 file structure. |
ODS5 | TRUE if volume is mounted OS5. FALSE otherwise. |
ODV | TRUE if device is capable of providing output. |
OPCNT | Operation count of the device. If the pathname is specified, only the operation count for that path is returned. Otherwise, the aggregate count for all paths is returned. |
OPR | TRUE if the device is an operator. FALSE otherwise. |
OWNUIC | Owner ID of the device owner. |
PATH_AVAILABLE | TRUE if the specified path is vailable. FALSE otherwise. If pathname is omitted, information about the current path of the device is returned. |
PATH_NOT_RESPONDING | TRUE if the specified path is marked as not responding. FALSE otherwise. If pathname is omitted, information about the current path of the device is returned. |
PATH_POLL_ENABLED | TRUE if the specified path is enabled for multipath polling. FALSE otherwise. If pathname is omitted, information on the current path of the device is returned. |
PATH_SWITCH_FROM_TIME | Time from which this path was switched. |
PATH_SWITCH_TO_TIME | Time to which this path was switched. |
PATH_USER_DISABLED | TRUE if specified path has been disabled. FALSE otherwise. If pathname is omitted, information on the current path of the device is returned. |
PID | Process ID of the device owner. |
PREFERRED_CPU | A 64-bit integer where the corresponding CPU index that is the preferred CPU for this device is set to 1. |
PREFERRED_CPU_BITMAP | Equivalent to PREFERRED_CPU except that the result is a string of 0s and 1s corresponding to the bits returned by PREFERRED_CPU. |
PROT_SUBSYSTEM_ENABLED | TRUE if the device is mounted with the protection subsystems enabled. FALSE otherwise. |
QLEN | Current queue length of the device. This is the number of I/O requests in the device's driver. |
RCK | TRUE if the device has reach checking enabled. FALSE otherwise. |
RCT | TRUE if the disk contains RCT. FALSE otherwise. |
REC | TRUE if the device is record oriented. FALSE otherwise. |
RECSIZ | Current maximum blocked record size of device, in bytes. |
REFCNT | Reference count of processes using the device. |
REMOTE_DEVICE | TRUE if the device is remote. FALSE otherwise. |
RND | TRUE if device allows random access. FALSE otherwise. |
ROOTDEVNAME | Device name of the root volume in a volume set (disks only). |
RTM | TRUE if the device is real-time. FALSE otherwise. |
SCSI_DEVICE_FIRMWARE_REV | Firmware revision number of a SCSI device. Null returned for other devices. |
SDI | TRUE if the device is single-directory structured. FALSE otherwise. |
SECTORS | Number of sectors per track (disks only). 0 is returned for disks without those metrics available (such as virtual disks). |
SERIALNUM | Volume serial number (disks only). For non-disks, if the device reports a serial number, it is returned here. Otherwise null. |
SERVED_DEVICE | TRUE if this is a served device. FALSE otherwise. |
SET_HOST_TERMINAL | TRUE if the device is a remote terminal from a remote node (via SET HOST). FALSE otherwise. |
SHDW_CATCHUP_COPYING | TRUE if the device is a member that is the target of a full copy operation. FALSE otherwise. |
SHDW_COPIER_NODE | The name of the node that is actively performing the copy or merge operation. |
SHDW_DEVICE_COUNT | The total number of devices in the shadow set, including devices being added as copy targets. |
SHDW_GENERATION | Current internal revision number for the shadow set. |
SHDW_MASTER | TRUE if this device is a shadow set. |
SHDW_MASTER_MBR | Name of master member unit used for merge, copy repair, and recovery operations. |
SHDW_MASTER_NAME | Device name representing the name of the shadow set that this device belongs to. |
SHDW_MBR_COPY_DONE | The percent of the copy operation completed on this shadow set member unit. |
SHDW_MBR_COUNT | The total number of devices in the shadow set, not including devices being added as copy targets. |
SHDW_MBR_MERGE | The percent of the merge operation complete on this member unit. |
SHDW_MBR_READ_COST | Read cost value for this unit in the shadow set. |
SHDW_MEMBER | TRUE if the device is a member of a shadow set. FALSE otherwise. |
SHDW_MERGE_COPYING | TRUE if the device is a merge member of a shadow set. |
SHDW_MINIMERGE_ENABLE | TRUE if the device will undergo a min-merge instead of a full merge, if a system in the cluster crashes. |
SHDW_NEXT_MBR_NAME | Device name of the next member in the shadow set. If the virtual shadow set device name is passed, the first device in the shadow set is returned. If there are no more members, null is returned. |
SHDW_READ_SOURCE | The name of the member unit that will be used for reads at this time. This will be the unit with the lowest sum of queue length and read cost. |
SHDW_SITE | The site value for the device. This is set by SET DEVICE or SET SHADOW. |
SHDW_TIMEOUT | The user-specified timeout value st for the device. If not set, the system default value is used. |
SHR | TRUE if the device is shareable. FALSE otherwise. |
SPL | TRUE if the device is being spooled. FALSE otherwise. |
SPLDEVNAME | Name of the device being spooled. |
SQD | TRUE if the device is sequential block-oriented. |
STS | Status information. |
SWL | TRUE if the device is software write-locked. FALSE otherwise. |
TOTAL_PATH_COUNT | Number of paths for a multipath device. |
TRACKS | Number of tracks per cylinder (disks only). Will return 0 if the disk has no metrics (such as virtual disks). |
TRANSCNT | Volume transaction count. |
TRM | TRUE if the device is a terminal. FALSE otherwise. |
TT_ACCPORNAM | The terminal server name and port name. |
TT_ALTYPEAHD | TRUE if the terminal has an alternate type-ahead buffer. |
TT_ANSICRT | TRUE if the terminal is an ANSI video terminal. |
TT_APP_KEYPAD | TRUE if the terminal is in keypad applications mode. |
TT_AUTOBAUD | TRUE if the terminal has automatic baud rate detection. |
TT_AVO | TRUE if the terminal has AVO (VT100-family). |
TT_BLOCK | TRUE if the terminal has block mode capability. |
TT_BRDCSTMBX | TRUE if terminal uses mailbox broadcast messages. |
TT_CHARSET | A bitmap indicating the coded character set supported by the terminal. |
TT_CRFILL | TRUE if the terminal requires fill after CR. |
TT_CS_HANGUL | TRUE if terminal supports the Hangul character set. |
TT_CS_HANYU | TRUE if terminal supports the Hanyu character set. |
TT_CS_HANZI | TRUE if terminal supports the Hanzi character set. |
TT_CS_KANA | TRUE if terminal supports the Kana character set. |
TT_CS_KANJI | TRUE if terminal supports the Kanji character set. |
TT_CS_THAI | TRUE if terminal supports the Thai character set. |
TT_DECCRT | TRUE if terminal is a DEC CRT terminal. |
TT_DECCRT2 | TRUE if terminal is a DEC CRT2 terminal. |
TT_DECCRT3 | TRUE if terminal is a DEC CRT3 terminal. |
TT_DECCRT4 | TRUE if terminal is a DEC CRT4 terminal. |
TT_DIALUP | TRUE if terminal is connected to dialup. |
TT_DISCONNECT | TRUE if the terminal can be disconnected. |
TT_DMA | TRUE if terminal has direct memory access mode. |
TT_DRCS | TRUE if the terminal supports loadable character fonts. |
TT_EDIT | TRUE if the terminal edit flag is set. |
TT_EDITING | TRUE if advanced editing is enabled. |
TT_EIGHTBIT | TRUE if the terminal uses 8-bit ASCII character set. |
TT_ESCAPE | TRUE if terminal generates escape sequences. |
TT_FALLBACK | TRUE if the terminal uses the multinational fallback option. |
TT_HALFDUP | TRUE if terminal is in half-duplex mode. |
TT_HANGUP | TRUE if the hangup flag is set. |
TT_HOSTSYNC | TRUE if the terminal uses host/terminal sync communication. |
TT_INSERT | TRUE if insert mode is the default line editing mode. |
TT_LFFILL | TRUE if terminal requires fill after LF. |
TT_LOCALECHO | TRUE if terminal has local echo set. |
TT_LOWER | TRUE if the terminal supports lowercase letters. |
TT_MBXDSABL | TRUE if mailboxes associated with the termainl will receive unsolicited input or input notification. |
TT_MECHFORM | TRUE if terminal has mechanical FF. |
TT_MECHTAB | TRUE if terminal has mechanical tabs (HT). |
TT_MODEM | TRUE if terminal is connected to a modem. |
TT_MODHANGUP | TRUE if the modify hangup characterstic is set. |
TT_NOBRDCST | TRUE if terminal will not receive briacast messages. |
TT_NOECHO | TRUE if input characters are not echoed. |
TT_NOTYPEAHD | TRUE if data must be solicited by a read operation. |
TT_OPER | TRUE if terminal is an operations terminal. |
TT_PAGE | Terminal page/screen height. |
TT_PASTHRU | TRUE if PASALL mode with flow control is available. |
TT_PHYDEVNAM | Physical device name associated with a handle or a virtual terminal. |
TT_PRINTER | TRUE if the terminal has a printer port. |
TT_READSYNC | TRUE if the terminal has read synchronization. |
TT_REGIS | TRUE if the terminal has ReGID graphics. |
TT_REMOTE | TRUE if terminal has established modem control. |
TT_SCOPE | True if the terrminal is a video terminal. |
TT_SECURE | TRUE if the terminal can recognize a secure server. |
TT_SETSPEED | TRUE if the terminal line speed can be set. |
TT_SIXEL | TRUE if the sixel is supported. |
TT_SYSPWD | TRUE if the system password is enabled for this terminal. |
TT_TTSYNC | TRUE if there is terminal/host synchronization. |
TT_WRAP | TRUE if CRLF should be inserted if the cursor moves beyond the right margin. |
UNIT | Unit number of device. |
VOLCHAR | 128-bit string indicating the volume characteristics/capabilities. If a bit is set, the feature is supported. |
VOLCOUNT | Count of volumes in a volume set. |
VOLNAM | Volume name the device is part of. |
VOLNUMBER | Number of the current volume in a volume set. |
VOLSETMEM | TRUE if the device belongs to a volume set. |
VOLSIZE | The current logical volume size. |
VOLUME_EXTEND_QUANTITY | Number of bytes that files on the volume are extended by. |
VOLUME_MOUNT_GROUP | TRUE if the volume is mounted /GROUP. |
VOLUME_MOUNT_SYS | TRUE if volume is mounted /SYSTEM. |
VOLUME_PENDING_WRITE_ERR | Number of pending write errors on device. |
VOLUME_RETAIN_MAX | Maximum retention time for the volume (via SET VOLUME/RETENTION). |
VOLUME_RETAIN_MIN | Minimum retention time for the volume (via SET VOLUME/RETENTION). |
VOLUME_SPOOLED_DEV_CBT | The number of devices spooled to the volume. |
VOLUME_WINDOW | Default window size for the volume. |
VPROT | VOlume protection mask. |
WCK | TRUE if the device has write-checking enabled. |
WRITETHRU_CACHE_ENABLED | TRUE if volume is mounted with write-through caching enabled. |
WWID | Worldwide identifier for a Fibre Channel device. |
Now that we've described the function from a user-perspective, and defined the new
constants we are using, we're ready to consider the code that implements the F$GETDVI
function (Parse_GetDVI
).
However, given the length of this article, we'll save that for the next article.