Guardian Programmer's Guide
Table Of Contents
- Guardian Programmer’s Guide
- Contents
- What’s New in This Manual
- About This Manual
- Legal Notices
- 1 Introduction to Guardian Programming
- 2 Using the File System
- 3 Coordinating Concurrent File Access
- 4 Using Nowait Input/Output
- 5 Communicating With Disk Files- Types of Disk Files
- Using Unstructured Files- Creating Unstructured Files
- Opening Unstructured Files
- Positioning, Reading, and Writing With Unstructured Files
- Locking With Unstructured Files
- Renaming Unstructured Files
- Avoiding Unnecessary Cache Flushes to Unstructured Files
- Closing Unstructured Files
- Purging Unstructured Files
- Altering Unstructured-File Attributes
 
- Using Relative Files
- Using Entry-Sequenced Files
- Using Key-Sequenced Files- Creating Key-Sequenced Files
- Opening Key-Sequenced Files
- Positioning, Reading, and Writing With Key-Sequenced Files
- Locking, Renaming, Caching, Closing, Purging, and Altering Key-Sequenced Files
- Key-Sequenced File Programming Example
- Using Alternate Keys With an Entry-Sequenced File
- Using Alternate Keys With a Key-Sequenced File
 
- Using Partitioned Files
- Using Alternate Keys
 
- 6 Communicating With Processes- Sending and Receiving Messages: An Introduction
- Sending Messages to Other Processes
- Queuing Messages on $RECEIVE
- Receiving and Replying to Messages From Other Processes
- Receiving Messages From Other Processes: One-Way Communication
- Handling Multiple Messages Concurrently
- Checking for Canceled Messages
- Receiving and Processing System Messages
- Handling Errors
- Communicating With Processes: Sample Programs
 
- 7 Using DEFINEs
- 8 Communicating With a TACL Process
- 9 Communicating With Devices
- 10 Communicating With Terminals
- 11 Communicating With Printers
- 12 Communicating With Magnetic Tape- Accessing Magnetic Tape: An Introduction
- Positioning the Tape
- Reading and Writing Tape Records
- Blocking Tape Records
- Working in Buffered Mode
- Working With Standard Labeled Tapes- Enabling Labeled Tape Processing
- Creating Labeled Tapes
- Checking for Labeled Tape Support
- Accessing Labeled Tapes
- Writing to the Only File on a Labeled Tape Volume
- Writing to a File on a Multiple-File Labeled Tape Volume
- Writing to a File on Multiple Labeled Tape Volumes
- Reading From the Only File on a Labeled Tape Volume
- Reading From a File on a Multiple-File Labeled Tape Volume
- Reading From a File on Multiple Labeled Tape Volumes
 
- Accessing a Labeled Tape File: An Example
- Working With Unlabeled Tapes
- Terminating Tape Access
- Recovering From Errors
- Accessing an Unlabeled Tape File: An Example
 
- 13 Manipulating File Names
- 14 Using the IOEdit Procedures
- 15 Using the Sequential Input/Output Procedures- An Introduction to the SIO Procedures
- Initializing SIO Files Using TAL or pTAL DEFINEs
- Opening and Creating SIO Files
- Getting Information About SIO Files
- Reading and Writing SIO Files
- Accessing EDIT Files
- Handling Nowait I/O
- Handling Interprocess Messages
- Handling System Messages
- Handling BREAK Ownership
- Handling SIO Errors
- Closing SIO Files
- Initializing SIO Files Without TAL or pTAL DEFINEs
- Using the SIO Procedures: An Example
 
- 16 Creating and Managing Processes
- 17 Managing Memory- An Introduction to Memory-Management Procedures
- Managing the User Data Areas
- Using (Extended) Data Segments- Overview of Selectable Segments
- Overview of Flat Segments
- Which Type of Segment Should You Use?
- Using Selectable Segments in TNS Processes
- Accessing Data in Extended Data Segments
- Attributes of Extended Data Segments
- Allocating Extended Data Segments
- Checking Whether an Extended Data Segment Is Selectable or Flat
- Making a Selectable Segment Current
- Referencing Data in an Extended Data Segment
- Checking the Size of an Extended Data Segment
- Changing the Size of an Extended Data Segment
- Transferring Data Between an Extended Data Segment and a File
- Moving Data Between Extended Data Segments
- Checking Address Limits of an Extended Data Segment
- Sharing an Extended Data Segment
- Determining the Starting Address of a Flat Segment
- Deallocating an Extended Data Segment
 
- Using Memory Pools
 
