UKAEA RESEARCH GROUP Report # DATA ORGANIZATION FOR 3-DIMENSIONAL CALCULATIONS ON THE IBM 360/91 USING HIGH-SPEED DRUM TRANSFERS G KUO-PETRAVIC M PETRAVIC K V ROBERTS CULHAM LABORATORY Abingdon Berkshire 1973 Available from H. M. Stationery Office Enquiries about copyright and reproduction should be addressed to the Librarian, UKAEA, Culham Laboratory, Abingdon, Berkshire, England # DATA ORGANIZATION FOR 3-DIMENSIONAL CALCULATIONS ON THE IBM 360/91 USING HIGH -SPEED DRUM TRANSFERS by G Kuo-Petravic\* M Petravic\* K V Roberts # ABSTRACT Mesh calculations in 3 dimensions require that several Mbytes of fast scratch storage should be available to hold the physical variables that must be updated each timestep. This report discusses the general principles that govern the data organization for such calculations, and describes a subroutine TRANSF which uses the EXCP macro to transfer data between the main store of the IBM 360/91 and two IBM 2301 drums in synchronism with the physical calculation, thus securing efficient CPU utilization. An initialization subroutine SETDRM is also described. Both subroutines can be called from Fortran. The listings have been carefully documented, together with page references to the relevant IBM manuals, and program commentaries and indexes are also provided. \*Dept of Engineering, University of Oxford UKAEA Research Group Culham Laboratory Abingdon, Berks. September 1973 SBN: 85311 016 6 # CONTENTS LIST - Introduction 1. - Organization of 3-Dimensional Calculations 2. - Optimum Choice of Hardware Configuration and Operating System 3. - Technical Characteristics of the IBM 2301 Drum 4. - Initialization of Data on Drums 5. - Reading and Writing Data using the EXCP Macro 6. - Timing Measurements 7. - Acknowledgements 8. # References | Appendix I. | The TRINITY MHD Equations | |---------------|----------------------------------------------------| | Appendix II. | Generalized Data Organization in Fortran | | Appendix III. | Program Commentary for Subprogram SETDRM | | Appendix IV. | Program Commentary for Subprogram TRANSF | | Appendix V. | Listing of Subprogram SETDRM | | Appendix VI. | Listing of Subprogram TRANSF | | Appendix VII. | Documentation Conventions | | Figure 1. | Explicit Leapfrog Difference Scheme | | Figure 2. | Data Organization | | Figure 3. | IBM 360/91 Computer Configuration used at Garching | | Figure 4. | A Machine Configuration for Large Calculations | | Figure 5. | Control Blocks for Subroutine SETDRM | | Figure 6. | Control Blocks for Subroutine TRANSF | # 1. Introduction A necessary requirement for 3-dimensional mesh calculations in hydrodynamics, magnetohydrodynamics (MHD), plasma physics and other fields of classical computational physics is that there should be at least a few Mbytes of scratch storage available to the problem programmer in order to hold the current values of the dependent variables which must be updated at each timestep. A basic 3D MHD program using a mesh of size 64x64x64 with 8 dependent variables at each mesh point requires 8 Mbytes of scratch storage. Most large computer systems, however, possess only around 1 Mbyte of main core store available to an individual problem programmer. Therefore most of the data have to reside on some form of fast backing store, and they are transferred to and from the main store as required, usually in a regular cyclic fashion as the scan proceeds across the mesh, in parallel with the main calculation. This report describes a scheme which has been implemented by the authors for solving 3D MHD problems on the IBM 360/91 installation at the Institut für Plasma Physik at Garching-bei-München, F.R.Germany. Two IBM 2301 drums were available to the problem programmer, each being connected to a separate channel, with a combined nominal data transfer rate of 2.4 Mbytes/second. The full resources of the computer are to be dedicated to this single large calculation whilst it is in progress (i.e. no multiprogramming), so that in order to maintain high CPU efficiency it is necessary to ensure that the two drum transfers and the CPU calculation proceed simultaneously so far as possible. This is achieved by the use of Channel Command programs to control the drums directly, a program being initiated each time it is required by an EXCP (execute channel program) macro which contains the necessary Supervisor Call. An IBM 360 Assembler Language subprogram was written to control the drum transfers and this is reproduced in Appendices V & VI in slightly modified form, being now divided into two subprograms SETDRM and TRANSF which can be called from Fortran. Numbered section-headings are included together with references to the specific pages of the six IBM manuals (references 1-6) where various points are explained. Appendices III & IV are Program Commentaries which explain the operation of the code, and these include alphanumeric indexes for all the identifiers that are employed. Some changes may have to be made in the coding to use these subprograms with other types of direct access storage device, but it should be fairly clear from Appendices III to VI and from the references how to do this. It is believed that many of the general principles outlined in this report should also apply to the use of rotating storage devices on other types of computer system. Conversion for the ICL System 4 should be fairly direct. Care has been taken to make these assembler language subprograms as intelligible as possible. The documentation techniques which have been employed should also be appropriate for other types of software including major systems programs and are therefore briefly examined in Appendix VII. # 2. Organization of 3-Dimensional Calculations The 3D MHD calculation TRINITY [8-11] typically employs a mesh of size 64x64x64 with 8 variables $\rho$ , $\underline{V}$ , T, $\underline{B}$ at each mesh point, representing the density, velocity, temperature and magnetic field respectively. If we assume that each variable occupies 4 bytes, the total amount of storage needed to hold the main physical variables is 8 Mbytes, to which must be added that needed for auxiliary variables, instructions and the Supervisor. The TRINITY calculation uses the explicit leapfrog scheme [9], with alternate points located at even and odd timesteps (Fig.1), and is organized in such a way that the updating of the alternate points in each k-plane is completed before moving on to the next. Let 0 denote the plane that is currently being computed, and N (north) and S (south) the two planes on either side that are needed for the formation of z-derivatives. planes are held in a quadruple core buffer (Fig. 2), the fourth section M (move) being used to transfer the data to and from the drums. south) plane is transferred from M back to the drums while the first half of O is computed, and then M is refilled with the FN (far north) plane during the computation of the second half. The quadruple buffer is then 'rotated' by 90° by resetting the appropriate indexes and the calculation moves on to the next plane. A similar technique can be used for any explicit 3D calculation that can be expressed in terms of first space derivatives. The main calculation routines of TRINITY are coded in automatically-generated assembler language [11], but Appendix II explains how the required indexing may be done in Fortran. Appendix I contains the MHD equations in Symbolic Algol I[10]. This method of handling the data always employs 4 resident core planes so that the amount of main storage needed is reduced by a factor 16 from 8 Mbytes to $\frac{1}{2}$ Mbyte, in addition to that required for the instructions and data. The factor is likely to increase as computers grow larger and faster. The accuracy provided by 64 mesh points in each space direction is hardly adequate since only some 16 Fourier modes or less can be described without serious error. Machines now under construction will enable a mesh of size $100 \times 100 \times 100$ to be used, thus giving a substantial improvement in accuracy and a reduction factor of 25. In the case of a 3D particle code we may envisage keeping the single array that holds the charge and potential values on a 100x100x100 mesh permanently in main storage, while the 6N coordinates and velocities of the N particles are transferred to and from the backing store as they are needed of 13. If we assume that the size of the triple buffer is small enough to be neglected and that there are 4 particles on average in each mesh cell, we again find a similar reduction factor of 24 between the total data and that held in-core, although in this case it does not depend directly on the mesh size. # 3. Optimum Choice of Hardware Configuration and Operating System Careful planning is required if this type of calculation is to work efficiently. In the case of a second generation, batch-processing system such as the ICL KDF9 or IBM 7090, it was possible to use magnetic tapes as the backing store, and the scheme devised for the GALAXY 2D particle code has previously been published [13]. The IBM 360/91 discussed in the present report has a CPU speed which is of order 50 times faster than that of the KDF9, and a first requirement is that the data transfer rates of the channels and of the direct access storage devices (DASD) which are used should increase in proportion. Let m = number of words of data for each mesh point r = data transfer rate (bytes/second) n = number of instructions used at each point T = mean instruction time. Then $$r > 16 \text{ m/nT}$$ (3.1) A factor 4 comes from the number of bytes per word, 2 from the fact that only half the points are recomputed at each step, and 2 from the fact that each point must be transferred both in and out. Fig. 3 illustrates the type of configuration that was used at Garching. It is believed that this is likely to be a good arrangement for most large 3D calculations and for most types of computer system. In designing an installation to be used for this type of work a careful distinction should be made between the three classes of DASD equipment A,B,C which are used respectively by user files, by the system, and for scratch data storage. The technical requirements are in fact quite different, and strictly random access is not in fact required for class C since the data transfer takes place according to a methodical pattern, e.g. write plane k-2 read plane k+2 write plane k-1 read plane k+3 write plane k read plane k (3.2) As CPU speeds increase it may be that this simplification will enable special-purpose DASD equipment to keep up. The scratch backing storage C available at Garching consists of two IBM 2301 drums with their associated IBM 2820 control units [3], each drum holding 4 Mbytes of data and having a nominal transfer rate of 1.2 Mbytes/second. Two independent channels were used to communicate with the two drums simultaneously, giving a combined rate of 2.4 Mbytes/second which adequately fulfils condition (3.1) for the TRINITY code. Two additional drums and other I/O devices on separate channels were available to meet requirements A and B. It is noteworthy that many of the facilities which are built into current hardware and software are either irrelevant or an actual embarrassment for this type of calculation. It has already been explained that random access is not strictly necessary. File protection is not needed when an entire device or set of devices is dedicated to a single program. In fact it is really not necessary that data transfers to scratch files on dedicated devices should be made via the Supervisor at all. Although the facility was not used by the EGDON operating system [14], the hardware of the ICL KDF9 did enable specific I/O channels and areas of core store to be allocated to an individual program by hardware registers set by the Supervisor, and the program could then itself control the peripheral devices and transfer data by means of single machine instructions without the use of Supervisor Calls. Moreover the core areas currently allocated to this data were protected from the calculation until the transfer had been completed, and were then automatically unlocked. Similar arrangements might be of great advantage for the large 3D calculations of the future. It is sometimes argued that paging and multiprogramming facilities make it unnecessary for problem programmers to concern themselves with the details of data transfer, since while this is taking place some other program will gain control of the CPU and no time will be lost. It is not clear that this view is adequately supported by quantitative information-engineering measurements for the type of calculation which is envisaged in this report. Because of the severe requirements on storage which are inevitably made by 3D calculations it seems preferable to run production jobs at night, with a single region of maximum size, a cut-down Supervisor, and multi-access probably switched off. (Under these conditions, 1.5 Mbytes of main core storage were available at Garching to the individual programmer). It is then important that the program should be able to keep the CPU busy by overlapping the calculation with data transfer as described in this report. One might try to use an automatic paging algorithm, but since the exact algorithm is quite straightforward and is known to the writer of the program there seems no good reason to do so, and by careful design it is possible to reach almost 100% utilization. Three-dimensional numerical solutions of the initial-value problems of classical physics are of interest to scientific disciplines ranging from geophysics to cosmology as well as in technology and environmental studies. It seems worthwhile to adopt a unified approach to such problems, and perhaps to design hardware, software and computer installations specifically to handle them. Attention must then be paid to the need for program modification, compilation, linkage editing and testing as well to the major production runs. It will also often be desirable and economic to monitor such runs dynamically from one or more display consoles, suspending a run as soon as any difficulty is encountered and replacing it by the next job in the queue. Fig.4 illustrates a scheme that could be used for this purpose, in which all the auxiliary duties are carried out by a smaller front-end machine. The bulk storage device D is needed to store the data which defines the 'current state' of each job which is currently suspended and may later be recontinued. (Evidently this amounts with a $100 \times 100 \times 100$ mesh to > 32 Mbytes for TRINITY and > 96 Mbytes for the particle code discussed in §2). Device E preserves an 'historical record' of the programs of each job for subsequent analysis and here again there are extensive data requirements [13]. # 4. Technical Characteristics of the IBM 2301 Drum An IBM 2301 drum [3] contains 200 usable tracks each capable of storing up to 20430 bytes of data. The rotation period, which also governs the data transfer rate, is 17.5 msec. Optimization dictates that there should be one record (of ~ 20 Kbytes) per track, and that several tracks should be written or read consecutively with no rotational delay between them, otherwise alternate revolutions are likely to be missed and the data transfer rate consequently halved. The Command Chaining facility of the IBM 360 enables this to be achieved provided that all the tracks that are to be chained together lie within the same 'protection domain' or 'cylinder', which on the IBM 2301 consists of eight tracks. Because part of Track O, Cylinder O is used by the system to hold the volume label [ref.2 p.75] and must therefore be protected from damage by the problem programmer, the Supervisor always issues a Set File Mask command which forbids the chaining of a Write or Seek command across a cylinder boundary [ref.3 p.13]. We found it convenient to fit in with this scheme by using a 60x80x48 space mesh. Only 24 cylinders = 192 tracks are then used, so avoiding Cylinder O altogether, and each cylinder holds half of each of two K-planes, the other half being held on the corresponding cylinder of the other drum. Thus four tracks are chained together, lying entirely within a cylinder and starting or ending at a cylinder boundary. Within each K-plane there are eight records each holding ten rows of the mesh, i.e. 60x10 mesh points = 19.2 Kbytes. The first four records (i.e. the first half plane) reside on Drum 1 and are chained for reading and writing, while the remaining four records reside on Drum 2. Evidently the structure of the hardware and software plays a considerable part in determining the optimum mesh configuration and this will probably often be the case. #### 5. Initialization of Data on Drums A subprogram with the standard Fortran-Assembler interface [ref.6 p.92] SUBROUTINE SETDRM (RW,STASTO,DIM,VAR,TABLE) is used for writing all the 48 K-planes on the two drums at the beginning of the calculation. This process does not need to be particularly efficient since it is only done once, and data transfers are therefore not overlapped. Table I defines the meaning of the formal parameters. Table I. Formal Parameters used by SETDRM | Name | Туре | Mnemonic | Comments | |--------|--------------------------------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | RW | integer | Read-Write | RW=1 Read records<br>RW=2 Write records | | STASTO | integer | Start-stop | STASTO=1 First call: open data sets<br>STASTO=2 Last call: close data sets<br>STASTO=0 Intermediate calls | | DIM | integer array,<br>dimension 4 | Dimensions | DIM(1)≡KCORE Number of K-planes in core at once DIM(2)≡NREC Number of records in ½ K-plane DIM(3)≡RECLEN Record length in bytes DIM(4)≡TNREC Total number of records in one drum | | VAR | Real array | Variables | Holds the core buffer. In the example quoted in the text, its size is 60x80x4x8 full words. | | TABLE | integer array<br>dimension 192 | Table | Table which holds the relative addresses of the 192 records which have been written to drum. Each is 4 bytes long | Although it would be possible to declare these parameters as variables in Fortran COMMON, for the sake of generality this has not been done. By setting RW=1 it is possible to use SETDRM to read records. This is a useful facility which allows one to check that the calculation has been initialised correctly. The listing is given in Appendix V and a program commentary in Appendix III. # 6. Reading and Writing Data using the EXCP Macro A subprogram with the standard Fortran-Assembler interface SUBROUTINE TRANSF (CHOICE, MESHCR, RECNUM, NN, VAR, TABLE, DIM) is used for reading and writing K-planes using the EXCP macro [ref.4 p.66]. The very first time TRANSF is called it performs two special functions which are later by-passed. These are: - (a) Open the data sets on drums 1 and 2 for EXCP. - (b) Convert the relative addresses of records into absolute addresses on drums in the form CCHHR(cylinder-track-block,ref.4 p.101) ready for use by the Channel Command Words (CCW's). Table II defines the meaning of the formal parameters. Again it is assumed Table II. Formal Parameters used by TRANSF | Name | Туре | Meaning | Comments | |--------|--------------------------------|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | CHOICE | Integer | Type of<br>Call | 1. Wait for completion of previous read, then read 2. Wait for completion of previous read, then write 3. Wait for completion of previous read 4. Read 5. Write 6. Wait for completion of previous write, then read 7. Wait for completion of previous write, then write 8. Wait for completion of previous write | | MESHCR | Integer | Mesh point<br>in core | The first main storage word to be transferred, relative to the base address of VAR; i.e. the origin of the current move area within the buffer | | RECNUM | Integer | Record<br>Number | Starting record number on Drum 1 to be trans-<br>ferred. | | NN | Integer | Number<br>of Call | NN=1 means first call (see (a) and (b) above) | | VAR | Real array | Variables | See Table I | | TABLE | Integer array<br>dimension 192 | Table | See Table I | | DIM | Integer array<br>dimension 4 | Dimen-<br>sions | See Table I | that they are not in COMMON, although some CPU time would be saved if they did not have to be passed and decoded each time the subprogram is called. Whenever the calculation proceeds onto a new K-plane, TRANSF is called with CHOICE=2. This means that two WAIT macros are first issued to check if the previous Reads on Drums 1 and 2 have been completed. If not, the CPU Waits until their successful completion is indicated in the Event Control Block (ECB). After this, two EXCP macros are issued to Write the first half of a K-plane onto Drum 1, and the second half on Drum 2, simultaneously. When the calculation has reached the half-way mark in the K-plane, TRANSF is called again with CHOICE=6. This now first Waits for the completion of the previous Writes, followed by two EXCP Read macros which will bring in a new K-plane. The major part of the subprogram is amply documented in Appendixes IV and VI and does not need further comment here. The exception is the channel program, composed of CCW's. Table III exhibits the structure of a CCW, which is a double word divided into 6 fields [ref.5 pp.19,99; ref.3 p.10]. Table III. Structure of a Channel Command Word | Field | Bits | Name | Purpose | |-------|-------|--------------------------------------------|---------------------------------------------------------------------------------------------------------------------------| | | 0-7 | O-7 Command Code Operation to be performed | | | 2 | 8-31 | Data address | Base Address in core | | 3 | 32-36 | Flags | 32 Chain Data (CD) 33 Chain Command (CC) 34 Suppress Length Indicator (SLI) 35 Skip 36 Program Control Interruption (PCI) | | 4 | 37-39 | | Must be zero, except for Transfer in Channel (TIC), where ignored. | | 5 | 40-47 | (Not used) | | | 6 | 48-63 | Count | Number of bytes to be transferred | The order in which the CCW's should appear is very difficult to decipher from the 2820 hardware manual and in the present case has been arrived at after a certain amount of trial and error. Reference 3 does however fully explain the meaning of the individual CCW's and should be consulted. The chained channel program for reading is comparatively simple and consists basically of 3 kinds of CCW's: - 1) CCWR1 CCW X'31', IOBR1 + 35, X'40', X'05" - 2) CCW X'08', CCWR1, X'00', X'00' - 3) AR1 CCW X'86', †, X'40', 19200 - 4) BR1 CCW X'86', †, X'40', 19200 - 5) CR1 CCW X'86', †, X'40', 19200 - 6) DR1 CCW X'86', +, X'00', 19200 Statement 1 is a Search ID Equal CCW. This causes a comparison to be made between 5 bytes of data transmitted by the CPU from the core (the address being specified by field 2, in this case IOBR1+35, and the number of bytes by field 6), and the record identifier portion of a count area from the 2301. X'31' is the Command Code for Search ID Equal, while X'40' sets bit 33 to 1 and thus indicates that the CCW's are being chained together in sequence. Control passes to Statement 2 if the comparison is unsuccessful, but skips to Statement 3 when agreement is found. Statement 2 is a Transfer in Channel (TIC) CCW, as indicated by the Command Code X'08'. This is simply a branching instruction to allow for chaining between CCW's not located in adjacent double words in main core store. In this case it can be read as 'branch to address CCWR1', since the correct record has not been found, i.e. loop back to the previous CCW. However if the correct cylinder, head and record number has been found, then a status modifier bit is sent to the channel by the 2820 and the channel automatically slips over Statement 2 and gives control to Statement 3. Statements 3-5. These are Read Data CCW with Multi-Track Mode (MTM): X'06' indicates Read, and X'86' Read with MTM. When MTM is specified and the index point is passed, the track address is automatically updated so that the Read operation can continue on the next track. The position indicated by † has been previously filled with the address in main core where the record is to be placed. The flag field '40' specifies Command Chaining, hence the next CCW is to be chained. The Count Field 6 containing 19200 specifies the number of bytes to be moved; this is set in TRANSF by the value of RECLEN. Statement 6. This differs from 3-5 only by having a zero in bit position 33; i.e. no Command Chaining so that the sequence is terminated. The corresponding channel program for writing records is more complex (Appendices IV and VI). In this case although the Write Data CCW contains X'40' in the flag field, i.e. Command Chaining, it is still necessary to do a Search ID Equal on the next track and to verify its address before writing to the next record. The Command Code 'B1' in the Search ID Equal CCW specifies multitrack mode which means that the next track can be used automatically in the search. # 7. Timing Measurements By means of a model program we have been able to prove, in collaboration with Mr H Fisser, that the above method does indeed access the drums synchronously. The real problem set-up was timed with a module which combined SETDRM, TRANSF, and the generated TRINITY equations in assembler language. The space loops were in assembler language, as were the border point resetting routines. It was found that together with the transfers on two drums, the TRINITY equations on a 60x80x48 mesh took 17 sec. of CPU time/step. It is possible to establish, from a timing experiment without drum transfers on a smaller mesh, that the CPU should take $\sim 13.6$ sec to run through all the computations at every alternate mesh point for one timestep. In other words, the time needed by the CPU to calculate one K-plane is 283 ms. The minimum time required to write one K-plane and read one K-plane from drums can be estimated as follows: #### Table IV. Drum Transfer Times | | | | 1 | .75 | ms | |------------|----------------------------------|---|---|------|----| | Time taken | to read 4 records synchronously | 4 | x | 17.5 | ms | | Rotational | delay for 2 unrelated drums | | | 17.5 | ms | | Time taken | to write 4 records synchronously | 4 | x | 17.5 | ms | | Rotational | delay for 2 unrelated drums | | | 17.5 | ms | the drum rotational period being 17.5 ms. Therefore the CPU should not be kept in a Wait state by drum transfers. This ensures that the elapsed time for the run will not be much greater than the CPU time. However a certain amount of CPU time does have to be spent on drum transfers. The exact amount will depend on the details of the program and can only be found by experimentation. When an Input/Output macro such as the EXCP is issued, a Supervisor-Call interrupt is effected which passes control to the Input/Output Supervisor. The I/O Supervisor performs many tasks, such as checking the validity of the various control blocks, scheduling the I/O request, and issuing the start I/O (SIO) instruction to activate the I/O device. Once the I/O has been initiated, the channel transfers information to and from main core store simultaneously with CPU activity, with the exception that if the channel requires access to main store, it has priority over the CPU. When the channel program has been successfully executed, the I/O Supervisor once more is responsible for placing a completion code in the event control block. The time taken by peripheral activities at each timestep such as handling the Fortran-Assembler interface, transferring guard planes for the purpose of resetting the border points, can be estimated to take approximately 1 sec. Therefore it has been possible to reach the following conclusions regarding the time CPU spent on various part of the program: #### Table V. CPU Time/Step | CPU time spent on calculation at mesh points | 13.6 sec | |---------------------------------------------------------|----------| | CPU time spent on peripheral calculations and transfers | 1.0 sec | | CPU time spent on drum transfers | 2.4 sec | | Total | 17.0 sec | Taking into account initialization and the output of results, it is therefore practicable to perform 3D calculations on the Garching IBM 360/91 at about 200 timesteps/hour, and therefore at an economically attractive cost. #### 8. Acknowledgements We would like to thank most warmly Professor A Schlüter, Dr K Von Hagenow, and Dr F Hertweck of the Max-Planck Institut für Plasma Physik, Garching bei München, F R Germany, for their interest and encouragement and the provision of most excellent computing facilities. We are also very grateful to Herr F Köpfer, Herr K Goihl and Herr H Fisser for many helpful discussions. #### References - 1. IBM System/360 Operating System. Supervisor and Data Management Macro Instructions. Form C28-6647-3 (4th Ed.Nov.1968). - 2. IBM System/360 Operating System. Supervisor and Data Management Services. Form C28-6646-2 (3rd Ed.Nov.1968). - IBM System/360 Component Descriptions 2820 Storage Control and 2301 Drum Storage. Form A22-6895-2 (3rd Ed.Sept.1968). - 4. IBM System/360 Operating System. System Programmer's Guide. Form C28-6550-5 (6th Ed.Nov.1968). - 5. IBM System/360 Operating System. Principles of Operation. Form A22-6821-7 (8th Ed.Sept.1968). - 6. IBM System/360 Operating System. Fortran IV(G) Programmer's Guide. Form C28-6639-1 (2nd Ed.1966). - 7. IBM System/360 Operating System. Programmer's Guide to Debugging. Form C28-6670-1 (2nd Ed.Nov.1968). - K V Roberts and J P Boris, 'TRINITY: Programs for 3D Magnetohydrodynamics', Proceedings of the Institute of Physics Computational Physics Conference, Culham Laboratory, July 1969, paper 44. Culham Report CLM-CP(1969), HMSO(London). - 9. K V Roberts and D E Potter, 'Magnetohydrodynamic Calculations', published in Methods in Computational Physics, Vol.9 p.339, Academic Press, New York, 1970. - 10. K V Roberts and J P Boris, 'The Solution of Partial Differential Equations using a Symbolic Style of Algol', Journ.Comp.Phys. 8 83 (1971). - M Petravic, G Kuo-Petravic and K V Roberts, 'Automatic Optimization of Symbolic Algol Programs, I. General Principles', Journ. Comp. Phys. 10, 503 (1972). - 12. R W Hockney, 'The Potential Calculation and Some Applications', loc.cit. ref.9, p.135 (and references contained therein). - 13. J P Boris and K V Roberts, 'The Optimization of Particle Calculations in 2 and 3 Dimensions', Journ. Comp. Phys. 4, 552 (1969). - 14. International Computers Ltd., KDF9 Egdon System, Reference Manual Vol.1 - 15. International Computers Ltd., System 4-50, Fortran Reference Manual. - 16. K V Roberts, 'The Publication of Scientific Fortran Programs', Computer Physics Communications 1, 1 (1969). - 17. K V Roberts, 'Program Readability', in 'Software Engineering', Infotech State-of-the-Art Report 11, p.495, published by Infotech Information Ltd., Maidenhead, 1972. #### APPENDIX I #### The TRINITY MHD Equations The TRINITY 3DMHD differential equations are 3D MHD Equations Used in the TRINITY Code | | | | _ | |----|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------| | | Current | $\mathbf{j} = \nabla \times \mathbf{B}$ | | | (4 | Pressure | $P_{ij} = \rho T \delta_{ij} + \rho v_i v_j + (B^2/2) \delta_{ij} - B_i B_j$ | | | | Temperature equation | $\partial T/\partial t = -\nabla \cdot (T\mathbf{v}) + (2 - \gamma) T \nabla \cdot \mathbf{v} + \kappa \nabla^2 T + (\gamma - 1)\eta j^2/\rho + (\gamma - 1)\nu[(\nabla \times \mathbf{v})^2 + (\nabla \cdot \mathbf{v})^2]$ | | | | Townsystems squation | $2T/3t = \nabla \cdot (T_1) + (2 \cdot \cdot \cdot) T \nabla \cdot \cdot \cdot \cdot + \nabla^2 T$ | (I.1) | | | Magnetic equation | $\partial \mathbf{B}/\partial t = \mathbf{\nabla} \times (\mathbf{v} \times \mathbf{B}) + \eta \nabla^2 \mathbf{B}$ | (- 1) | | | Momentum equation | $\partial(\rho v_i)/\partial t = -\partial/\partial x_i(p_{ij}) + \nu \nabla^2 \rho v_i$ | | | | Continuity equation | $\partial \rho/\partial t = -\nabla \cdot \rho \mathbf{v}$ | | | | | | | and in Symbolic Algol I can be expressed as [10] 3D MHD Equations Programmed in Symbolic Algol I ``` procedure INVOKE DIFFERENCE EQUATIONS; begin CONTINUITY EQUATION: DT := 2 \times DELTA T; Cl := C2 := 1; Q: = 1 + I + 1 + (J + 1) \times PI + (K + 1) \times PI \times PJ; NEW RHO: = RHO - DT \times DIV(RHO \times V); MOMENTUM EQUATION: DT: = 2 \times DELTA T/(1 + NU/EPS); for Cl: = 1, 2, 3 do AV[CI, Q] = (RHO \times V + DT \times (-DIV 2(P) + NU \times DELSO(RHO \times V)))/NEW RHO; ARHO[Q]: = NEW RHO; (I.2) MAGNETIC EQUATION: DT: = 2 \times DELTA T/(1 + ETA/EPS); for Cl: = 1, 2, 3 do AB[CI, Q] := B + DT \times (CURL(CROSS(V, B)) + ETA \times DELSQ(B)); TEMPERATURE EQUATION: DT: = 2 \times DELTA T/(1 + KAPPA/EPS); CI: = 1; ATEM[Q]: = TEM + DT \times (-DIV(TEM \times V) + KAPPA \times DELSQ(TEM) + (2 - GAMMA) \times SAV(TEM) \times DIV(V) + (GAMMA - 1) \times (ETA \times SQM(CURL(B))/SAV(RHO) + NU \times (SQM(CURL(V)) + DIV(V) \uparrow 2))); end; real procedure P; P: = if Cl = C2 then (RHO \times (TEM + V \times V) + 0.5 \times DOT(B, B) - B \times B) else (RHO \times V \times V2 - B \times B2); ``` The meanings of the identifiers are given in Table VI. These equations were written in Symbolic Algol II as explained in reference 11 and automatically converted into IBM 360 assembler language. An equivalent hand-coded Fortran version of TRINITY is discussed in Appendix II and reference 8. TABLE VI. Symbolic Algol I Identifiers | Identifier | Туре | Mathematical<br>equivalent | Meaning | |-----------------------|------------------------------------------------------------------------|----------------------------|-----------------------------------------------------| | B<br>CROSS<br>CURL | Vector function Algebraic vector operator Differential vector operator | B<br>X<br>curl | magnetic field<br>cross product | | DELSQ<br>DIV<br>DOT | Differential scalar operator " vector " " " " " | √ <sup>2</sup><br>div | dot product | | DT<br>ETA | Scalar<br>Scalar | dt<br>N | timestep<br>resistivity | | GAMMA<br>GRAD | Scalar Differential vector operator | γ<br>grad | ratio of specific heats | | KAPPA<br>NEWRHO<br>NU | Scalar<br>Scalar<br>Scalar | κ<br>ρnew<br>ν | thermal conductivity new value of density viscosity | | RHO<br>SAV | Scalar function Integral scalar operator | ρ<br>〈 〉av | density space average over 6 neighbouring points | | TEM<br>TEN | Scalar function Algebraic tensor operator | T<br>? | temperature $TEN(v,v) \equiv v_i v_j$ | | V | Vector function | Ā | velocity | #### APPENDIX II # Generalized Data Organization in Fortran Mesh calculations require the calculation of centred differences such as $$\frac{f(x,y,z+\Delta z) - f(x,y,z-\Delta z)}{2\Delta z}$$ (II.1) where $\Delta x$ is the mesh interval. This would normally be coded in Fortran as (say) $$(F(I,J,K+1) - F(I,J,K-1)) * RDZ2$$ (II.2) where RDZ2 $\equiv$ $(2 \Delta_z)^{-1}$ . There are however advantages to be gained from storing F as a 1-dimensional array and coding (II.1) as $$(F(N) - F(S)) * RDZ2$$ , (II.3) where the integers N and S refer respectively to the two points of the computational molecule that are situated one step 'north' and 'south' of the central point O. Other points are denoted by E(east), W(west), U(upper), L(lower), SE(south-east) etc. in an obvious way, while FN(far north) denotes the point $(x,y,z+2\Delta z)$ . Broadly speaking the advantages of this 'compass notation' are the following: - (a) The code is shorter and more intelligible, so that it is easier to write and mistakes are less likely to be made. - (b) Most compilers produce faster code for singly-subscripted than for triply-subscripted arrays. - (c) By suitable definition of the indices O, N, S, E, W, U, L etc. the variables can be laid out in the main store in any way required. - (d) The details of the layout do not appear in the physical difference equations. - (e) The layout can readily be changed to accommodate a different type of machine configuration, without changing the physical difference equations which are often very complex. # Scanning across the mesh Prior to the calculation of each new mesh-point the indices are updated by Fortran statements of the type $$0 = 0 + DX$$ $$N = N + DX$$ $$S = S + DX$$ $$E = E + DX$$ (etc) where the integer DX represents the frequency with which adjacent <u>recomputed</u> values of the same function are located in the main store. This depends on the difference scheme and on the method of storage used. For an ordinary leapfrog or Lax-Wendroff scheme alternate mesh-points are being recomputed at any given stage, and therefore DX = 2 if the fastest scan is in the x-direction. An adjustment must be made at the end of each row, depending on the precise boundary conditions that are being used (e.g. to jump over 'guard' or 'symmetry' points). ## Separation of odd and even points In certain cases there may be an advantage in separating the storage locations of the 'odd' and 'even' points, so that all the function values that are to be recomputed occur together in the store. One application of this idea is to a vector-processing computer such as the CDC STAR-100, whose effective speed would drop by approximately a factor 2 if alternate storage locations were skipped. Another application is to the Lax-Wendroff scheme, in which a factor 2 both in data transfer rate and also in backing storage size would be lost if the 'auxiliary' points whose values do not need to be retained were unnecessarily transferred to and fro. Such a separation can readily be achieved by making the two sets of indices (0, NE, NW, SE, SW, ....) and (N, S, E, W, U, L, ....) point to different areas of the main store. #### Interlaced variables For the IBM 360/91 version of TRINITY another form of optimization was achieved by arranging for the 8 physical variables RHO, VX, VY, VZ, BX, BY, BZ, TEM corresponding to any given mesh point to be stored sequentially, followed by the 8 variables at the adjacent point, so that DX in (II.4) now takes the value 16. This cannot be done with the triple-subscript notation of (II.2), but with that of (II.3) it is easily achieved by means of equivalence statements: EQUIVALENCE(CORE(8), TEM(1)) DIMENSION RHO(1), VX(1), ... TEM(1) where CORE is an array whose dimension is that of the whole quadruple buffer of Fig.2. We exploit here the useful fact that most Fortran compilers do not check for subscript values which lie outside array boundaries, so that the array names serve only as base addresses and only nominal dimensions need be given in (II.5). A more scrupulous compiler could however be mollified by inserting the correct dimensions in the declaration. Interlacing enables all the variables associated with a given batch of mesh points to be transferred to and from the backing store by means of one reference to the array CORE, while at the same time the physical difference equations use the meaningful mnemonics RHO, VX, ... in the usual way. # Quadruple buffer The array CORE holds four 'planes' of the calculation corresponding to the four areas S, O, N, M in the quadruple cyclic biffer of Fig.2. When one plane has been calculated the indices S, O, N are updated by 'rotating' the buffer, and the other indices are then computed from these. A general prescription might be with Here MPSIZE is the number of storage locations in each plane, NCPLNS is the number of planes in the buffer (in this case 4), and NZERO is the relative storage location of the first point to be calculated. The counters MCS, MCO, MCN cycle through the values (0, 1, ... NCPLNS-1). A counter MCM belonging to the 'move' plane is cycled in a similar way, $$MCM = MOD(MCM+1, NCPLNS)$$ (II.8) and from this one can calculate the areas of main store to be transferred at each stage. Similar counters handle the corresponding storage areas on the drums. # Implementation Although the logic of this scheme is necessarily somewhat complex, involving a combination of : Interlaced variables Leapfrogging across the mesh Special treatment at the boundary points Rotation of the cyclic buffer Computation of the drum storage areas, in practice it can be implemented and tested very easily if a number of obvious points are borne in mind : - (a) All index computation can be done in Fortran. - (b) Index computation and the solution of the physical equations are logically independent of one another. The latter can be tested in-core, using a small mesh, and can be omitted from the final program until the data organization has been perfected. - (c) Index computation is also logically independent of the actual use of drums or of a quadruple CORE buffer. - (d) The logic of the index computation can be tested in the first instance on a very small mesh. - (e) The initial checks of the complete system can be made with core and drum areas of limited size in order to obtain a sufficiently fast daytime turnaround. Using these ideas it was found possible to check out the indexing logic in runs lasting less than 1 second of IBM 360/91 time, the physics and data transfer routines being replaced by dummies that printed out a 'diary' describing the operation to be performed and the values of the indices. Clearly such tests could readily be made on-line. Finally, in any future implementation of the methods described in this report the authors would recommend breaking up the routines SETDRM and TRANSF into smaller components called from a main organizational routine written in Fortran, in order to clarify the logic as much as possible without any significant sacrifice of speed. #### APPENDIX III # Program Commentary for Subprogram SETDRM The references and headings used in the listing correspond to those of the text. A '+' in the listing indicates that the instruction has been generated by an IBM system macro. # SUBROUTINE SETDRM (RW, STASTO, DIM, VAR, TABLE) As described in §5 this subprogram writes the initial values of the physical variables on to Drums 1 and 2. It can also be used to read them back as a check. There is no need to employ overlapped data transfers at this stage and therefore SETDRM uses the Basic Sequential Access Method (BSAM) (ref.2,p.100) which is compatible with EXCP. Normally a quadruple buffer is used (§2) and therefore 4 planes are initialized at once. However to allow for other possible applications the corresponding parameter KCORE is referenced symbolically. # Arguments The arguments (formal parameters) are explained in Table I of $\S 5$ . Note that the four components of the array DIM are given individual identifiers. #### References Because the understanding of subprograms SETDRM and TRANSF requires detailed reference to 6 IBM manuals, page references are distributed freely throughout the listing, starting in column 64. # 1. Storage All storage other than that organized by macros is contained in this section. #### 1.1 Set Constants for Debug It is a convention of the Fortran-Assembler interface (ref.6 p.92) that 4 bytes from the entry point there should be a byte containing the length of the subroutine name, followed by the name itself; this name should be rounded up to an odd integer. The convention is slightly different on the ICL System 4 (ref.15 p.A3-5). #### 1.2 Save Area # 1.3 Arguments The values of integer arguments, the array base addresses, and the values of those components of DIM that are used are stored here for convenience. # 1.4 Internal Variables and Constants CUAD is a marker defining the current address in the array TABLE. # 2. Define Data Event Control Blocks (DECB) The Basic Sequential Access Method (BSAM, ref.2 p.100) which is employed in this subprogram uses two blocks which are set up by macro instructions, namely the Data Event Control Block (DECB) and the Data Control Block (DCB). The DECB contains a pointer to the DCB as indicated in Fig.5 and it also contains a 1-word Data Event Block (DEB) which is used by the system to return information about the status of an I/O operation. The list forms (ref.1 pp.267 & 269) of the READ and WRITE macro instructions are used in this section to set up the 4 DECBs that are needed, 2 for each drum, and to plant pointers to the DCBs. The section is not executed. ## 3. Define Data Control Blocks (DCB) This section, which is also not executed, sets up the 4 DCBs themselves (ref.1 p.49). The parameter DSORG = PS specifies that the data set organization is to be physical sequential, while MACRF = (RP) specifies firstly a read operation, and secondly that the NOTE macro is to be used (ref.1 p.127) in order to return the relative position on the drum of the previous block read. Similarly for writing. The data set names to be used on DD control cards are DSET1, DSET2, and these cards must specify the required number of cylinders and the correct record length. #### 4. Fortran-Assembler Interface After the initial branch, execution proper begins at START. This subsection contains the standard Fortran-Assembler interface (ref.6 p.92). A SAVE area is not strictly needed in SETDRM, although care should generally be taken in using the system macros because they overwrite registers as their expansions indicate. #### 4.2 Integer Arguments The values of RW and STASTO are transferred to locations in section 1. #### 4.3 Test Type of Call If RW = 1 the program branches to READING (section 7). Otherwise STASTO is tested and unless it has the value 1 a branch is taken to WNFIRST (section 6; write - not first). ### Initial Call This section stores the remaining arguments and opens the data sets for writing. Notice that the subprogram should not be overlaid until it is no longer required, otherwise these argument values will be lost. #### 5.1 Initialize Array Base Addresses The base addresses BAVAR and BADIM of the arrays VAR and DIM are stored in section 1. VAR is the core buffer and must remain unchanged since BAVAR is not updated on subsequent calls. # 5.2 Store Components of DIM The three components KCORE, NREC, RECLEN of DIM that are needed are stored in section 1. ## 5.3 Open the Data Sets The two data sets are opened for writing. # 5.4 First Relative Address The current address (CUAD) # 6. Program for Writing on Drums # 6.1 Specify Program Interruption Exit A SPIE macro (ref.1 p.173) is issued to cause a dump in case of program failure. The parameter 0 used here is relevant to the Garching system; it should be changed or the macro removed for use at another installation. # 6.2 Initialize Registers Two loops are now initialized; an outer loop over the KCORE planes in core at one time (normally 4), and an inner loop over the NREC records in one ½-plane (normally 4). Register 5 is initialized to the base address BAVAR of the core buffer VAR. #### 6.3 Write Records on Drum 1 A record is written to Drum 1 using the WRITE macro (ref.1 p.280). The address of the record in core is communicated in register 5, and the next available block on the drum is automatically selected by the fact that we are using the BSAM method. Since however this access method cannot be used in subprogram TRANSF, we extract the relative drum address by using a NOTE macro (ref.1 p.127) which returns its value in register 1 and stores it in TABLE for later use. Before issuing NOTE it is necessary to issue CHECK (ref.1 p.37) to ensure that the data transfer is complete. CUAD is the next available location in TABLE and is updated each time, while the address in register 5 is incremented by the record length RECLEN. # 6.4 Write Records on Drum 2 The WREC records belonging to the second half of a given K-plane are written to Drum 2 as soon as the NREC records belonging to the first half have been written to Drum 1. A CHECK macro is issued after each record has been written to ensure that the next transfer can go ahead, but TABLE need not be updated since the two data sets have identical structures. ## 6.5 Prepare for Next K-plane Register 3 is reset to NREC and Register 4 which is initially set to KCORE is decremented each time, a branch back to WNEX1 (write next plane on Drum 1) occurring until the transfer is complete. ## 6.6 Test for Completion If STASTO $\neq$ 2 the program branches to FINISH (section 8); otherwise all the data has now been set up and the two data sets must now be closed. #### 6.7 Close the Data Sets The CLOSE macro (ref.1 p.45) is issued for both data sets and a branch to FINISH is again taken. #### 7. Program for Reading from Drums # 7.1 Test whether Data Sets are Open The data sets are open if STASTO $\neq$ 1, in which case the program branches to RNFIRST (read - not first). # 7.2 Open Data Sets An OPEN macro is issued for each data set (ref.1 p.129) #### 7.3 Initialize Registers As in section 6.2, registers 3 and 4 are initialized to give an inner loop over the records in each ½-plane, and an outer loop over the planes in the core buffer. Register 5 is initialized with the base address BAVAR of the core buffer VAR. #### 7.4 Read Records from Drum 1 NREC records are read, using the READ macro in its execute form (ref.1 p.149). A CHECK is issued to ensure that each transfer is complete before proceeding to the next. #### 7.5 Read Records from Drum 2 When the first ½-plane has been read from Drum 1, the second is read from Drum 2. # 7.6 Prepare for next K-plane As sub-section 6.5. # 7.7 Test for Completion As sub-section 6.6. # 7.8 Close the Data Sets As sub-section 6.7. # 8. Return to Calling Subprogram This is the standard Fortran-Assembler interface described in ref.6 p.95. | INITIAL VALUE | | | Set by MACRO | | Set by MACRO | 4 | 4 | Set by MACRO | | | |----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------|----------------------------------------------------|-------------------------------------------------|---------------------------------------------------------|----------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | PURPOSE | Base address of DIM, which holds KCORE NREC RECLEN, TNREC<br>Base address of TABLE of relative addresses of drum records<br>Base address of core buffer area holding physical variables | Current address in TABLE | Data Event Control Block name Data Event Control Block name Data Event Control Block name Data Event Control Block name Data Event Control Block name Dummy name for array holding KCORE, NREC, RECLEN, INREC | Return to calling sub program via Fortran - Assembler interface | Data Control Block name<br>Data Control Block name | Number of K-planes in core at once, (usually 4) | Number of records in $\frac{1}{2}$ K-plane, (usually 4) | Data Control Block name<br>Data Control Block name | Entry point for reading records from drums Record length in bytes Read records for first half of K-plane from Drum 1 Read records for second half of K-plane from Drum 2 Data sets are open; initialize registers 1 = read records, 2 = write records | Save registers used in this sub program (MACRO calls) Write initial K-planes, and read them as a check. (4 at a time) Entry to Fortran - Assembler Linkage 1 = First call: open data sets. 2 = Last call, Close Data Sets 0 = Intermediate calls (normal case) | | SECTION | 1.3<br>1.3<br>1.3 | 1.4 | ссс | 8 | 8 8 | 1.3 | 1.3 | 1.4<br>3 | 7.1<br>1.3<br>7.4<br>7.5<br>7.3<br>1.3, H | 1,2<br>H<br>4,1<br>1,3,·H | | MINEMONIC | Base Address of DIM .<br>Base Address of TABLE<br>Base Address of VAR | Current Address | DECB for Drum 1, Read DECB for Drum 1, Write DECB for Drum 2, Read DECB for Drum 2, Write Dimensions | Task Finished | DCB for Drum 1, Input<br>DCB for Drum 2, Input | K-planes in Core | Records in ½ - plane | Number '1'<br>DCB for Drum 1, Output<br>DCB for Drum 2, Output | Program for Reading Record Length Read next record, Drum 1 Read next record, Drum 2 Read (Not First) Read-Write | Save Area<br>Set Drums<br>Start executable program<br>Start - Stop | | SIZE | בון בין בין | Ē. | (MACRO)<br>(MACRO)<br>(MACRO)<br>(MACRO)<br>(4F) | | (MACRO) | Đ. | [t-j | F<br>(MACRO)<br>(MACRO) | EL EL | 18F | | TYPE | Address<br>Address<br>Address | Address | Block<br>Block<br>Block<br>Block<br>IAP | Label | Block<br>Block | П | П | I<br>Block<br>Block | Label<br>I<br>Label<br>Label<br>Label<br>I, Ip | IA<br>CSECT<br>Label<br>I, IP | | (L. IDENTIFIER | BADIM<br>BATABLE<br>BAVAR | CUAD | DECELR DECELW DECEZR DECEZW DIM | FINISH | INDCB1<br>INDCB2 | KCORE | NREC | ONE<br>OUTDCBI<br>OUTDCB2 | READING RECLEN RNEXI RNEXZ RNEXZ RNFIRST RW | SAVE<br>SETDRM<br>START<br>STASTO | INDEX OF IDENTIFIERS FOR SUBPROGRAM SETDRM | INITIAL VALUE | 2 | | | | |---------------|---------------------------------------------|------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|----------| | H | | | | <u> </u> | | | | | | | | PURPOSE | Table of relative addresses of drum records | Core buffer for physical variables | Write records from first half of K-plane to Drum 1<br>Write records from second half of K-plane to Drum 2<br>Data sets are open; specify a dump before writing | | | SECTION | Н<br>1•4 | н | 6.3<br>6.4<br>6.1 | n ** | | MNEMONIC | Table<br>Number 121 | Variables | Write next record, Drum 1<br>Write next record, Drum 2<br>Write (not first) | | | SIZE | (192F)<br>F | (153600F) | | | | TYPE | IAP<br>I | RAP | Label<br>Label<br>Label | | | IDENTIFIER | TABLE | VAR | WNEX1<br>WNFIRST | | No. #### APPENDIX IV # Program Commentary for Subprogram TRANSF # SUBROUTINE TRANSF (CHOICE, MESHCR, RECNUM, NN, VAR, TABLE, DIM) As described in §6 this subprogram performs the reading and writing to and from the drums using the EXCP macro (ref.4 p.66 and ref.3 p.77). This is the most direct and fast method of transfer of data between main core and backing store as it issues channel commands to the channel hardware of the device used, thus bypassing the usual access method interfaces. While the channel is transferring data at a rate limited by the device characteristics, the CPU can be carrying on with the main calculation. The use of the EXCP macro also enables us to take advantage of chained scheduling (ref.1 p.125). This effectively means combining a series of read or write operations in one step, thus reducing both the CPU time and the channel start/stop time. The effects of rotational delay are also reduced. # Arguments The arguments (formal parameters) are explained in Table II of §6. # References See Appendix III. #### Storage Data Control Blocks (DCB), Input-Output Blocks (IOB) and Event Control Blocks (ECB) are located in section 9, and Channel Command Programs in section 10. Otherwise all storage other than that organized by system macros is contained in this section. ### 1.1 Set Constants for Debug See Appendix III. ### 1.2 Save Area See Appendix III. # 1.3 Arguments The arguments (formal parameters) are explained in Table II of §6. ## 1.4 Internal Variables and Constants # 2. Fortran-Assembler Linkage # 2.1 Standard Linkage See Appendix III # 2.2 Integer Arguments The values of the arguments CHOICE, MESHCR, RECNUM and NN are extracted and stored. #### 2.3 Test for Initial Call If NN $\neq$ 1 the data sets have been opened ( $\S6$ ) and a branch is made to NOOPEN (now open). # Initial Call This section is used to perform a number of operations that are needed the first time subroutine TRANSF is called, including opening the data sets, converting relative track addresses to absolute form and storing them in core areas requested from the Supervisor, and planting the actual record lengths into the Channel Command Words (CCW). The subroutine must not be overlaid once this has taken place. # 3.1 Initialize Array Base Address The base addresses BAVAR, BATABLE and BADIM of the arrays VAR, TABLE, DIM are extracted and stored; they must not be subsequently changed. # 3.2 Store Last 2 Components of DIM Only RECLEN and TNREC are needed. # 3.3 Open the Data Sets for EXCP The OPEN macro is issued 4 times, to open each of the data sets DSET1 and DSET2 for both reading and writing (ref.4 p.84). This constructs a Data Event Block (DEB) inside the Supervisor, and initializes the Data Control Block (DCB) as indicated in Fig.6. # 3.4 Request Storage for Addresses The GETMAIN macro is issued twice (ref.1 p.11) to request two main core storage areas of 1600 bytes. Each will be used to store up to 192 double-word absolute track addresses. The base addresses of these areas are returned in register 1 and are stored in BADMTAB1, BADMTAB2. (Base Address of Dimension Table). #### 3.5 Convert Addresses Conversion from a relative track address which was planted in TABLE by subroutine SETDRM to its absolute counterpart is carried out by a system routine IECPCNVT. The entry point of this routine is contained in the Communication Vector Table (CVT) at byte 28, the address of the CVT itself being at absolute location 16. Further information is to be found in ref.4 pp.100-102. The variable CUDA contains the location of the next available double word in the table currently under construction. # 3.6 Insert Record Lengths in CCW As explained in §6 and in ref.3 p.10, the 8-byte CCWs contain the record length RECLEN in bytes in bits 48-63, which is called the count field. This field is now set up for the 4 channel programs contained in section 10, and since the flag bits 32-36 which are set in that section will now be overwritten, these are explicitly restored. # 4. Prepare for Input/Output # 4.1 Specify Program Interruption Exit See Appendix III. # 4.2 Calculate Addresses ADCORE is the base address of the first record to be transferred to or from Drum 1, POINT1 is the location of the first double-word absolute address on Drum 1, and similarly for POINT2. # 4.3 Wait for READ if CHOICE = 1,2,3 As explained in Table II, §6, a WAIT macro is to be issued unless CHOICE = 4 or 5. This subsection tests for the values 1,2,3 and the other possibilities are tested in subsection 5.4. #### 5. Wait for Completion of Previous I/O This section uses the WAIT macro (ref.1 p.205) to check whether or not the previous Write or Read operation has been completed successfully. The system waits for completion and then returns a marker in the ECB (ref.4 p.88), the value X'7F' indicating success. # 5.1 Wait for Completion of Read The ECB addresses are ECBR1, ECBR2. # 5.2 Test for Success, Fail if not The values which have been returned in the two ECBs are compared with X'7F' (ref.4 p.89). If either read operation has been unsuccessful, control is given to an illegal instruction in order to force an interrupt, followed by a dump. # 5.3 Test CHOICE (1,2 or 3) As indicated in Table II the subsequent action depends on the value of CHOICE, which currently can only have a value $\leq 3$ . # 5.4 Test CHOICE (4-8) This point WAITW will have been reached if CHOICE $\geqslant$ 4. Table II indicates that for CHOICE = 4 or 5 no WAIT is issued, and a branch is therefore made to section 6 (RD = Read) or section 7 (WT = Write) respectively. # 5.5 Wait for Completion of Write As subsection 5.1. #### 5.6 Test for success, fail if not As subsection 5.2. # 5.7 Test CHOICE (6,7 or 8) As indicated in Table II the subsequent action depends on the value of CHOICE, which currently can only have a value 6,7 or 8. # 6. Set up and Execute Read Program This section sets up the Channel Command Programs in subsection 10.1 for reading 4 records on 4 tracks, and then issues two EXCP macros to execute them. This involves setting addresses and clearing markers. Minor changes in the coding would be required if the number of tracks had to be altered. #### 6.1 Drum Addresses Subsection 4.2 has already planted the absolute addresses of the first records to be read from the two drums in POINT1, POINT2 respectively. These are placed in registers 4 and 5 ready for use in subsections 6.3 and 6.4 # 6.2 Clear The Event Control Blocks are cleared by using the XC (Exclusive OR) instruction, ready for the return code to be supplied at the end of the operation. # 6.3 Prepare IOB The first 5 bytes of the Input Output blocks in subsection 9.2 are filled as specified by ref.4 p.87. Here X'40' in byte 1 indicates that Command Chaining will be employed, while '75' in byte 5 is the completion code for a successful operation. The 8-byte extent + seek addresses are then filled (ref.4 p.88) with the values of POINT1 and POINT2. These will be used by the Supervisor to locate the correct cylinders. ### 6.4 Prepare DCB Identical information is required in bytes 5-12 of the Data Control Blocks (ref.4 p.81). ### 6.5 Prepare Channel Command Program The 4 CCWs for Drum 1 are loaded with the addresses of the core areas to be filled, replacing the Command Code X'86' and incrementing the core address by RECLEN each time. The same process is then carried out for Drum 2. #### 6.6 Execute Channel Program The only parameter for the EXCP is the address of the Input Output Block. ## 7. Set Up and Execute Write Program This section sets up the Channel Command Programs in subsection 10.2 for writing 4 records on 4 tracks, and then issues two EXCP macros to execute them. This involves setting addresses and clearing markers. Minor changes in the coding would be required if the number of tracks had to be altered. #### 7.1 Drum Addresses Subsection 4.2 has already planted the absolute addresses of the first records to be written for the two drums in POINT1, POINT2 respectively. These are placed in registers 4 and 5 ready for use in subsections 7.3 and 7.4. ### 7.2 Clear The Event Control Blocks are cleared by using the XC (Exclusive OR) instruction, ready for the return code to be supplied at the end of the operation. ### 7.3 Prepare IOB The first 5 bytes of the Input Output Blocks in subsection 9.3 are filled as specified by ref.4 p.87. Here X'40' in byte 1 indicates that Command Chaining will be employed, while X'7F' in byte 5 is the completion code for a successful operation. The 8-byte extent + seek addresses are then filled (ref.4 p.88) with the values of POINT1 and POINT2. These will be used by the Supervisor to locate the correct cylinders. #### 7.4 Prepare DCB Identical information is required in bytes 5-12 of the Data Control Block (ref.4 p.81). # 7.5 Store Cylinder/Head/Record Addresses Since the channel program for writing to drums requires that the absolute address of each record be checked before writing even when command chaining has been specified, this section moves the 5 bytes containing the CCHHR address for each record into a region names CCHHR1 and CCHHR2. These addresses will be referred to by the channel programs for writing to Drums 1 and 2 respectively. ### 7.6 Prepare Channel Command Program The 4 CCWs for drum 1 are loaded with the addresses of the core areas from which records of length RECLEN are to be written. The operations code in the first byte is reloaded in case it has been overwritten by the previous operation. The same process is then repeated for drum 2. # 7.7 Execute Channel Programs The only parameter for the EXCP is the address of the Input Output Block. # 8. Return to the Calling Subprogram This follows the standard Fortran-Assembler interface for return to the calling subprogram. # 9. Control Blocks The required blocks are discussed in ref.4 p.68 and illustrated in Fig.6. # 9.1 Data Control Block (DCB) A Data Control Block is generated for each of the datasets DSET1, DSET2 by issuing a DCB macro instruction with MACRF = (E), (ref.4 pp.77,78). The data set organization is specified to be direct access, physical sequential (ref. 4 p.80, ref.2 pp 71 et seq.). ### 9.2 IOB and ECB (Read) The Input Output Block (IOB) must start on a full-word boundary (ref.4 p.86): it is filled here with the addresses of - (a) Event Control Block (ECBR) - (b) Start of Channel Program (CCWR) - (c) Data Control Block (DCB) space being left for other information explained in the table in ref.4 p.87. There is one Event Control Block (ECB) for each data set, consisting of one full word which is used to receive information for the Supervisor (ref.4 pp.88-89). ### 9.3 IOB and ECB (Write) Similar to subsection 9.2. #### 10. Channel Programs This section contains 2 Channel Programs for reading, and 2 for writing. Reference 3 and §6 explain how these are to be constructed. The Write programs require Search ID Equal commands ACCWW, BCCWW etc. whose Data Address fields refer to 5-byte addresses which are contained in subsection 10.3, having been constructed in subsection 7.5. #### 10.1 Read The structure of the two Channel Command Programs contained here has been explained in §6. The CCWs AR, BR, ... defined here are overwritten in subsections 3.6 and 6.5 but their structure is given for clarity. #### 10.2 Write As explained in §6, it is necessary to perform a Search ID Equal before each Write operation, looping until the correct record is found. This requirement is laid down in ref.3 p.21. #### 10.3 Cylinder-Head-Record addresses This subsection contains the record addresses required by the Search ID Equal commands just mentioned. | INITIAL VALUE | | 5 | | |---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | PURPOSE | Locates pos. of first channel command word for writing to drum 1 Locates pos. of first channel command word for writing to drum 2 Address in core of the first record to be moved Beginning of loop for address conversion, Drum 2 Beginning of loop for address conversion, Drum 2 Locates the CCW for the actual reading of first record from drum 1 Locates the CCW for the actual reading of first record from drum 2 Locates the CCW for the actual writing of first record to drum 1 Locates the CCW for the actual writing of first record to drum 1 Locates the CCW for the actual writing of first record to drum 2 | Base address of DIM, which holds KCORE, NREC, RECLEN, TWREC Base address of table giving absolute addresses on Drum 1 Base address of table giving absolute addresses on Drum 2 Base address of TABLE of relative addresses of drum records Base address of core buffer area bolding physical variables Locates the position of first CCW for writing second record to drum 2 Locates the CCW for the actual reading of second record from drum 1 Locates the CCW for the actual reading of second record from drum 1 Locates the CCW for the actual writing of second record from drum 2 Locates the CCW for the actual writing of second record to drum 1 Locates the CCW for the actual writing of second record to drum 2 | Locates the position of the first CCW for writing 3rd record to drum 1 Locates the position of the first CCW for writing 3rd record to drum 2 Contains actual addresses (CCHHR) for the 4 records to be moved, drum 1 Contains actual addresses (CCHHR) for the 4 records to be moved, drum 1 Locates the position of the first CCW for reading from drum 2 Options are defined in Table II Locates the CCW for the actual reading of 3rd record from drum 2 Locates the CCW for the actual reading of 3rd record from drum 2 Locates the CCW for the actual reading of 3rd record from drum 2 Locates the CCW for the actual writing of 3rd record to drum 2 Locates the CCW for the actual writing of 3rd record to drum 2 Locates the CCW for the actual writing of 3rd record to drum 2 | | SECTION | 10.2<br>10.2<br>1.4<br>1.4<br>5.5<br>5.5<br>10.1<br>10.2 | 1.3<br>1.4<br>1.64<br>1.3<br>10.2<br>10.2<br>10.1<br>10.1 | 10.2<br>10.2<br>10.3<br>10.3<br>10.1<br>1.3, H<br>10.1<br>10.1 | | MNEMONIC | First CCW for writing 1st rec.to drum 1 First CCW for writing 1st rec.to drum 2 Address in Core Convert next Drum 1 address Convert next Drum 2 address Read first record from drum 1 Read first record from drum 2 Write first record to drum 1 Write first record to drum 2 | Base Address of DIM B.A. of Drum Table 1 B.A. of Drum Table 2 Base Address of TABLE Base Address of VAR First CCW for writing sec.rec. to drm.1 First CCW for writing sec.rec. to drm.2 Read second record from drum 1 Read second record from drum 2 Write second record to drum 1 Write second record to drum 2 | First CCW for writing 3rd rec.to drum 1 First CCW for writing 3rd rec.to drum 2 CCHHR addresses, drum 1 CCHHR addresses, drum 2 First CCW for reading from drum 1 First CCW for reading from drum 2 Choice of call Read 3rd record from drum 1 Read 3rd record from drum 2 Current Address Write 3rd record from drum 1 Write 3rd record from drum 1 | | SIZE | 000 0000 | | 00 4 4 00 4 00 | | TYPE | Label Label Address Label Label Label Label Label Label | Address Address Address Address Address Label Label Label Label Label Label | Label Label Label Label Label Label Label I, IP Label Label Label Label Label Label Label Label | | IDENTIFIER | ACCWN1<br>ACCWW2<br>ADCORE<br>AGAIN1<br>AGAIN2<br>AR1<br>AR2<br>AW1 | BADIN<br>BADWIABI<br>BADWIABE<br>BATABLE<br>BAVAR<br>BCCWW1<br>BRL<br>BRL<br>BRZ<br>BWI<br>BWI | CCCWW1 CCCWW2 CCHHR1 CCHHR2 CCWR1 CCWR1 CCWR2 CHOICE CR1 CR2 CR2 CUDA CW1 CW2 CW2 CW2 CW2 CW2 CW2 CW3 CW3 | | INITIAL VALUE | Set by MACRO " " " | 0000 | 5 4 | See listing | 1 1 | 1 | |---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------|-------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | PURPOSE | Date Control Block name Data Control Block name Data Control Block name Data Control Block name Data Control Block name Locates the position of first CCW for writing 4th record to drum 1 Locates the position of first CCW for writing 4th record to drum 2 Integer array containing KCORE WREC RECLEN, TWREC Byte displacement from start of drum table Locates the CCW for the actual reading of 4th record from drum 1 Locates the CCW for the actual writing of 4th record to drum 1 Locates the CCW for the actual writing of 4th record to drum 1 Locates the CCW for the actual writing of 4th record to drum 1 | Event control block for reading from drum 1 Event control block for reading from drum 2 Event control block for writing to drum 1 Event control block for writing to drum 2 | Return to calling sub program via Fortron - Assembler interface | Input Output Block name Input Output Block name Input Output Block name Input Output Block name | First mesh point of current K-plane = 1 the first time that the sub program is called Data Sets are open; specify a dump | Skip to this point if previous read was successful Skip to this point if previous read was successful Skip to this point if previous write was successful Skip to this point if previous write was successful | | SECTION | 9.1<br>9.1<br>9.1<br>9.1<br>10.2<br>10.2<br>10.1<br>10.1<br>10.2 | 9 9 9 9<br>5 5 6 9 | 8<br>1.4<br>1.4 | 9.2 | 1.3, H<br>1.3, H<br>4.1 | 5.2<br>5.2<br>5.6<br>5.6<br>1.4 | | MNEMONIC | DCB for Drum 1, Read DCB for Drum 2, Read DCB for Drum 1, Write DCB for Drum 2, Write 1st CCW for writing 4th rec.to drum 1 1st CCW for writing 4th rec.to drum 2 array containing dimensions Displacement Read 4th record from drum 1 Read 4th record from drum 2 Write 4th record to drum 1 Write 4th record to drum 2 | ECB for Drum 1, Read ECB for Drum 2, Read ECB for drum 1, write ECB for drum 2, write Number '8' | Task Finished<br>Number '5'<br>Number '4' | IOB for Drum 1, Read IOB for Drum 2, Read IOB for Drum 1, Write IOB for Drum 2, Write | Mesh Point in Core<br>Number of Call<br>Now Open | Read OK on Drum 1 Read OK on Drum 2 Write OK on Drum 1 Write OK on Drum 2 Number 'l' | | SIZE | (MACRO) (MACRO) (MACRO) (MACRO) D 16F F D D D D D D D D D D D D D D D D D D | الدين الدين الدين | Eu Eu | 9F<br>9F<br>9F | Бu Бu | | | TYPE | Block Block Block Label Label Label Label Label Label Label Label | Block<br>Block<br>Block<br>Block<br>I | Label<br>I<br>I | Block<br>Block<br>Block<br>Block | I, IP<br>I, IP<br>Label | Label<br>Label<br>Label<br>Label<br>I | | IDENTIFIER | DCBR1 DCBR2 DCBW1 DCBW2 DCWW1 DCWW1 DCWW2 DCWW2 DIM DISPLA DR2 DW1 DW2 | ECBR1<br>ECBR2<br>ECBW1<br>ECBW2<br>EIGHT | FINISH<br>FIVE<br>FOUR | IOBR1<br>IOBR2<br>IOBW1<br>IOBW2 | MESHCR<br>NN<br>NOOPEN | OKR1<br>OKR2<br>OKW1<br>OKW2<br>ONE | | INITIAL VALUE | | | 29 | , w a | | | | |---------------|--------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------|---------------------------------------------------------------------------------------|------| | PURPOSE | Pointer to absolute address on Drum 1<br>Pointer to absolute address on Drum 2 | Section for reading from drums<br>Record length in bytes<br>Number of first record to be transferred, Drum 1 | Save registers used in this sub program (MACRO calls) Save registers 9-12 (IECPCNVT) Entry to Fortran - Assembler linkage | Table containing relative addresses of records to be transferred<br>Total number of records on each drum<br>Sub program for reading and writing K-planes, using 2 drums | Array containing all variables of the calculation which are in core | Test whether to wait for completion of previous write<br>Section for writing to drums | | | SECTION | 1.4 | 6.1<br>1.3<br>1.3, H | 1.2 | 1.4<br>1.3<br>1.4 | | 5.4 | | | MNEMONIC | Pointer for Drum 1<br>Pointer for Drum 2 | Record Length<br>Record Number | Save Area<br>Save Area (9-12)<br>Number '7'<br>Number '6'<br>Start executable program | Table of addresses Number '3' Total Number of Records Transfer K-planes | Array containing all the variables | Wait for Write?<br>Write | | | SIZE | 뚀ᄕ | 단단 | . 18F<br>4F<br>F | 768F<br>F<br>F | | | | | TYPE | Address | . Label<br>I<br>I, IP | IA<br>IA<br>I<br>I<br>Label | IA<br>I<br>I<br>CSECT<br>I | RA | Label<br>Label | i ii | | IDENTIFIER | POINT1<br>POINT2 | RD<br>RECLEN<br>RECNUM | SAVE<br>SAVE9<br>SEVEN<br>SIX<br>START | TABLE<br>THREE<br>TNREC<br>TRANSF | VAR | WAITW<br>WT | | ``` 111+ DC A(OUTDGBI) DCB ADDRESS 112+ DC A(O) AREA ADDRESS 113+ DC A(O) RECORD POINTER WORD 114 * RITE OECB2W, SF, OUTDGB2, MF=L 116+DECB2W DC F'O' EVENT CONTROL BLOCK 117+ DC X'00' TYPE FIELD 119+ DC X'20' TYPE FIELD 119+ DC AL2(O) LENGTH 120+ DC A(OUTDGB2) DCB ADDRESS 121+ DC A(OUTDGB2) DCB ADDRESS 121+ DC A(OUTDGB2) DCB ADDRESS 122+ DC A(O) AREA ADDRESS 123 * CACONTROL BLOCK 124 * DC A(OUTDGB2) DCB ADDRESS 125 *L 126 * DC A(OUTDGB2) DCB ADDRESS 127 *PS NEANS BSAM 128 *R = READ, W = WRITE, P = POINT (IMPLIES NOTE) 129 *PS NEANS BSAM 128 *R = READ, W = WRITE, P = POINT (IMPLIES NOTE) 3. DEFINE DATA CONTROL BLOCKS (DCB) R1/P49 R1/P50 R1/P59 130 INDCB1 DCB DDNAME=DSET1, DSDRG=PS, MACRF= (RP) DATA CONTROL BLOCK 132+* 133+* 134+[NDCB1 OF'O' DRIGIN ON WORD BOUNDARY * **TABLE STORES THE RELATIVE ADDRESS OF THE RECORDS WRITTEN ON DRUM 136+* DIRECT ACCESS DEVICE INTERFACE BL16'0' FDAD, DVFBL A(O) KEYLE, DEVT, TRBAL REFERENCES (REF/PAGE) COMMON ACCESS METHOD INTERFACE SUPERVISOR AND DATA MANAGEMENT INSTRUCTIONS SUPERVISOR AND DATA MANAGEMENT SERVICES 2820 STORAGE CONTROL AND 2301 DRUM STORAGE SYSTEM PROGRAMMERS GUIDE PRINCIPLES OF OPERATION FORTRAN LY IG 6 HI PROGRAMMERS GUIDE 141+4 AL1(0) BUFNO AL3(1) BUFCB AL2(0) BUFL BL2'0100000000000000 DSORG 143+ 144+ 145+ 146+ 147+ 149++ CSECT USING *,15 START SETORM BL1'00000000' BFTEK,BFLN,HIARCHY AL3(1) EODAD BL1'00000000' RECFM AL3(0) EXLST 44 45 ¢ 46 ¢- 47 *L 48 * 49 *L 50 * 51 52 53 * 54 *L 55 * $ -- $ L $ L STORAGE 156+ EDUNDATION BLOCK 1.1. SET CONSTANTS FOR DEBUG R6/P132 CLB'DSET1' DDNAME 158+ DC BL1'00000010' DFLGS BL1'00000000' IFLG BL2'0010010000000000' MACR DC 160+ X'7' CL7'SETDRM' 1.2. SAVE AREA 163+ BSAM-BPAM-QSAM INTERFACE BLI'00000000' RER1 AL3(1) CHECK, GERR, PERR A(1) SYNAD H'0' CINDI, CIND2 ALZ(0) BLKSIZE F'0' WCPD, WCPL, OFFSR, OFFSW A(1) IOBA AL1(0) NCP AL3(1) EDBR, EOBAD 165+ DC DC DC DC DC DC 56 SAVE DS IBF SAVE AREA FOR REGISTERS 160+ 167+ 168+ 169+ 170+ 171+ 172+ 173+ 56 54 57 ¢ 58 ¢L 59 ¢ ARGUMENTS RW=1 RFAU, RW=2 WRITE STASTO=1 START, STASTO=2 STOP SASE ADDRESS OF ARRAY DIM BASE ADDRESS OF VAR BASE ADDRESS OF TABLE 59 % 60 RU 61 STASTO 62 BADIN 63 BAVAR 64 RATASLE 65 * 0S 0S 0S * KCORF NREC RECLEY * *L 175++ BSAM-BPAM INTERFACE NUMBER OF K PLANES IN CORE NO. OF RECORDS IN 1/2 K PLANE RECORD LENGTH IN BYTES A(1) EOBW H'O' DIRCT ALZ(0) LRECL A(1) CNTRL, NOTE, POINT 177+ INTERNAL VARIABLES AND CONSTANTS 180+ 1.4. INTERVAL VARIABLES AND CONSTANT 1.2. CURRENT ADDRESS IN TABLE WHERE 1.3. EXEMPTED ADDRESS OF THE RECORD 1.4. EXEMPTED ON ORUM IS TO BE STORED 1.5. ONE DC F:1' 1.6. TWO DC F:2' 1.7. EXEMPTED ATA EVENT CONTROL BLOCKS 1.5. OFFINE DATA EVENT CONTROL BLOCKS 1.6. ONE DC FILE 1.4. INTERVAL VARIABLES AND CONSTANT 2. EXEMPTED ON ORUM IS TO BE STORED 2. DEFINE DATA EVENT CONTROL BLOCKS 3. ONE DEFINE DATA EVENT CONTROL BLOCKS 3. ONE DEFINE DATA EVENT CONTROL BLOCKS 3. ONE DEFINE DATA EVENT CONTROL BLOCKS 4. DATA EVENT CONTROL BLOCKS 4. ONE DATA EVENT CONTROL BLOCKS 4. ONE DATA EVENT CONTROL BLOCKS 4. ONE DATA EVENT CONTROL BLOCK CURRENT ADDRESS IN TABLE WHERE THE RELATIVE ADDRESS OF THE RECORD JUST WRITTEN ON DRUM IS TO BE STORED DCB DDNAME=DSET2 , DSDRG=PS , MACRF= (RP) 182 INDCB2 DATA CONTROL BLOCK OF'O' DRIGIN ON WORD BOUNDARY DEFINE DATA EVENT CONTROL BLOCKS (DECB) 188+* DIRECT ACCESS DEVICE INTERFACE BL16'0' FDAD, DVTBL A(0) KEYLE, DEVT, TRBAL R1/P267 193+0 COMMON ACCESS METHOD INTEREACE READ DECBIR, SF, INDCBI, MF=L DC F101 EVENT CONTROL BLOCK DC X'001 TYPE FIELD DC AL2(0) LENGTH DC AL(10) LENGTH DC AL(10) AREA ADDRESS DC AL(0) RECORD POINTER WORD AL1(0) BUFNO AL3(1) BUFCB AL2(0) BUFL 195+ DC 87+DEC 31 R 83+ 83+ 90+ 91+ 91+ 92+ 93+ 94 * 95 96+DECB2R 97+ 98+ 99+ 100+ 87+DECALR 196+ DC AL2:01:000000000000000 DSORG A(1) IDBAD 198+ 201+* FOUNDATION EXTENSION 203+ 204+ 205+ 206+ BLI'00000000' BFTEK,BFLN,HIARCHY AL3(1) EODAD BLI'00000000' RECFM AL3(0) EXLST READ DC DC DC DC DC DC DECB2R, SF, INDCB2, MF=L F10' EVENT CONTROL BLOCK X'00' TYPE FIELD X'80' TYPE FIELD ALZIO] LENGTH A(INDCB2) DCB ADDRESS A(0) AREA ADDRESS A(0) RECORD POINTER WORD 208+* FOUNDATION BLOCK 101+ 210+ 211+ 212+ 213+ CLB'DSFT2' DDNAME 102+ DC A(0) 103 ¢ 104 *LIST FORM OF WRITE 105 * BL1'00000010' DFLGS BL1'00000000' IFLG BL2'0010010000000000' MACR R1/P279 WRITE DECBIM.SF,OUTDCB1,MF=L DC F*O* EVENT CONTROL BLOCK DC X*00* TYPE FIELD DC X*20* TYPE FIELD DC ALZ(0) LENGTH 106 107+DECB1W 215+4 BSAM-BPAM-QSAM INTERFACE BL1'00000000' RERI AL3(1) CHECK, GERR, PERR ``` ``` I IOBA 219+ 220+ 221+ 222+ 223+ 224+ 225+ A(1) SYNAD H'O' CIND1, CIND2 ALZIO) BLKSIZE F'O' WCPD, WCPL, OFFSR, OFFSW A(1) IOBA 327+ 0C 0C 0C 0C O) NCP 1) EOBR, EOBAD BSAM-BPAM INTERFACE 331+* AL1(0) NCP AL3(1) EOBR. EOBAD EDBW DIRCT O) LRECL CNTRL, NOTE, POINT 334+ 337 * 338 *---- 339 *L 340 *L 341 *L 342 * 343 START 344 345 344 345 346 347 351 * 352 *L 353 * 355 * 357 * 358 359 360 * 361 *L 362 *L 363 * BSAM-BPAM INTERFACE 227+0 229+ 0C 0C 0C A(1) EDBW H'O' DIRCT AL2(0) LRECL A(1) CNTRL, NOTE, POINT 229+ 230+ 231+ 232+ 233 * 234 OUTOCB1 FORTRAN-ASSEMBLER INTERFACE STANDARD LINKAGE 4.1 DDNAME=DSET1, DSDRG=PS, MACRF=(WP) SAVE REGISTERS 14,15 AND 0-12 ADDRESS OF CURRENT SAVE AREA STORE BACKWARD LINK IN CURRENT SAVE AREA STORE FORWARD LINK IN PREVIOUS SAVE AREA 13 NOW HOLDS ADDRESS OF CURRENT SAVE AREA 0000C 0000C 00004 00008 2,12(13) STM AVE (12) (13) 2 LA ST ST 236+* 237+* 238+DUTDC81 DC DATA CONTROL BLOCK OF 'O' DRIGIN ON WORD BOUNDARY ,13 DIRECT ACCESS DEVICE INTERFACE 240+* BL16'0' FDAD, DVTBL A(O) KEYLE, DEVT, TRBAL 242+ INTEGER ARGUMENTS 11 5,0(5) 5,RH 00000 00000 00054 TRANSFER BASE ADDRESS OF RW COMMON ACCESS METHOD INTERFACE L L ST 245+ AL1(0) BUFND AL3(1) BUFCB AL2(0) BUFL BL2*0100000000000000 DSORG A(1) IOBAD TRANSFER BASE ADDRESS OF STASTO 5.4(1) 00004 00000 5,0(5) 5,STASTO L TEST TYPE OF CALL FOUNDATION EXTENSION 253++ BL1'00000000' BFTEK, BFLN, HIARCHY 255+ 256+ 257+ 258+ 0C 0C 0C 00054 00078 0038E AL3(1) EDDAD BL1'00000000' RECFM AL3(0) EXLST R#-1 IF R#=1 THEN BRANCH TO READING 3.STASTO FOUNDATION BLOCK STASTO-1 IF STASTO NOT = 1 THEN BRANCH TO WNFIRST 260+* WNFIRST CL8'DSET1' DDNAME BL1'00000010' DFLGS BL1'00000000' IFLG BL2'0000000000100100' MACR 262+ 263+ 264+ 265+ * L INITIAL CALL INITIALIZE ARRAY BASE ADDRESSES 5.1. BSAM-BPAM-OSAM INTERFACE 267+= 00008 L ST BASE ADDRESS OF DIM 269+ 270+ 271+ 272+ BL1'00000000' RER1 AL3(1) CHECK, GERR, PERR 00 5,12(1) 5,84VAR 00000 A(1) SYNAD H'O' CIND1, CIND2 BASE ADDRESS OF VAR AL2(0) BLKSIZE F'O' WCPD, WCPL, OFFSR, OFFSW A(1) 108A AL1(0) NCP AL3(1) EOBR, EOBAD 382 * 383 384 385 * 386 * 387 * 388 273+ 274+ 275+ 00000 5,15(1) 5,BATABLE L BASE ADDRESS OF TABLE 275+ STORE COMPONENTS OF *DIM* BSAM-BPAM INTERFACE 279+* L 5.BADIM A(1) EOBH H'O' DIRCT AL2(O) LRECL A(1) CNTRL, NOTE, POINT 281+ 390 391 392 * 393 394 395 * 396 397 398 * 400 * 401 402+ 403+ 4,0(5) 4,KCORE L ST 282+ 283+ 284+ 285 * 286 DUTDC32 4,4(5) 4,NREC DDNAME=DSET2, DSDRG=PS, MACRF=(HP) DCB 288+* 289+* 290+DUTDC62 DATA CONTROL BLOCK R1/P129 DPEN THE DATA SETS OF 'O' DRIGIN ON WORD BOUNDARY OC (OUTDCB1, (OUTPUT)) OPEN DATASET ON DRUML 292+* DIRECT ACCESS DEVICE INTERFACE 0,4 1,±+8 LOAD REG1 W/LIST ADDR. ALI(143) OPTION BYTE AL3(OUTDCB1) DCB ADDRESS 19 ISSUE OPEN SVC BAL 400+ 400+ 4007 6 4007 6 4009+ 4109+ 4114 412+ 4113+ 4114 8 415 9L 416 8 417 8 418 419 8 420 6 421 0L 422 4 423 8L 424 424 8L 425 MINFIRST 420 1424 1426 405+ DC SVC COMMON ACCESS METHOD INTERFACE 297+= (OUTDCB2,(OUTPUT)) OPEN DATASET ON DRUM2 ALI(0) BUFNO AL3(1) BUFCB AL2(0) BUFL 299+ 300+ 301+ 302+ 303+ 0C 0C 0C 0,4 1,*+8 LOAD REGI W/LIST ADDR. ALI(143) OPTION BYTE AL3(OUTDCB2) DCB ADDRESS 19 ISSUE OPEN SVC BAL DC DC SVC BL2'01000000000000000 DSGRG A(1) [DBAD FOUNDATION EXTENSION 305+4 FIRST RELATIVE ADDRESS BL1'00000000 BFTEK, BFLN, HIARCHY AL3(1) E0DAD BL1'00000000 RECFM AL3(0) EXLST START STORING THE RELATIVE ADDRESS ON DRUM AT HEAD OF TABLE 307+ DC DC DC 6,BATABLE 308+ 309+ 310+ PROGRAM FOR WRITING DN DRUMS 312+* FOUNDATION BLOCK SPECIFY PROG. INTERRUPTION EXIT RI/P173 6.1. CL8'DSET2' DDNAME BL1'00000010' DFLGS BL1'00000000' IFLG BL2'0000000000100100' MACR PRODUCE A DUMP IF PROGRAM ABENDS O PRUDUCE A OUT 2,4 1,**12 LOAD BRANCH ADDRESS 1,1 BRANCH AROJNO PARAMS. A(0) EXIT ROUTINE ADDRESS AL2(0) INTERUPTION MASK 14 ISSUE SPIE SVC 426+ 427+WNF IRST 423+ 430+ 431+ 432 * 433 *L 434 * 435 436 LA BALR DC DC SVC BSAM-BPAM-QSAM INTERFACE 319+ BL1'00000000' RER1 AL311 CHECK, GERR, PERR A(1) SYMAO H'0' CIND1, CIND2 AL2(0) BLKSIZE F'0' WCPD, WCPP, OFFSK, OFFSW 321+ DC DC DC INITIALIZE REGISTERS NUMBER OF RECORDS IN EACH 1/2-PLANE ``` ``` 437 L 5,BAVAR 438 * 439 * 440 *L 441 * 442 *OUTER LOOP OVER PLANES 444 * *INNER LOOPS OVER RECORDS 444 * 443 *INNER LOOPS OVER RECORDS 444 * 445 *NEX1 RITE DECOIM-SF., 446+3NEX1 LA 1,DECBIM LO 447+ MVI 5(1),X*20* 448+ LA 14,015) LOA 449+ ST 14,12(1,0) 451+ L 15,96(0,15) 451+ L 15,96(0,15) 451+ L 15,96(0,15) 452+ BALR 14,15 LINK 453 * 454 C-4ECK DECBIM 455+ LA 1,DECBIM LO 456+ LA 1,DECBIM LO 457+ L 15,52(0,14) 459+ BALR 14,15 LINK 459 * 460 NOTE NOTEONIA 461+ LA 1,DUTDUBL LI 462+ L 15,94(0,11) 463+ BALR 14,15 LINK 464- 465- SPECIFIES ADDRESS FROM WHICH RECORD IS TO WRITE RECORDS ON DRUML R1/P280 CHECK DECBIN CHECK FOR COMPLETION OF WRITE LA LIDECHIN LOAD PARAMETER REG 1 L 14,810,11 PICK JP DCB ADDRESS L 15,52(0,14) LOAD CHECK ROUT. ADDR. BALR 14,15 LINK TO CHECK ROUTINE NOTE OUTDOBL RETURN POSITION OF LAST BLOCK LA 1, DUTDOBL LOAD PARAMETER REG 1 R1/P127 LA 1, DUTDUBL LOAD PARAMETER REG 1 L 15,84(0,1) LOAD NOTE RTN ADDRESS BALR 14,15 LINK TO NOTE ROUTINE 480 WNEX2 491+#NEX2 482+ 483+ 484+ 485+ 486+ 487+ 488 * 489 490+ 491+. CHECK DECB2W LA 1,0ECB2W LOAD PARAMETER REG I L 14,8(0,1) PICK JP DCR ADDRESS L 15,52(0,14) LOAD CHECK ROUT. ADDR. HALR 14,15 LINK TO CHECK ROUTINE 492+ 493+ 494 $ 495 496 A 5,RECLEN BCT 3,WNEX2 REPEAT WRITING ON DRUMZ NREC TIMES PREPARE FOR NEXT K-PLANE 6.5. 500 501 3.NREC 4.HNEX1 REPEAT THE ABOVE KCORE TIMES TEST FOR COMPLETION 6.6. 3,STASTO 3,THO FINISH IF STASTO NOT = 2 DO NOT CLOSE DATASETS CLOSE THE DATA SETS R1/P45 CLUSE (DUTDCB1) CNUP 0,4 1,**8 BRANCH ARJUND LIST OC ALI(129) OPTION BYTE OC ALI(129) DOTION BYTE OC ALI(100TOCBI) DCB ADDRESS SVC 20 ISSUE CLOSE SVC CLOSE (GUTDCB2) 0,4 1,*+8 BRANCH AROUND LIST ALIHI29) OPTION BYTE AL3(OUTDCB2) DCB ADDRESS 20 ISSUE CLOSE SVC SVC В FINISH PROGRAM FOR READING FROM DRUMS OPEN (INDC81,(INPUT)) CNOP 0,4 542 543+ 544+ 545+ 546+ 0,4 1,*+8 LOAD REGI W/LIST ADDR. ALI(128) OPTION BYTE AL3(INDCB1) DCB ADDRESS BAL DC DC ``` ``` SVC 19 ISSUE OPEN SVC (INDCB2, (INPUT)) 0,4 1,*+8 LOAD REGI H/LIST ADDR. ALI(128) OPTION BYTE AL3(INDCB2) DCB ADDRESS 19 ISSUE OPEN SVC INITIALIZE REGISTERS NUMBER OF K-PLANES TO BE READ BASE ADDRESS OF FIRST RECORD NUMBER OF RECORDS IN EACH 1/2-PLANE READ RECORDS FROM DRUM 1 DECBIR.SF.,O(5),MF=E 1.DECBIR LOAD DECB ADDRESS 5(1),x'80' SET TYPE FIELD 14,O(5) LOAD AREA ADDRESS 14,12(1,0) STORE AREA ADDRESS 15,11,0) LOAD CCD ADDRESS 15,48(0,15) LOAD CDA ROUTINE ADDR 14,15 LINK TO ROWR ROUTINE READ 569+ 570+ 571+ 572+ 573+ 574+ 575 * 575 577+ 578+ 578+ 570+ 580+ 581 * 5,RECLEN 3,RNEX1 583 584 * 585 * 586 * 587 588 ** 589+** 590+ 591+ 592+ 7.5. READ RECORDS FROM DRUM 2 3,NREC DEC32R,SF,-2(5),MF=E 1,DECB2R LOAD DECB ADDRESS 5(1),X'80' SET TYPE FIELD 14,J(5) LOAD AREA ADDRESS 14,12(1,0) STORE AREA ADDRESS 15,8(1,0) LOAD DCG ADDRESS 15,8(1,0) LOAD DCG ADDRESS 15,48(1,15) LOAD ADDR ROUTINE 14,15 LINK TO ROHR ROUTINE 593+ 594+ 595+ BALR 596 * 597 598+ 599+ | CHECK | DECB2R | | 1,DECB2R | LOAD | PARAMETER REG | 1 | 14,810,11 | PICK JP DCB ADDRESS | 1,552(0,14) | LOAD CHECK ROUT. ADDR. BALK | 14,15 | LINK TO CHECK ROUTINE 600+ 602 * 603 604 605 * 606 *L 7.6. PREPARE FOR NEXT K-PLANE 609 3.NREC 4.RNEX1 BCT 610 % 611 % 612 % 613 614 615 % 617 % 618 % 620+ 621+ 622+ 623+ 624+ 625 % 624+ 626- 627+ 628+ 628+ 628+ 630+ 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 631- 63 TEST FOR COMPLETION 7.7. 3,STASTO 7.8. CLOSE THE DATA SETS CLOSE (INDCB1) CNOP 0.4 BAL 1.*+8 BRA 0,4 1,*+8 BRANCH ARDUND LIST ALI(128) OPTION BYTE ALI(1NOCBL) DCB ADDRESS 20 ISSUE CLOSE SVC SVC CLOSE (INDCB2) CNOP 0.4 BAL 1.#+8 BRA OC AL1(128) (1) O.4 1. ±+8 BRANCH ARDUND LIST ALI(128) DPTION BYTE AL3(1) NOCB2) DCB ADDRESS 20 ISSUE CLOSE SVC RETURN TO CALLING SUBPROGRAM 86/P133 RESTORE ADDRESS OF PREVIOUS SAVE AREA RESTORE REGISTERS 14,15 AND 0-12 POINTER TO DEBUG ROUTINE FOR RE-ENTRY RETURN 13,4(13) 14,12,12(13) 12(13),X'FF' LM MVI BR END ``` 640 ``` SUBROUTINE TRANSFICHDICE, MESHCR, RECNUM, NN, VAR, TABLE, DIM) READ AND WRITE ON TWO DRUMS USING EXCP ARSUMENTS AKJUMENTS *CHOICE=1 MAIT FOR COMPLETION OF LAST READ THEN EXECUTE PRESENT READ *CHOICE=2 MAIT FOR COMPLETION OF LAST READ THEN EXECUTE PRESENT WRITE *CHOICE=3 MAIT FOR COMPLETION OF LAST READ ONLY *CHOICE=5 SKIP MAIT THEN READ *CHOICE=5 SKIP MAIT THEN MRITE *CHOICE=5 MAIT FOR COMPLETION OF LAST MRITE AND THEN READ *CHOICE=7 MAIT FOR COMPLETION OF LAST MRITE AND THEN WRITE *CHOICE=8 MAIT FOR COMPLETION OF LAST MRITE DULY *MESHCR=MESH POINT IN CORE OF FIRST RECORD TO BE MOVED E-G. *((I-1)+ (J-1)*PI+(K-1)*PIPJ)*VV * (IT-1)+ (J-1)+P)+(K-1)+P)+OJEVV **RECOMM-STARTING RECORD NUMBER UN DRUML TO BE TRANSFERRED, THE SECOND **POLITION OF THE FIRST, HEVELOUS RECOUNTION FOR DRIM2 IS THE SAME **NN-1 THE FIRST TIME THE MODULE IS CALLED, HEVGE OPEN DATASETS AS WELL **AS TRANSFERRING BASE ADDRESSES OF FIXED ARRAYS AND CONVERT RELATIVE **ADDRESS TO ABSOLUTE ADDRESS **BAVAR IS BASE ADDRESS OF THE MAIN ARRAY VAR CSECT USING *,15 START 50 TRANSF 54 *- 55 *L STORAGE 1. 56 ¢ 57 ¢L 58 * SET CONSTANTS FOR DEBUG 1.1. R6/P132 X'7' CL7'TRANSF' 60 * *L 1.2. SAVE AREA SAVE AREA FOR REGISTERS ٥L ARGUMENTS CHOICE MESHOR OPTIONS FOR READ, WATERWAY TO THE TRUE HERE REJORD IS TO BE OF THE TRUE HERE REJORD IS TO BE YOVED STARTING RECORD NO. ON DRUMI TO BE TRANSFERRED =1 THE FIRST TIME MODULE IS CALLED BASE ADDRESS OF DATA ARRAY VAR BASE ADDRESS OF TABLE BASE ADDRESS OF ARRAY DIN RECORD LEWGTH TOTAL NO. OF RECORDS ON EACH DRUM # RECNUM DS F 72 * 73 NN 74 BAVAR 75 BATABLE 76 BADIM 77 RECLEN 78 TNREC 79 * 80 *L 81 * 82 ADCORE 83 * 4 BADMTAB1 DS DS DS DS *L * ADCORE DS INTERNAL VARIABLES AND CONSTANTS ADDRESS IN CORE OF FIRST RECORD TO BE WOVED BASE ADDRESS OF TABLE CONTAINING ABSOLUTE ADDRESSES OF SEQJENTIAL RECORDS ON DRUMI BASE ADDRESS OF TABLE CONTAINING ABSOLUTE ADDRESSES OF TABLE CORDS OF TABLE CORDS OF TABLE CORDS OF TABLE THE ABSOLUTE ADDRESS OF TABLE THE ABSOLUTE ADDRESS OF TABLE THE ABSOLUTE ADDRESS OF TABLE THE ABSOLUTE ADDRESS OF TABLE TO BE TO THE ADDRESS OF TABLE THE ABSOLUTE ADDRESS OF TABLE TO THE TABLE TO THE TABLE TO THE TABLE TO THE TABLE T BADMIARI DS 86 BADMTAB2 DS 86 CUDA ns THE ABSOLUTE ADDRESS OF A RECORD IS IS ON STORED RECNUMBB, DISPLACEMENT IN BYTES FROM THE START OF DATAB CONTAINS ADDRESS AT WHICH THE ASSOLUTE ADDRESS ON DRUM1 OF FIRST RECORD TO BE MOVED IS TO BE FOUND CONTAINS ADDRESS AT WHICH THE ASSOLUTE ADDRESS ON DRUMY OF FIRST RECORD TO BE MOVED IS TO BE FOR FIRST RECORD TO BE MOVED IS TO BE FOUND TO BE MOVED IS TO BE FOUND TO BE MOVED IS TO BE FOUND TO BE MOVED IS TO BE FOUND TO BE MOVED IS TO BE FOUND TO BE MOVED IS TO BE FOUND TO BE MOVED IN THE PROPERTY OF 4F 100 * 101 ONE 102 TWD 103 THREE 104 FOUR 105 FIVE 106 SIX 107 SEVEN 108 EIGHT 00 00 00 00 00 00 00 ``` ``` 111 *L 112 * 113 *L 114 * FORTRAN-ASSEMBLER INTERFACE R6/P132 STANDARD LINKAGE 2.1. SAVE REGISTERS 14,15 AND 0-12 ADDRESS OF CURRENT SAVE AREA STORE BACKWARD LINK IN CURRENT SAVE AREA STORE FORARD LINK IN PARVIJUS SAVE AREA 13 NOW HOLDS ADDRESS OF CURRENT SAVE AREA 14,12,12(13) STM 115 ST 116 117 118 119 120 121 122 * 123 *L 124 * LA 12,5AVE ST 13,44(12) ST 12,94(13) LR 13,12 DROP 15 USING SAVE,13 NEJ BASE ADDRESS INTEGER ARGUMENTS 2.2. 5.0(1) L 5,0(5) 5,CHOICE 128 * 5,4(1) 5,0(5) 5,MESHCR 130 131 132 133 134 135 136 137 139 140 141 142 143 144 145 * 5,12(1) TEST FOR INITIAL CALL 5, ONE NOUPEN DATA SETS ARE NOW OPEN IF NN. VE. 1 146 *-- 147 *L 148 * 149 *L 150 * 151 152 153 * 155 156 * 157 INITIAL CALL 3.1. INITIALIZE ARRAY BASE ADDRESSES 5,15(1) 5,84VAR 5,24(1) 5,840IM 158 159 160 161 STORE LAST 2 COMPONENTS OF *DIM* 3.2. RECORD LENGTH 4.12(5) FOTAL NO. OF RECORDS ON ONE DRUM 166 167 168 169 170 171 172 173+ 174+ 175+ 4.THREC OPEN THE DATA SETS FOR EXCP *OPEN CONSTRUCTS DEB IN SUPERVISOR, AND INITIALIZES DCB R4/P84 (DCBR1,(INPUT)) OPEN 0,4 1,*+8 LOAD REGI H/LIST ADDR. ALI(129) DPTION BYTE AL3(DCBRI) DCB ADDRESS 19 ISSUE DPEN SVC BAL DC DC SVC 176+ 177+ 178 * 179 180+ 181+ 182+ 183+ 184+ 185 * OPEN CNOP BAL DC DC DC SVC (DCBR2,(INPJT)) 0.4 1.*+8 LOAD REGI #/LIST ADDR. ALI(128) OPTION BYTE AL3(DCBR2) DCB ADDRESS 19 ISSUE OPEN SVC (OCBW1,(OUTPUT)) 0,4 l,++8 LOAD REGI M/LIST ADDR. ALI(143) OPTION BYTE AL3(DCBW1) DCB ADDRESS 19 ISSUE OPEN SVC 189+ BAL DC DC SVC 190+ 191+ 192 * 193 194+ # 195+ 196+ 197+ 198+ 200 *L 201 * 202 203+ (DCBW2,(DUTPUT)) 0,4 1,**9 LOAD REGI H/LIST ADDR. ALI(143) OPTION BYTE AL3(DCBHZ) DCB ADDRESS 19 ISSUE OPEN SVC REQUEST STORAGE FOR ADDRESSES R1/P111 IN R.LV=1600 REQUEST STORAGE AREA 1600 BYTES LONG 0,1500(0,0) LOAD LENGTH 1,++4 INDICATE GETMAIN 10 ISSUE GETMAIN SVC 1,BADMTABL BASE ADDRESS OF STORAGE AREA RETURNED IN REG 1, STORE IN BADMTABL GETMAIN BAL SVC ST 204+ 205+ SVC 10 ISSUE GETMAIN SVC. 206 ST 1, BADMTABI BASE ADDRESS OF STORAGE AREA RE 207 * REG 1, STORE IN BADMTABI 209 * GETMAIN R, LV=1500 REQUEST STORAGE AREA 210+ L3 0, ISSUE 3, DE ADDRESS OF STORAGE AREA 210+ L3 0, ISSUE 3, DE ADDRESS OF STORAGE AREA 211+ BAL 1,0+4 INDICATE GETMAIN 212+ SVC 10 ISSUE GETMAIN SVC 213 ST 1, BADMTABC 214 * 215 *L 3.5. CONVERT ADDRESSES 216 * 3.5. CONVERT ADDRESSES 217 *CONVERSION IS CARRIED OUT BY SYSTEM ROUTINE LECPCONVT 218 *CONVERT FROM RELATIVE ADDRESS TO AMSOLUTE ADDRESS ON DR.JM1 219 * 220 L 4, TNREC R4/P100 ``` ``` 221 L 7,84 222 STM 9,12 223 LR 8,13 224 L 1,0C 225 L 2,84 226 ST 2,64 227 * 2,84 227 * 2,84 228 *LOOP OVER RECOROS 229 AGAINI L 0,0C 230 L 3,16 231 * L 15,2 231 * L 15,2 233 BALR 14,1 234 LR 13,8 235 LM 9,12 236 LM 7,44 RELATIVE ADDRESS IS IN TABLE SAVE REGISTERS 9--12 BASE REG 13 IS SAVED IN REG 8 ADDRESS OF DATA EXTENT BLOCKIDEB) REG 2 CONTAINS CURRENT BLOCKIDES ASSOLUTE ADDRESS WHERE ASSOLUTE ADDRESS OF DRIVING IS TO 3E STORED 7,BATABLE 9,12,SAVE9 8,13 1,DCBR1+44 2,BAOMTAB1 2,CJDA (RECNUM-1)*8 DISPLA=(RECNUM-1)*8 4,EIGHT 5,DISPLA M ST 5.BADMTAB1 5.POINT1 BADMTAB1+(RECNUM-1)*8 POINTS TO ABSOLUTE ADDRESS ON DRUM1 334 335 336 * 337 5.DISPLA 5.BADMTAB2 5.PJINT2 RELATIVE ADDRESS IS CONTAINED IN REG O ADDRESS OF CUTICOMMUNICATION VESTOR TABLE) AT ABSOLUTE LOCATION 16 ENTRY POINT OF IECPCNUT BRANCH TO CONVERSION MODULE RELOAD BASE REGISTER RELOAD REGISTERS 9-12 MOVE IN NEXT RELATIVE ADDRESS 0,0(7) 15,28(3) 14,15 13,8 9,12,SAVE9 7,4(7) 2,CJDA 2,8(2) 2,CJDA 4,AGAINI 236 237 238 239 ABSOLUTE ADDRESS IS 8 BYTES LONG REPEAT FOR NEXT RECORD 240 241 * 242 * 243 244 245 246 247 248 249 250 * 251 * *REPEAT THE ABOVE PROCEDURE FOR DRUM2 4.TNREC 7.BATABLE 9.12.SAVE9 8.13 1.DCBR2+44 L STM 1,1 1,1 2,0 85 2,0 251 *LDDP OVER RECORDS 252 AGAIN2 L 0.2 253 L 254 255 256 ADDRESS OF DATA EXTENT BLOCK (DEB) 2,BADMTAB2 2,CUDA OROS 0,3(7) 3,15(0) 15,28(3) 14,15 13,8 9,12,SAVE9 7,4(7) 2,6(7) 2,8(2) 2,6(1) 4,ASAIN2 ECBRI.X*7F* CHECK-IF ECBRI CONTAINS '7F' OKRI BRANCH IF EVENT COMPLETED X'0000' ILLEGAL INSTRUCTION TO FORCE DUMP ECBRI(4),ECBRI ZERO ECBRI BE DC XC 370 371 372 373 DKR1 374 * 375 376 377 378 DKR2 379 * 380 *L 381 * INSERT RECORD LENGTHS IN CCW R3/P10 ECBR2.X*7F* CHECK IF ECBR2 CONTAINS '7F' OKR2 0KR2D00' BRANCH IF EVENT COMPLETED X*0000' ILLEGAL INSTRUCTION TO FORCE DUMP ECBR2(4),ECBR2 ZERO ECBR2 * *THE FLAGS ARE OVERWRITTEN AND ARE THEREFORE RESTORED 5.3 TEST CHOICE (1.2 DR 3) MOVE RECORD LENGTH INTO CCW READ DATA MOVE RECORD LENGTH INTO SCW READ DATA 5,CHOICE L S BE 363 384 385 * 5.THREE FINISH BRANCH TO FINISH IF CHOICE=3 MOVE RECORD LENGTH INTO CON READ DATA 5.CHDICE 5.DNE RD WI 386 387 276 MOVE RECORD LENGTH INTO CCW READ DATA ST 3,031+4 DR1+4,X'30' 388 389 390 ÷ 391 *L 392 * 393 WALTW BRANCH TO RD IF CHOICE=1 BRANCH TO WT IF CHOICE=2 DRUM2 T 3, A32+4 VI A2+4, Y01 I 3, B32+6, Y140 IVI BR2+4, Y140 IVI CR2+4, # PEAD FROM DR SI VVI SI MVI ST MVI ST MOVE RECORD LENGTH INTO CCW READ DATA TEST CHOICE (4-8) 5.4. 281 282 287 284 285 286 287 288 296 297 298 299 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 307 308 310 *L 311 * 312 *L 313 *L MOVE RECORD LENGTH INTO CCW READ DATA 5,CHOICE 5,FIVE WT MOVE RECORD LENGTH INTO CCW READ DATA BRANCH TO WT IF CHOICE=5 395 396 # BE MOVE RECORD LENGTH INTO CCW READ DATA L S BE 5,CHOICE 397 398 399 5,FOUR RO BRANCH TO RD IF CHOICE=4 TO DRUMI ST VVI ST MVI ST MVI 3, AH1+4 AH1+4, X'40 MOVE RECORD LENGTH INTO CCM WRITE DATA AWI+4,X'40* 3,8WI+4 BWI+4,X'40* 3,CWI+4 CWI+4,X'40* 3,DWI+4 DWI+4,X'20* MOVE RECORD LENGTH INTO CCW WRITE DATA MOVE RECORD LENGTH INTO CCH WRITE DATA MOVE RECORD LENGTH INTO CCW WRITE DATA TO DRUM2 ST 3,A42+4 WY AV2+4,X'40* ST 3,6#2+4 MYI BW2+4,X'40* ST 3,C42+4 MYI CW2+4,X'40* ST 3,C42+4 MYI DW2+4,X'50* MOVE RECORD LENGTH INTO CCW WRITE DATA MOVE RECORD LENGTH INTO CCW WRITE DATA 414 * 415 *L 416 * 417 MOVE RECORD LENGTH INTO CCW WRITE DATA 5.6. TEST FOR SUCCESS, FAIL IF NOT MOVE RECORD LENGTH INTO CCW WRITE DATA ECBAL, X*7F' CHECK IF ECBAL COUTEN '7F' DKAL BRANCH IF EYENT SICCESSFULLY COMPLETED X*CODOO' ILLEGAL INSTRUCTION TO FORCE OWNP ECBAL(4), ECBAL 417 418 419 420 0KW1 421 * 422 423 424 425 0KW2 425 * 427 *L 428 * 429 430 BE DC XC PREPARE FOR INPUT/OUTPUT ECBW2,X*7F' CHECK IF ECBW2 CONTAINS '7F' OKN2 BRANCH IF EVENT SUCCESSFULLY COMPLETED X*0300' ILLEGAL INSTRUCTION TO FORCE DUMP ECBW2(4),ECBW2 ZERO ECBW2 CL1 BE SPECIFY PROG. INTERRUPTION EXIT R2/P42 4.1. DC SPIE CNOP LA BALR DC DC O REQUEST DJMP 2.4 1,**12 LOAD BRANCH ADDRESS 1.1 BRANCH ARDJNO PATAMS. A(0) EXIT ROJTIVE ADDRESS AL2(0) INTEXUPTION MASK 14 ISSJE SPIE SVC REQUEST DUMP IF PROGRAM ABENDS 315+ NODPEN 316+ NODPEN 317+ 318+ 319+ 320+ 321 & 322 &L 323 & 324 5.7. TEST CHOICE (6,7 OR 8) 5,CHDICE L S BE 5,EIGHT FINISH SVC BRANCH TO FINISH IF CHOICE=8 431 432 * 433 CALCULATE ADDRESSES 4.2. 434 435 436 * 437 * 438 *- 439 *L 5,MESHCR 4,FOUR 5,BAVAR 5,ADCORE BRANCH TO WT IF CHOICE=7 DTHERWISE READ A ST SET UP AND EXECUTE READ PROGRAM 5,RECNUM 5,ONE RECNJM-1 ``` ``` 551 552 553 554 555 556 557 559 560 561 562 563 564 565 567 570 571 572 573 574 577 577 577 577 579 580 583 MVC. 7.4. PREPARE DOB DC8#1+5(8),0(4) MVC ADDRESS ON DRUMI MOVED INTO DCBH1+5 ADDRESS ON DRUM2 MOVED INTO DCBH2+5 DCBd2+5(8).0(5) * * L 7.5. STORE CYLINDER/HEAD/RECORD ADDRESSES ADDRESS ON DRUM1 OF FIRST RECORD IS MOVED INTO A REGION WAMED CCHHR READY FOR USE BY CCH, ONLY 5 BYTES OF THE 8-BYTE ADDRESS ARE NEEDED MVC CCHHR1(5).3(4) *COMMAND CHAINING 4, COMPLETION CODE 7F NVC 108R1(5),-X'*400000007F' MOVE 5 BYTES INTO 108R1 NVC 108R2(5),-X'*400000007F' MOVE 5 BYTES INTO 108R2 460 R4/P89 MVC CCHHR2(5).3(5) 461 MVC IOBR2(5),=X*40000 463 *SEEK ADDRESS 38CC+HR 464 MVC IOBR2+32(8),0(4) 455 * 466 MVC IOBR2+32(8),0(5) 467 * 468 * 469 *L 6-4- PREI 470 * 471 *FULL DISC ADDRESS FDAD-MBBCCHHR 472 MVC DCBR2+5(8),0(5) 474 MVC DCBR2+5(8),0(5) 4,8(4) 5,8(5) CCHHRL+5(5),3(4) INCREMENT ADDRESS INCREMENT ADDRESS MOVE ADDRESS ON DRUM OF SECOND RECORD LA LA MVC 24/088 ADDRESS OF RECORD MOVED INTO IDBR1+32 ADDRESS OF RECORD MOVED INTO IDBR2+32 CCHHR2+5(5).3(5) INCREMENT ADDRESS INCREMENT ADDRESS MOVE ADDRESS ON DRUM OF THIRD RECORD PREPARE DOB ADDRESS OF RECORD MOVED INTO COBR2+5 OCBR2+5 OCBR2+5 MVC CCHHR2+10(5),3(5) LA LA MVC INCREMENT ADDRESS INCREMENT ADDRESS MOVE ADDRESS ON DRUM OF FOURTH RECORD 4,8(4) 5,8(5) CCHHR1+15(5),3(4) MVC DCBR2+5(8).0(5) 474 475 * 584 585 * CCHHR2+15(5).3(5) 476 * 477 *L 586 587 MVC * *L, 6.5. PREPARE CHANNEL COMMAND PROGRAM 587 * 588 *L 589 * 590 *DRUM1 591 $93 594 * 593 594 * 595 596 597 PREPARE CHANNEL COMMAND PROGRAM 478 * 479 *THE CODES ARE OVERWRITTEN AND ARE THEREFORE REPLACED 479 $THE C 480 $ 481 $DRUM1 482 483 484 $ 485 486 $ 487 488 489 $ 490 491 LDAD REG 7 WITH ADDRESS IN CORE OF FIRST RECORD TO BE WRITTEN MOVE ADDRESS IN CORE OF FIRST RECORD INTO CCW 05 INDICATES WRITE INCREMENT ADDRESS COPY ADDRESS IN CORE OF SECOND RECORD INTO L LOAD REG 7 WITH ADDRESS IN CORE MOVE ADDRESS IN CORE OF FIRST RECORD INTO CHANNEL COMMAND WORD(CCW) INDICATES READ WITH MULTIPLE TRACK OPTION IN CCW INCOME INCREMENT ADDRESS MOVE ADDRESS IN CORE OF SECONO RECORD INTO CCW 7,ADCORE 7,AR1 ST MVI A ST AW1,X'05' 7,RECLEN 7,B#1 MVI AR1.X'86' 7.RECLEN 7.BR1 A ST CCW O5 INDICATES WRITE CCW MOVE '86' INTO BRI INCREMENT ADDRESS MOVE ADDRESS IN CORE OF THIRD RECORD INTO CCW IVM BW1 - X 105 MVI BR1.X'86 500 7.RECLEN 7.CH1 A ST 491 492 493 494 495 A ST 7, RECLEN 7, CR1 601 COPY ADDRESS IN CORE OF THIRD RECORD INTO 602 CCW OS INDICATES WRITE CW1,X'05' 7,RECLEN 7,DW1 603 MVI MVI A CR1,X'86' A S T COPY ADDRESS IN CORE OF FOURTH RECORD INTO MOVE ADDRESS IN CORE OF FOURTH RECORD INTO 496 497 * ST 7.031 606 # CCW 05 INDICATES WRITE 607 MVI DW1,X'05' 7,RECLEN 498 MVI DR1.X 1861 609 *REPEAT FOR DRUM2 ST 7.AW2 MVI AW2,X*05* A 7.RECLEN 500 *REPEAT SETTING UP FOR DRUM2 610 7,RECLEN 7,AR2 AR2,X'86' 501 05 INDICATES WRITE 502 ST 613 614 615 616 617 618 619 620 621 622 623 624 A ST MVI 7,RECLEN 7,BW2 8W2,X'05' 7,RECLEN 7,CW2 CW2,X'05' 7,RECLEN 7,DW2 DW2,X'05' 35 INDICATES WRITE 05 INDICATES WRITE 05 INDICATES WRITE * *L 7.7. EXECUTE CHANNEL PROGRAMS R4/P65 IOBAL EXECUTE CHANNEL PROGRAM USING IOBMI 1, JUMI LUAD PARAMETER REG 1 0 ISSUE SVC FOR EXCP 625 626+ 627+ 628 * 629 630+ 631+ 632 $ 625 EXCP SVC 108W2 EXECUTE CHANNEL PROGRAM USING 108W2 1,138W2 LUAD PARAMETER REG 1 0 ISSUE SVC FOR EXCP SVC *L FINISH RETURN TO CALLING SUBPROGRAM 13,4(13) 14,12,12(13) 12(13),X*FF* 14 RESTORE ADDRESS OF PREVIOUS SAVE AREA RESTORE REGISTERS 14,15 AND 0-12 POINTER TO DEBUG ROUTINE FOR RE-ENTRY RETURN 637 638 R4/P68 DATA CONTROL BLOCK (DCB) R4/P77 ADDRESS AT WHICH THE ABSOLUTE ADDRESS OF THE FIRST RECORD TO BE WRITTEN ON ORUML IS TO BE FOUND THE ADDRESS OF THE FIRST RECORD TO BE WRITTEN ON DRUME IS TO BE FOUND R4/P80 90331 DCB DDNAME=DSET1, MACRF=(E), DEVD=DA, DSDRG=PS 541 542 543 544 545 546 547 548 549 550 DATA CONTROL BLOCK CLEAR ECB 7.2. 653+DE381 OF'S' DRIGIN ON WORD BOUNDARY ECB41(4), ECB41 ECB42(4), ECB42 ZERD ECBW1 ZERD ECBW2 DC. 555+# DIRECT ACCESS DEVICE INTERFACE PREPARE 108 7.3. BL15'O' FDAD, DVTBL A(0) KEYLE, DEVT, TRBAL IOBWI (5), = X 40000007F' MOVE 5 BYTES INTO LOBWI ``` | 660+* | | COMMON ACCESS METHOD INTERFACE | |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 662+ | DC | ALI(0) BJFNO | | 663+ | DC<br>DC | AL3(1) BJFCB<br>AL2(0) BUFL | | 665+ | DC | BL2'0100000000000000 DSORG | | 663+* | DC | FOUNDATION EXTENSION | | 670+ | DC | BL1'00000000' BFTEK, BFLN, HIARCHY | | 671+ | 00 | AL3(1) EDDAD | | 672+ | DC | BLI'00000000' RECFM<br>AL3(0) EXLST | | 675+* | | FOUNDATION BLOCK | | | DC | CLB'DSET1' DDNAME | | 677+<br>678+ | DC | BL1'00000000' OFLGS<br>BL1'00000000' IFLG | | 679+<br>680+ | DC | BL1'00000000' IFLG<br>BL2'110100000001000' MACR | | 681 *<br>682 DCBR2 | DCB | DDNAME=DSET2, MACRF={E}, DEVD=DA, DSDRG=PS | | Work. | | | | 684+# | | DATA CONTROL BLOCK | | 685+*<br>686+DCBR2 | DC | OF'D' DRIGIN ON WORD BOUNDARY | | 688+* | | DIRECT ACCESS DEVICE INTERFACE | | | 0.0 | | | 690+ | DC<br>DC | BL15'0' FDAD, DVTBL<br>A(0) KEYLE, DEVT, TRBAL | | 693+* | | COMMON ACCESS METHOD INTERFACE | | 695+ | DC | ALI(0) BUFNO | | 696+ | DC | AL3(1) BUFCB | | 697+ | DC | AL2(0) BUFL.<br>BL2'01000000000000000 DSDRG | | 699+ | DC | A(1) IDBAD | | 701+# | | FOUNDATION EXTENSION | | 703+ | DC | BL1'00000000' BFTEK, BFLN, HIARCHY | | 704+<br>705+ | 00 | AL3(1) EDDAD<br>BL1'00000000' RECFY | | 706+ | DC | AL3(0) EXLST | | 708+* | | FOUNDATION BLOCK | | 710+ | DC | CLB'DSET2' DDNAME | | 711+<br>712+ | DC | BL1'00000010' DFLGS<br>BL1'00000000' IFLG | | 713+ | oc. | BL2'1101000000001000' MACR | | | 00 | BE2-110100000001000 . MACK | | 714 * | 15754<br>118070 | | | | 008 | DDNAME=OSET1, MACRF=(E), DEVD=DA, DSDRG=PS | | 714 * 715 OCSW1 | 15754<br>118070 | | | 714 * 715 DC5W1 717+* 718+* | 15754<br>118070 | DDNAME=DSET1,MACRF=(E),DEVD=DA,DSDRG=PS | | 714 * 715 DC5w1 717+* 718+* 719+DC3w1 | oca | DDNAME=DSET1,MACRF=(E),DEVD=DA,DSORG=PS DATA CONTROL BLOCK OF 3 CRIGIN ON HORD BOUNDARY | | 714 * 715 DC3w1 717+* 718+* 719+DC3w1 721+* | DC B | DONAME=DSET1, MACRE=(E), DEVD=DA, DSORG=PS DATA CONTROL BLOCK DF'0' ORIGIN ON WORD BOUNDARY DIRECT ACCESS DEVICE INTERFACE | | 714 * 715 DC5w1 717+* 718+* 719+DC3w1 | oca | DDNAME=DSET1,MACRF=(E),DEVD=DA,DSORG=PS DATA CONTROL BLOCK OF 3 CRIGIN ON HORD BOUNDARY | | 714 * 715 DC3W1 717+* 718+* 719+DC3W1 721+* 723+ | DC DC | DDNAME=DSET1, MACRF=(E), DEVD=DA, DSORG=PS DATA CONTROL BLOCK DF'0' ORIGIN ON HOPD BOUNDARY DIRECT ACCESS DEVICE INTERFACE BL15'0' FDAD, DVIBL | | 714 * 715 DCSW1 717+* 718+* 719+DC3W1 721+* 723+ 724+ 726+* | 008<br>00<br>00<br>00 | DDNAME=DSET1, MACRF=(E), DEVD=DA, DSORG=PS DATA CONTROL BLOCK OF 0' ORIGIN ON HOPD BOUNDARY DIRECT ACCESS DEVICE INTERFACE BLIS'0' FDAD, OVIBL A(O) KEYLE, DEVT, TRBAL COMMON ACCESS METHOD INTERFACE | | 714 * 715 0C3w1 717+** 718+* 719+0C3w1 721+* 723+ 726+* 728+ 728+ 729+ | DC DC DC DC DC DC DC DC | DDNAME=DSET1, MACRF=(E), DEVD=DA, DSORG=PS DATA CONTROL BLOCK OF 0' ORIGIN ON HOPD BOUNDARY DIRECT ACCESS DEVICE INTERFACE BLIS'0' FDAD, OVIBL A(O) KEYLE, DEVT, TRBAL COMMON ACCESS METHOD INTERFACE ALI(0) 9JFNO ALI(1) 9JFCB | | 714 * 715 0C3w1 717+* 718+* 719+0C3w1 721+* 729+ 729+ 730+ 731+ | 000<br>000<br>000<br>000<br>000<br>000 | DDNAME=DSET1, MACRF=(E), DEVD=DA, DSORG=PS DATA CONTROL BLOCK OF'O' ORIGIN ON WORD BOUNDARY OTRECT ACCESS DEVICE INTERFACE BL15'O' FDAD, DVTBL A(O) KEYLE, DEVT, TRBAL COMMON ACCESS METHOD INTERFACE ALI(O) BUFNO ALI(O) BUFCB | | 714 * 715 0C3w1 717+* 718+* 719+0C3w1 721+* 724+ 726+* 729+ 730+ 731+ 732+ | DC DC DC DC DC DC DC | DDNAME=DSET1, MACRF=(E), DEVD=DA, DSORG=PS DATA CONTROL BLOCK OF'O' ORIGIN ON WOPD BOUNDARY OIRECT ACCESS DEVICE INTERFACE BLIS'O' FDAD, DVTBL A(O) KEYLE, DEVT, TRBAL COMMON ACCESS METHOD INTERFACE ALI(O) BUFNO ALI(I) BUFCB ALI(O) BUFL BLIZ'O(100000000000000)' DSORG A(I) 108A0 | | 714 * 715 0C3w1 717+* 718+* 719+0C3w1 721+* 729+ 729+ 730+ 731+ | 000<br>000<br>000<br>000<br>000<br>000 | DDNAME=DSET1, MACRF=(E), DEVD=DA, DSORG=PS DATA CONTROL BLOCK OF'O' ORIGIN ON WORD BOUNDARY OTRECT ACCESS DEVICE INTERFACE BL15'O' FDAD, DVTBL A(O) KEYLE, DEVT, TRBAL COMMON ACCESS METHOD INTERFACE ALI(O) BUFNO ALI(O) BUFCB | | 714 * 715 0C3w1 717+* 718+* 719+0C3w1 721+* 729+ 724+ 726+* 729+ 730+ 731+ 732+ 734+* 736+ 736+ | DC8 | DDNAME=DSET1, MACRF=(E), DEVD=DA, DSORG=PS DATA CONTROL BLOCK OF 0' ORIGIN ON HOPD BOUNDARY DIRECT ACCESS DEVICE INTERFACE BLIS'0' FDAD, OVIBL A(O) KEYLE, DEVT, TRBAL COMMON ACCESS METHOD INTERFACE ALI(0) BUFL BL2'(1) BUFCB AL2(0) BUFL BL2'(1) DODOODOODOODOODOODOODOODOODOODOODOODOOD | | 714 * 715 0C3w1 717+** 718+* 719+0C3w1 721+* 724+ 726+* 728+ 729+ 730+ 731+ 732+ 736+ 737+ 737+ 738+ | DC8 | DDNAME=DSETI,MACRF=(F),DEVD=DA,DSORG=PS DATA CONTROL BLOCK OF'O' ORIGIN ON WORD BOUNDARY DIRECT ACCESS DEVICE INTERFACE BLIS'O' FDAD,DVTBL A(D) KEYLE,DEVT,TRBAL COMMON ACCESS METHOD INTERFACE ALI(0) BUFNO ALI(1) BUFCB AL2(0) BUFL BL2(0)00000000000000000000000000000000000 | | 714 * 715 0C3w1 717+* 718+* 719+0C3w1 721+* 729+ 729+ 730+ 731+ 732+ 731+ 732+ 731+ 732+ 731+ 732+ 731+ 733+ 739+ | 000<br>000<br>000<br>000<br>000<br>000<br>000 | DDNAME=DSET1, MACRF=(E), DEVD=DA, DSORG=PS DATA CONTROL BLOCK OF 0' ORIGIN ON WORD BOUNDARY DIRECT ACCESS DEVICE INTERFACE BL15'0' FDAD, DVIBL A(D) KEYLE, DEVT, TRBAL COMMON ACCESS METHOD INTERFACE AL1(0) BUFL BL2'01030030003000000' DSORG A(1) IOBAD FOUNDATION EXTENSION BL1'00003000' BFTEK, BFLN, HIARCHY AL3(1) EODAD BL1'00303000' RECEN AL3(0) EXLST | | 714 * 715 0C3w1 717+** 718+* 719+0C3w1 721+* 724+ 726+* 728+ 729+ 730+ 731+ 732+ 736+ 737+ 737+ 738+ | DC8 | DDNAME=DSET1, MACRF=(E), DEVD=DA, DSORG=PS DATA CONTROL BLOCK OF 0' ORIGIN ON WORD BOUNDARY OTRECT ACCESS DEVICE INTERFACE BL15'0' FDAD, DVTBL A(0) KEYLE, DEVT, TRBAL COMMON ACCESS METHOD INTERFACE AL1(0) BUFL BL2'0(10)0000000000000000000000000000000000 | | 714 * 715 0C3×1 717+* 718+* 719+0C3×1 721+0 723+ 724+ 726+0 730+ 730+ 730+ 731+ 732+ 736+ 737+ 737+ 738+ 741+* | 000<br>000<br>000<br>000<br>000<br>000<br>000<br>000 | DDNAME=DSET1, MACRF=(F), DEVD=DA, DSORG=PS DATA CONTROL BLOCK OF'O' ORIGIN ON WORD BOUNDARY DIRECT ACCESS DEVICE INTERFACE BL15'O' FDAD, DVIBL A(D) KEYLE, DEVT, TRBAL COMMON ACCESS METHOD INTERFACE AL1(0) BJFNO AL3(1) BJFNO AL3(1) BJFCB AL2(0) BUFL BL2'0100000000000000000000000000000000000 | | 714 * 715 0C3w1 717+* 718+* 719+DC3w1 721+* 728+ 726+* 728+ 729+ 730+ 730+ 731+ 732+ 734+* 736+ 737+ 737+ 737+ 739+ 741+* 743+ 744+ 745+ | DC D | DDNAME=DSETI,MACRF=(F),DEVD=DA,DSORG=PS DATA CONTROL BLOCK OF'O' ORIGIN ON WORD BOUNDARY DIRECT ACCESS DEVICE INTERFACE BL15'O' FDAD,DVIBL A(D) KEYLE,DEVT,RBAL COMMON ACCESS METHOD INTERFACE AL1(0) 9JFNO AL3(1) 8JFCB AL2(0) BUFL BL2'0100000000000000000000000000000000000 | | 714 * 715 0C3w1 717+* 718+* 719+0C3w1 721+* 729+ 729+ 730+ 731+ 732+ 736+* 736+ 737+ 738+ 739+ 739+ 739+ 739+ 739+ 739+ 739+ 739 | DC D | DDNAME=DSETI,MACRF=(F),DEVD=DA,DSORG=PS DATA CONTROL BLOCK OF'O' ORIGIN ON WORD BOJNDARY DIRECT ACCESS DEVICE INTERFACE BL15'O' FDAD,DVIBL A(D) KEYLE,DEVT,RBAL COMMON ACCESS METHOD INTERFACE AL1(0) 9JFNO AL3(1) 8JFCB AL2(0) BUFL BL2'0100000000000000000000000000000000000 | | 714 * 715 0C3w1 717+* 718+* 719+DC3w1 721+* 728+ 726+* 728+ 729+ 730+ 730+ 731+ 732+ 734+* 736+ 737+ 737+ 737+ 739+ 741+* 743+ 744+ 745+ | DC D | DDNAME=DSETI,MACRF=(F),DEVD=DA,DSORG=PS DATA CONTROL BLOCK OF'O' ORIGIN ON WORD BOUNDARY DIRECT ACCESS DEVICE INTERFACE BL15'O' FDAD,DVIBL A(D) KEYLE,DEVT,RBAL COMMON ACCESS METHOD INTERFACE AL1(0) 9JFNO AL3(1) 8JFCB AL2(0) BUFL BL2'0100000000000000000000000000000000000 | | 714 * 715 0C5×1 717+* 718+* 719+0C3×1 721+* 723+ 724+ 726+* 728+ 730+ 731+ 732+ 731+ 732+ 736+ 737+ 738+ 739+ 741+* 744+ 745+ 746+ 747 743 0C6×2 | DC D | DDNAME=DSETI,MACRF=(F),DEVD=DA,DSORG=PS DATA CONTROL BLOCK OF'O' ORIGIN ON WORD BOJNDARY DIRECT ACCESS DEVICE INTERFACE BL15'O' FDAD,DVIBL A(D) KEYLE,DEVT,RBAL COMMON ACCESS METHOD INTERFACE AL1(0) 9JFNO AL3(1) 8JFCB AL2(0) BUFL BL2'0100000000000000000000000000000000000 | | 714 * 715 0C3w1 717+* 718+* 719+0C3w1 721+* 723+ 724+ 726+* 728+ 730+ 731+ 732+ 731+ 732+ 736+ 737+ 733+ 737+ 739+ 741-* 743 744- 745+ 746- 747 748 0C6w2 | DC D | DDNAME=DSET1, MACRF=(F), DEVD=DA, DSORG=PS DATA CONTROL BLOCK OF'O' ORIGIN ON HOPD BOUNDARY DIRECT ACCESS DEVICE INTERFACE BLIS'O' FDAD, DVIBL A(O) KEYLE, DEVT, TRBAL COMMON ACCESS METHOD INTERFACE ALI(O) BUFLO BLIS'OLOODOODOOOOOOOOOOOOOOOOOOOOOOOOOOOOOO | | 714 * 715 0C3x1 717+* 718+* 719+0C3x1 721+* 723+ 724+ 726+* 729+ 730+ 731+ 730+ 731+ 732+ 734+* 736+ 737+ 737+ 737+ 737+ 744- 744- 744- 744- 744- 744- 750+* 750+* 750+* 750+* 750+* 750+* 750+* 750+* | DC D | DDNAME=DSET1, MACRF=(F), DEVD=DA, DSORG=PS DATA CONTROL BLOCK OF'O' ORIGIN ON HOPD BOUNDARY DIRECT ACCESS DEVICE INTERFACE BLIS'O' FDAD, DVIBL A(O) KEYLE, DEVT, TRBAL COMMON ACCESS METHOD INTERFACE ALI(O) BUFLO ALI(O) BUFLO BLI' OLOODODOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOO | | 714 * 715 0C3 k1 717+* 718+* 719+ 0C3 k1 721+* 723+ 724+ 726+* 728+ 729+ 730+ 731+ 732+ 736+ 737+ 737+ 737+ 737+ 737+ 737+ 737 | DC D | DDNAME=DSET1, MACRF=(F), DEVD=DA, DSORG=PS DATA CONTROL BLOCK OF'O' ORIGIN ON WORD BOUNDARY DIRECT ACCESS DEVICE INTERFACE BLIS'O' FDAD, DVIBL A(O) KEYLE, DEVT, TRBAL COMMON ACCESS METHOD INTERFACE ALI(O) BUFNO ALI(I) BUFCB AL2(O) BUFL BL2'OLOOODOODOODOODO' DSORG A(I) IDBAD FOUNDATION EXTENSION BL1'OOODOODO' BFTEK, BFLN, HIARCHY ALI(I) ECOMO BL1'OOODOODOODOODOODOODOODOODOODOODOODOODOO | | 714 * 715 0C3x1 717+* 718+* 719+0C3x1 721+* 723+ 724+ 726+* 729+ 730+ 731+ 730+ 731+ 732+ 734+* 736+ 737+ 737+ 737+ 737+ 744- 744- 744- 744- 744- 744- 750+* 750+* 750+* 750+* 750+* 750+* 750+* 750+* | DC D | DDNAME=DSET1, MACRF=(F), DEVD=DA, DSORG=PS DATA CONTROL BLOCK OF'O' ORIGIN ON HOPD BOUNDARY DIRECT ACCESS DEVICE INTERFACE BLIS'O' FDAD, DVIBL A(O) KEYLE, DEVT, TRBAL COMMON ACCESS METHOD INTERFACE ALI(O) BUFLO ALI(O) BUFLO BLI' OLOODODOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOO | | 714 * 715 0CSW1 717+* 718+* 719+DCSW1 721+* 723+ 726+* 726+* 730+ 730+ 731+ 730+ 731+ 730+ 731+ 730+ 731+ 730+ 731+ 730+ 731+ 730+ 731+ 730+ 731+ 730+ 731+ 731+ 731+ 731+ 731+ 731+ 731+ 731 | DC D | DDNAME=DSET1, MACRF=(F), DEVD=DA, DSORG=PS DATA CONTROL BLOCK OF'O' ORIGIN ON WORD BOUNDARY DIRECT ACCESS DEVICE INTERFACE BLIS'O' FDAD, DVTBL A(D) KEYLE, DEVT, TRBAL COMMON ACCESS METHOD INTERFACE ALI(0) 9JFNO ALI(1) BUFCB ALI(1) BUFCB ALI(1) BUFCB ALI(1) BUFCB ALI(1) BUFCB BLI'000000000000000000000000000000000000 | | 714 * 715 0CSW1 717+* 718+* 719+DCSW1 721+* 726+* 728+ 729+ 730+ 731+ 730+ 731+ 732+ 734+* 736+ 737+ 739+ 741-* 748 DCSW2 750+* 751+* 752+DCSW2 754+* 756+ 757+ 759+* | DC D | DDNAME=DSET1,MACRF=(F),DEVD=DA,DSORG=PS DATA CONTROL BLOCK OF'O' ORIGIN ON WORD BOUNDARY DIRECT ACCESS DEVICE INTERFACE BLIS'O' FDAD,DVTBL A(DI KEYLE,DEVT,TRBAL COMMON ACCESS METHOD INTERFACE ALI(0) 9JFNO ALI(1) 8JFNO ALI(1) 8JFNO ALI(1) 10JFCB BLI'00JOJOJO' BFTEK,BFLN,HIARCHY ALI(1) EONDA FOUNDATION BLOCK CLR'DSET1' DDNAME BLI'00JOJOJO' FFLGS BLI'00JOJOJO' FFLGS BLI'00JOJOJO' FFLGS BLI'00JOJOJO' FFLGS BLI'00JOJOJO' BFLGS BLI'00JOJOJOJO' MACR DDNAME=DSET2,MACRF=(E),DEVD=DA,DSORG=PS DATA CONTROL BLOCK OF'D' GRIGIN ON WORD BOJNDARY DIRECT ACCESS DEVICE INTERFACE BLIS'O' FDAD,DVTBL A(OI KEYLE,DEVT,TRBAL | | 714 * 715 DCSW1 717+* 718+* 719+DCSW1 721+* 726+* 728+ 729+ 730+ 731- 731- 731- 732- 734-* 736- 737- 733- 734-* 736- 737- 739- 731- 739- 741-* 740- 750 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 751 | DC D | DDNAME=DSETI,MACRF=(F),DEVD=DA,DSORG=PS DATA CONTROL BLOCK OF'O' ORIGIN ON WORD BOJNDARY DIRECT ACCESS DEVICE INTERFACE BL15'O' FDAD,DVIBL A(D) KEYLE,DEVT,RBAL COMMON ACCESS METHOD INTERFACE AL1(0) BJFNO AL3(1) BJFNO AL3(1) BJFNO BL2'0100000000000000000000000000000000000 | | 714 * 715 0C5w1 717+* 718+* 713+* 713+* 724+ 726+* 728+ 729+ 730+ 731+ 730+ 731+ 732+ 734+* 736+ 737+ 737+ 739+ 741+* 744+ 744+ 745+ 746+ 747 752+ 750+* 751+* 752+ 756+ 757+ 759+9 761+ | DC D | DDNAME=DSET1,MACRF=(F),DEVD=DA,DSORG=PS DATA CONTROL BLOCK OF'O' ORIGIN ON WORD BOUNDARY DIRECT ACCESS DEVICE INTERFACE BLIS'O' FDAD,DVTBL A(DI KEYLE,DEVT,TRBAL COMMON ACCESS METHOD INTERFACE ALI(0) 9JFNO ALI(1) 8JFNO ALI(1) 8JFNO ALI(1) 10JFCB BLI'00JOJOJO' BFTEK,BFLN,HIARCHY ALI(1) EONDA FOUNDATION BLOCK CLR'DSET1' DDNAME BLI'00JOJOJO' FFLGS BLI'00JOJOJO' FFLGS BLI'00JOJOJO' FFLGS BLI'00JOJOJO' FFLGS BLI'00JOJOJO' BFLGS BLI'00JOJOJOJO' MACR DDNAME=DSET2,MACRF=(E),DEVD=DA,DSORG=PS DATA CONTROL BLOCK OF'D' GRIGIN ON WORD BOJNDARY DIRECT ACCESS DEVICE INTERFACE BLIS'O' FDAD,DVTBL A(OI KEYLE,DEVT,TRBAL | ``` FOUNDATION EXTENSION 767++ SLI'00000000 BFTEK,BFLN,HIARCHY AL3(1) EODAD BLI'00000000 RECEM AL3(0) EXLST EDUNDATION BLOCK 774+* CL3'OSET2' DDNAME BL1'00000010' DFLGS BL1'0000000' IFLG BL2'1101000000001000' MACR 776+ 777+ 778+ 779+ 779+ 780 + 781 +L 782 + IDB AND ECB (READ) 9.2. R4/P87 792 * 783 105R1 785 786 787 787 787 789 790 791 792 * 793 794 FORCE ON FULL-WORD BOUNDARY DS DS DC DC DC 1F A(ECBR1) 2F'0' A(CCWR1) ADDRESS OF EVENT CONTROL BLOCK(ECBR1) ADDRESS OF START OF CHANNEL PROGRAM FOR READING ON DRUMI ADDRESS OF DATA CONTROL BLOCK(DCB) FOR READING ON DRUMI ACDCBRLL DC 4F'0" nc DS DC DC 1F A(ECBR2) 2F'3' A(CCWR2) ADDRESS OF EVENT CONTROL BLOCK(ECBR2) 794 795 ADDRESS OF START OF CHANNEL PROGRAM FOR READING ON DRUYZ ADDRESS OF OATA CONTROL BLOCKIOCBI FOR READING ON DRUYZ 796 797 * 798 799 * nc 4(DCBR2) 800 * 801 * 802 * 803 *C3R1 804 *EC3R2 805 * 806 *L DC 4F101 R4/P88 OF F'O' 9.3. IOB AND ECB (WRITE) DS DC DC DC 808 IOSW1 1F A(EJBW1) ADDRESS OF EVENT CONTROL BLOCK(EC3WL) 810 811 912 * A(ACCHW1) ADDRESS OF START OF CHANNEL PROGRAM FOR ARITING ON DRUMI ADDRESS OF DATA CONTROL BLOCK(DCB) FOR ARITING ON DRUMI 912 * 813 814 * 915 816 105 W 2 817 818 819 920 * 821 DC A ( DC BW1 ) 4F'0' 1F A(ESBW2) 2F'3' A(ACCW/2) DS DC DC ADDRESS OF EVENT CONTROL BLOCK(ECBW2) ADDRESS OF START OF CHANNEL PROGRAM FOR ARTTING ON DRUM2 ADDRESS OF DATA CONTROL BLOCKLOCB) FOR ALDCBW21 nc 822 * 823 824 825 * ARITING ON DRUM2 4F'0' CHANNEL PROGRAMS COMMAND CODES HRITE DATA TRANSFER IN CHANNEL SEARCH EQUAL TO EEAD DATA AITH MULTI-TRACK MODE(MTM) SEARCH EQUAL TO AITH MULTI-TRACK MODE(MTM) R3/P12 R3/P23 R3/P12 FLAGS DRIVIAHO DNAMHOO CM DRIVIAHO DNAMHOO R3/P10 842 * 843 *CCM ARE DUUGL. 844 *CCM ARE DUUGL. 845 * 846 *L 847 * 849 *READ FROM DAUM! 844 *COMRI COM X'31',IOBR1+35,X'40',X'00' 851 CCM X'39',CCMR1,X'30',X'40',X'000000' 852 ARI CCM X'39',CCMR1,X'30',X'40',X'000000' 853 BRI CCM X'39',X'300000',X'40',X'000000' 854 CM CCM X'39',X'000000',X'40',X'000000' 855 DRI CCM X'35',X'000000',X'40',X'000000' 856 * 857 **READ FROM DRUM2* 858 CCM X'38',X'000000',X'40',X'000000' 859 CCM X'38',X'000000',X'40',X'000000' 850 CCM X'38',X'000000',X'40',X'000000' 851 BR2 CCM X'38',X'000000',X'40',X'000000' 852 CCM X'38',X'000000',X'40',X'000000' 853 BR CCM X'38',X'000000',X'40',X'000000' 854 BR CCM X'38',X'000000',X'40',X'000000' 855 BR CCM X'38',X'000000',X'40',X'000000' FORCE ON DOUBLE WORD BOUNDARY R3/P22 R3/P22 SEARCH ID EQUAL TRANSFER IN CHANNEL(TIC) READ DATA WITH MTM READ DATA WITH MTM READ DATA WITH MTM READ DATA WITH MTM SEARCH ID EDJAL TRANSFER IN CHANNEL(TIC) READ DATA WITH MTM READ DATA WITH MTM READ DATA WITH MTM READ DATA WITH MTM 863 DRZ 864 * 865 *L 866 * 869 ACCHWI 869 ACCHWI 870 AWI 871 BCCWWI 873 * 873 AWI 873 BT4 AWI 875 CCCWWI 875 * TO ORUM! CC# X:31',CCHHR1,X'40',X'05' CCW X:00',ACCW#1,X'70',X'00',X'00' CCW X:05',X'30000',X'40',X'0000000' CC# X:81',CCHHR1+5,X'40',X'05' SEARCH ID EQUAL TRANSFER IN CHANNEL(TIC) WRITE DATA WRITE DATA HULTI-TRACK MDE TRANSFER IN CHANNEL(TIC) WRITE DATA SEARCH ID EQUAL MITH MULTI-TRACK MODE x'03',3CCH41, X'00', X'00' X'05', X'000000', X'40', X'000000' X'81',CCHHR1+10, X'40', X'05' ccw ``` ``` 977 CCW X'08',CCCMH1,X'00',X'00' MRITE DATA 878 CH1 CCW X'05',X'030300',X'40',X'00' MRITE DATA 880 CM1 CCW X'05',X'030300',X'40',X'05' SEARCH ID EQUAL WITH 881 CCW X'05',X'000000',X'30',X'000000' MRITE DATA 882 DH1 CCW X'05',X'000000',X'30',X'000000' MRITE DATA 883 * 884 **WRITE TO DRUM2 885 ACCWN2 CCW X'33',ACCWM2,X'30',X'00' TRANSFER IN CHANNEL(TIC) 886 CCW X'05',X'000000',X'40',X'000000' MRITE DATA 888 BCCWN2 CCW X'05',X'000000',X'40',X'000000' MRITE DATA 888 BCCWN2 CCW X'05',X'000000',X'40',X'000000' MRITE DATA 889 * CCW X'08',BCCWM2,X'00',X'00' MRITE DATA 889 CCW X'08',BCCWM2,X'00',X'00' MRITE DATA 890 CCW X'08',BCCWM2,X'00',X'00' MRITE DATA 891 BW2 CCW X'05',X'0000000',X'40',X'000000' MRITE DATA 892 CCCWM2 CCW X'05',X'0000000',X'40',X'00' MRITE DATA 893 CCCW X'05',X'000000',X'40',X'00' MRITE DATA 894 CCW X'05',X'000000',X'40',X'00' MRITE DATA 895 CCCW X'05',X'0000000',X'40',X'00' MRITE DATA 896 CCCW X'05',X'0000000',X'40',X'00' MRITE DATA 897 CCW X'05',X'0000000',X'40',X'00' MRITE DATA 898 CCW X'05',X'0000000',X'40',X'00' MRITE DATA 899 CCW X'05',X'0000000',X'00',X'00' MRITE DATA 890 CCW X'05',X'0000000',X'00',X'00' MRITE DATA 891 CCW X'05',X'0000000',X'00' MRITE DATA 892 CCW X'05',X'0000000',X'00' MRITE DATA 893 CCW X'05',X'0000000',X'00' MRITE DATA 894 CCW X'05',X'0000000',X'00' MRITE DATA 895 CCW X'05',X'0000000',X'00' MRITE DATA 896 CCW X'05',X'0000000',X'00' MRITE DATA 897 CCW X'05',X'0000000',X'00' MRITE DATA 898 CCW X'05',X'0000000',X'00' MRITE DATA 899 CCW X'05',X'0000000',X'00' MRITE DATA 890 CCW X'05',X'0000000',X'00' MRITE DATA 891 CCW X'05',X'0000000',X'00' MRITE DATA 892 CCW X'05',X'000000',X'00' MRITE DATA 893 CCW X'05',X'000000',X'00' MRITE DATA 894 CCW X'05',X'000000',X'00' MRITE DATA 895 CCW X'05',X'0000000',X'00' MRITE DATA 896 CCW X'05',X'000000' MRITE DATA 897 CCW X'05',X'000000' MRITE DATA 898 CCW X'05',X'000000' MRITE DATA 899 CCW X'05',X'000000' MRITE DATA 890 CCW X'05',X'000000' MRITE DATA 890 CCW X'05',X'000000' MRITE DATA 890 CCW X'05',X'000000' MRITE DATA 890 CCW X'05',X'000000' ``` #### APPENDIX VII #### Documentation Conventions There are many advantages in deliberately making the complex and expensive logic of assembler language programs as intelligible as possible to the reader. The extensive provisions for mnemonics and comments that are available with IBM 360-type assemblers enable this goal to be achieved fairly readily provided that an adequate set of conventions is established at the outset before coding begins. Although the routines SETDRM and TRANSF were written some time ago, they have been brought up to date by extensive recommenting and it is hoped that a brief discussion of the documentation conventions used here will be helpful in planning future codes. References 16 and 17 provide a detailed discussion of the readibility problem with specific recommendations for Fortran and assembler language. ### (a) Calling Sequence and arguments It is often difficult to determine the calling sequence of a routine simply by inspection. We recommend that where it is designed to be called from Fortran, the equivalent Fortran SUBROUTINE or FUNCTION statement is included as a comment, with a description explaining the meaning of the arguments. #### (b) References The two routines discussed in this report cannot readily be understood in full detail without constant reference to six IBM manuals, and page references are therefore inserted in the code wherever the reader might encounter any difficulty (R6P132 means reference 6, page 132). ### (c) Sections and subsections Although many assembler language routines are nowadays freely commented so far as local details are concerned it is often very hard to understand their overall structure. It is therefore recommended that large routines should be divided into decimally numbered sections and subsections with appropriate headings according to the conventions that have already been proposed for Fortran in reference [16]. 'Blank' and 'ruled' lines are used to emphasize this structure. The 'L' in column 2 enables a contents list to be made by selectively printing only these lines. ### (d) Definition of identifier The meaning of each identifier should be carefully explained, and it is convenient to do this by arranging declarations such as DC, DS, EQU in alphanumeric or other suitable order with an appropriate comment on each line. Neat tables defining the storage layout or the meaning of the registers can readily be maintained in this way. ### (e) Comments In addition to the headings and subheadings two other types of comments are employed; those starting in column 30 of a statement line (an advantage over Fortran), and comment lines starting in column 2. # (f) Program commentary To avoid extensive comments within the body of the code Appendices III and IV provide a commentary which uses the same decimal numbering scheme so that cross-referencing is facilitated. Fig.1 Explicit Leapfrog Difference Scheme The physical region is a parallelopiped containing NIxNJxNK cells. Because of the periodic symmetry the three faces which may be denoted by East, Upper and North do not have to be independently calculated and act as guard planes. An extra set of guard planes is provided outside the West, Lower and South faces. In Fig.1(a) and Fig.1(c) points O are recalculated at even steps, and points X are recalculated at odd steps. Points () and X are guard points, set by symmetry. Fig.1(b) shows the compass notation which can conveniently be employed for Fortran or hand-coded assembler language, together with the location of the FS and FN planes which are transferred to and from the drums while the calculation of the central plane is in progress. Fig. 2 <u>Data Organization</u> For maximum efficiency it is necessary to relate the space mesh to the structure of the direct access storage devices used. In this calculation there are 48 K-planes, half of each plane being stored on Drum 1 and half on Drum 2. Each half-plane lies entirely within a single protection domain or 'cylinder', so that it can be transferred in one operation. During the calculation of plane 0 the two FS half-planes are first transferred from the M-buffer to the drums (Stage 1), and then the M-buffer is refilled with the two FN half-planes (Stage 2). Finally the buffer indices are updated so that the next calculation takes place in the core area previously labelled N. CLM-R118 Fig.3 IBM 360/91 Computer Configuration used at Garching Large 2D and 3D calculations were facilitated by having two IBM 2301 drums available as fast 'class C' direct access scratch storage for the problem program. These drums were attached to separate channels so that the data transfer rate could be maximized. User ('class A') and system ('class B') files were held on other devices attached to different channels leaving the problem programmer free to organize his scratch data in whichever way suited the particular calculation best. These large calculations were run outside normal hours and in order to make as much main core storage available as possible (1.5 Mbytes) they were not multiprogrammed with other jobs, making it desirable to develop CPU calculations and I/O transfers as much as possible in order to reduce the machine time required. Fig.4 A Machine Configuration for Large Calculations Several requirements must be met in a configuration which is specifically designed for large 3D calculations if the full power of available hardware is to be exploited. This diagram indicates a possible solution. Production runs would be carried out in a special-purpose fast CPU coupled to a large main core store and a scratch backing store C, the total storage requirements being of order 108 bytes with a transfer speed exceeding 107 bytes/second. Such runs would often need to be monitored on-line and a historical record preserved on device E for subsequent analysis. Complex calculations might need to be 'steered' from the console or temporarily suspended on device D to allow time for thought. The front-end machine would also handle routine work such as compilations, printing, file editing and short test runs. References are to subroutine SETDRM Fig. 5 Control Blocks for Subroutine SETDRM This diagram shows the control blocks and macros, explained in ref.[1], and the sections of the subroutine in which they are used. CLM-R118 Fig.6 Control Blocks for Subroutine TRANSF This diagram shows the control blocks, macros and channel program for EXCP, explained in ref.[4], and the sections of the subroutine in which they are used. CLM-R118 ### HER MAJESTY'S STATIONERY OFFICE Government Bookshops 49 High Holborn, London WC1V 6HB 13a Castle Street, Edinburgh EH2 3AR 109 St Mary Street, Cardiff CF1 1JW Brazennose Street, Manchester M60 8AS 50 Fairfax Street, Bristol BS1 3DE 258 Broad Street, Birmingham B1 2HE 80 Chichester Street, Belfast BT1 4JY Government publications are also available through booksellers