1 Introduction
2 Ground Rules

Building a File System
3 File Systems
4 File Content Data Structure
5 Allocation Cluster Manager
6 Exceptions and Emancipation
7 Base Classes, Testing, and More
8 File Meta Data
9 Native File Class
10 Our File System
11 Allocation Table
12 File System Support Code
13 Initializing the File System
14 Contiguous Files
15 Rebuilding the File System
16 Native File System Support Methods
17 Lookups, Wildcards, and Unicode, Oh My
18 Finishing the File System Class

The Init Program
19 Hardware Abstraction and UOS Architecture
20 Init Command Mode
21 Using Our File System
22 Hardware and Device Lists
23 Fun with Stores: Partitions
24 Fun with Stores: RAID
25 Fun with Stores: RAM Disks
26 Init wrap-up

The Executive
27 Overview of The Executive
28 Starting the Kernel
29 The Kernel
30 Making a Store Bootable
31 The MMC
32 The HMC
33 Loading the components
34 Using the File Processor
35 Symbols and the SSC
36 The File Processor and Device Management
37 The File Processor and File System Management
38 Finishing Executive Startup

Users and Security
39 Introduction to Users and Security
40 More Fun With Stores: File Heaps
41 File Heaps, part 2
42 SysUAF
43 TUser
44 SysUAF API

Terminal I/O
45 Shells and UCL
46 UOS API, the Application Side
47 UOS API, the Executive Side
48 I/O Devices
49 Streams
50 Terminal Output Filters
51 The TTerminal Class
52 Handles
53 Putting it All Together
54 Getting Terminal Input
55 QIO
56 Cooking Terminal Input
57 Putting it all together, part 2
58 Quotas and I/O

UCL
59 UCL Basics
60 Symbol Substitution
61 Command execution
62 Command execution, part 2
63 Command Abbreviation
64 ASTs
65 Expressions, Part 1
66 Expressions, Part 2: Support code
67 Expressions, part 3: Parsing
68 SYS_GETJPIW and SYS_TRNLNM
69 Expressions, part 4: Evaluation

UCL Lexical Functions
70 PROCESS_SCAN
71 PROCESS_SCAN, Part 2
72 TProcess updates
73 Unicode revisted
74 Lexical functions: F$CONTEXT
75 Lexical functions: F$PID
76 Lexical Functions: F$CUNITS
77 Lexical Functions: F$CVSI and F$CVUI
78 UOS Date and Time Formatting
79 Lexical Functions: F$CVTIME
80 LIB_CVTIME
81 Date/Time Contexts
82 SYS_GETTIM, LIB_Get_Timestamp, SYS_ASCTIM, and LIB_SYS_ASCTIM
83 Lexical Functions: F$DELTA_TIME
84 Lexical functions: F$DEVICE
85 SYS_DEVICE_SCAN
86 Lexical functions: F$DIRECTORY
87 Lexical functions: F$EDIT and F$ELEMENT
88 Lexical functions: F$ENVIRONMENT
89 SYS_GETUAI
90 Lexical functions: F$EXTRACT and F$IDENTIFIER
91 LIB_FAO and LIB_FAOL
92 LIB_FAO and LIB_FAOL, part 2
93 Lexical functions: F$FAO
94 File Processing Structures
95 Lexical functions: F$FILE_ATTRIBUTES
96 SYS_DISPLAY
97 Lexical functions: F$GETDVI
98 Parse_GetDVI
99 GetDVI
100 GetDVI, part 2
101 GetDVI, part 3
102 Lexical functions: F$GETJPI
103 GETJPI
104 Lexical functions: F$GETSYI
105 GETSYI
106 Lexical functions: F$INTEGER, F$LENGTH, F$LOCATE, and F$MATCH_WILD
107 Lexical function: F$PARSE
108 FILESCAN
109 SYS_PARSE
110 Lexical Functions: F$MODE, F$PRIVILEGE, and F$PROCESS
111 File Lookup Service
112 Lexical Functions: F$SEARCH
113 SYS_SEARCH
114 F$SETPRV and SYS_SETPRV
115 Lexical Functions: F$STRING, F$TIME, and F$TYPE
116 More on symbols
117 Lexical Functions: F$TRNLNM
118 SYS_TRNLNM, Part 2
119 Lexical functions: F$UNIQUE, F$USER, and F$VERIFY
120 Lexical functions: F$MESSAGE
121 TUOS_File_Wrapper
122 OPEN, CLOSE, and READ system services

