The OpenNET Project / Index page

[ новости /+++ | форум | теги | ]

Поиск:  Каталог документации | DEC

OpenVMS Frequently Asked Questions (FAQ), Part 4/5

This posting contains answers to frequently asked questions about the OpenVMS operating system from Compaq Computer Corporation, and the computer systems on which it runs.
Archive-name: dec-faq/vms/part4
Posting-Frequency: quarterly
Last-modified: 2 Oct 2001
Version: VMS-FAQ-4.TXT(7)

This is the OpenVMS Frequently Asked Questions Part 4/5. 
Please see Part 1/5 for administrivia, indexing, archiving, etc.


------------------------------------------------------------
DECW1.  How do I let someone else display something on my workstation?

On a workstation, you go into "Customize" menu of the session manager utility
and select "Security".  When the pop-up box appears, you can put
node/user/tranport to allow who can launch an application to the display on
that workstation.
                                             [Mike Raspuzzi]

> Yah, but this doesn't seem to work with non-VMS systems.  What do I put in 
> for the transport?  I tried "TCPIP" just for kicks, but it didn't work.

        You need a checklist of sorts:

      1) Make sure  that  you've  specified  the X-windows "display"
         correctly  on  the remote side.  For DECNET it's  something
         like NODE::0.0, for TCP/IP it's Node.Domain:0.0, etc.  On a
         unix system, define the DISPLAY environment variable so:

            csh:
	      # setenv DISPLAY myvax.domain:0.0  
            sh and ksh:
              $ DISPLAY=myvax.domain:0.0 ; export DISPLAY

      2) If you've verified 1) and things still aren't working, make
         sure the Security settings on  the  VMS side will allow the
         connection:  Pull  down the "Options" menu in  the  Session
         Manager, select "Security..."  near  the  bottom.   If  you
         don't  find  your  host  (and  username) listed on the left
         under "Authorized Users", go to the  right side of the menu
         and   fill   in  the  three  fields,  "Node",   "Username",
         "Transport".  Then click on the Add botton, then the  Apply
         and  OK  buttons  to  add  the  new  host  to  the security
         database.

          a) There are  various  transports: LOCAL, DECNET, LAT,
             TCPIP,  etc.   Select  the one appropriate  to  the
             client machine's connection to the VMS machine.

	  b) If the connection is DECNET, do *NOT* add :: to the
             node name!

          c) If the connection is TCPIP, "Username" _must_ be an
             asterisk (*) because the  TCP/IP protocol used does
             not provide the remote username.

          d) If the connection is TCPIP, it's best to use a full
             domain name, e.g.,  Node.Subd.Domain.  However, you
             _may_  have  to use the IP address  itself,  rather
             than  the  domain  name  (EWS  requires  this).   I
             generally  add two entries for each TPCIP host, the
             first using the  domain  name,  the  second  the IP
             address.

          e) There are a  various  3rd  party vendors who supply
             TCP/IP  packages for VMS, including but not limited
             to  TGV  (Multinet)  and  Wollongong  (Pathway  ?).
             Multinet  (and  DEC's  own  UCX) call the transport
             "TCPIP", Wollongong, at least in some incarnations,
             uses "WINTCP".  You need to use the appropriate
             vendor's package transport name  in the "Transport"
             field.

      3) If things _still_  aren't  working, make sure the transport
         you  want  has  been activated for DECwindows.  This  is  a
         system manager job, but you can do the ground work yourself
         before bothering the sysmgr.  Do the following:

	    $ DIR SYS$MANAGER:DECW$PRIVATE_SERVER_SETUP.COM

         If that file exists, then do:

	    $ SEARCH SYS$MANAGER:DECW$PRIVATE_SERVER_SETUP.COM -
            $_    DECW$SERVER_TRANSPORTS

         You sould find something like:

	    $ decw$server_transports == "DECNET,LOCAL,LAT,TCPIP"

         If the transport you want,  e.g., TCPIP, isn't listed, have
         your  system  manager  make  the  appropriate  changes  and
         restart DECwindows.  If the file doesn't exist, the  sysmgr
         will  have  to  create  it  by  copying  the  corresponding
         .TEMPLATE file  to  .COM  and  uncommenting  the  line that
         defines decw$server_transports.

          a) If you're wanting  to  use  TCP/IP to connect, make
             sure  TCP/IP is available on the VMS host.   TCP/IP
             is _not_ native to VMS.  You  need  to  be  running
             either Compaq's TCP/IP or a 3rd party vendor's TCP/IP
             product.   If  you're  not,  none of the above will
             help.
				    [[email protected]]

There is a log file created in SYS$MANAGER which tells you which transports
are loaded, and also tell you what connect attempts were rejected, including
showing what the presented credentials were.  This file is
SYS$MANAGER:DECW$SERVER_0_ERROR.LOG, although the 0 could be another number if
you have multiple servers on the workstation.  I have found this file to be
very useful for tracking down what needs to be put in the Session Manager
Security entries.
				    [[email protected]]

------------------------------------------------------------
DECW2.  How do I create a display on another workstation?

$ SET DISPLAY /CREATE /TRANSPORT=net_transport /NODE=remote_node

for LAT the command might look like this:

$ SET DISPLAY /CREATE /TRANSPORT=LAT /NODE=REMOTE_NODE

for DECnet:

$ SET DISPLAY /CREATE /TRANSPORT=DECNET /NODE=NODE

for TCP/IP

$ SET DISPLAY /CREATE /TRANSPORT=TCPIP /NODE=128.12.4.122

Note that LAT is typically used for X terminals but can be used from
OpenVMS to OpenVMS systems on OpenVMS Alpha V6.1 (if you have setup the X
server to allow the LAT transport - check the docs).  LAT will be supported
on OpenVMS VAX as a transport for DECwindows in a future OpenVMS VAX
release.
					[Mike Raspuzzi]

There is a log file created in SYS$MANAGER which tells you which transports
are loaded, and also tell you what connect attempts were rejected, including
showing what the presented credentials were.  This file is
SYS$MANAGER:DECW$SERVER_0_ERROR.LOG, although the 0 could be another number if
you have multiple servers on the workstation.  I have found this file to be
very useful for tracking down what needs to be put in the Session Manager
Security entries.
                                        [[email protected]]

------------------------------------------------------------
DECW3.  How can I get the information from SHOW DISPLAY into a symbol?

Use the undocumented SHOW DISPLAY/SYMBOL, and then reference the symbols
DECW$DISPLAY_NODE,  DECW$DISPLAY_SCREEN, DECW$DISPLAY_SERVER and/or
DECW$DISPLAY_TRANSPORT.
					[[email protected]]

An example of calling the underlying (and also undocumented) sys$qio 
programming interface for the WSDRIVER (WSAn:) is available at:

  http://www.openvms.compaq.com/freeware/srh_examples/DECUS_UNDOC_CLINIC/

------------------------------------------------------------
DECW4.  How do I get a log of a DECterm session?

If you are working from a Decterm, you can use the AutoPrint feature. Choose
the "Printer..." menu item from the "Options" menu, set the printing
destination to the name of the file you want, and set "Auto Print Mode".
You are now free to continue.

It should be noted that ALL the characters and escape sequences are captured,
but if you display the log file on a DECterm you will get EXACTLY what you had.
					[Yaacov Fenster]

------------------------------------------------------------
DECW5.  Problem - the DELETE key deletes forward instead of backward!

This has to do with Motif's virtual bindings.  When a Motif application starts
up, it looks at the vendor string returned in the display connection
information and attempts to match the string to a table of virtual bindings.

You can override the default bindings in your decw$xdefaults.dat file. Here is
the entry you would make to get the default VMS bindings.
    
*defaultVirtualBindings:\
 osfCancel	:		<Key>F11	\n\
 osfLeft	:		<Key>Left	\n\
 osfUp		:		<Key>Up		\n\
 osfRight	:		<Key>Right	\n\
 osfDown	:		<Key>Down	\n\
 osfEndLine	:Alt		<Key>Right	\n\
 osfBeginLine	:Alt		<Key>Left	\n\
 osfPageUp	:		<Key>Prior	\n\
 osfPageDown	:		<Key>Next	\n\
 osfDelete	:Shift		<Key>Delete	\n\
 osfUndo	:Alt		<Key>Delete	\n\
 osfBackSpace	:		<Key>Delete	\n\
 osfAddMode	:Shift		<Key>F8		\n\
 osfHelp	:		<Key>Help	\n\
 osfMenu	:		<Key>F4		\n\
 osfMenuBar	:		<Key>F10	\n\
 osfSelect	:		<Key>Select	\n\
 osfActivate	:		<Key>KP_Enter	\n\
 osfCopy	:Shift		<Key>DRemove	\n\
 osfCut		:		<Key>DRemove	\n\
 osfPaste	:		<Key>Insert

To merge:

	$ xrdb :== $decw$utils:xrdb.exe
	$ xrdb -nocpp -merge decw$xdefaults.dat
					[Fred Kleinsorge]

------------------------------------------------------------
DECW6.  Why is DECwindows Motif not starting?

First check to see if there is a graphics device, usually a G* device.
(eg: On a DEC 2000 model 300, use the command SHOW DEVICE GQ)  If you
do not find a graphics device:

a) OpenVMS has failed to find the appropriate IRQ information for an
   EISA graphics card (on the DEC 2000 series) such as the Compaq QVision,
   and did not autoconfigure it.  Run the correct ECU (for Tru64 UNIX and 
   OpenVMS) and reboot.  This is necessary only on EISA-based systems.

b) You have an EISA-based system (such as the DEC 2000 model 300) and do 
   not have a Compaq QVision video card.  This EISA graphics card should 
   have Compaq printed on it, and identifies itself as a CPQ3011 or a 
   CPQ3111.  If it is not one of these two EISA devices, then OpenVMS 
   does not support it.  (There are no other supported EISA graphics
   controllers, and EISA graphics are normally used with DECwindows only 
   on the DEC 2000 series systems.)

c) You have a PCI-based system and do not have a supported graphics
   controller -- examples of supported controllers include the

     PowerStorm 3D30
     PowerStorm 4D20
     PowerStorm 300
     PowerStorm 350
     ELSA GLoria Synergy

   See MGMT24 for information on some of these graphics controllers.

d) You have booted the system minimally, or have otherwise disabled
   the device autoconfiguration process.

If there is a G* graphics device present:

a) There may have been a severe error in the DECwindows startup. Type the
   contents of SYS$MANAGER:DECW$SERVER_0_ERROR.LOG for any information on
   errors starting the server.

b) The system parameter WINDOW_SYSTEM is not set to 1.  This is a common 
   way for system managers to disable the DECwindows server startup.

   If you really do not want a workstation system to bootstrap as and
   to represent itself as a workstation to DECwindows, add the following 
   definition to SYLOGICALS.COM:

     $ DEFINE/SYSTEM/EXEC DECW$IGNORE_WORKSTATION TRUE

c) You may not have a valid Motif license.    To check for the Motif 
   license, type the commands:

     $ LICENSE LIST DW-MOTIF/FULL 
     $ LICENSE LIST NET-APP-SUP*/FULL

   and examine the information displayed.  Make sure that one of these
   licenses is present, valid and active.

d) Check that the DECW$PRIVATE_SERVER_SETUP.COM is correct for the
   graphics controller in use.  For instance:

     From the 9FX Vision 330 Owners Guide, EK-V330G-OG pg 2-9

     Place the following in DECW$PRIVATE_SERVER_SETUP.COM (copy from 
     .TEMPLATE, if needed).  Have the file in SYS$SPECIFIC:[SYSMGR] or 
     in SYS$COMMON:[SYSMGR] as apropriate.

       $ DECW$XSIZE_IN_PIXELS == <xvalue>
       $ DECW$YSIZE_IN_PIXELS == <yvalue>
       $ DEFINE/SYSTEM DECW$SERVER_REFRESH_RATE <rate in Hz>

