![]() |
HP OpenVMS systems documentation |
| Previous | Contents | Index |
map_buffer_size = (PMM$C_LENGTH * ret-val) + 4 |
Figure SYS-2 SYI$_PFN_MEMORY_MAP---Alpha and I64
The first longword of the physical memory contains a count of descriptors. This number is equal to the value returned when the SYI$_PMD_COUNT item code is specified.
Each descriptor contains at least 3 longwords: a word containing the length of the descriptor (always use PMM64$C_LENGTH when determining descriptor size); a flags word (whose bits are defined in the following table); and the starting PFN for that physical memory cluster and the number of PFNs in that cluster.
| Bit | Meaning When Set |
|---|---|
| PMM64$V_CONSOLE | The physical memory descriptor is in use by the console (hardware). |
| PMM64$V_OPENVMS | The physical memory descriptor is in use by OpenVMS. |
| PMM64$V_AVAILABLE | The physical descriptor is not in use by either the console (hardware) or OpenVMS. |
| Remaining bits | The remaining bits in the PMM64$W_FLAGS word are reserved for HP. |
The structure definition for the physical memory descriptor resides in PMMDEF.H.
Because the size of the physical memory map returned by $GETSYI can vary from system to system, HP recommends using the following steps when using this item code:
map_buffer_size = (PMM64$C_LENGTH * ret-val) + 4 |
Because this number is a longword, the buffer length field in the item descriptor should specify 4 (bytes).
Because this number is a longword, the buffer length field in the item descriptor should specify 4 (bytes).
Because this number is a quadword, the buffer length field in the item descriptor should specify 8 (bytes).
Because this number is a longword, the buffer length field in the item descriptor should specify 4 (bytes).
Because this number is a longword, the buffer length field in the item descriptor should specify 4 (bytes).
Because this number is a longword, the buffer length field in the item descriptor should specify 4 (bytes).
Because this number is a longword, the buffer length field in the item descriptor should specify 4 (bytes).
Because this number is a quadword, the buffer length field in the item descriptor should specify 8 (bytes).
Because this number is a longword, the buffer length field in the item descriptor should specify 4 (bytes).
Note: OpenVMS support for RADs is available only on the AlphaServer GS series systems. For more information about using RADs, refer to the HP OpenVMS Alpha Partitioning and Galaxy Guide.
Note: OpenVMS support for RADs is available only on the AlphaServer GS series systems. For more information about using RADs, refer to the HP OpenVMS Alpha Partitioning and Galaxy Guide.
Note: OpenVMS support for RADs is available only on the AlphaServer GS series systems. For more information about using RADs, refer to the HP OpenVMS Alpha Partitioning and Galaxy Guide.
Note: OpenVMS support for RADs is available only on the AlphaServer GS series systems. For more information about using RADs, refer to the HP OpenVMS Alpha Partitioning and Galaxy Guide.
See the SYI$_CPUTYPE item code for a list of symbols and processors.
Because this number is a quadword, the buffer length field in the item descriptor should specify 8 (bytes).
On Alpha and I64 systems, SYI$_SID returns a value in which all fields are 0 except the CPU-type field, which always contains the value 256.
Because the value of this register is a longword hexadecimal number, the buffer length field in the item descriptor should specify 4 (bytes).
Because this number is a longword, the buffer length field in the item descriptor should specify 4 (bytes).
Because this number is a longword, the buffer length field in the item descriptor should specify 4 (bytes).
| Bit Position | Meaning When Set |
|---|---|
| KGB$V_DYNAMIC | Allows holders of the identifier to remove it from or add it to the process rights list using the DCL command SET RIGHTS_LIST. |
| KGB$V_NOACCESS | Makes any access rights of the identifier null and void. This attribute is intended as a modifier for a resource identifier or the Subsystem attribute. |
| KGB$V_RESOURCE | Allows holders of an identifier to charge disk space to the identifier. It is used only for file objects. |
| KGB$V_SUBSYSTEM | Allows holders of the identifier to create and maintain protected subsystems by assigning the Subsystem ACE to the application images in the subsystem. |
Allocate a buffer that is sufficient to hold the system rights list, because $GETSYI returns only as much of the list as will fit in the buffer.
Because SYI$_SYSTEM_UUID is 128 bits long, the buffer length field in the item descriptor must specify 16 bytes.
Because the version number is 8-byte blank-filled, the buffer length field in the item descriptor should specify 8 (bytes).
You should obtain the general processor type value first by using the SYI$_CPU item code. For some of the general processor types, extended processor type information is provided by the item code, SYI$_XCPU. For other general processor types, the value returned by the SYI$_XCPU item code is currently undefined.
Because the processor type is a longword decimal number, the buffer length field in the item descriptor should specify 4 (bytes).
On VAX systems, the $PRDEF macro defines the following symbols for the extended processor types:
| VAX Processor Type Symbol |
Extended Processor Type |
Extended Processor Symbol |
|---|---|---|
| PR$_SID_TYPUV |
MicroVAX II
VAXstation II |
PR$_XSID_UV_UV2 |
|
MicroVAX 2000
VAXstation 2000 |
PR$_XSID_UV_410 | |
| PR$_SID_TYPCV | MicroVAX 3300, 3400, 3500, 3600, 3800, 3900 series | PR$_XSID_CV_650 |
| VAX 6000-200, 6000-300 series | PR$_XSID_CV_9CC | |
| VAXstation 3520, 3540 | PR$_XSID_CV_60 | |
| VAXstation 3100 series | PR$_XSID_CV_420 | |
| VAXft 3000 Model 310 | PR$_XSID_CV_520 | |
| PR$_SID_TYP8NN | VAX 8530 | PRS$_XSID_N8500 |
| VAX 8550 | PRS$_XSID_N8550 | |
| VAX 8810 (8700) | PRS$_XSID_N8700 | |
| VAX 8820-N (8800) | PRS$_XSID_N8800 | |
| PR$_SID_TYPRV | VAX 4000-300 | PR$_XSID_RV_670 |
| VAX 6000-400 series | PR$_XSID_RV_9RR |
Because the value of this register is a longword hexadecimal number, the buffer length field in the item descriptor should specify 4 (bytes).
The buffer must specify a longword into which $GETSYI writes the value of the specified system parameter. For a list and description of all system parameters, refer to the HP OpenVMS System Management Utilities Reference Manual.
The Get Systemwide Information service returns information about the local system or about other systems in an OpenVMS Cluster configuration.None
This service uses the process's AST limit quota (ASTLM).
$ALLOC, $ASSIGN, $BRKTHRU, $BRKTHRUW, $CANCEL, $CREMBX, $DALLOC, $DASSGN, $DELMBX, $DEVICE_SCAN, $DISMOU, $GETDVI, $GETDVIW, $GETMSG, $GETQUI, $GETQUIW, $INIT_VOL, $MOUNT, $PUTMSG, $QIO, $QIOW, $SNDERR, $SNDJBC, $SNDJBCW, $SNDOPR
SS$_NORMAL The service completed successfully. SS$_ACCVIO The caller cannot read the item list, cannot write to the buffer specified by the buffer address field in an item descriptor, or cannot write to the return length address field in an item descriptor. SS$_BADPARAM The item list contains an invalid item code. SS$_EXASTLM The process has exceeded its AST limit quota. SS$_NOMORENODE You requested a wildcard operation, and $GETSYI has returned information about all available nodes. SS$_NOSUCHNODE The specified node does not exist or is not currently a member of the OpenVMS Cluster system. SS$_UNREACHABLE Remote node is not currently reachable.
Same as those returned in R0.
/* Defining __NEW_STARLET enables the program to benefit from better type
checking for prototypes and structures provided by OpenVMS. */
#define __NEW_STARLET 1
#include <efndef> /* No Event Flag Event Flag */
#include <iledef> /* Item List Entry Definitions */
#include <iosbdef> /* I/O Status Block Structure Definition */
#include <starlet> /* Function Prototypes for System Services */
#include <stdio> /* C Standard I/O Functions */
#include <string> /* memset Prototype */
#include <syidef> /* $GETSYI Item Code Definitions */
#define NUM_ILE 3
#define BUFFER_SIZE 20
/* Macro to initialize a 32-bit item_list_3. */
#define init_ile32(ile, length, code, bufaddr, retlen_addr) \
{ (ile)->ile3$w_length = (length); \
(ile)->ile3$w_code = (code); \
(ile)->ile3$ps_bufaddr = (bufaddr); \
(ile)->ile3$ps_retlen_addr = (retlen_addr); }
/* Simple status checking macro. */
#define bad_status(status) (((status) & 1) != 1)
main ()
{
char
node_name [BUFFER_SIZE],
version_string [BUFFER_SIZE];
int
status;
unsigned short
node_name_length,
version_string_length;
ILE3
syi_ile [NUM_ILE];
IOSB
iosb;
/* Zeroing the item list has the effect of creating the terminating entry. */
memset (syi_ile, 0, ILE3$K_LENGTH*NUM_ILE);
/* Initialize the item list entries to fetch the operating system version
and the node name. */
init_ile32 (
&syi_ile [0],
BUFFER_SIZE,
SYI$_VERSION,
version_string,
&version_string_length);
init_ile32 (
&syi_ile [1],
BUFFER_SIZE,
SYI$_NODENAME,
node_name,
&node_name_length);
status = sys$getsyiw (
EFN$C_ENF,
NULL,
NULL,
&syi_ile,
&iosb,
NULL,
0);
if (bad_status (status)) return status;
if (bad_status (iosb.iosb$w_status)) return iosb.iosb$w_status;
/* Zero terminate the strings before displaying them. */
version_string [version_string_length] = '\0';
node_name [node_name_length] = '\0';
printf ("Version: %s Node Name: %s\n",
version_string,
node_name);
}
|
This example C program demonstrates how to use $GETSYIW to obtain the operating system version number string and the node name.
Returns information about the local system or about other systems in a cluster.The $GETSYIW service completes synchronously; that is, it returns to the caller with the requested information. For asynchronous completion, use the Get Systemwide Information ($GETSYI) service; $GETSYI returns to the caller after queuing the information request, without waiting for the information to be returned. In all other respects, these services are identical; refer to the documentation about $GETSYI for information about the $GETSYIW service.
For additional information about system service completion, refer to the Synchronize ($SYNCH) service.
On Alpha and I64 systems, this service accepts 64-bit addresses.
SYS$GETSYIW [efn] ,[csidadr] ,[nodename] ,itmlst [,iosb] [,astadr] [,astprm]
int sys$getsyiw (unsigned int efn, unsigned int *csidadr, void *nodename, void *itmlst, struct _iosb *iosb, void (*astadr)(__unknown_params), int astprm);
You must specify either the csidadr or the nodename argument, but not both. For wildcard operations, however, you must use the csidadr argument.
Returns the current system time in a 64-bit format.On Alpha and I64 systems, this service accepts 64-bit addresses.
SYS$GETTIM timadr
int sys$gettim (struct _generic_64 *timadr);
timadr
OpenVMS usage: date_time type: quadword (unsigned) access: write only mechanism: by 32- or 64-bit reference (Alpha and I64) mechanism: by 32-bit reference (VAX)
The 32- or 64-bit address (on Alpha and I64 systems) or the 32-bit address (on VAX systems) of a quadword to receive the current time in 64-bit format.
The Get Time service returns the current system time in 64-bit format. The quadword is the number of nanoseconds since November 17, 1858. Based upon system time initialization, all bits in the time quadword are valid.On VAX systems, system time is updated every 10 milliseconds.
On Alpha and I64 systems, the frequency at which system time is updated varies, depending on the clock frequency of the Alpha or I64 processor, or approximately 1 millisecond.
None
None
$ASCTIM, $BINTIM, $CANTIM, $CANWAK, $NUMTIM, $SCHDWK, $SETIME, $SETIMR
For additional information about the system time, refer to the HP OpenVMS System Manager's Manual.
SS$_NORMAL The service completed successfully. SS$_ACCVIO The quadword to receive the time cannot be written by the caller.
| Previous | Next | Contents | Index |