UCL Commands
123 WRITE
124 Symbol assignment
125 The @ command
126 @ and EXIT
127 CRELNT system service
128 DELLNT system service
129 IF...THEN...ELSE
130 Comments, labels, and GOTO
131 GOSUB and RETURN
132 CALL, SUBROUTINE, and ENDSUBROUTINE
133 ON, SET {NO}ON, and error handling
134 INQUIRE
135 SYS_WRITE Service
136 OPEN
137 CLOSE
138 DELLNM system service
139 READ
140 Command Recall
141 RECALL
142 RUN
143 LIB_RUN
144 The Data Stream Interface
145 Preparing for execution
146 EOJ and LOGOUT
147 SYS_DELPROC and LIB_GET_FOREIGN

CUSPs and utilities
148 The I/O Queue
149 Timers
150 Logging in, part one
151 Logging in, part 2
152 System configuration
153 SET NODE utility
154 UUI
155 SETTERM utility
156 SETTERM utility, part 2
157 SETTERM utility, part 3
158 AUTHORIZE utility
159 AUTHORIZE utility, UI
160 AUTHORIZE utility, Access Restrictions
161 AUTHORIZE utility, Part 4
162 AUTHORIZE utility, Reporting
163 AUTHORIZE utility, Part 6
164 Authentication
165 Hashlib
166 Authenticate, Part 7
167 Logging in, part 3
168 DAY_OF_WEEK, CVT_FROM_INTERNAL_TIME, and SPAWN
169 DAY_OF_WEEK and CVT_FROM_INTERNAL_TIME
170 LIB_SPAWN
171 CREPRC
172 CREPRC, Part 2
173 COPY
174 COPY, part 2
175 COPY, part 3
176 COPY, part 4
177 LIB_Get_Default_File_Protection and LIB_Substitute_Wildcards
178 CREATESTREAM, STREAMNAME, and Set_Contiguous
179 Help Files
180 LBR Services
181 LBR Services, Part 2
182 LIBRARY utility
183 LIBRARY utility, Part 2
184 FS Services
185 FS Services, Part 2
186 Implementing Help
187 HELP
188 HELP, Part 2
189 DMG_Get_Key and LIB_Put_Formatted_Output
190 LIBRARY utility, Part 3
191 Shutting Down UOS
192 SHUTDOWN
193 WAIT
194 SETIMR
195 WAITFR and Scheduling
196 REPLY, OPCOM, and Mailboxes
197 REPLY utility
198 Mailboxes
199 BRKTHRU
200 OPCOM
201 Mailbox Services
202 Mailboxes, Part 2
203 DEFINE
204 CRELNM
205 DISABLE
206 STOP
207 OPCCRASH and SHUTDOWN
208 APPEND

Glossary/Index


Downloads

FS services

I had intended to cover these services in later articles, but while writing the previous few articles, and the corresponding code, I decided that this system service ought to be covered along with the current set of articles.

The FS service provides for a File System in a file. LBR services should use this service rather than directly accessing a File System object instance, and I've updated them. You should note that the FS service doesn't exist on VMS, so this is an extension to VMS specification. Herein, we cover the documentation for the FS service routines.

All File System service routine names are prefixed with "FS_". A file system file is a file store that contains a complete UOS file system. A new file system can be created in a new file and various file system operations can be performed on the file system in the file. The FS_Open service opens an existing file system file, or creates a new one, and returns an integer context which is used by other FS_ service routines. When done with a file system file, the FS_Close routine should be called. For clarity, a reference to the "FS File" indicates the file that contains the file system within a file. "File system file" indicates a file within the FS File's file system.

FS_Close

FS_Close closes an open FS file.

Format:

FS_Close context

Returns:

Returns a condition code.

Argument:

context
A pointer to the context value returned by FS_Open that indicates the FS file to close.

Description

Closes a FS file opened with FS_Open. This should always be called when you are finished with a FS file.

Condition Codes Returned:

FS_INVCONT Specified context is not valid.
SS_NORMAL Normal completion.