Also see DECW14
					[Kleinsorge, Hoffman]

------------------------------------------------------------
DECW7 relocate to SUPP7

------------------------------------------------------------
DECW8 relocated to SUPP8

------------------------------------------------------------
DECW9.  How do I set the title on a DECterm window?

If you are creating a new DECterm window, check 
HELP CREATE /TERMINAL /WINDOW_ATTRIBUTES.

If you want to change the title of an existing window, use the following
control sequences, where <esc> is the ANSI escape code, value decimal 27, 
and <text label> is what you want to display:

To set the DECterm title, send <esc>]21;<text label><esc>\
To set the icon label, send    <esc>]2L;<text label><esc>\

To set both the DECterm title and icon to the full device name:

$  esc[0,7] = 27
$  fulldevnam = F$Edit(F$GetDVI("TT","FULLDEVNAM"),"UPCASE,COLLAPSE")
$  write sys$output esc+ "]21;" + fulldevnam + esc + "\"
$  write sys$output esc+ "]2L;" + fulldevnam + esc + "\"

You can also change the title and the icon using the Options-Window...
menu.

Also see MISC2, DCL12.

------------------------------------------------------------
DECW10. How do I customize DECwindows, including the login screen?

To customize various DECwindows Motif characteristics including the defaults
used by the SET DISPLAY command, the DECwindows login screen background logo
used (the default is the DIGITAL or Compaq logo), various keymaps, the 
FileView defaults, session manager defaults, the DECwindows login processing,
DECwindows log file processing, and various other DECwindows attributes, see
the example file:

  SYS$STARTUP:DECW$PRIVATE_APPS_SETUP.TEMPLATE

This example template file is typically copied over to the filename
SYS$COMMON:[SYS$STARTUP]DECW$PRIVATE_APPS_SETUP.COM and then modified to meet
site-specific requirements.

Additionally, various X tools such as xsetroot, bitmap and xrdb -- some these
can be useful in customizing the appearance of an application or of the
DECwindows Motif display -- are provided in the DECW$UTILS: area.

When using DECwindows V1.2-4 and later on OpenVMS Alpha, the default desktop 
is the Common Desktop Environment (CDE).  You can select your prefered 
desktop (CDE or DECwindows Motif) when logging in, or you can change the 
default to the DECwindows Motif desktop using the DCL symbol 
decw$start_new_desktop in the DECwindows private application setup command 
procedure.  See SYS$STARTUP:DECW$PRIVATE_APPS_SETUP.TEMPLATE for further 
details, and how to create DECW$PRIVATE_APPS_SETUP.COM.

Note that with DECwindows CDE, the root window is no longer visible by 
default.  The root window is hidden behind the "backdrop" window of the 
current CDE workspace.  To make the root window visible, use the CDE 
style manager selection "backdrop none", and use information such as 
that in the OpenVMS FAQ to set the root window.

To add a new backdrop to the DECwindows CDE environment, the backdrop
must first be in or be converted into X11 pixmap format.  (This conversion
is often possible using tools such as xv.)  Then (if necessary) create
the default backdrop directory SYS$COMMON:[CDE$DEFAULTS.USER.BACKDROPS].
Place the X11 pixmap file containing the desired image into the backdrops
directory, ensure that it has a filename extension of .PM.  (The xv
default filename extension for the X11 pixmap file is .XPM, while CDE
expects only to see files with .PM.)  Now invoke the CDE style manager
and select a new backdrop.  You will find your image will be placed at
the end of the list of backdrops available.
 
					[Stephen Hoffman]

------------------------------------------------------------
DECW11. Why doesn't XtAppAddInput() work on OpenVMS?

XtAppAddInput() does work on OpenVMS.  The MIT definition of the X Windows
call XtAppAddInput() includes platform-specific arguments.

On platforms where C is the typically the primary programming language for
the platform, the file descriptor mask is one of the arguments to the
XtAppAddInput() call.

On OpenVMS, the platform-specific arguments to this call include an event
flag and an IOSB, as these are the traditional OpenVMS constructs used to
synchronize the completion of asynchronous operations.  While it would be
easier to port non-OpenVMS C code that calls XtAppAddInput() over to
OpenVMS if the arguments included the C file descriptor, this would make
the call unusable from other OpenVMS languages, and would make it extremely
difficult to use OpenVMS features such as ASTs and sys$qio calls.

One restriction on the event flag: the event flag chosen must be from event
flag cluster zero.  When using the traditional lib$get_ef and lib$free_ef
calls to allocate and deallocate event flags, you must first explicitly
call lib$free_ef to free up some event flags in event flag cluster zero.
Please see the event flag documentation for specific details on these calls
and for specific event flags that can be freed in event flag cluster zero.

Here is some example code that covers calling this routine on OpenVMS:

    m->InputID = XtAppAddInput(
        m->AppCtx,
        m->InputEF,
        m->InputIosb,
        the_callback, 1 );
    if ( !((int) m->InputID ))
        {
        XtAppErrorMsg(
            m->AppCtx,
            "invalidDevice",
            "XtAppAddInput",
            "XtToolkitError",
            "Can't Access Device",
            (String *) NULL,
            (Cardinal *) NULL );
        ...
					[Stephen Hoffman]

------------------------------------------------------------
DECW12. Why do the keyboard arrow keys move the DECwindows cursor?

Congratulations, you have just stumbled into "dead rodent" mode.
This DECwindows environment -- where the keyboard arrow keys
move the mouse cursor and where the [SELECT], [PREV], and [NEXT]
keys emulate the three mouse buttons -- allows rudimentary system 
operations when the mouse is among the casualties.

To enter or exit the "dead rodent" mode. press: [CTRL][SHIFT][F3]

------------------------------------------------------------
DECW13. Why does half my DECwindows display blank?

This is likely a result of receiving an OPCOM or other console
message on a system that shares the system console with the 
DECwindows graphics workstation display.

You can toggle off the console display window using [CTRL/F2], 
and you can enable a serial console per ALPHA7 or VAX10.

Also see the console message window application available with
recent DECwindows versions -- recent DECwindows versions (V1.2-3
and later) will enable this window by default.  For details on
this console message window, see the DECW$CONSOLE_SELECTION 
option in SYS$STARTUP:DECW$PRIVATE_APPS_SETUP.TEMPLATE.

On older releases, you can disable output using the following:

  SET TERMINAL/PERMANENT/NOBROADCAST OPA0:
  DEFINE/USER SYS$COMMAND OPA0:
  REPLY/DISABLE

Also see VAX9 and MGMT22, as well as DCL4.

------------------------------------------------------------
DECW14. %DECW-W-NODEVICE, No graphics device found on this system?

To resolve the following error:

 %DECW-W-NODEVICE, No graphics device found on this system
   -DECW-I-NODECW, DECwindows graphics drivers will not be loaded


1) Ensure that the SYSGEN parameter WINDOW_SYSTEM is set to 1:

    $ MCR SYSGEN SHOW WINDOW_SYSTEM

   If it is not set to a value of 1, issue the commands:

    $ MCR SYSGEN
    SYSGEN> USE CURRENT
    SYSGEN> SET WINDOW_SYSTEM 1
    SYSGEN> WRITE ACTIVE
    SYSGEN> WRITE CURRENT
    SYSGEN> EXIT
    $ REBOOT

2) Check the SYSMAN IO PREFIX LIST to ensure that the DECW$ prefix is
   included in the existing list.  If it is not, you will need to add it:

    $ MCR SYSMAN
    SYSMAN> IO SHOW PREFIX
    SYSMAN> IO SET PREFIX=(DECW$,*)   * = list returned by the show command
    SYSMAN> IO AUTO/LOG
    SYSMAN> EXIT
3) Ensure that the image SYS$SHARE:DECW$ICBM.EXE is installed in memory.
   If it is not installed, then install it:

    $ INSTALL LIST/FULL SYS$SHARE:DECW$ICBM

    $ INSTALL REPLACE SYS$SHARE:DECW$ICBM

    $ EDIT SYS$MANAGER:SYCONFIG.COM

      $! The following line was added to install
      $! support for the Mach64 Graphics Card
      $!
      $ INSTALL REPLACE SYS$SHARE:DECW$ICBM
      $ ^Z

    $ SHUTDOWN
   REBOOT the system.

If the system still complains that NO GRAPHICS DEVICES COULD BE FOUND
then:

4)   o Boot the system as normal
     o Login as "system"
     o Create the file:
         $ SYS$COMMON:[SYSMGR]DECW$USER_AUTOCONFIG.DAT (W:RE)
     o Add the following string on the very first line:
         CLEAR_PFLAG = ISA_4BYTE
     o Save the file
     o Set the file protections
     o Reboot the system

     EXAMPLE:

     $ create SYS$COMMON:[SYSMGR]DECW$USER_AUTOCONFIG.DAT
       CLEAR_PFLAG = ISA_4BYTE
       ^Z

     $ SET FILE/PROTECTION=(W:RE) SYS$COMMON:[SYSMGR]DECW$USER_AUTOCONFIG.DAT
     $ REBOOT

Also see DECW6
					[Kleinsorge, Hoffman]

------------------------------------------------------------
DECW15. How can I reset the warning bell volume?

  With DECwindows CDE drivers and ECOs starting with ECOs for the
  DECwindows keyboard driver SYS$IKBDRIVER.EXE in OpenVMS Alpha V7.1-2 
  and V7.2-1 and with the SYS$IKBDRIVER.EXE included in OpenVMS V7.2-1H1 
  and later, the DECwindows CDE controls will now correctly manage the 
  setting of the warning bell volume. 

  Unfortunately, the equivalent controls in the older DECwindows Motif 
  interface are not compatible and can no longer manage the warning 
  bell volume.

  If you need to manage the volume with DECwindows Motif, consider 
  using the following approach:

    $ @decw$utils:decw$define_utils
    $ xset b 1 100 100

  The numerics are the volume, pitch, and duration, respectively.

  Why?   When OpenVMS first started supporting the PC-style keyboards, 
  the X Windows Server and the keyboard driver interface did not support 
  the pitch and duration, and neither did DECwindows Motif.  The 
  DECwindows keyboard driver was accordingly changed to use the volume 
  from the keyclick setting (keyclick is not available in a PC-style 
  keyboard) and the bell volume setting to control the pitch and duration.

  DECwindows CDE does provide sliders for setting pitch and duration,
  so the keyboard driver and X Windows Server were modified to provide 
  all of the information, and now the DECwindows CDE sliders work.  This 
  change is unfortunately incompatible with the old scheme used on the
  pre-CDE desktops, and the volume controls are now incompatible with 
  the current keyboard drivers.  Hence the use of xset.

------------------------------------------------------------
DECW16. How can I alter the DECwindows CDE backdrop?

To select a separate backdrop to be displayed on each screen using 
DECwindows CDE:

1. Click on the Appliction Manager.
   This is the drawer icon on the CDE toolbar.
2. Click on Desktop Tools
3. Click on Set Default Screen and select the required screen
4. Click on the Style Manager.
   This is the one containing the mouse and ttt on the CDE toolbar
5. Now change the background.

                                             [Geoff Kingsmill]

------------------------------------------------------------
DECW17. How can I enable the DECwindows TCP/IP Transport

  To configure the TCP/IP transport for DECwindows, first ensure that
  a TCP/IP package is installed and configured.  Then set the DCL symbol
  DECW$SERVER_TRANSPORTS in SYS$MANAGER:DECW$PRIVATE_SERVER_SETUP.COM
  to the appropriate local value, based on the comments in that file.

  If you do not have a copy of SYS$STARTUP:DECW$PRIVATE_SERVER_SETUP.COM,
  the use the following COPY command to create this file based on the
  provided template file:

    COPY SYS$MANAGER:DECW$PRIVATE_SERVER_SETUP.TEMPLATE -
         SYS$COMMON:[SYSMGR]DECW$PRIVATE_SERVER_SETUP.COM