- 18 Managing Time
- 19 Formatting and Manipulating Character Data- Using the Formatter
- Manipulating Character Strings
- Programming With Multibyte Character Sets- Checking for Multibyte Character-Set Support
- Determining the Default Character Set
- Analyzing a Multibyte Character String
- Dealing With Fragments of Multibyte Characters
- Handling Multibyte Blank Characters
- Determining the Character Size of a Multibyte Character Set
- Case Shifting With Multibyte Characters
- Testing for Special Symbols
- Sample Program
 
 
- 20 Interfacing With the ERROR Program
- 21 Writing a Requester Program
- 22 Writing a Server Program
- 23 Writing a Command-Interpreter Monitor ($CMON)- Communicating With TACL Processes
- Controlling the Configuration of a TACL Process
- Controlling Logon and Logoff
- Controlling Passwords
- Controlling Process Creation
- Controlling Change of Process Priority
- Controlling Adding and Deleting Users
- Controlling $CMON While the System Is Running
- Writing a $CMON Program: An Example
- Debugging a TACL Monitor ($CMON)
 
- 24 Writing a Terminal Simulator
- 25 Debugging, Trap Handling, and Signal Handling
- 26 Synchronizing Processes
- 27 Fault-Tolerant Programming in C- Overview of Active Backup Programming
- Summary of Active Backup Processing
- What the Programmer Must Do
- C Extensions That Support Active Backup Programming- Starting the Backup Process
- Opening a File With a Specified Sync Depth
- Retrieving File Open State Information in the Primary Process
- Opening Files in the Backup Process
- Retrieving File State Information in the Primary Process
- Updating File State Information in the Backup Process
- Terminating the Primary and Backup Processes
 
- Organizing an Active Backup Program
- Updating State Information
- Providing Communication Between the Primary and Backup Processes
- Programming Considerations
- Comparison of Active Backup and Passive Backup
- Active Backup Example 1
- Active Backup Example 2
 
- 28 Using Floating-Point Formats- Differences Between Tandem and IEEE Floating-Point Formats
- Building and Running IEEE Floating-Point Programs
- Compiling and Linking Floating-Point Programs
- Link-Time Consistency Checking
- Run-Time Consistency Checking
- Run-Time Support
- Debugging Options
- Conversion Routines
- Floating-Point Operating Mode Routines
 
- A Mixed Data Model Programming
- Glossary
- Index

Glossary
Guardian Programmer’s Guide — 421922-014
Glossary - 20
noninteractive mode
noninteractive mode.  A mode of operation that usually involves a command file (an EDIT 
file that contains a series of commands). Contrast with interactive mode.
nowait I/O.  An operation with an I/O device or process where the issuing process does not 
wait for the I/O operation to finish. Contrast with waited I/O.
object code accelerator (OCA).  See TNS Object Code Accelerator (OCA).
object code file.  A file containing compiled machine instructions for one or more routines. 
This file can be an executable loadfile for a program or library or a not-yet-executable 
linkfile for some program module. On other systems, an object code file is also known 
as a binary or as an executable.
object code interpreter (OCI).  See TNS Object Code Interpreter (OCI).
OCA.  (1) The command used to invoke the TNS Object Code Accelerator (OCA) on a 
TNS/E system. (2) See TNS Object Code Accelerator (OCA).
OCA region loading.  A task performed when necessary by the TNS emulation software for 
TNS/E machines. This task involves mapping into memory the Intel® Itanium® 
instructions and any tables needed at run time from the TNS Object Code Accelerator 
(OCA) region (called the Itanium instruction region) of an OCA-generated object file.
OCA region of an object file.  The region of a TNS Object Code Accelerator (OCA)-
generated object file, also called the Intel® Itanium® instruction region, that contains 
Itanium instructions and tables necessary to execute the object file on a TNS/E system 
in TNS accelerated mode. The TNS Object Code Accelerator (OCA) creates this 
region. See also OCA-accelerated object code. Contrast with Accelerator region of an 
object file.
OCA-accelerated object code.  The Intel® Itanium® instructions that result from processing 
a TNS object file with the TNS Object Code Accelerator (OCA).
OCA-accelerated object file.  A TNS object file that has been augmented by the TNS 
Ob
ject Code Accelerator (OCA) with equivalent but faster Intel® Itanium® instructions. 
An OCA-accelerated object file contains the original TNS object code, the OCA-
accelerated object code and related address map tables, and any Binder and symbol 
information from the original TNS object file. An OCA-accelerated object file also can 
be augmented by the Accelerator with equivalent MIPS RISC instructions. 
OCA-generated Itanium instructions.  See 
Intel® Itanium® instructions.
OCI.  See TNS Object Code Interpreter (OCI).
object code library.  Synonym for library.
object file.  A file generated by a compiler or linker that contains machine instructions and 
other information needed to construct the executable code spaces and initial data for a 
process. The file may be a complete program that is ready for immediate execution, or 