FS_Create_File

FS_Create_File creates a file in an open FS file.

Format:

FS_Create_File context name info

Returns:

Returns a condition code.

Argument:

context
A pointer to the context value returned by FS_Open that indicates the FS file to affect.

name
The address of a SRB structure that points to the full file specification of the file to create. The name must be a complete valid path and cannot be null.

info
The address of a UOS_File_Info structure that contains information about the file to create. The structure has the following format:
OffsetSize in bytesDescription
08Size of file, in bytes.
88Logical end of file (byte offset)
168reserved. Should be 0.
244Clustersize, in bytes. Must be a power of 2.
284reserved. Should be 0.
328Creation date/timestamp.
408Last modified date/timestamp.
484Creator ID.
524Owner ID.
568Flags. The FAF_* constants can be used for this, but several of them have no meaning in this context.
644Version limit.
688reserved. Should be 0.
768reserved. Should be 0.
848reserved. Should be 0.
928reserved. Should be 0.
The Creator ID, Owner ID, and Version limit are user-defined.

Description

Creates a file in a FS file opened with FS_Open.

Condition Codes Returned:

FS_INVCONT Specified context is not valid.
FS_INVNAME Specified name is not valid.
SS_NORMAL Normal completion.

FS_Delete_File

FS_Delete_File deletes a file from an open FS file.

Format:

FS_Delete_File context name

Returns:

Returns a condition code.

Argument:

context
A pointer to the context value returned by FS_Open that indicates the FS file to affect.

name
The address of a SRB structure that points to the full file specification of the file to delete from the file system. The name must be a complete valid path and cannot be null.

Description

Deletes a file from a FS file opened with FS_Open.

Condition Codes Returned:

FS_INVCONT Specified context is not valid.
FS_INVNAME Specified name is not valid.
SS_NORMAL Normal completion.

FS_Expand

FS_Expand Alters the size of an open FS file.

Format:

FS_Expand context size

Returns:

Returns a condition code.

Argument:

context
A pointer to the context value returned by FS_Open that indicates the FS file to affect.

size
The address of an 8-byte integer that contains the new size of the FS file, in bytes. This cannot be smaller than the current FS file size.

Description

Expands the size of a FS file opened with FS_Open. This cannot be used to reduce the size of the file. The actual amount of expansion will depend upon the FS File system's clustersize and the result may be larger than requested. If the FS file size cannot be changed, an error code indicating the problem will be returned. For instance, if the calling process lacks necessary privileges or quotas, or if there isn't enough room on the store for the additional FS file space requirements.

Condition Codes Returned:

FS_INVCONT Specified context is not valid.
FS_BADSIZE The specified size is not supplied or is smaller than the current FS file size.
FS_NOCHNG The FS file size was not changed.
SS_NORMAL Normal completion.
Other errors can be returned if the FS file resize has an error.

FS_Open

FS_Open creates a new FS file or opens an existing one.

Format:

FS_Open context name flags allocation label password clustersize fclustersize

Returns:

Returns a condition code.

Argument:

context
A pointer to the context value to be returned by FS_Open. The context is not set if the service fails.

name
The address of a SRB structure that points to the full file specification of the FS file to create or open. The name cannot be null. If the file doesn't exist, it is created and a new file system is initialized in it.

flags
The address of an 8-byte integer containing the open flags to use for the FS file.

allocation
The address of an 8-byte integer containing the size of the new file, in bytes, if a new file is being created. Otherwise, it is ignored.

label
The address of an SRB structure that points to a label for the file system. Only used when a new file system is created. It is ignored otherwise.

password
The address of an SRB structure that points to a password for the file system. On creation, it is applied to the file system. For existing file systems, this must match the file system's existing password.

clustersizs
The address of an 8-byte integer containing the default clustersize for files created in the file system, in bytes. It must be a power of 2. Only used when creating a new file system. Ignored otherwise.

fclustersizs
The address of an 8-byte integer containing the default clustersize for folders created in the file system, in bytes. It must be a power of 2. Only used when creating a new file system. Ignored otherwise.

Description