------------------------------------------------------------
MISC1 relocated to WIRES1

------------------------------------------------------------
MISC2.    Where can I find information on escape and control sequences?

Information on escape and control sequences can be found in the OpenVMS
I/O User's Reference Manual, in the section on the terminal driver.
This section includes details on the general format and content of
these sequences.

Specific details on the escape and control sequences supported by a
particular serial device are typically found in the documentation
provided with the specific device.  Information on the sequences 
supported by DECwindows DECterm terminal emulator are included in the 
DECwindows documentation.

Examples of common escape and control sequences -- those typically used
by the OpenVMS screen management package -- can be found in the OpenVMS 
system file SYS$SYSTEM:SMGTERMS.TXT.

The following refers to the function keys on the VTxxx series terminals,
and compatibles.  In the following, {CSI} is decimal code 155 and can be 
replaced by the sequence "{ESC}[" (without the quotes) particularly for 
seven-bit operations, SS3 is decimal code 143 and can be replaced by 
"{ESC}O" particularly for seven-bit operations.  Older VT1xx series
terminals and any other terminals operating with seven-bit characters 
should not be sent eight-bit operators such as {CSI} and {SS3}.

PF1={SS3}P PF2={SS3}Q PF3={SS3}R PF4={SS3}S
KP0={SS3}p KP1={SS3}q KP2={SS3}r KP3={SS3}s KP4={SS3}t KP5={SS3}u
KP6={SS3}v KP7={SS3}w KP8={SS3}x KP9={SS3}y KPCOMMA={SS3}l KPMINUS={SS3}m
KPPERIOD={SS3}n ENTER={SS3}M DNARROW={CSI}B UPARROW={CSI}A LFARROW={CSI}D
RTARROW={CSI}C FIND={CSI}1~ INSERT={CSI}2~ REMOVE={CSI}3~ SELECT={CSI}4~
PREV={CSI}5~ NEXT={CSI}6~ F6={CSI}17~ F7={CSI}18~ F8={CSI}19~ F9={CSI}20~
F10={CSI}21~ F11={CSI}23~ F12={CSI}24~ F13={CSI}25~ F14={CSI}26~
HELP={CSI}28~ DO={CSI}29~ F17={CSI}31~ F18={CSI}32~ F19={CSI}33~ F20={CSI}34~

An example of working with escape sequences (in DCL) follows:

$ esc5m = "*[5m"
$ esc5m[0,8] = 27
$ esc0m = "*[0m"
$ esc0m[0,8] = 27
$ write sys$output esc5m + "blinking text" + esc0m

Documentation on an ANSI terminal relatively similar to the VT525 series
is available at:

  ftp://ftp.boundless.com/pub/text/adds/docs/260_prog/
  ftp://ftp.boundless.com/pub/text/adds/docs/260_user/

Also see the various documentation and manuals available at:

  http://www.vt100.net/

Information on the ReGIS graphics character set is available at:

  http://www.cs.utk.edu/~shuford/terminal/dec_regis_news.txt

Also:

  http://www.boundless.com/Text_Terminals/VT/

Also see DECW9, DCL12.

------------------------------------------------------------
MISC3 relocated to SUPP4

------------------------------------------------------------
MISC4 relocated to WIRES2

------------------------------------------------------------
MISC5 relocated to ALPHA5

------------------------------------------------------------
MISC6.    What does "failure on back translate address request" mean?

The error message:

  BCKTRNSFAIL, failure on the back translate address request

indicates that the destination node is running DECnet-Plus, and that its 
naming service (DECnet-Plus DECdns, LOCAL node database, etc) cannot 
locate a name to associate with the source node's address.  In other 
words, the destination node cannot determine the node name for the node
that is the source of the incoming connection.

Use the DECNET_REGISTER mechanism (on the destination node) to register
or modify the name(s) and the address(es) of the source node.  Check
the namespace on the source node, as well.

Typically, the nodes involved are using a LOCAL namespace, and the
node name and address settings are not coherent across all nodes.
Also check to make sure that the node is entered into its own LOCAL
namespace.  This can be a problem elsewhere, however.  Very rarely,
a cache corruption has been known to cause this error.  To flush the
cache, use the command:

NCL> flush session control naming cache entry "*"

Also check to see that you are using the latest ECO for DECnet-Plus
for the version you are running.

DECnet-Plus can use the following namespaces:
  o DECdns: DECnet-Plus distributed name services.
  o LocalFile: a local file containing names and addresses.
  o DNS/Bind: the IP distributed name services.
  o The UCX local host file.

					[Stephen Hoffman]

------------------------------------------------------------
MISC7.    How to determine the network hardware address?

  Most Alpha and VAX systems have a console command that displays
  the network hardware address.  Many systems will also have a sticker
  identifying the address, either on the enclosure or on the network
  controller itself.

  The system console power-up messages on a number of VAX and Alpha
  systems will display the hardware address, particularly on those
  systems with an integrated Ethernet network adapter present.

  If you cannot locate a sticker on the system, if the system powerup
  message is unavailable or does not display the address, and if the
  system is at the console prompt, start with the console command:

  >>> HELP

  A console command similar to one of the following is typically used
  to display the hardware address:

  >>> SHOW DEVICE
  >>> SHOW ETHER
  >>> SHOW CONFIG

  On the oldest VAX Q-bus systems, the following console command can
  be used to read the address directly off the (DELQA, DESQA, or the
  not-supported-in-V5.5-and-later DEQNA) Ethernet controller:

  >>> E/P/W/N:5 20001920

  Look at the low byte of the six words displayed by the above command.
  (The oldest VAX Q-bus systems -- such as the KA630 processor module
  used on the MicroVAX II and VAXstation II series -- lack a console
  HELP command, and these systems typically have the primary network
  controller installed such that the hardware address value is located
  at the system physical address 20001920.)

  If the system is a VAX system, and another VAX system on the network
  is configured to answer Maintenance and Operations Protocol (MOP)
  bootstrap requests (via DECnet Phase IV, DECnet-Plus, or LANCP), the
  MOM$SYSTEM:READ_ADDR.EXE tool can be requested:

  >>> B/R5:100 ddcu
  Bootfile: READ_ADDR

  Where ddcu is the name of the Ethernet controller in the above command.
  The primarly local DELQA, DESQA, and DEQNA Q-bus controllers are usually
  named XQA0.  An attempt to MOP download the READ_ADDR program will ensue,
  and (if the download is successful) READ_ADDR will display the hardware
  address.

  If the system is running, you can use DECnet or TCP/IP to display the
  hardware address with one of the following commands.

    $ MCR NCP SHOW KNOWN LINE CHARACTERISTICS    ! DECnet Phase IV

    $ MCR NCL SHOW CSMA-CD STATION * ALL STATUS  ! DECnet-Plus

    $ UCX SHOW INTERFACE/FULL    ! TCP/IP versions prior to V5.0

    $ TCPIP SHOW INTERFACE/FULL  ! TCP/IP versions V5.0 and later

  A program can be created to display the hardware address, reading the
  necessary information from the network device drivers.  An example C
  program for reading the Ethernet hardware address (via sys$qio calls
  to the network device driver(s)) is available at the following URL:

    http://www.openvms.compaq.com/wizard/swdev/ethernVMS.html

  To use the DECnet Phase IV configurator tool to watch for MOP SYSID
  activity on the local area network:

  $ NCP SET MODULE CONFIGURATOR KNOWN CIRCUIT SURVEILLANCE ENABLED

  Let the DECnet configurator run for at least 20 minutes. Then issue
  the following commands:

  $ NCP SHOW MODULE CONFIGURATOR KNOWN CIRCUIT STATUS TO filename.txt
  $ NCP SET MODULE CONFIGURATOR KNOWN CIRCUIT SURVEILLANCE DISABLED

  The resulting file (named filename.txt) can now be searched for the
  information of interest.  Most DECnet systems will generate MOP SYSID
  messages identifying items such as the controller hardware address and
  the controller type, and these messages are generated and multicast
  roughly every ten minutes.

  Information on the DECnet MOP SYSID messages and other parts of the
  maintenance protocols is included in the DECnet network architecture
  specifications referenced in section DOC9.

------------------------------------------------------------
MISC8 combined into SUPP3

------------------------------------------------------------
MISC9.    Why can't I use PPP and RAS to connect to OpenVMS Alpha?

  OpenVMS Alpha PPP does not presently support authentication, and the 
  Microsoft Windows NT option to disable authentication during a RAS 
  connection apparently doesn't currently work -- RAS connections will 
  require authentication -- and this will thus prevent RAS connections.
                                               [Stephen Hoffman]

------------------------------------------------------------
MISC10 relocated to SUPP5

------------------------------------------------------------
MISC12.   Does DECprint (DCPS) work with the LRA0 parallel port?

The parallel printing port LRA0: found on many OpenVMS Alpha 
systems is capable of some bidirectional communications, with
enough for basic operations with most parallel printers.

DECprint (DCPS) requires more than just the simple handshaking 
provided by the LRA0: port, therefore DCPS does not work with 
the LRA0: port.
                                     [Paul Anderson]

------------------------------------------------------------
MISC13.   How do I check for free space on a (BACKUP) tape?

You cannot know for certain, though you can certainly estimate
the remaining capacity.

Tape media is different than disk media, as disks have a known 
and pre-determined fixed capacity.  Modern disks also appear 
logically perfect, based on bad block revectoring support and 
the extra blocks hidden within the disk structure for these
bad block replacements.

The capacity of tape media is not nearly as pre-determined, and 
the capacity can vary across different tape media (slightly
different media lengths or different foil markers or other
variations, for instance) and even on the same media over time
(as bad spots in the media arise).  Tapes can vary the amount of
recording media required, depending on the remaining length of 
the tape, the numbers of correctable and uncorrectable media 
errors that might occur, the numbers and sizes of the inter-record 
gaps and related tape structure overhead, the particular media
error recovery chosen, the tape density, the efficiently of any 
data compression in use, and the storage overhead required by 
BACKUP, tar, and other similar commands.

BACKUP using with the default settings results in approximately
15% overhead, in terms of saveset size.  (eg: Assuming a 500 KB 
input, the total size would be 575 KB.)

  Assuming no compression:
   4 GB media / 575 KB saveset =  7294 savesets 

  Assuming 1:2 compression:
   8 GB media / 575 KB saveset = 14588 savesets 