FS_Open can open an existing file containing a file system, or create a new one. When creating a new one, the arguments can be used to define the characteristics of the file system, including default clustersizes, passwords, and so forth. When the caller is finished with the FS file, FS_Close should be called to release the FS file and associated resources.

Condition Codes Returned:

FS_INVCONT Specified context is not valid.
FS_INVFLAG One or more invalid flags were specified.
FS_INVNAME Specified name is not valid.
SS_NORMAL Normal completion.
Also, any errors that can result from opening or creating the FS file may be returned.

FS_Open_File

FS_Open_File opens a file within the file system in an open FS file.

Format:

FS_Open_File context name result

Returns:

Returns a condition code.

Argument:

context
A pointer to the context value returned by FS_Open that indicates the FS file to affect.

name
The address of an SRB structure that points to the fully-qualified file name within the file system. This must be provided and cannot be null.

result
The address of an 8-byte integer which will receive the address of a UOS_File instance.

Description

Opens the specified file within the file system of the FS file associated with the context. The file is opened in read/write mode. The file must exist and an error is returned if it does not. No UOS_File instance is returned if there is an error. The returned file instance is an object instance with a CORBA-compliant VMT. The methods of this instance are as follows:
PrototypeDescription
TUnified_Exception* Initialize()Initializes the object.
TUnified_Exception* Terminate()Terminates the object.
void Attach()Increments the reference count.
bool Detach()Decrements the reference count. Returns true if the object is completed dereferenced.
bool Is_Class( char* Name )Returns true if the passed name matches the name of the class or one of its ancestors.
int32 Interface_Version()Version of interface.
int32 Facility_ID()Facility ID for object.
int32 Facility_Version()Facility version for the object.
TDebug_Interface* Debugger()Returns nil.
TUnified_Exception* Last_Error()Returns last exception.
void* Extension()Returns nil.
constructor Create()Constructor for the object.
destructor Destroy()Destructor for the object.
TUnified_Exception* Set_Last_Error( TUnified_Exception* E )Sets an exception.
int32 Create_Stream( char* Name )Creates an ancillary data stream with the specified name. Returns the stream index.
void Delete_Stream( char* Name, int32 Index )Deletes an ancillary data stream with either the specified name or index.
char* Stream_Name( int43 Index )Returns the name of the specified ancillary data stream.
int32 Max_Stream()Returns the highest ancillary data stream index.
int64 Read( int32 Stream, int64 Position, int64 Length, void* Buff, int43 Flags )Reads the specified stream at the specified position for the specified length into the provided buffer. Returns the number of bytes actually read.
int64 Write( int32 Stream, int64 Position, int64 Length, void* Buff, int43 Flags )Writes the specified stream to the specified position for the specified length from the provided buffer. Returns the number of bytes actually written.
int64 Get_Stream_Size( int32 Stream )Returns the size, in bytes, of the ancillary data stream with the passed index.
void Set_Stream_Size( int32 Stream, int64 Value )Sets the specified ancillary data stream to the specified size, in bytes.
bool Get_Contiguous()Returns true if the file is contiguous.
void Set_Contiguous( bool Value )Sets the file to contiguous/non-contiguous.
int64 Get_File_Size()Returns the file's data size, in bytes.
void Set_File_Size( int64 Value )Sets the file's data size.
bool Read_Only()Returns true if the file is set to read-only.
bool Write_Only()Returns true if the file is set to write-only.
int64 XSpaceAvail()Returns the maximum possible space available to the file, in bytes. This includes space on the store that could be used to extend the file.
bool Is_Store()Returns true if the file is a store. This will always return true for a file in a FS file.
char* Name()Returns the name of the file.
int64 ID()Returns the internal File ID.
int64 Last_Error_Code()Returns the error code for the last operation (0 = no error).
int64 Owner()Returns the Owner ID.
int64 ACL()Returns the ACL pointer.
int64 Flags()Returns the file flags.
These methods all use the C calling standard (stdcall). When finished with this object instance, be sure to call Detach(), which will free the instance when all other references to the object are released. Note that if the FS file is closed with FS_Close, the object is no longer valid.

Condition Codes Returned:

FS_INVCONT Specified context is not valid.
FS_INVNAME Specified name is not valid.
SS_NORMAL Normal completion.
Other errors can be returned.

In the next article, we will look at the code that implements the FS service.