NB: There are no inter-record gaps on DAT tapes.  (When determining
media capacity, you have to consider these with nine-track magtape
media.  Not with DAT (DDS).  However, the block structure underneath 
the variable length record recording is based on a block size of circa 
124 KB.  Further, writing doubles filemarks and such can cause a loss 
of up to the underlying block size.  Thus even though there are no 
inter-record gaps on DAT, larger savesets are still usually best.

The compression algorithms used on various devices are generally not 
documented -- further, there is no way to calculate the effective data
compression ratio, the tape mark overhead, and similar given just the 
data to be stored on tape -- short of actually trying it, of course. 

A typical compression ratio found with "everyday" data is somewhere
around 1:1.8 to 1:2.

NB: OpenVMS often uses the term COMPACTION for compression control, 
as in the qualifier /MEDIA_FORMAT=COMPACTION.
                                          [Hoffman, Froehlin, Williams]

------------------------------------------------------------
MISC14.   So what happened to sys$cmsuper?

There is no SYS$CMSUPR service.  

The typical wisdom for getting into supervisor access mode (from 
user mode) is to execute a routine in executive mode (via a call 
to SYS$CMEXEC and the appropriate privilege) and then issue a 
SYS$DCLAST with the ASTADR parameter pointing to your routine 
entry point and the ACMODE parameter specified as PSL$C_SUPER.

Alternatively, you can reset mode in the call stack return path 
and unwind from executive or kernel out into supervisor mode.
                                    [Brian Schenkenberger]

------------------------------------------------------------
MISC15.   How can I send radio pages from my OpenVMS system?

There are third-party products available to send messages to radio
paging devices (pagers), communicating via various protocols such
as TAP (Telocator Alphanumeric Protocol).

RamPage (Ergonomic Solutions) is one of the available packages that
can generate and transmit messages to radio pagers.  Target Alert
(Target Systems; formerly the DECalert product) is another.  
Networking Dynamics Corp has a product called Pager Plus.  The 
System Watchdog package can also send pages.  The Process Software
package PMDF can route specific email addresses to a paging service, 
as well.

Many commercial paging services provide email contact addresses 
for their paging customers -- you can simply send email directly
to the pager.

Some people implement the sending of pages to radio pagers by sending
commands to a modem to take the "phone" off the "hook", and then the
paging sequence, followed by a delay, and then the same number that
a human would dial to send a numeric page.  (This is not entirely
reliable, as the modem lacks "call progress detection", and the
program could simply send the dial sequence when not really connected
to the paging company's telephone-based dial-up receiver.)

See SOFT1 for information on the available catalog of products.

------------------------------------------------------------
MISC16 relocated to WIRES3

------------------------------------------------------------
MISC17.   How do I reset the LAN (DECnet-Plus NCL) counters?

On recent OpenVMS releases:

  LANCP> SET DEVICE/DEVICE_SPECIFIC=FUNCTION="CCOU" devname


------------------------------------------------------------
MISC18.   What are the prefixes for the powers of ten?

        Power   Prefix  Abbreviation
        10^-18  atto    a
        10^-15  femto   f
        10^-12  pico    p
        10^-09  nano    n
        10^-06  micro   ╣
        10^-03  milli   m
        10^-02  centi   c
        10^-01  deci    d
        10^+01  deca    da
        10^+02  hecto   h
        10^+03  kilo    k
        10^+06  mega    M
        10^+09  giga    G
        10^+12  tera    T
        10^+15  peta    P
        10^+18  exa     E


------------------------------------------------------------
MISC19.   OpenVMS Cluster (SCS) over DECnet?  Over IP?

The OpenVMS Cluster environment operates over various network
protocols, but the core of clustering uses the System 
Communications Services (SCS) protocols, and SCS-specific 
network datagrams.  Direct (full) connectivity is assumed.

An OpenVMS Cluster DOES NOT operate over DECnet, nor over IP.

No SCS protocol routers are available.

Many folks have suggested operating SCS over DECnet or IP over the
years, but SCS is too far down in the layers, and any such project 
would entail a major or complete rewrite of SCS and of the DECnet 
or IP drivers.  Further, the current DECnet and IP implementations
have large tracts of code that operate at the application level, 
while SCS must operate in the rather more primitive contexts of the 
system and particularly the bootstrap -- to get SCS to operate over 
a DECnet or IP connection would require relocating major portions of 
the DECnet or IP stack into the kernel.  (And it is not clear that
the result would even meet the bandwidth and latency expectations.)

The usual approach for multi-site OpenVMS Cluster configurations
involves FDDI, Memory Channel (MC2), or a point-to-point remote bridge,
brouter, or switch.  The connection must be transparent, and it must
operate at 10 megabits per second or better (Ethernet speed), with 
latency characteristics similar to that of Ethernet or better.
Various sites use FDDI, MC2, ATM, or point-to-point T3 link.


------------------------------------------------------------
MISC20.   Correctly using license PAKs and LMF?

  If you have multiple LMF$LICENSE.LDB databases in your OpenVMS
  Cluster, then each and every PAK must be installed in each and
  every license database present in an OpenVMS Cluster.  Even if
  you use /EXCLUDE or /INCLUDE, you need to have a consistent set
  of PAKs registered across all licensing databases present in the 
  OpenVMS Cluster.

  If your software license permits it, you can use the following 
  two commands to transfer license PAKs:

    $ LICENSE COPY...
    $ LICENSE ISSUE/PROCEDURE/OUTPUT=file product,...

  To display the particular license(s) required (such as when you
  receive a NOLICENSE error), use the following DCL sequence:

    $ SET PROCESS/PRIVILEGE=ALL
    $ REPLY/ENABLE
    $ DEFINE/SYSTEM/EXECUTIVE LMF$DISPLAY_OPCOM_MESSAGE

  This logical name will cause all license failures to generate OPCOM 
  messages, and this will hopefully show which license(s) you need -- 
  there may well also be additional license failures displayed, as 
  various products can check for and can be enabled by multiple license 
  PAKs.  You will want to deassign this logical name when done.

  Some of the more common license PAKs:

  DECnet Phase IV:   DVNETRTG, DVNETEND, DVNETEXT, or NET-APP-SUP*
  DECnet-Plus:       DVNETRTG, DVNETEND, DVNETEXT, or NET-APP-SUP*
  TCP/IP Services:   UCX, or NET-APP-SUP*
  OpenVMS Alpha:     OPENVMS-ALPHA and OPENVMS-ALPHA-USER
  OpenVMS VAX:       VAX-VMS
  OpenVMS Galaxy:    OPENVMS-GALAXY
  Cluster (Alpha):   VMSCLUSTER, NET-APP-SUP*
  Cluster (VAX):     VAXCLUSTER, NET-APP-SUP*

  Various NET-APP-SUP (NAS) license packages are available, each with
  differing collections of products authorized.  See the various NAS
  Software Product Description (SPD) documents for specific details.

    http://www.compaq.com/info/spd/

  To determine which license PAK is failing (via a license check failure
  OPCOM message), use the command:

    $ DEFINE/SYSTEM/EXECUTIVE LMF$DISPLAY_OPCOM_MESSAGE TRUE

  Realize that defining this logical name will cause license checks
  that are otherwise hidden (unimplemented, latent, or part of a check
  for any of a series of licenses) to become visible.  In other words,
  expect to see some spurious license check calls when you define this.

------------------------------------------------------------
MISC21.   Third-party disk/tape/controllers/SCSI/widgets on OpenVMS?

  A wide variety of third-party widgets -- SCSI and IDE disks and tapes, 
  graphics controllers, etc -- are available for various platforms.

  If you purchase third-party "generic" SCSI or IDE storage devices, 
  you and your device vendor will be responsible for the testing and 
  the support of the devices.  I would tend to expect that Compaq will 
  address non-standards-compliance problems within OpenVMS (changes 
  that will also not prevent operations with other supported devices, 
  of course), but you and/or the device vendor and/or the device 
  manufacturer are responsible for finding and fixing problems in the 
  particular third-party device and or controller involved.

  In particular, realize that neither SCSI nor IDE is a particularly
  standard interface, these interfaces tend to be a collection of 
  optionally-implemented and standardized interface features.  You 
  should not and can not simply assume that all SCSI nor IDE storage
  devices are interchangeable.  If you want to try to use a generic 
  SCSI device, use V6.2 or later, or (better) V7.1-2 or later.  If
  you wish to try to use IDE, use OpenVMS V7.1-2 or later. 

  On older OpenVMS releases, see the disk capacity limits (FILE5).

  With SCSI disks on releases prior to V6.2, ensure that you have the 
  ARRE and ARWE settings configured correctly (disabled).  (If not, 
  you will see DRVERR fatal drive errors and error log entries.)

  Some SCSI disks set the medium type byte as part of the SCSI size
  field -- this is a SET CAPACITY extension to SCSI specs.  This 
  problem also applies to VAX V7.1 and later.

  Disks with SCSI disk sizes past 8.58 GB and/or with the SET CAPACITY
  extension require ALPSCSI07 ECO or the OpenVMS Alpha V7.1-2 or 
  later release.  (See FILE5 for further details.)

  Based on the displays of the (undocumented) SYS$ETC:SCSI_INFO tool;
  this tool is present in OpenVMS V6.2 and later:

    Issuing 6-byte MODE SENSE QIOW to get current values for page 01h
           Page Code ................. 01h
           Page Name ................. Read-Write Error Recovery
           Saveable .................. Yes
           Size ...................... 10
           Hex Data .................. E6 08 50 00 00 00 08 00
                                       00 00

    The E6 indicates that the AWRE and ARRE bits are set, and this is
    not acceptable on OpenVMS versions prior to V6.2.  Further along 
    in the SCSI_INFO display, if you also see:

    Issuing 6-byte MODE SENSE QIOW to get changeable values for page 81h
           Page Code ................. 01h
           Page Name ................. Read-Write Error Recovery
           Saveable .................. Yes
           Size ...................... 10
           Hex Data .................. C0 08 50 00 00 00 08 00
                                       00 00

    The C0 value means that the AWRE and ARRE values can be changed
    on this particular SCSI device.  (This is not always the case.)
    Use RZDISK from the OpenVMS Freeware, and reset the E6 flag byte 
    to hexadecimal 26 (or whatever the remaining mask when you remove
    bits C0) on page one.

  Each SCSI and IDE host contains non-trivial SCSI and IDE driver 
  software, and each device contains equally non-trivial firmware -- 
  taken together with the mechanical and electronic components, this 
  software and firmware will determine whether or not a particular
  device will function as expected.

  Also note that various devices -- such as various SCSI CD-R devices
  -- can implement and can require vendor-specific protocol extensions, 
  and these extensions can require modifications to OpenVMS or the 
  addition of various utilities.  In various of these cases, these
  devices perform functions that will require them to use SCSI or IDE
  commands that are (hopefully) architecturally-compatible SCSI or IDE
  command extensions.  (Also see UTIL1 and FILE7.)

  In order for OpenVMS to officially support a particular device,
  integration and testing work is mandated.  There can be no certainty 
  that any particular device will operate as expected in any particular 
  configuration without first performing this (non-trivial) work. 

  It is quite possible to find two devices -- both entirely compliant 
  with applicable standards or interface documents -- that will not 
  interoperate.

  The same general statement holds for OpenVMS bootstrapping on an
  unsupported VAX or Alpha platform.  It might or might not work.
  In particular, please see the OpenVMS Software Product Description 
  (SPD) for the list of platforms supported by OpenVMS.  OpenVMS is 
  not supported on the Personal Workstation -a series, on the Digital 
  Server series platforms, on the AlphaServer 2100 series 5/375 CPU, 
  on the Multia, and on a variety of other platforms.  (You might or
  might not see success booting OpenVMS on any of these platforms.)
					[Stephen Hoffman]

------------------------------------------------------------
MISC22.   How do I convert?  Disk Blocks?  KB, MB, GB, TB?

The granularity of disk storage allocation is called a disk block.
Groups of disk blocks are organized together into the smallest unit
of storage that can be allocated, and this unit is called a disk
cluster.  The number of blocks in a cluster is the cluster factor,
and is established when the disk volume is initialized.

Each individual disk block is composed of five hundred twelve (512)
bytes, or one-half kilobyte.  Each byte is comprised of eight bits.
A bit represents the smallest unit of information, typically refered
to as a one or a zero.

OpenVMS tends to uses base two notation for disk storage, while disk
storage capacity specifications from most storage vendors (including
Compaq) will generally use base ten notation.

An OpenVMS disk block is 512 bytes in size; this is one-half kilobyte
in base two notation.

The following table describes the prefix, the abbreviation, and the
associated base ten (marketing) and base two (OpenVMS) values.

            Base Ten                        Base Two
            -----------------------------   ----------------------
  Kilobyte  (KB)  10**3              1000   2**10             1024
  Megabyte  (MB)  10**6           1000000   2**20          1048576
  Gigabyte  (GB)  10**9        1000000000   2**30       1073741824
  Terabyte  (TB)  10**12    1000000000000   2**40    1099511627776
  Petabyte  (PB)  10**15 1000000000000000   2**50 1125899906842624


The base ten representation of the 2**40 value is 1099511627776, which
is obviously rather ugly.  When viewed as a base eight or base sixteen
(octal or hexadecimal, respectively) value, the value is far nicer.
Specifically, the value is 10000000000 and 40000000 when represented
in octal and hexadecimal, respectively.

Notational note: Within the OpenVMS FAQ, a Kilobit is represented by the
appreviation Kb, while a Kilobyte is represented as KB.

To convert OpenVMS disk blocks to (base two) kilobytes (KB; 1024 bytes),
simply divide by two.  To convert blocks to (base two) megabytes, divide
by 2048.  Blocks to (base two) gigabytes (GB), divide by 2097152.  These
particular divisions can also be performed using bitshifts: to divide
a value by two, shift the binary value rightwards by one bit position.

To convert OpenVMS disk blocks to (base ten) kilobytes, divide by
approximately 1.953125.

And for those rummaging around deep in SYSGEN, a microfortnight is
approximately one second.

------------------------------------------------------------
SOFT1.    Where can I find freeware/shareware/software for OpenVMS?

Details on many commercial OpenVMS products are available in the 
catalog located at:

  http://www.compaq.com/csa/directory/

  ----

An OpenVMS Freeware CD-ROM is distributed with OpenVMS, and is also
available separately (QA-6KZAA-H8).  The contents of the OpenVMS 
Freeware CD-ROM media are also available online at:

        http://www.openvms.compaq.com/freeware/
        ftp://ftp.montagar.com/
        ftp://mvb.saic.com/freewarev40/

and at various other sites.  The website also includes various updates
and new packages that become available after the CD-ROM distributions 
are created.

Submissions to the OpenVMS Freeware can be made via:

        http://www.openvms.compaq.com/openvms/freeware/

To acquire the OpenVMS Freeware CD-ROM distribution, you can order an
OpenVMS distribution from Compaq (the Freeware is included)(see the
OpenVMS SPD for part numbers), or you can specifically order a Freeware 
distribution from Compaq under part number:

  QA-6KZAA-H8

The Freeware CD-ROM set contains a large assortment of freeware, and
is a good starting point if looking for utilities.  Many of the packages
listed below are also on the Freeware CD.  Some of the most oft-requested
OpenVMS tools on the Freeware CD include ZIP and UNZIP and GZIP (please
see SOFT14), MMK (make), PINE, PERL, TAR, UUENCODE and UUDECODE.  Many 
other tools are available on the Freeware.

The UUENCODE and UUDECODE tools and various other tools are also available 
as part of TCP/IP Services package.  (Use the DCL command procedure
SYS$STARTUP:TCPIP$DEFINE_COMMANDS.COM available on V5.0 and later to set 
up the necessary DCL foreign command symbols used for these and for 
various other tools provided by TCP/IP Services.)

  ----

OpenVMS software (formerly at Western Kentucky University (WKU) is
now available via Madgoat and via Process Software archives:

  http://www.process.com/openvms/index.html
  http://www.madgoat.com/
                                           [Hunter Goatley]

  ----

The FILESERV packages are also available via anonymous FTP from:

  Via anonymous FTP from:
    ftp://ftp.process.com/vms-freeware/
    ftp.process.com, under [.WKU.VMS.FILESERV].
    ftp.vms.stacken.kth.se, under [.MIRRORS.WKU.VMS.FILESERV].
    ftp.ctrl-c.liu.se, under [.WKU.VMS.FILESERV].
    ftp.riken.go.jp
    ftp.vsm.com.au, under kits and kits/decwindows.
    ftp.vsm.com.au, via the WWW instead of FTP.

or via e-mail from [email protected]. Send the commands HELP and
   DIR ALL in the body of a mail message for more information.

  ----

Another source of free software is the vmsnet.sources newsgroup (and the
corresponding vmsnet.sources.d discussion group).  See the monthly posting
"vmsnet.sources archives" for a list of sites which archive submissions
to vmsnet.sources.

  ----

Arne VajhЬj runs an OpenVMS WWW page, with software and other pointers, at:
  http://www.levitte.org/~ava/

  ----

Kermit is available at:
  http://www.columbia.edu/kermit/ or
  ftp://kermit.columbia.edu/

  ----

ZMODEM is available at:
  ftp://ftp.cs.pdx.edu/pub/zmodem
See the FILES file in that directory for further details.
Note that this freeware version of ZMODEM will interoperate only with 
ZMODEM software that is licensed from Omen Technology.
(Also on Freeware CD)
				[Steve Lionel]

  ----

A good source of software for DEC boxes (and anything else pretty much)
is the DECUS library. online catalogs are available as well as some
software via ftp.decus.org; there's a gopher server 
  gopher://gopher.decus.org/
an FTP server:
  ftp://ftp.decus.org/
and a WWW server:
  http://www.decus.org/

Phone for DECUS orders is 508-841-3502. Lots of good stuff from lots of 
good folks, and copies on media (tapes, CDs) are cheap.
				[[email protected]]

  ----

   DECUS SIG Tape collections are available on Mark Berryman's system, 
     ftp://mvb.saic.com/

  ----

   David Jones's DECthreads-based HTTP_SERVER World-Wide Web server 
   for OpenVMS. 
     http://kcgl1.eng.ohio-state.edu/www/doc/serverinfo.html
					    [Hunter Goatly]

  ----

   Secure Shell (SSH) Server for OpenVMS:
     http://kcgl1.eng.ohio-state.edu/~JONESD/ssh/DOC/

   Secure Shell (SSH) Client for OpenVMS:
     http://www.free.lp.se/fish/

   Information on OpenSSL (SSLeay) for OpenVMS:
     http://www.free.lp.se/openssl/
                                            [Leo Demers]

   The SSH terminal client FISH:
     http://www.free.lp.se/fish/

   Information on OpenSSL (SSLeay) and OSU Web server interoperation:
     http://www.ourservers.net/openvms_ports/

  ----

DECwindows Motif V1.2-3 includes NCSA Mosaic 2.4 built for UCX.  V1.2-4
includes Spyglass Enhanced Mosaic, which supports many "Netscape" 
enhancements.    Netscape Navigator is also available for OpenVMS.

  ----

A port of Mosaic 2.7-4 which supports UCX, Multinet and SOCKETSHR/NETLIB 
is available from:
  ftp://wvnvms.wvnet.edu/mosaic/

  ----

Lynx (a character-cell World-Wide-Web reader) is available from
  ftp://ftp2.cc.ukans.edu/pub/lynx
					    [Steve Lionel]

  ----

Netscape Navigator and Mozilla web browsers are available at:
  http://www.openvms.compaq.com/ebusiness/Technology.html  
  http://www.mozilla.org/

  ----

PGP (Phil Zimmerman's "Pretty Good Privacy") is available from various
distribution sites, including those listed in the PGP FAQ.   Information
on an OpenVMS download of PGP is available at:
  http://www.pgpi.com/
  http://zone.pspt.fi/pgp/platforms/vms/
  http://www.yrl.co.uk/~phil/pds/pds.html

  ----

GNU Privacy Guard (GPG, GnuPG):

Search the comp.os.vms newsgroup archives for information regarding GnuPG; 
the source code, binaries for various platforms, and documentation are all
available at:

  http://www.gnupg.org/

The OpenVMS source code and OpenVMS Alpha images can be found at:

  http://seqaxp.bio.caltech.edu/pub/SOFTWARE/GNUPG1_0_4_VMS.ZIP

As of this time, the port only runs on OpenVMS Alpha, but an investigation
of an OpenVMS VAX port is reportedly under consideration. 

                                     [Aaron Sakovich]

  ----

An archive of the CENA DECwindows, X Windows, and VMS software 
packages can be found at the following sites:

  http://decwarch.free.fr/
  ftp://ftp2.cnam.fr/decwindows/
  ftp://ftp.ctrl-c.liu.se/decwindows/
  ftp://ftp.vms.stacken.kth.se/mirrors/decwindows/
  http://www.multimania.com/pmoreau/decw/

(See also Freeware CD)
					    [Patrick Moreau]

  ----

ImageMagick is an X11 package for display and interactive manipulation of
images.  The package includes tools for image conversion, annotation,
compositing, animation, and creating montages.  ImageMagick can read and 
write many of the more popular image formats (e.g. JPEG, TIFF, PNM, XPM, 
Photo CD, etc.). 
  http://www.imagemagick.org/
(Also on Freeware CD)
					    [[email protected]]

  ----

XV is available from:
  ftp://ftp.cis.upenn.edu/pub/xv
  http://www.sanface.com/
  ftp://www-pi.physics.uiowa.edu/~dyson/xv-3_10a-vms.zip

  ----

Many software packages are available for displaying various bitmap files 
(.JPG, .GIF, .BMP, etc) on OpenVMS.  Xloadimage, Xli, Xv, ImageMagick are 
the most common tools used under OpenVMS.  Various web browsers such as
Mozilla (qv) can also display various file formats on OpenVMS.  You can 
find some of these tools at the DECwindows Archive:

  http://www.multimania.com/pmoreau/decw/index.html
  http://www.multimania.com/pmoreau/decw/images.html
                                           [Patrick Moreau]

  ----

GHOSTSCRIPT (gs) and GHOSTVIEW (gv) are available from:
  http://www.openvms.compaq.com/freeware/freeware50/
  Also available on the Freeware V5 CD-ROM.

  Also see:
    http://www.cs.wisc.edu/~ghost/gnu/

  ----

XPDF, a viewer for PDF (Adobe Acrobat) files, is available from:
  http://www.openvms.compaq.com/freeware/freeware50/xpdf/
  http://www.foolabs.com/xpdf/
  Also available on the Freeware V5 CD-ROM.

                                            [Ki Suk Hahn, Hoffman]

  Beware: the XPDF tool included on OpenVMS Freeware V4.0 is dated, 
  and has been found to have various bugs.  Use the Freeware V5.0 
  version of the XPDF kit, or later.

A Java-based PDF viewer is available from Adobe, and is known to operate on 
recent OpenVMS Alpha releases:
  http://www.adobe.com/

  ----

Various OpenVMS-related tools -- both freeware and shareware -- such as 
txt2pdf -- are available from at:
  http://www.sanface.com/

  ----

The MPEG library version 1.1 is available for OpenVMS VAX and Alpha at
  ftp://ftp.x.org/contrib/vms/mpeglib-11-vms.readme
  ftp://ftp.x.org/contrib/vms/mpeglib-11-vms.zip
					    [Patrick Moreau]

  ----

List of FTP Mirror Sites for the DECWINDOWS archive:

AXP.PSL.KU.DK             (Multinet)  Mirror of CENA DECW archive
FTP2.CNAM.FR              (MadGoat)   Mirror of CENA DECW archive

ftp.x.org (in /contrib/vms)  not really a mirror, but I try to put all my
new ports at this site.

  ----

List of HTTP Mirror Sites for the DECWINDOWS archive:

  http://axp616.gsi.de:8080/wwwar/cena/decwindows/cena.html

Some X clients from the OpenVMS Freeware CDROM are located in
[.DECWINDOWS.CDFREEWARE] directory.
						[Patrick Moreau]

  ----

I have written and installed on INFO.CS.PUB.RO an 'Archie' clone for VMS
software. Telnet to that machine, and login as VMSARCI.
It contains now listings for over 30 ftp servers with >14 GB of VMS software.
The most useful commands are LIST, which generates a list of scanned ftp
servers, and FIND <string>, whichs looks for a file containing "string"
in the name; the search modes are only "substring" [default] and "exact",
and regex search is not supported (so FIND EMACS will work, but FIND *EMACS*
or FIND *EMACS*.* will not). The search is case-insensitive.
Those of you that know other ftp servers with VMS software that I haven't
found, please let me know. (The program that build the databases can
recursively scan whole servers or just specific directories).

Sorry, this service is VERY SLOW [by Western standards], because it runs
on a quite-busy oldie-but-goodie VAXStation 3400 with 20Mb and a RF71, and
the Internet link is only 256 Kpbs (sometimes unavailable).
						[[email protected]]

  ----

  The Levitte (extended :-) Family (and OpenVMS) website:
    http://www.levitte.org/
    http://www.levitte.org/~ava/

  ---

  Robert's OpenVMS Hobbyist Systems, including OpenVMS public domain 
  software and various ports:

    http://www.ourservers.net/

                                          [Robert Alan Byer]
  ----

  CalTech Software Archives:
    http://seqaxp.bio.caltech.edu/pub/SOFTWARE/AAA_CONTENTS.TXT

  ----

  DJE Systems Website (David J. Dachtera) 
    http://www.djesys.com/freeware/vms/

  ----

  Web Servers:
    Apache Web server (Compaq Secure Web Server (CSWS)):
      http://www.openvms.compaq.com/ebusiness/Technology.html
      http://www.er6.eng.ohio-state.edu/~jonesd/apache/1_3_9/
    OSU Web server
      http://www.er6.eng.ohio-state.edu/www/doc/serverinfo.html
      http://www.kjsl.com/archives/
      email list: [email protected]
    WASD Web server
      http://wasd.vsm.com.au/wasd/
    Purveyor Web server:
      email list: [email protected] 
         no subject, one line message: SUBSCRIBE PURVEYOR

  ----

  CD-R (CD-Recordable) media tools:
    please see FILE7

  ----

  Grace (WYSIWYG 2D plotting tool)
    http://plasma-gate.weizmann.ac.il/Grace/

  ----

  The POV-Ray ("Persistance of Vision" Raytracer) ray-tracing graphics 
  package is available on the OpenVMS Freeware.

  ----

  Majordomo mailing list handler:
    http://www.openvms.compaq.com/ebusiness/Technology.html

  ----

  PINE (OpenVMS tools for sending and receiving MIME mail):
    ftp://ftp2.kcl.ac.uk/pub/vms/pine-vms/
    http://www.agh.cc.kcl.ac.uk/files/vms/pine-vms/

  A MIME tool is available in OpenVMS V7.2 and later.

  Also see the mmencode base64 encode and decode available at:
    http://nucwww.chem.sunysb.edu/htbin/software_list.cgi
  

  ----

Menufinder (menu-driven system management environment):
   http://www.itre.com/mf/download.html

  ----

tcgmsg, pvm, mpi, linda:
  ftp://v36.chemie.uni-konstanz.de/tcgmsg_vms/tcgmsg_vms.zip

  ----

OpenVMS software that can control a Tripp-Lite Uninterruptable Power 
Supply (UPS) is available from:

    http://seqaxp.bio.caltech.edu/pub/SOFTWARE/TCONTROL.ZIP
                                            [David Mathog]

UPShot web-based software for controlling a UPS is available from:
    http://www.tmesis.com/apc/beta.htmlx
                                            [Brian Schenkenberger]


  ----

Examples of using the OpenVMS Foreign MAIL interface are available at:
  http://www.hhs.dk/anonymous/pub/vms/collection/foreignmail.zip
  http://www.hhs.dk/anonymous/pub/vms/nbl/nbl.zip

                                            [Arne Vajhoej]

For tools to manage or to search your OpenVMS MAIL file, see:
  http://vms.process.com/scripts/fileserv/fileserv.com?MLSEARCH
                                            [Phillip Helbig,
                                            Hunter Goatley]

  ----
AscToHTM attempts to convert any plain text file to HTML, while
AscToTab restricts itself to files that are plain text tables.
(Versions are also availabe on the OpenVMS Freeware).
    http://www.jafsoft.com/asctohtm/index.html
    http://www.jafsoft.com/asctotab/index.html
                                            [Jaf]

  ----

Information on the SAMBA package (PC disk and print services)
is available at:
  http://ifn03.ifn.ing.tu-bs.de/ifn/sonst/samba-vms.html
  http://www.samba.org/

To subscribe to the SAMBA-VMS mailing list e-mail [email protected] 
with no subject line and the following single line of text:

 subscribe samba-vms Your Full Name

Also see:
  http://lists.samba.org/

  ----

Perl: See SOFT12

  ----

XML:

  Source code of an XML Parser is available from Oracle.

  Also see:

    http://www.python.org/sigs/xml-sig/


  An XML parser is available as part of OpenVMS V7.3 and later.

  ----

GTK+ (The GIMP GUI Tookit) for OpenVMS:
  http://www.openvms.compaq.com/ebusiness/Technology.html

  ----

OpenVMS Porting Library now available - for easier porting of C/C++ 
applications from UNIX to OpenVMS:
  http://www.openvms.compaq.com/ebusiness/Technology.html

  ----

Mlucas (specialized FFT):

  ftp://hogranch.com/pub/mayer/README.html
                               [Robert Deininger]

  ----

Tools to monitor the terminals and the activity of other OpenVMS users 
(in addition to existing auditing capabilities in OpenVMS) are available.
Peek and Spy (Networking Dynamics) and Contrl (Raxco) are two of the
commercial packages, while the freeware Supervisor package is available 
on OpenVMS VAX.

  http://www.networkingdynamics.com/
  http://www.raxco.com/

  ----

Python for OpenVMS:

  http://www.python.org/
  http://decus.decus.de/~zessin/python/

Various packages:
  http://richj.home.mindspring.com/richware/index.html
  http://www3.sympatico.ca/n.rieck/links/cool_vax_vms.html

  ----

TSM (Terminal Server Manager) is available via:

  http://www.compaq.com/support/digital_networks_archive/servers/tsm/index.html
  http://www.openvms.compaq.com/freeware/freeware50/
  (Beware: The TSM saveset on the Freeware V5.0 disk media is busted.)

  ----

Information on the Kermit tool ("file transfer, terminal emulation, script 
programming, and character-set conversion") is available via:

  http://www.columbia.edu/kermit/

  ----

TCL for OpenVMS:

  ftp://sapodilla.rsmas.miami.edu/pub/VMS-tcl/tcl8.0p2-tk8.0p2/

  ----

make, gmake, mmk and other build tools are available on the Freeware.

  ----

An OpenVMS port of the ht://Dig web search engine is available at:

  ftp://ftp.pdv-systeme.de/vms/

------------------------------------------------------------
SOFT2.    Where can I find the UNIX <whatever> tool for OpenVMS?

POSIX:
  POSIX-compliant, Compaq-supported versions of POSIX routines and
  utilities:

    lex, yacc, grep, tar, uuencode, uudecode, rcs, man, cpio, make,
    awk, ar, mail, etc., the POSIX shell, the POSIX C programming
    interface, etc.

    POSIX utilities can be used from within the POSIX shell, and
    via the DCL `POSIX/RUN POSIX$BIN:tool.' command.

    POSIX is a separately-installed package, and is licensed with
    OpenVMS V5.5 later.  The POSIX installation kit is included
    on the consolidated distribution CD-ROM kit, and installation
    kits are also available separately.

    The POSIX package is no longer supported on OpenVMS, components 
    of the POSIX standard such as parts of the POSIX API are being 
    added into OpenVMS.  Versions of POSIX generally do not operate
    on V7.x OpenVMS VAX and OpenVMS Alpha releases.

C: 
  Common C system and library routines are present in the DEC C run-time
  library, which is available for V5.5 and later, and is shipped in V6.1
  and later.  DEC C is the upgrade for VAX C, DEC C and VAX C can coexist
  on the same system OpenVMS VAX system, and both compilers can be enabled
  via the "C" license PAK.

    Also see SYS$EXAMPLES:, and (if either is installed) the DECW$EXAMPLES:
    and UCX$EXAMPLES: areas.

X Windows:
  Various Compaq X Windows utilities:

    xwd, xev, mosaic WWW browser, xrdb, bmtoa and atobm, xpr, ico, etc.

    In DECW$UTILS: in DECwindows Motif V1.2-3 and later.  Also see
    DECW$EXAMPLES: for example X and C programs.

Miscellaneous tools and examples:
  Various unsupported OpenVMS tools and code examples:

    DWAUTH (X Windows SYSUAF authorize-like tool), various versions	
    of grep, fgrep, yacc, vmstar, uuencode, gawk, etc.  html tools,
    the mx SMTP mail exchange package, X windows flight simulator,
    the mxrn X windows news reader, the OSU HTTPD WWW server, a WWW
    gopher browser, etc. are all on the FreeWare V2.0 CD-ROM.

IP tools:
  DEC TCP/IP (UCX) contains tools such as ping, uuencode, smtp, snmp,
  rcp, nfs, tnfs, etc.  OpenVMS V6.2 and UCX V3.3 and later can be used
  together in support of the /FTP, /RCP, /RLOGIN, /TELNET, and /TN3270
  qualifiers on various DCL commands.

    Also see the various C examples in UCX$EXAMPLES:

					[Stephen Hoffman]

vi clones

  vile, vim and elvis (vi clones) run on OpenVMS.

  The current version of vile is 7.1
  It's available at
	http://www.clark.net/pub/dickey/vile/vile.html
	Versions of VILE are also on the OpenVMS Freeware


  vim: vi improved
    http://www.polarfox.com/vim/
                                        [Zoltan Arpadffy]

GNU tools:

  Information on the GNU on VMS (GNV) Project, which aims to port 
  GNU software (BASH, etc) to OpenVMS, is available at:

    http://gnv.sourceforge.net/

  Software info:

    http://vms.gnu.ai.mit.edu/software/

  Software archive:

    ftp://vms.gnu.ai.mit.edu/gnu-vms/software/


GCC:

  A mirror for work performed at the Progis company in Germany in porting
  GCC (GNU C) to OpenVMS Alpha and OpenVMS VAX is available at:

    ftp://vms.gnu.org/progis_mirror/gcc
    http://www.levitte.org/~ava/vms_gnu.htmlx

  The latest (known to me) GCC version for VAX/VMS (binaries only) is 2.7.1
  from Pat Rankin's site. 

    ftp://ftp.caltech.edu/pub/rankin/ 

                                    [Jason Armistead, Richard Levitte, 
                                    Arne Vajhoej, John E. Malmberg]

There are also updated header files for GCC on OpenVMS VAX that allow it 
to work with TCP/IP Sockets and the Compaq C C RTL at:

  ftp://ftp.qsl.net/pub/wb8tyw/gcc281_u/

                                        [John E. Malmberg]


Some of the available console management options for OpenVMS:

  http://www.robomon.com/  (Heroix)
  http://www.ki.com/products/clim/  (KI Products)
  http://www.globalmt.com/ (Global Maintech)
  http://www.tditx.com/ (TECsys)
  http://www.cai.com/products/commandit.htm (CA)
                                       [Kerry Main]

If you need to change the file modification date and are looking 
for a utility such as the UNIX touch tool, look at DFU on the 
OpenVMS Freeware (DFU SET or simular), or use an existing DCL 
commands such as:

  SET FILE/PROTECT=(current_protection_mask) [...]*.*


A table listing translations between UNIX shell and OpenVMS DCL 
commands was posted to comp.os.vms by Christopher Smith:

  http://deja.com/getdoc.xp?
    AN=581596523.1&CONTEXT=953337549.952369155

  --

The UNIX touch tool is available via various means:

  $ RENAME filename.ext;version *
  http://nucwww.chem.sunysb.edu/helplib/@hvmsapps/TOUCH
  MadGoat FILE tool (see the MadGoat archives)
    use /REVISION_DATE or /CREATION_DATE
  The DFU tool (see the OpenVMS Freeware)
  The pair:
    $ set file 'p1' /acl=(ident=[system],access=none)
    $ set file 'p1' /acl=(ident=[system],access=none) /delete
  SET FILE/VERSION=0
  The following hack:
    $!   Command procedure SETDATE.COM
    $!
    $!   Changes the DATES for an input file to a
    $!   file named OUTFILE.
    $!
    $assign/nolog 'p1' outfile
    $convert/fdl=sys$input 'p1' outfile:
    date
    creation   01-apr-2010
    expiration 01-Apr-2012
    revision   01-Apr-2011
    backup
    ...
  The following RMS system service sequence:
    $open (with xabrdt)
    set the desired values in the xabrdt
    $close

------------------------------------------------------------
SOFT3.    Where can I get the Netscape Navigator Mozilla.org Web Browser?

Mozilla.org is the open source organization providing Netscape and 
other interested parties with a browser.  Netscape is expected to 
commercialize this mozilla.org browser, add additional proprietary 
features, and release it as Netscape Communicator (version number TBD).
This Netscape Communicator will contain the features that the Internet 
community expected to see in Netscape Communicator V5.

OpenVMS Engineering is currently porting Mozilla.org's web browser
to OpenVMS -- OpenVMS baselevels of the browser are currently available 
for download.  

The Mozilla.org web browser schedule is available at:

  http://www.mozilla.org/

The latest information and current downloads are available at:

  http://www.openvms.compaq.com/ebusiness/Technology.html

See section SOFT9 for information on various certificates for V3.003 
Netscape Navigator; certificates that have presently expired.
					[Sue Denham]
					[Stephen Hoffman]

------------------------------------------------------------
SOFT4.    Where can I get Java for OpenVMS?

  Java is available on and is included with OpenVMS Alpha, starting 
  with the OpenVMS Alpha V7.2 and later releases.  Java download kits 
  are available for OpenVMS Alpha V7.1 and later releases.

  Java is not available on OpenVMS VAX.  As for why: the Java language 
  definition requires a floating point format (IEEE) that is not native 
  to VAX, and this would require the emulation of all floating point 
  operations within Java applications.  Further, the C source code used 
  to implement for Java itself is heavily dependent on passing IEEE 
  floating point values around among the many internal subroutines, and 
  adding support for VAX would entail changes to the Compaq C compiler 
  for OpenVMS VAX -- and specifically to the VAX VCG code generator that 
  is used by Compaq C on OpenVMS VAX systems -- in order to add support 
  for passing IEEE-format floating point doubles around.  Alternatively, 
  extensive changes to the Java source code to remove the assumption that 
  the double is an IEEE floating point value.

  There are currently no plans to make a version of Java available for
  OpenVMS VAX.  (A prototype version of Java was created for OpenVMS VAX,
  and performance was found to be inadequate at best.)

  If Java2 or other environment lifts the requirements for IEEE floating
  point as part of the language definition, this decision may be revisited.

  If you are having problems with Display Postscript, you need to upgrade
  your Java kit -- 1.2.2-3 and later remove the requirement for Display
  Postcript extensions, and Java 1.2.2-3 is required with DECwindows 
  V1.2-6 and later.

  For additional information on Java for Alpha systems, please see the
  OpenVMS documentation (V7.2 and later), and the following site:

    http://www.compaq.com/java/alpha/index.html

  Compaq Secure Web Server (CSWS) includes CSWS_JAVA, which provides the
  following Apache Tomcat technologies: JavaServer Pages 1.1, Java Servlet 
  2.2, and MOD_JK.  (CSWS is based on the Apache web server.  See SOFT1.)


------------------------------------------------------------
SOFT5.    VAX C and DEC C, and other OpenVMS C Programming Considerations?

  VAX C V3.2 was released for OpenVMS VAX systems in 1991.  DEC C V4.0
  replaced VAX C V3.2 in 1993 as the Compaq C compiler for OpenVMS VAX
  systems.  Compaq C is the ANSI C compiler for OpenVMS Alpha systems.
  VAX C predates the ANSI C standards, and has various areas that are
  not compliant with ANSI C requirements.  Compaq C is an ANSI C compiler,
  and can also compile most VAX C code when /STANDARD=VAXC is specified.
  Versions of this compiler between V3.2 and V6.0 (exclusive) were known 
  as either DEC C or DIGITAL C.

  Both compilers can be installed at the same time on the same OpenVMS
  VAX system, allowing a migration from VAX C to DEC C, and allowing
  the same DEC C code to be used on OpenVMS VAX and OpenVMS Alpha.  In
  1999, the C compiler version is Compaq C V6.0.

  The system manager can choose the system default C compiler when
  Compaq C is installed on a system with VAX C, and a C programmer can
  explicitly select the required compiler for a any particular compilation.

  A current "C" license PAK allows access to both VAX C and Compaq C on the
  same OpenVMS VAX system.

  Various Compaq C versions can be installed on OpenVMS VAX V5.5-2 and later.
  OpenVMS VAX releases such as V5.5-2 and V6.0 will require the installation
  of a Compaq C RTL kit, a kit that is included with the Compaq C compiler.
  OpenVMS VAX versions V6.1 and later do not require a seperate RTL kit, 
  but Compaq C RTL ECO kits are available to resolve problems found with 
  the C RTL on various OpenVMS releases.

  Wwith Compaq C, for automatic resolution of the standard C library 
  routines by the LINKER utility, use the /PREFIX qualifier, such as
  /PREFIX=ALL_ENTRIES.  If a particular application program replaces an
  existing C library routine, use /PREFIX=(ALL_ENTRIES,EXCEPT=(...)).
  (VAX C required explicit specification of an RTL shareable image or
  C object library during the link.)

  When the /PREFIX is requested, the compiler generates a "decc$" prefix
  on the specified symbols.  This prefix allows the LINKER to resolve the
  external symbols against the symbols present in the DECC$SHR library.
  The DECC$SHR library is included in the IMAGELIB.OLB shareable image
  library, and IMAGELIB is searched by default when any program (written
  in any language) is LINKed.  Because the standard C library routine
  names are very likely to match application routines written in other
  languages, a prefix "decc$" is added to the C symbol names to assure
  their uniqueness; to prevent symbol naming conflicts.  C programs,
  however, can sometimes have private libraries for various purposes,
  and the external routines share the same names as the library routines.
  (This is not recommended, but there are applications around that use
  this technique.)  Thus the need to explicity specify whether or not
  the "decc$" prefix should be prepended to the external symbol names
  by the compiler.

  The qualifiers, and most (all?) with associated pragmas, that may be
  of interest when migrating VAX C code to Compaq C include:

    /PREFIX=ALL_ENTRIES
      As mentioned above.  Failure to specificy this qualifier can
      cause the compiler to not add the prefixes for the names of
      the C library routines into the references placed in the object
      module, which can in turn cause problems resolving the external
      symbols in the library when the object code is linked.

    /ASSUME=WRITABLE_STRING_LITERALS
      Some VAX C programs erroneously write to the string literals.
      By default, Compaq C does not allow the constants to change.

    /SHARE_GLOBALS
      Enables sharing ("shr") of globals and of extern variables.
      Compaq C sets externs as non-shareable ("noshr"), VAX C as "shr".

    /EXTERN_MODE=COMMON_BLOCK
      VAX C assumes common block model for external linkages.

    /[NO]MEMBER_ALIGNMENT
      Refers to the padding placed between member elements within
      a struct.  Disabling member alignment packs the data more
      tightly into memory, but this packaging has performance
      implications, both on OpenVMS VAX and particularly on
      OpenVMS Alpha systems.

  Permit structure members to be naturally aligned whenever possible,
  and avoid using /NOMEMBER_ALIGNMENT.  If you need to disable member
  alignment, use the equivilent #pragma to designate the specific
  structures.  The alignment of structure members normally only comes
  into play with specific unaligned data structures -- such as the
  sys$creprc quota itemlist -- and with data structures that are using
  data that was organized by a system using byte or other non-member
  alignment.

  Versions of Compaq C such as V6.0 include the capability to extract the
  contents of the standard header libraries into directories such as
  SYS$SYSROOT:[DECC$LIB...], and provide various logical names that can
  be defined to control library searches.  With Compaq C versions such 
  as V6.0, the default operations of the compiler match the expectations
  of most OpenVMS programmers, without requiring any definitions of
  site-specific library-related logical names.  (And logical names left
  from older DEC C versions can sometimes cause the compiler troubles
  locating header files.)

  Compaq C V5.6 and later include a backport library, a mechanism by
  which Compaq C running on older OpenVMS releases can gain access to 
  newer RTL routines added to the RTL in later OpenVMS releases -- the 
  language RTLs ship with OpenVMS itself, and not with the compilers.

  Example C code is available in SYS$EXAMPLES:, in DECW$EXAMPLES (when
  the DECwindows examples are installed), in UCX$EXAMPLES (when Compaq
  TCP/IP Services is installed), on the Freeware CD-ROMs, and at web 
  sites such as

    http://www.openvms.compaq.com/wizard/

  Other common C issues:

    The localtime() function and various other functions maintain the 
    number of years since 1900 in the "struct tm" structure member 
    tm_year.  This field will contain a value of 100 in the year 2000, 
    101 for 2001, etc., and the yearly incrementation of this field is
    expected to continue.

    The C epoch typically uses a longword (known as time_t) to contain 
    the number of seconds since midnight on 1-Jan-1970.  At the current 
    rate of consumption of seconds, this longword is expected to overflow 
    (when interpreted as a signed longword) circa 03:14:07 on 19-Jan-2038 
    (GMT), as this time is circa 0x7FFFFFFF seconds since the C base date.
    (The most common solution is to ensure that time_t is an unsigned.)

    If C does not correctly handle the display of the local system time,
    then check the UTC configuration on OpenVMS -- the most common symptom
    of this is a skew of one hour (or whatever the local daylight savings
    time change might be).  This skew can be caused by incorrect handling 
    of the "is_dst" setting in the application program, or by an incorrect
    OpenVMS UTC configuration on the local system.  (See section TIME4.)

    When sharing variables with other languages, here is some example 
    Compaq C code...

      ...
      #pragma extern_model save
      #pragma extern_model strict_refdef
      extern int   VMS$GL_FLAVOR;
      #pragma extern_model restore
      ...

    and here is some associated example Bliss code...

      ...
      EXTERNAL
         VMS$GL_FLAVOR,
      ....


  Other common C++ issues:

    Compaq C++ (a separate compiler from Compaq C) provides both symbol
    mangling and symbol decoration.  Some of the details of working with
    longer symbol names and the resulting symbol name mangling in mixed
    language environments are listed in the shareable image cookbook,
    and in the C++ documentation.  Symbol name decoration permits the
    overloading of functions (by adding characters to the external symbol 
    for the function to indicate the function return type and the argument
    data types involved), and mixed-language external references can and 
    often do need to disable this decoration via the extern "C" declaration 
    mechanism:

      extern "C"
        {
        extern int ExternSymbol(void *);
        extern int OtherExternSymbol(void *);
        }

  Also see ALPHA16 for information on /ARCHITECTURE and /OPTIMIZE=TUNE.

  See PROG17 for information on the C system and the lib$spawn call in
  CAPTIVE environments.

  Constructs such as the order of incrementation or decrementation and
  the order of argument processing within an argument list are all
  implementation-defined.  This means that C coding constructs such as:

    i = i++;
    a[i] = i++;
    foo( i, i++, --i);

  are undefined and can have (adverse) implications when porting the C
  code to another C compiler or to another platform.  In general, any
  combination of ++, --, =, +=, -=, *=, etc operators that will cause
  the same value to be modified multiple times (between what the
  ANSI/ISO C standard calls "sequence points") produce undefined and
  implementation-specific results.

  Within C, the following are the "sequence points": the ";" at the end
  of a C statment, the ||, &&, ?:, and comma operators, and a call to
  a function.  Note specifically that = is NOT a sequence point, and
  that the individual arguments contained within a function argument
  list can be processed from right to left, from left to right, or at
  any random whim.

  Compaq C for OpenVMS VAX (formerly DEC C) and VAX C do differ in the
  related processing.

  So you are looking for OpenVMS-specific definitions (include files)?

  UCBDEF.H, PCBDEF.H and other OpenVMS-specific definitions -- these are 
  considered part of OpenVMS and not part of the C compiler kit -- are 
  available on all recent OpenVMS Alpha releases.

  To reference the version-dependent symbol library sys$share:sys$lib_c.tlb,
  use a command similar to the following for compilation:

    CC sourcea+SYS$LIBRARY:SYS$LIB_C/LIB

  You can also define DECC$TEXT_LIBRARY to reference the library.

  You will want to review the Programming Concepts manual, and specifically
  take a quick look at Chapter 21.

  And some general background: the STARLET definitions (and thus the
  sys$starlet_c.tlb library) contain the symbols and the definitions that 
  are independent of the OpenVMS version.  The LIB definitions (and thus
  sys$lib_c) contain symbols and definitions that can be dependent on the 
  OpenVMS version.  You won't need to rebuild your code after an OpenVMS 
  upgrade if you have included definitions from STARLET.  The same cannot 
  be said for some of the definitions in LIB -- you might need to rebuild 
  your code.  (The UCB structure can and has changed from release to 
  release, for instance.)

  Recent versions of C automatically search sys$starlet_c.tlb.  Explicit
  specification of sys$lib_c.tlb is required.

  Also see the Ask The Wizard website (www.openvms.compaq.com/wizard/)
  topics (2486), (3803), and (1661).
  
------------------------------------------------------------
SOFT6.    Obtaining user input in DCL CGI script?

If you choose to use the GET method, then the form data is available 
in the DCL symbol QUERY_STRING, in URL-encoded format.

If you use the POST method, then you need to read the form data from 
stdin. For a DCL CGI script running under the Netscape FastTrack web 
server, you can read the data using the following READ command:

  $ READ SYS$COMMAND postdata

to read the information in.
                                                [Colin Blake]

The following describes the use of DCL command procedures as CGI
scripts with the OSU web server:

http://www.levitte.org/~ava/cgiscripts_other.htmlx
                                                [Leif Jansson]

------------------------------------------------------------
SOFT7.    How do I get my own batch entry number?

To have a batch procedure retrieve its own batch entry number,
use the following:

  $ Entry = F$GETQUI("DISPLAY_ENTRY", -
      "entry_number","display_entry","this_job")

Remember that the entry numbers issued by the OpenVMS Job Controller 
are opaque longword values.  Don't assume you know the format of the 
number, nor the range of numbers you might see...
                                                [Peter Weaver]

------------------------------------------------------------
SOFT8.    How do I convert to new CMS libraries?

A change was made to the format of the CMS database for CMS libraries
starting with V3.5-03 -- to ensure that earlier versions of CMS are
unable to access the database once the "conversion" to V3.5-05 and
later is made, you must issue the following two commands when upgrading
from V3.5-03 and prior.  (The only differences between CMS version
V3.5-03 and CMS version V3.5-05 involve changes to ensure that np
earlier version of CMS can access the "converted" database.)

To perform the "conversion", issue the following commands for each
CMS library present:

    $ RENAME disk:[directory]00CMS.* 01CMS.*
    $ COPY NLA0: disk:[directory]00CMS.CMS

The new file 00CMS.CMS must have the same security settings as the
01CMS.CMS file, and is created solely to ensure continued compatibility
with tools that expect to find a 00CMS.CMS file (eg: various versions
of the Language-Sensitive text editor LSEDIT).

------------------------------------------------------------
SOFT9.    Where can I get new certificates for Netscape Navigator?

The URLs that I found for adding/updating root certificates are:

http://www.entrust.net/customer/generalinfo/import.htm        entrust
http://www.thawte.com/                                        thwate
https://www.verisign.com/server/prg/browser/root.html         verisign
                                          [Ken Chaney]

To update certificates in Netscape Navigator V3.03 on OpenVMS,
use the following:

Here's how to update your Root certificates in Netscape:

Thawte Server certificate which expired in 1998:

1) Under the Options Menu choose "Security Preferences..."
2) Select the "Site Certificates" tab
3) Select "Thawte Server CA" in the list of certificates
4) Select "Delete Certificate" and then "OK"
5) Go to http://www.thawte.com/serverbasic.crt
6) Follow the instructions on the popup dialog box to accept the certificate
   This mostly involves hitting the "Next" button and clicking an accept
   button and then naming the resulting certificate.  I named it the same
   name as the original.

VeriSign/RSA Server certificate which expired Dec 31, 1999:

1) Under the Options Menu choose "Security Preferences..."
2) Select the "Site Certificates" tab
3) Select "Verisign/RSA Secure Server CA" in the list of certificates
4) Select "Delete Certificate" and then "OK"
5) Go to https://www.verisign.com/server/prg/browser/root.html
6) Follow the instructions on the popup dialog box to accept the certificate
   This mostly involves hitting the "Next" button and clicking an accept
   button and then naming the resulting certificate.  Verisign suggests
   using the name "VeriSign CA".

                                          [Vance Haemmerle]

------------------------------------------------------------
SOFT10.   Why doesn't DCL symbol substitution work?

The DCL symbol substitution processing occurs only at the DCL prompt, 
not within data and not within files.  If you wish to perform symbol 
substitution in this environment, you typically write a small file 
containing the command(s) and data to be invoked -- potentially only 
the data -- and you then invoke the created procedure or reference 
the specified data.

In this case, use of a file containing nolinemode commands or other
techniques might be useful -- you will want to ensure that the text
editor you use does not attempt to use screen mode or similar, as this
is not generally considered adventageous within a command procedure.

Tools such as FTP have alternatives: COPY/FTP.

DCL symbol substitution occurs in two passes, using the ampersand and
the apostrophe.  In most cases, only the apostrophe is necessary.  In
a few cases -- such as the DCL PIPE command -- you will may need to use
the ampersand to get the substitution to work.  The following example
uses ampersand substitution to transfer the contents of the header
into a logical name:

  $ PIPE CC/VERSION | (READ SYS$PIPE hdr ; DEFINE/JOB/NOLOG hdr &hdr )

A logical name (in the job logical name table; shared by all processes 
in the current job) was used as DCL symbols cannot be returned back out
from a DCL PIPE or other spawned subprocess.


------------------------------------------------------------
SOFT11.   Duplicates MGMT40.

------------------------------------------------------------
SOFT12.   Where can I get Perl for OpenVMS?

OpenVMS support is included in the standard distribution of Perl, the 
popular scripting language created by Larry Wall.  In addition to nearly 
all of the functionality available under Unix, OpenVMS-specific Perl 
modules provide interfaces to many native features, as well as access
to Oracle, Ingres, and Sybase databases via the Perl DBI available on 
OpenVMS.

A website useful for getting started with Perl on OpenVMS -- where you 
will find such things as download links, instructions, auxiliary tools, 
and sample scripts -- is available at:

     http://www.sidhe.org/vmsperl

If you have a C compiler, the best way to obtain Perl is to download 
and build it yourself.  The latest production quality source kit is 
available from:

     http://www.perl.com/CPAN/src/stable.tar.gz

You will need GUNZIP and VMSTAR (both available from the OpenVMS Freeware
CD, or from other sites) to unpack the archive; once you've done that, 
read the instructions in the README.vms file.

Binary distributions for most Alpha and VAX environments are available 
on the OpenVMS Freeware CD-ROM and from various websites, including the 
following:

     http://www.sidhe.org/vmsperl/prebuilt.html
     http://www.openvms.compaq.com/freeware/perl5/

During active Perl development cycles, test kits are sometimes found at:
from:

     ftp://ftp.sidhe.org/

Watch the mailing list (see below) for details on experimental releases.

Charles Lane maintains pages on how to write CGI scripts in Perl for the 
OSU HTTP server, as well as more general tips, tricks, and patches for 
building and running Perl on OpenVMS:

     http://www.crinoid.com/crinoid.htmlx

There are OpenVMS-specific Perl modules that implement interfaces to a 
subset of the VMS System Services. With these modules, you can get (and 
often set) device, job, queue, user, system, and performance information. 
The lock manager, RMS indexed files, screen management utilities, and 
Intracluster Communication Services are also accessible via Perl.  The 
relevant modules are all available from:

     http://www.perl.com/CPAN/modules/by-module/VMS

To subscribe to the OpenVMS Perl mailing list (a discussion forum for 
both user support and new development), send an email message to:

    [email protected]

The mailing list archives may be searched at:

    http://www.xray.mpe.mpg.de/mailing-lists/vmsperl
                                              [Craig Berry]

------------------------------------------------------------
SOFT13.   Where can I get DECmigrate (VEST and TIE)?

  The DECmigrate image translation tool, a tool that translates 
  OpenVMS VAX images for use on OpenVMS Alpha is available at:

     http://www.support.compaq.com/amt/decmigrate/index.html

  This tool is not currently supported.

  See UTIL4.

------------------------------------------------------------
SOFT14.   Where can I get Zip, Unzip, self-extracting zip, etc?

  Many packages are provided in ZIP, GZIP, or BZIP format, which 
  requires you to acquire the associated unzip tool to unpack it.
  You can get ZIP and UNZIP from the following areas:

  http://www.openvms.compaq.com/freeware/freeware50/000tools/
  http://www.openvms.compaq.com/freeware/freeware50/bzip2/
  http://www.openvms.compaq.com/freeware/freeware50/info-zip/
  http://www.openvms.compaq.com/freeware/freeware40/000tools/
  ftp://ftp.process.com/vms-freeware/unzip.alpha_exe
  ftp://ftp.process.com/vms-freeware/unzip.vax_exe
  http://www.decus.de:8080/www/vms/sw/zip.htmlx
  http://www.djesys.com/zip.html
  http://www.djesys.com/unzip.html

  or you can request the FILESERV_TOOLS package from the e-mail server.

  [Beware: The [000TOOLS...] pre-built versions of ZIP on the OpenVMS 
  Freeware V4 (http://www.openvms.compaq.com/freeware/freeware40/)
  CD-ROM will erroneously return BILF errors on OpenVMS V7.2 and later.
  Use of the source on the Freeware V4 to rebuild the ZIP image(s), or 
  acquiring a pre-built ZIP image from one of the above areas can avoid 
  this.  The pre-built version of ZIP on the Freeware V4 kit is older 
  than the included ZIP sources, and it contains a latent bug.]

  Directions for using sfx (self-extracting zip) are available in the 
  unzip kit available at:

    http://www.openvms.compaq.com/freeware/freeware50/unzip542/

  Specifically:

    http://www.openvms.compaq.com/freeware/freeware50/UNZIP542/UNZIPSFX.TXT

  If you want to build the zip images for yourself (eg: for an older
  OpenVMS version), pull over the entire contents of:

    http://www.openvms.compaq.com/freeware/freeware50/unzip542/vms-binaries/

  and invoke LINK.COM.

[End of Part 4/5]

 --------------------------- pure personal opinion ---------------------------
   Hoff (Stephen) Hoffman   OpenVMS Engineering   hoffman#xdelta.zko.dec.com




Партнёры:
PostgresPro
Inferno Solutions
Hosting by Hoster.ru
Хостинг:

Закладки на сайте
Проследить за страницей
Created 1996-2025 by Maxim Chirkov
Добавить, Поддержать, Вебмастеру