Restricted Materials of IBM Corporation LY26-3921-0 File No. S370-31 **Program Product** MVS/370 Linkage Editor Logic Data Facility Product 5665-295 Release 1.0 # First Edition (April 1983) This edition applies to Release 1.0 of MVS/370 Data Facility Product, Program Product 5665-295, and to any subsequent releases until otherwise indicated in new editions or technical newsletters. Changes are periodically made to the information herein; before using this publication in connection with the operation of IBM systems, consult the latest <u>IBM System/370 and 4300 Processors</u> <u>Bibliography</u>, GC20-0001, for the editions that are applicable and current. References in this publication to IBM products, programs, or services do not imply that IBM intends to make these available in all countries in which IBM operates. Any reference to an IBM program product in this publication is not intended to state or imply that only IBM's program product may be used. Any functionally equivalent program may be used instead. Publications are not stocked at the address given below; requests for IBM publications should be made to your IBM representative or to the IBM branch office serving your locality. A form for readers' comments is provided at the back of this publication. If the form has been removed, comments may be addressed to IBM Corporation, P.O. Box 50020, Programming Publishing, San Jose, California, U.S.A. 95150. IBM may use or distribute whatever information you supply in any way it believes appropriate without incurring any obligation to you. This document contains restricted materials of International Business Machines Corporation. © Copyright International Business Machines Corporation 1972, 1983. All rights reserved. #### HOW TO USE THIS BOOK This publication describes the internal organization and logic of the linkage editor. The linkage editor, a processing program, combines and edits modules to produce a load module that can be loaded into virtual storage by the control program. This manual consists of seven sections. The first three sections describe the overall organization, beginning with a general description and progressing to a detailed discussion of the components of the linkage editor. The last four sections are reference sections for analyzing storage dumps and for accessing specific areas of code in the program listing. The seven sections are: - "Introduction" describes the linkage editor as a whole, including its relationship to the operating system. The major divisions of the program and the relationships among them are also described. - 2. "Method of Operation" provides: - a. An overview of the logic of the linkage editor - b. Detailed descriptions of specific operations Use the operation diagrams included at the end of this section with the text. They illustrate the flow of data through the tables and buffers used during linkage editor processing. - "Program Organization" describes the organization of the linkage editor. Program components (modules, control sections, and routines) are described both in terms of their operation and their relation to other components. - "Microfiche Directory" helps the reader find the named areas of code in the program listing. Microfiche cards contain the program listing. - "Table Layouts" are used for analysis of storage dumps. They are illustrated in this section. - "Diagnostic Aids" includes general register contents at entry to modules, and an error message—module cross-reference table. - 7. "Appendix" includes input conventions and record formats. Read the Introduction first for an overview of the linkage editor within the operating system. Consult the Method of Operations section for the overall logic of the linkage editor. Finally, read the Program Organization section for detailed examination of the program components. Refer to the last four sections for named areas of code, table layouts, register contents, input conventions, and record formats while reading the Method of Operation and Program Organization sections. If more detailed information is required, refer to the contents and coding in the linkage editor program listings. Other publications that are required for an understanding of the linkage editor are: - MVS/370 Data Management Services, GC26-4058 - MVS/370 Data Management Macro Instructions, GC26-4057 - <u>OS/VS2 MVS JCL</u>, GC28-0692 The reader should also refer to the corequisite publications: - MVS/370 Linkage Editor and Loader, GC26-4061 - <u>OS/VS2 System Programming Library: Debugging Handbook</u>, Volumes 1 through 3, GC28-1047 through GC28-1049 # CONTENTS | Introduction | 1 | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------| | | • • • | | Purpose of Linkage Editor | 1 | | Politionship to the Openating System | 2 | | Purpose of Linkage Editor | | | General Description | 2 | | Madula Standama | • • • | | General Description | • • • | | External Symbol Dictionary Relocation Dictionary Composite Dictionaries Linkage Editor Options | 3 | | Delegation Distinguish | 4 | | Kelocation Dictionary | 4 | | Composite Dictionaries | 4 | | Tomposite Brothondines | • • • | | Linkage Editor Options | 5 | | Modulo Attributos | 6 | | module actributes | | | Module Attributes | 8 | | Tamul (Outant Elan | 11 | | Input/Output Flow | 11 | | | | | M. Albart and M. annu Albar | | | Method of Operation | 15 | | Logic of the Linkage Editor | 15 | | Logic of the Linkage Editor | | | Initialization | 15 | | Tanada Baranasian | | | Input Processing | 15 | | Intermediate Processing | 16 | | Intermediate Processing | | | Second Pass Processing | 1/ | | Final Processing | 1.9 | | | 10 | | Initialization | 19 | | Initialization | 1.0 | | rreparing the All-rurpose lable (Arl) | 17 | | Analyzing Control Information | 19 | | | • • • • | | Upening Data Sets | 20 | | Allocating Virtual Storage | 21 | | Allocating virtual Storage | | | Buffer Allocation | 21 | | Table Allegation | 21 | | ignie attocación | 21 | | Input Processing | 22 | | Reading Blocked Input Record Lengths for SYSPRINT Record Lengths for SYSTERM | 2. | | keading blocked input | 23 | | Record Lengths for SYSPRINI | 23 | | December 4 - CYCTEDM | | | Kecord Lengths for STSTERM | 23 | | Control Statement | 23 | | on the statement of | | | Control Statement Processors | 25 | | Object Module Processing | 7.1 | | | | | | • • == | | Load Module Processing | 32 | | Object Module Processing | 32 | | ESD Record Types | 34 | | ESD Record Types | 34 | | ESD Record Types | 34 | | ESD Record Types | 34 | | ESD Record Types | 34 | | ESD Record Types | 34 | | ESD Record Types | 34<br>35<br>35<br>Data 40 CESD Record Types and Subtypes ESD Processing IDR Processing Processing Object Module END Records Containing IDR Processing Load Module IDRs Processing IDENTIFY Control Statement Data IXT Processing Processing Object Module Text Processing Load Module Text Writing Text on SYSUT1 | 34<br>35<br>35<br>Data 40<br>41<br>42 | | ESD Record Types CESD Record Types and Subtypes ESD Processing IDR Processing Processing Object Module END Records Containing IDR Processing Load Module IDRs Processing IDENTIFY Control Statement Data TXT Processing Processing Object Module Text Processing Load Module Text Writing Text on SYSUT1 RLD Processing | 34<br>35<br>35<br>Data 40<br>41<br>41 | | ESD Record Types CESD Record Types and Subtypes ESD Processing IDR Processing Processing Object Module END Records Containing IDR Processing Load Module IDRs Processing IDENTIFY Control Statement Data TXT Processing Processing Object Module Text Processing Load Module Text Writing Text on SYSUT1 RLD Processing | 34<br>35<br>35<br>Data 40<br>41<br>41 | | ESD Record Types CESD Record Types and Subtypes ESD Processing IDR Processing Processing Object Module END Records Containing IDR Processing Load Module IDRs Processing IDENTIFY Control Statement Data TXT Processing Processing Object Module Text Processing Load Module Text Processing Load Module Text Processing Load Module Text Writing Text on SYSUT1 RLD Processing END Processing | 34<br>35<br>Data 40<br>41<br>42<br>43 | | ESD Record Types CESD Record Types and Subtypes ESD Processing IDR Processing Processing Object Module END Records Containing IDR Processing Load Module IDRs Processing IDENTIFY Control Statement Data TXT Processing Processing Object Module Text Processing Load Module Text Processing Load Module Text Processing Load Module Text Writing Text on SYSUT1 RLD Processing END Processing | 34<br>35<br>Data 40<br>41<br>42<br>43 | | ESD Record Types CESD Record Types and Subtypes ESD Processing IDR Processing Processing Object Module END Records Containing IDR Processing Load Module IDRs Processing IDENTIFY Control Statement Data TXT Processing Processing Object Module Text Processing Load Module Text Processing Load Module Text Processing Load Module Text Writing Text on SYSUT1 RLD Processing END Processing | 34<br>35<br>Data 40<br>41<br>42<br>43 | | ESD Record Types CESD Record Types and Subtypes ESD Processing IDR Processing Processing Object Module END Records Containing IDR Processing Load Module IDRs Processing IDENTIFY Control Statement Data IXT Processing Processing Object Module Text Processing Load Module Text Writing Text on SYSUT1 RLD Processing END Processing Include Processing Automatic Library Call Processing | | | ESD Record Types CESD Record Types and Subtypes ESD Processing IDR Processing Processing Object Module END Records Containing IDR Processing Load Module IDRs Processing IDENTIFY Control Statement Data IXT Processing Processing Object Module Text Processing Load Module Text Writing Text on SYSUT1 RLD Processing END Processing Include Processing Automatic Library Call Processing | 34<br>35<br>Data 40<br>41<br>42<br>43 | | ESD Record Types CESD Record Types and Subtypes ESD Processing IDR Processing Processing Object Module END Records Containing IDR Processing Load Module IDRs Processing IDENTIFY Control Statement Data TXT Processing Processing Object Module Text Processing Load Module Text Writing Text on SYSUT1 RLD Processing END Processing Include Processing Automatic Library Call Processing Intermediate Processing | | | ESD Record Types CESD Record Types and Subtypes ESD Processing IDR Processing Processing Object Module END Records Containing IDR Processing Load Module IDRs Processing IDENTIFY Control Statement Data TXT Processing Processing Object Module Text Processing Load Module Text Writing Text on SYSUT1 RLD Processing END Processing Include Processing Automatic Library Call Processing Intermediate Processing Address Assignment | | | ESD Record Types CESD Record Types and Subtypes ESD Processing IDR Processing Processing Object Module END Records Containing IDR Processing Load Module IDRs Processing IDENTIFY Control Statement Data TXT Processing Processing Object Module Text Processing Load Module Text Writing Text on SYSUT1 RLD Processing END Processing Include Processing Automatic Library Call Processing Intermediate Processing Address Assignment | | | ESD Record Types CESD Record Types and Subtypes ESD Processing IDR Processing Processing Object Module END Records Containing IDR Processing Load Module IDRs Processing IDENTIFY Control Statement Data TXT Processing Processing Object Module Text Processing Object Module Text Writing Text on SYSUT1 RLD Processing END Processing Include Processing Automatic Library Call Processing Intermediate Processing Address Assignment ENTAB Size Determination | | | ESD Record Types CESD Record Types and Subtypes ESD Processing IDR Processing Processing Object Module END Records Containing IDR Processing Load Module IDRs Processing IDENTIFY Control Statement Data TXT Processing Processing Object Module Text Processing Object Module Text Writing Text on SYSUT1 RLD Processing END Processing Include Processing Automatic Library Call Processing Intermediate Processing Address Assignment ENTAB Size Determination Entry Processing | | | ESD Record Types CESD Record Types and Subtypes ESD Processing IDR Processing Processing Object Module END Records Containing IDR Processing Load Module IDRs Processing IDENTIFY Control Statement Data TXT Processing Processing Object Module Text Processing Object Module Text Writing Text on SYSUT1 RLD Processing END Processing Include Processing Automatic Library Call Processing Intermediate Processing Address Assignment ENTAB Size Determination Entry Processing | | | ESD Record Types | | | ESD Record Types | | | ESD Record Types CESD Record Types and Subtypes ESD Processing IDR Processing Processing Object Module END Records Containing IDR Processing Load Module IDRs Processing IDENTIFY Control Statement Data TXT Processing Processing Object Module Text Processing Load Module Text Writing Text on SYSUT1 RLD Processing END Processing Include Processing Automatic Library Call Processing Intermediate Processing Address Assignment ENTAB Size Determination Entry Processing Intermediate Output Processing MAP/XREF Processing Second Pass Processing | | | ESD Record Types CESD Record Types and Subtypes ESD Processing IDR Processing Processing Object Module END Records Containing IDR Processing Load Module IDRs Processing IDENTIFY Control Statement Data TXT Processing Processing Object Module Text Processing Load Module Text Writing Text on SYSUT1 RLD Processing END Processing Include Processing Automatic Library Call Processing Intermediate Processing Address Assignment ENTAB Size Determination Entry Processing Intermediate Output Processing MAP/XREF Processing Second Pass Processing | | | ESD Record Types CESD Record Types and Subtypes ESD Processing IDR Processing Processing Object Module END Records Containing IDR Processing Load Module IDRs Processing IDENTIFY Control Statement Data TXT Processing Processing Object Module Text Processing Load Module Text Writing Text on SYSUT1 RLD Processing END Processing Include Processing Include Processing Automatic Library Call Processing Intermediate Processing Address Assignment ENTAB Size Determination Entry Processing Intermediate Output Processing MAP/XREF Processing Second Pass Processing Relocation of Address Constants | | | ESD Record Types CESD Record Types and Subtypes ESD Processing IDR Processing Processing Object Module END Records Containing IDR Processing Load Module IDRs Processing IDENTIFY Control Statement Data TXT Processing Processing Object Module Text Processing Load Module Text Writing Text on SYSUT1 RLD Processing END Processing Include Processing Include Processing Automatic Library Call Processing Intermediate Processing Address Assignment ENTAB Size Determination Entry Processing Intermediate Output Processing MAP/XREF Processing Second Pass Processing Relocation of Address Constants | | | ESD Record Types and Subtypes ESD Processing IDR Processing Processing Processing Object Module END Records Containing IDR Processing Load Module IDRs Processing IDENTIFY Control Statement Data TXT Processing Processing Object Module Text Processing Load Module Text Writing Text on SYSUT1 RLD Processing END Processing Include Processing Automatic Library Call Processing Intermediate Processing Address Assignment ENTAB Size Determination Entry Processing Intermediate Output Processing Second Pass Processing Relocation of Address Constants Relocation of Nonbranch-Type (A-Type) Address Constants | | | ESD Record Types and Subtypes ESD Processing IDR Processing Processing Object Module END Records Containing IDR Processing Load Module IDRs Processing IDENTIFY Control Statement Data TXT Processing Processing Object Module Text Processing Load Module Text Writing Text on SYSUT1 RLD Processing END Processing Include Processing Automatic Library Call Processing Intermediate Processing Address Assignment ENTAB Size Determination Entry Processing Intermediate Output Processing MAP/XREF Processing Relocation of Address Constants Relocation of Branch-Type (A-Type) Address Constants | | | ESD Record Types and Subtypes ESD Processing IDR Processing Processing Object Module END Records Containing IDR Processing Object Module END Records Containing IDR Processing Load Module IDRs Processing IDENTIFY Control Statement Data TXT Processing Processing Object Module Text Processing Load Module Text Writing Text on SYSUT1 RLD Processing END Processing Include Processing Automatic Library Call Processing Intermediate Processing Address Assignment ENTAB Size Determination Entry Processing Intermediate Output Processing MAP/XREF Processing Relocation of Address Constants Relocation of Branch-Type (A-Type) Address Constants | | | ESD Record Types and Subtypes ESD Processing IDR Processing Processing Processing Object Module END Records Containing IDR Processing Load Module IDRs Processing IDENTIFY Control Statement Data TXT Processing Processing Object Module Text Processing Load Module Text Writing Text on SYSUT1 RLD Processing END Processing Include Processing Automatic Library Call Processing Intermediate Processing Address Assignment ENTAB Size Determination Entry Processing Intermediate Output Processing Intermediate Output Processing Relocation of Address Constants Relocation of Monbranch-Type (A-Type) Address Constants Relocation of Branch-Type (V-Type) Address Constants ENTAB Creation | 344412335<br> | | ESD Record Types and Subtypes ESD Processing IDR Processing Processing Object Module END Records Containing IDR Processing Load Module IDRs Processing IDENTIFY Control Statement Data TXT Processing Processing Object Module Text Processing Load Module Text Processing Load Module Text Writing Text on SYSUT1 RLD Processing END Processing Include Processing Automatic Library Call Processing Intermediate Processing Address Assignment ENTAB Size Determination Entry Processing Intermediate Output Processing MAP/XREF Processing Relocation of Address Constants Relocation of Nonbranch-Type (A-Type) Address Constants ENTAB Creation Relocation Routine | | | ESD Record Types and Subtypes ESD Processing IDR Processing Processing Object Module END Records Containing IDR Processing Load Module IDRs Processing IDENTIFY Control Statement Data TXT Processing Processing Object Module Text Processing Load Module Text Processing Load Module Text Writing Text on SYSUT1 RLD Processing END Processing Include Processing Automatic Library Call Processing Intermediate Processing Address Assignment ENTAB Size Determination Entry Processing Intermediate Output Processing MAP/XREF Processing Relocation of Address Constants Relocation of Nonbranch-Type (A-Type) Address Constants ENTAB Creation Relocation Routine | | | ESD Record Types and Subtypes ESD Processing IDR Processing IDR Processing Processing Object Module END Records Containing IDR Processing Load Module IDRs Processing IDENTIFY Control Statement Data TXT Processing Processing Object Module Text Processing Load Module Text Writing Text on SYSUT1 RLD Processing END Processing Include Processing Automatic Library Call Processing Intermediate Processing Address Assignment ENTAB Size Determination Entry Processing Intermediate Output Processing MAP/XREF Processing Relocation of Address Constants Relocation of Branch-Type (A-Type) Address Constant Relocation Routine ENTAB Creation Relocation Routine Final Processing (HEWLFFNL) | | | ESD Record Types and Subtypes ESD Processing IDR Processing Processing Object Module END Records Containing IDR Processing Load Module IDRs Processing IDENTIFY Control Statement Data TXT Processing Processing Object Module Text Processing Upject Module Text Processing Load Module Text Writing Text on SYSUT1 RLD Processing END Processing Include Processing Automatic Library Call Processing Intermediate Processing Address Assignment ENTAB Size Determination Entry Processing Intermediate Output Processing Intermediate Output Processing Relocation of Address Constants Relocation of Nonbranch-Type (A-Type) Address Constant Relocation Relocation Relocation Final Processing (HEWLFFNL) Error Logging | 34433359<br> | | ESD Record Types and Subtypes ESD Processing IDR Processing Processing Object Module END Records Containing IDR Processing Load Module IDRs Processing IDENTIFY Control Statement Data TXT Processing Processing Object Module Text Processing Upject Module Text Processing Load Module Text Writing Text on SYSUT1 RLD Processing END Processing Include Processing Automatic Library Call Processing Intermediate Processing Address Assignment ENTAB Size Determination Entry Processing Intermediate Output Processing Intermediate Output Processing Relocation of Address Constants Relocation of Nonbranch-Type (A-Type) Address Constant Relocation Relocation Relocation Final Processing (HEWLFFNL) Error Logging | 34433359<br> | | ESD Record Types and Subtypes ESD Processing IDR Processing Processing Object Module END Records Containing IDR Processing Load Module IDRs Processing IDENTIFY Control Statement Data TXT Processing Processing Object Module Text Processing Load Module Text Writing Text on SYSUT1 RLD Processing END Processing Include Processing Automatic Library Call Processing Intermediate Processing Address Assignment ENTAB Size Determination Entry Processing Intermediate Output Processing Intermediate Output Processing Relocation of Address Constants Relocation of Branch-Type (A-Type) Address Constants Relocation Routine Final Processing (HEWLFFNL) Error Logging Cross-Reference Table | 344413335<br> | | ESD Record Types and Subtypes ESD Processing IDR Processing Processing Object Module END Records Containing IDR Processing Load Module IDRs Processing IDENTIFY Control Statement Data TXT Processing Processing Object Module Text Processing Load Module Text Writing Text on SYSUT1 RLD Processing END Processing Include Processing Automatic Library Call Processing Intermediate Processing Address Assignment ENTAB Size Determination Entry Processing Intermediate Output Processing Intermediate Output Processing Relocation of Address Constants Relocation of Branch-Type (A-Type) Address Constants Relocation Routine Final Processing (HEWLFFNL) Error Logging Cross-Reference Table | 344413335<br> | | ESD Record Types CESD Record Types and Subtypes ESD Processing IDR Processing Processing Object Module END Records Containing IDR Processing Load Module IDRs Processing IDENTIFY Control Statement Data TXT Processing Processing Object Module Text Processing Load Module Text Processing Load Module Text Writing Text on SYSUT1 RLD Processing END Processing Include Processing Automatic Library Call Processing Intermediate Processing Address Assignment ENTAB Size Determination Entry Processing Intermediate Output Processing Second Pass Processing Relocation of Address Constants Relocation of Branch-Type (A-Type) Address Constants Relocation of Branch-Type (V-Type) Address Constants ENTAB Creation Relocation Routine Final Processing (HEWLFFNL) Error Logging Cross-Reference Table Diagram 1. Overview of Linkage Editor | 34443333344413333544443333354444333444433344443334444333444433444444 | | ESD Record Types and Subtypes ESD Processing IDR Processing Processing Object Module END Records Containing IDR Processing Load Module IDRs Processing IDENTIFY Control Statement Data TXT Processing Processing Object Module Text Processing Load Module Text Writing Text on SYSUT1 RLD Processing END Processing Include Processing Automatic Library Call Processing Intermediate Processing Address Assignment ENTAB Size Determination Entry Processing Intermediate Output Processing Intermediate Output Processing Relocation of Address Constants Relocation of Branch-Type (A-Type) Address Constants Relocation Routine Final Processing (HEWLFFNL) Error Logging Cross-Reference Table | 34443333344413333544443333354444333444433344443334444333444433444444 | | Diagram 4. Input Processing | 79<br>80<br>81<br>82<br>83<br>84<br>85<br>86 | |-----------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------| | Program Organization | 9.9 | | Initial Processor—HEWLFINT (Chart BA) Attributes and Options Processor—HEWLFOPT Allocation Processor—ALLOO1 (Chart BA) | 88 | | Attributes and Options Processor—HEWLFOPT | 88 | | Allocation Processor—ALLOO1 (Chart BA) | 88 | | Table Allocation Processor—HEWLFALK (Chart BB) Input Processor—HEWLFINP (Chart CA) | 89 | | Object Module Processor—HEWLFMDI (Chart CB) | 89 | | Load Module Processor—INP270 (Chart CC) | 90 | | SYM Processor—HEWLFSYM (Chart CD) ESD Processor—HEWLFESD (Chart CE) Text and RLD Processor—HEWLFRAT (Chart CF) Text Processor—HEWLFTX (Chart CG) | 90 | | ESD Processor—HEWLFESD (Chart CE) | 91 | | Text and KLD Frocessor—newletkal (chart Cr) | 91 | | RLD Processor—RLD001 (Chart CJ) | 91 | | RLD Processor—RLD001 (Chart CJ) | 92 | | CSECT Identification Record (IDR) Processor—HEWLFIDR | | | (Chart CQ) | 92 | | Include Processor—HFWI FINC (Chart CI) | 92 | | Automatic Library Call Processor—HEWLCAUT (Chart CV) | 93 | | Intermediate Processing | 9.3 | | Address Assignment Processor—HEWLFADA (Chart DA) Intermediate Output Processor—HEWLFOUT (Chart EA) | 93 | | Socond Pass Processing | 93 | | Second Pass Processing | 94 | | Final Processing | 94 | | Final Processor—HEWLFFNL (Chart GA) | 94 | | SYNAD Routine—HEWLCR01 (Chart GB) | 95 | | Chart AA. Level Major Divisions | 98 | | Chart RR Table Allocation Processor (HFWLFALK) | 100 | | Chart CA. Input Processor (HEWLFINP) | 101 | | Chart CB. Object Module Processor (HEWLFMDI) | 102 | | Chart CB. Object Module Processor (HEWLFMDI) Chart CC. Load Module Processor (INP270) | 103 | | | 104<br>105 | | Chart CF. TXT and RLD Processor (HEWLFRAT) | 108 | | Chart CG. TXT Processor (HEWLFTXT) | 109 | | Chart CH. TXT Write Routine (on SYSUT1) (TXTBUF) | 110 | | Chart CJ. RLD Processor (RLD001) | 111<br>113 | | | 114 | | Chart CM. CSECT Identification Record Processor (HEWLFIDR) | 115 | | Chart CN. IDR Translator Data Processor (HEWLFIDR) | 116 | | Chart CP. IDRSPZAP Data Processor (HEWLFIDR) | 117<br>118 | | Chart CQ. IDR Identify Data Processor (HEWLFIDR) Chart CR. IDR User Data Processor (HEWLFIDR) | 119 | | Chart CS. Control Statement Scanner (HEWLFSCN) | 120 | | Chart CT. READ8 Routine | 122 | | Chart CU. Include Processor (HEWLFINC) | 123 | | Chart CV. Automatic Library Call Processor (HEWLCAUT) | 124<br>126 | | Chart DB. ENTAB Size Determination Routine (HEWLFENS) | 127 | | | 128 | | Chart DC. Entry Processor (HEWLFENT) | 130 | | Chart cd. Mar/ker frocessor (newermar) | 131<br>132 | | Chart EC. IDR WRITE Routine (HEWLFOUT) | 134 | | Chart FB. GETIDMUL Routine | 136 | | Chart FC. TXT Read Routine (RDTXT), RLD Read Routine | | | (RDRLD)—HEWLFSIO | 137 | | Chart FD. Text Write Routine (on SYSLMOD) | | | | | | |------------------------------------------------|---|---|---|---|-------| | (WRTTXT)—HEWLFSIO | | • | • | • | . 138 | | Chart FE. Relocation Routine (HEWLFREL) | | | | | | | Chart GA. Final Processor (HEWLFFNL) | | | | | | | Chart GB. SYNAD Routine (HEWLCRO1) | • | • | | • | . 143 | | Chart GC. Error Logging Routine (HEWLFLOG) | • | • | • | • | . 144 | | Microfiche Directory | • | • | • | • | . 145 | | Table Layouts | • | • | • | • | . 150 | | Diagnostic Aids | • | • | • | • | . 183 | | Appendix. Input Conventions and Record Formats | • | • | • | • | . 194 | | Input Conventions | • | • | • | • | . 194 | | Record Formats | • | • | • | • | . 195 | | Index | • | | | | . 207 | # **FIGURES** | 1. | Linkage Editor Processing—Simple Case | 3 | |------------|--------------------------------------------------------|-----| | 2. | Combining Control Dictionaries | 5 | | 3. | Linkage Editor Processing for the Overlay and TEST | _ | | ٠. | Attributes | 9 | | 4. | Attributes | , | | ٦. | Attaching | 11 | | | Attribute | 11 | | 5. | Input/Output Flow | 13 | | <u>6</u> . | Incompatible Module Attributes and Program Options . | 20 | | 7. | Control Statement Scanner Operation | 24 | | 8. | INCLUDE Statement Processing for a Sequential Data Set | 25 | | 9. | INCLUDE Statement Processing With Nested Members | 26 | | 10. | Overlay Statement Processing | 27 | | 11. | Order and Page Processing | 29 | | 12. | Library Statement Processing | 30 | | 13. | Library Statement Processing | 31 | | 14. | Thrut Popular Types—Load Module | 3 3 | | 15. | Input Record Types—Load Module | 33 | | | Deneral Register Information—Load Module Processing | 33 | | 16. | RLD Flag Field Processing | 46 | | 17. | Include Processing | 49 | | 18. | Automatic Library Call Processing | 51 | | 19. | ENTAB Size Determination | 55 | | 20. | Processing of Alias Symbols by the Entry Processor . | 57 | | 21. | Writing Scatter/Translation Records | 58 | | 22. | Nonbranch-Type Address Constants—Relative Relocation | 62 | | 23. | Nonbranch-Type Address Constants—Absolute Relocation | | | 24. | Nonbranch-Type Address Constants—Absolute and Relative | | | | Relocation | | | 25. | Example of Delinking | | | 26. | Example Oi Delinking | 67 | | | Entry List Processing | 0/ | | 27. | Relationship of KLD Flag Field to Relocation | 69 | | 28. | ENTAB Creation | 70 | | 29. | Building Error Messages | 73 | | 30. | Load Module Record Types and Associated Processors . | 90 | | 31. | Linkage Editor Organization | 96 | | 32. | Sample Flowchart Symbols | 97 | | 33. | Microfiche Directory | 145 | | 34. | Module/CSECT Cross-Reference Table | 149 | | 35. | Table Construction and Usage | 150 | | 36. | Table Construction and Usage | 151 | | 37. | Ali urpose lable (Ali) | 161 | | | Alias Table | | | 38. | Calls List (As built by RLD Processor) | TOT | | 39. | Calls List (As Altered and Used by ENTAB Size | | | | Determination Routine) | 161 | | 40. | Composite External Symbol Dictionary (CESD)—Internal | | | | Format | 162 | | 41. | Format Normal Combination of Internal CESD Types | 163 | | 42. | Delink Table | 164 | | 43. | Downward Calls List | 164 | | 44. | Entry List | 165 | | 45. | Entry Table (FNTAB) | 165 | | 46. | Entry Table (ENTAB) | 166 | | 47. | High ID Table (HIID) | 167 | | 48. | Virtual Storage Allocation Table | 168 | | | Postitional Openinting Disasters Post Africa | 100 | | 49. | Partitioned Organization Directory Record (As Received | 140 | | | from BLDL) | 169 | | 50. | Module Attributes | 170 | | 51. | Partitioned Organization Directory Record (As Built by | | | | Linkage Editor) | 172 | | 52. | Relocation Constant Table (RCT) | 173 | | 53. | Renumbering Table (RNT) | 173 | | 54. | RLD Input Control Block | 174 | | 55. | RLD Output Control Block | 175 | | 56. | RLD Note List | 176 | | 57. | Second Pass Text Control Block | 177 | | 58. | Segment Length Table (SEGLGTH) | 178 | | 59. | Segment Table (SEGTAB) | 179 | | 60. | TABLE and LIST (Referred to by HEWLFBTP) | 180 | | 61. | Text I/O Table | 180 | | | | | 1 | 62. | Text Note List | | | . 181 | |-----|-------------------------------------------------|---|---|-------| | 63. | XAD2CESD Table (Built and Referred to by | | | | | | Cross-Reference Table Routine) | _ | _ | . 181 | | 64. | ORDER Table (Built by HEWLFSCN) | • | - | . 182 | | 65. | General Register Contents at Major Entry Points | | | | | 66. | | | | | | | | | | | | 67. | Table Allocation | • | • | | | 68. | Error Message/Issuer Cross-Reference Table . | | | . 189 | | 69. | SYM Input Record (Card Image) | | | . 195 | | 70. | ESD Input Record (Card Image) | | | . 196 | | 71. | Text Input Record (Card Image) | | | . 197 | | 72. | RLD Input Record (Card Image) | | | . 197 | | 73. | END Input Record—Type 1 (Card Image) | | | . 198 | | 74. | END Input Record—Type 2 (Card Image) | | | | | 75. | IDR Data in an Object Module End Record | | | | | | | | | | | 76. | SYM Record (Load Module) | | | | | 77. | CESD Record (Load Module) | • | • | | | 78. | Scatter/Translation Record | | | . 201 | | 79. | Control Record (Load Module) | _ | _ | . 202 | | 80. | Relocation Dictionary Record (Load Module) . | | | | | | | | | | | 81. | Control and Relocation Dictionary Record (Load | | | | | 82. | Record Format of Load Module IDRs | • | • | . 204 | | | | • | |--|--|---| | | | ) | | | | 3 | # INTRODUCTION This section describes the purpose, organization, and internal operation of the linkage editor, and its relationship to the operating system. # PURPOSE OF LINKAGE EDITOR The linkage editor is one of the processing programs of the operating system. It is a service program used in conjunction with the language translators to prepare machine-language programs from symbolic-language programs written in FORTRAN, COBOL, report program generator, assembler language, or PL/I. Linkage editor processing is a necessary step that follows source program assembly or compilation. Linkage editor processing allows the programmer to divide a program into several parts, each containing one or more control sections. Each part may then be coded in the programming language best suited to it and may then be separately assembled or compiled by a language translator (under the rules applicable to each language translator). The primary purpose of the linkage editor is to combine and link object modules (the output of the language translators) into a load module. In that load module, all cross-references between control sections are resolved as though they had been assembled or compiled as one module. The load module produced by the linkage editor consists of executable machine-language code in a format that can be loaded into virtual storage and relocated by program fetch. In addition to combining and linking object modules, the linkage editor performs the following functions: - <u>Library Calls</u>. Modules (such as standard subroutines) stored in a library can be placed in the input to the linkage editor, either automatically or upon request. If unresolved external references remain after all input to the linkage editor is processed, an automatic library call routine retrieves the modules required to resolve the references. However, unresolved external references marked "weak call" or "never call" are not resolved by this routine. - Program Modification. Control sections can be replaced, deleted, or rearranged (in overlay programs) during linkage editor processing, as directed by linkage editor control statements. Common control sections generated by the FORTRAN, PL/I, and assembler language translators are provided locations within the output load module. - Order and Page Support. The linkage editor can order control sections in the sequence specified on the linkage editor control statements, and can assign control sections to page boundaries according to the control statements. - Addressing Mode, Residence Mode, and Read-Only Support. The linkage editor assigns an addressing mode for the entry points into a load module, assigns a residence mode for the load module, and indicates which control sections are read-only in a nucleus load module. - Program Processing History. CSECT identification records built during linkage editor processing contain data describing the language translators and the linkage editor that produced the program, any modifications to that program by AMASPZAP, and, optionally, up to 40 characters of user data for each control section within the program. - Overlay Module Processing. The linkage editor prepares modules for overlay by assigning relative locations within the module to the overlay segments and by inserting tables to be used by the overlay supervisor during execution. - Options and Error Messages. The linkage editor can: - Process special options that override automatic library calls or the effect of minor errors - Produce a list of linkage editor control statements that were processed - Produce coded diagnostic messages and a directory describing those diagnostic messages that were printed out during linkage editor processing - Produce a module map or cross-reference table of control sections in the output load module #### RELATIONSHIP TO THE OPERATING SYSTEM The linkage editor has the same relationship to the operating system as any other processing program. Control is passed to the linkage editor in one of three ways: - As a job step, when the linkage editor is specified on an EXEC job control statement in the input stream - As a subprogram, via the execution of a CALL macro instruction (after execution of a LOAD macro instruction), a LINK macro instruction, or an XCTL macro instruction - As a subtask, in multitasking systems, via execution of the ATTACH macro instruction ## GENERAL DESCRIPTION Linkage editor input may consist of a combination of object modules, load modules, and linkage editor control statements. The prime function of the linkage editor is to combine these modules, in accordance with requirements stated on control statements, into a single output load module that can be relocated and loaded into real storage by program fetch for execution. Output load modules are placed into partitioned data sets (libraries). Each module to be processed by the linkage editor has an origin that was assigned during assembly, during compilation, or during a previous execution of the linkage editor. Each module in the input to the linkage editor may contain symbolic references to control sections in other modules; such references are called external references. To produce an executable output load module, the linkage editor: - 1. Assigns relative virtual storage addresses to the control sections to be included in the output module. Because each input module has an origin that was assigned independently by a language translator, the order of the addresses in the input is unpredictable. (Two input modules, for example, may have the same origin.) The linkage editor assigns an origin to the first control section and then assigns addresses to all other control sections in the output relative to either this origin or to the last control section aligned on a page boundary. - 2. Resolves external references in the input modules. Cross-references between control sections in different modules are symbolic, and must be resolved (translated into relocatable machine addresses) in relation to the contiguous virtual storage addresses assigned to the output load > module. These symbolic cross-references are made by means of address constants. The linkage editor calculates the new address of each relocatable expression in a control section and determines the assigned origin (value) of the item to which it refers. Linkage editor processing is affected by specified options, operations requested on control statements, module attributes contained in partitioned data set directories, and control information contained within the modules themselves. The following paragraphs describe the relationship of module structure, linkage editor options, and module attributes to linkage editor processing. #### MODULE STRUCTURE Object modules and load modules have the same basic logical structure (see Figure 1). Each consists of: - Control dictionaries, containing the information necessary to resolve symbolic cross-references between control sections of different modules, and to relocate address constants - Text, containing the instructions and data of the program - An end of module (EOM) indicator (END record in object modules; EOM indication in load modules) Figure 1. Linkage Editor Processing—Simple Case Each language translator usually produces two kinds of control dictionaries: an external symbol dictionary (ESD) and a relocation dictionary (RLD). An object module always contains an ESD; a load module contains an ESD unless it is marked with the "not editable" attribute. Object and load modules usually contain an RLD (unless there are no relocatable address constants in the module). Control dictionary entries are generated when external symbols, address constants, or control sections are processed by a language translator. ## External Symbol Dictionary An external symbol dictionary contains entries for all external symbols defined or referred to within a module. (An external symbol is one that is defined in one module and can be referred to in another.) Each entry identifies a symbol, or a symbol reference, and gives its location, if any, within the module. When combining input modules, the linkage editor resolves references between different input modules by matching the referenced symbols to defined symbols; it does this by searching for the external symbol definitions in each input module's ESD. There is an ESD entry for each named control section and each named common area. The ESD also contains entries that identify unnamed control sections and unnamed common areas. ## Relocation Dictionary The relocation dictionary (RLD) lists all relocatable address constants that must be modified when the linkage editor produces an output load module. The linkage editor uses the RLD whenever it processes a module. The RLD is also used to adjust the value of address constants after program fetch reads an output load module from a library and loads it into virtual storage for execution. The RLD contains at least one entry for every relocatable address constant in a module. An RLD entry identifies an address constant by indicating both its location within a control section and the external symbol (in the ESD) whose value must be used to compute the value of the address constant. # Composite Dictionaries An output load module is composed of all input object modules and input load modules processed by the linkage editor (except those that are replaced or deleted). The control dictionaries of an output module are therefore a composite of all the control dictionaries in the linkage editor input. The control dictionaries of a load module are called the composite ESD (CESD) and the RLD. Figure 2 on page 5 shows how the control dictionaries of two input modules are combined into composite dictionaries by the linkage editor. The control dictionaries and their associated text are interrelated through a system of line numbers and pointers. Within an input module, each ESD item on which an address constant may depend has a line number (ESD identifier, or ESD ID); the line number indicates the position of the item, relative to the other ESD items associated with the text. Every item of text in an object or load module has associated control information that describes it. This control information includes the ESD ID of the ESD item for the control section that contains the text. (In Figure 2, the ESD ID of the text item that contains X and Y points to line 1 of the ESD for input module 1. The ESD ID of the text item containing Z points to line 1 of the ESD for input module 2.) Each RLD item must point to two ESD items: - The ESD item for the symbol on which the address constant depends. This is referred to by the RLD <u>relocation pointer</u> (R pointer). - The ESD item for the control section that contains the address constant. This is referred to by the RLD position pointer (P pointer). In an object module, one type of ESD item (ID) may have associated text or address constants that depend on it (see "ESD Processing"). Such ESD items are excluded from the numbering system. Figure 2. Combining Control Dictionaries In input module 1, X and Y are address constants in the same control section (CSECT A). X refers to a symbol in CSECT A; therefore, both pointers of its associated RLD item refer to the ESD entry for CSECT A (line 1). The value field of Y refers to a symbol in a different control section (CSECT C); therefore, the R pointer of its associated RLD points to the ESD entry for the external reference (line 2), whereas the P pointer refers to the ESD entry for its control section (line 1). When the linkage editor combines the input modules, it must maintain this system of pointers by renumbering the ESD items to reflect their relative positions in the CESD of the output module. It must also update the RLD pointers and control information for the text so that they refer to the renumbered CESD items; the resulting CESD and RLD items are shown in Figure 2. ## LINKAGE EDITOR OPTIONS Options for error diagnostics, processing, and space allocation may be specified by parameters listed on the EXEC card, or they may be passed internally by a program requesting the linkage editor via LINK, LOAD, ATTACH, or XCTL macro instructions.<sup>2</sup> If the options are passed internally, the user can also provide alternates for the standard ddnames.<sup>3</sup> If the For more information, see <u>JCL</u>. For more information, see <u>Data Management Services</u> and <u>Data</u> Management Macro Instructions. options are not user-specified, the defaults are used. The options that may be specified are as follows: - LIST. A list of all linkage editor control statements is written on the diagnostic output data set. - MAP. A module map, which lists external names and their storage addresses, is written on the diagnostic output data set. - <u>Cross-reference table (XREF)</u>. A cross-reference table, which includes a module map and a list of all address constants that refer to other control sections, is written on the diagnostic output data set. - <u>TERM</u>. Error messages are directed to the terminal data set as well as to the diagnostic output data set. - <u>LET</u>. The output module is marked as executable even though a severity 2 error condition was found during processing. - <u>Exclusive call (XCAL)</u>. The output module is marked as executable even though valid exclusive references between overlay segments have been made. - <u>No automatic library call (NCAL)</u>. The automatic library call mechanism is not to be invoked to resolve external references. - <u>SIZE (value 1, value 2)</u>. The user can supply two values to specify the maximum amount of storage to be obtained for linkage editor processing and what amount of the gotten storage is to be used as the load module buffer. - <u>DCBS</u>. The linkage editor initialization routine examines the SYSLMOD DD statement for a DCB BLKSIZE parameter and uses that value, if it is acceptable, for its block size limit. If the DEVTYPE capacity is less than the specified block size, the DEVTYPE value is used. # MODULE ATTRIBUTES When the linkage editor generates a load module in a library partitioned data set (PDS), it places an entry for the module in the PDS directory. This entry contains "attributes" describing the structure, content, and logical format of the load module. The control program uses these attributes to determine how a module is to be loaded, what it contains, whether or not it is executable, whether it is executable more than once without reloading, and whether it can be executed by concurrent tasks. Some options for module attributes can be specified by the user; others are specified by the linkage editor as a result of information gathered during processing. In the following list, attributes marked with an asterisk (\*) cannot be specified by the user. - <u>Reenterable (RENT)</u>. A reenterable module can be executed by more than one task at a time and cannot be modified by itself or by any other module during execution; that is, a task may begin executing a reenterable module before a previous task has finished executing it. - <u>Refreshable (REFR)</u>. A refreshable module cannot be modified by itself or by any other module during execution. A refreshable module can be replaced by a new copy during execution by a recovery management routine without changing either the sequence or results of processing. - <u>Serially reusable (REUS)</u>. A serially reusable module will be executed by only one task at a time, and will either initialize itself and/or will restore any instructions or any data in the module that it alters during its execution. - Overlay format (OVLY). A load module structured for overlay includes a segment table (SEGTAB) to enable the overlay supervisor to load the proper segments, and at least one ENTAB to assist in passing control from one segment to another. If a load module has the overlay format attribute, the reenterable, reusable, refreshable, hierarchy, scatter, addressing mode, and residence mode attributes cannot be present. - Hierarchy format (HIAR). When a HIARCHY statement is detected, the "number" and "name" operand values are used in building the scatter table and the translation table. The high-order byte of each CSECT address entry contains the hierarchy number that is included in the GETMAIN request for main storage for program loading. Hierarchy information is used only when the program is loaded under the OS system. - <u>Test (TEST)</u>. If this module is an assembler language program and testing by the test translator or the TSO TEST command is desired, this attribute can be specified. Test will cause SYM records to be written. Note that modules using TESTRAN should not be marked with the RENT, REUS, or REFR attribute. - Only loadable (OL). This attribute indicates that the control program may load this module only through the execution of the LOAD macro instruction. - <u>Scatter format (SCTR)</u>. In the OS environment, a load module in scatter format is suitable for block or scatter loading. The scatter table, translation table, and the relocation dictionary maintain logical linkage between scattered control sections when program fetch loads them into storage. In the virtual storage environment, the scatter format is ignored by program fetch. The SCTR attribute is, however, relevant in the link-editing of a nucleus for a virtual storage system, which requires the scatter and translate tables for its proper initialization. - <u>ALIGN2</u>. If the ALIGN2 attribute is present, all control sections or named common areas specified on the PAGE control statements are placed in storage on 2K-byte page boundaries. The ALIGN2 attribute also aligns on 2K-byte page boundaries those control sections or named common areas associated with the "P" operand on the ORDER control statement. - \*Block format. If neither the overlay nor scatter attributes are specified, it is implied that the module can only be block loaded. The control program will load the module only if enough contiguous storage is available for the entire module. - \*Executable. This attribute indicates that linkage editor did not find any errors that would prevent successful execution. If this attribute is not present, the control program will not load the module. - \*Module contains one text record and no relocation <u>dictionary records</u>. This attribute indicates that the control program does not have to allocate storage for relocation dictionary items when loading the module. also indicates that the first text record is the last one; there is no control record following it. The entire module can be read by program fetch in a single read operation. - $\underline{\text{Downward compatible (DC)}}$ . This attribute indicates that the module can be processed by either the level E or level F linkage editor. The downward-compatible attribute is assumed by the level E linkage editor. Modules processed by the level F linkage editor that are not marked "downward compatible" cannot be processed by the level E linkage editor. - \*Linkage editor assigned origin of first text record is zero. If this attribute is present, the first byte of instruction or data in the first text record is assigned to location zero. - <u>\*Entry point assigned by linkage editor is zero</u>. This attribute indicates that the entry point is at the first byte of the module. - <u>\*No relocation dictionary items present</u>. This attribute indicates to the control program that no allocation of storage is necessary to receive relocation dictionary items when program fetch loads them into virtual storage. - <u>Not editable (NE)</u>. This attribute indicates that the load module cannot be accepted by the linkage editor for subsequent processing. The CESD from an output load module is dropped to conserve space on the library. - <u>\*Symbol statements present</u>. If a module produced by the assembler language translator is to be tested by the test translator (TESTRAN) or the TSO TEST command, it may contain a testing symbol dictionary. In a load module, this dictionary contains the information from the SYM statement images that were in the input to the linkage editor. - <u>Authorization Code (AC)</u>. The output load module is assigned an authorization code that determines whether or not the load module may use restricted system services and resources. - Addressing Mode (AMODE). The entry points—either main, true alias, or alternate—into the output load module are assigned the addressing mode that is to be in effect when the load module is entered at those entry points. - <u>Residence Mode (RMODE)</u>. The output load module is assigned the residence mode that applies to that load module when it is loaded into virtual storage for execution. - \*Read-Only Control Section. "Read-only" is an attribute of a control section deliberately created as such by specification of the control section as an RSECT to the language translator. The attribute is effective only when the control section is included in the nucleus load module for an MVS/XA system; otherwise it is ignored. The attribute is obtained from the ESD entries for the read-only control sections and is reflected in the scatter table entries for those control sections in the nucleus load module. # LINKAGE EDITOR PROCESSING FOR ATTRIBUTES Several examples are given here of how linkage editor processing is affected by attributes specified by the user. Figure 1 on page 3 shows a simple case in which a single object module, containing only one control section, is processed by the linkage editor for block loading. Figure 3 on page 9 shows the processing of an object module and a load module, each containing several control sections. In this example, test translator macro instructions were included in an assembler language source program and test symbol (SYM) records were produced by the assembler language translator. The TEST and OVLY attributes were specified in the control information passed to the linkage editor, and overlay control statements were included in the input to the linkage editor. With these attributes, the output load module produced by the linkage editor contains: <u>SYM records to be used by the test translator</u>. (If the TEST attribute is not specified, input SYM records are not included in the output load module.) These records contain > blocked SYM and ESD statements created during a previous execution of the linkage editor. SYM records in load modules are passed unmodified through the linkage editor to the output load module. <u>A composite ESD</u>. CESD records contain the ESD items for the module. There is a maximum of 15 ESD items per record on the output record. The first 8 bytes of the CESD record contain control information pertaining to the ESD items in the record. This information consists of the ESD ID of the first ESD item and the number of bytes of ESD items in the record. Figure 3. Linkage Editor Processing for the Overlay and TEST Attributes - <u>CSECT Identification Records (IDR)</u>. The IDRs are input freeither an input load module, an END record, or the linkage editor IDENTIFY control statement. IDRs may contain data: The IDRs are input from - Identifying the language translator creating the control section, its level, and the translation date - Describing the most recent processing by the linkage editor - Describing any modification to the executable code of a control section Supplied by a user and associated with the executable code of a control section **Note:** The user-supplied data is specified on the IDENTIFY control statement. - A control record, or a composite control/RLD record, preceding each text record. The RLD portion, if present, contains the RLD items used to relocate the previous text.<sup>4</sup> The control portion may contain: - An end of segment (EOS) indication, if the following text record is the last text record of an overlay segment.<sup>5</sup> - An end of module (EOM) indication, if the following text record is the last text record of the module.<sup>5</sup> - The number of bytes of RLD information that follow, if it is a composite control/RLD record. - The number of bytes of control information. The control portion also contains the IDs and lengths (in bytes) of all the control sections in the following text, to a maximum of 60, and a channel command word (CCW). The channel command word contains the address assigned by the linkage editor to the first byte of that record, plus the total length of the record. This information is used by program fetch to read the following text. Note: The control portion contains as many IDs and lengths as there are control sections in the following text record. <u>Text for each control section</u>. Text records contain the instructions and data for the module. In overlay, the linkage editor produces two special types of text records, the segment table (SEGTAB) and entry table (ENTAB). SEGTAB, located in the root segment, is used by the overlay supervisor to keep track of the relationship of segments during execution. ENTAB is a separate control section that may be created by the linkage editor for each overlay segment. ENTAB is used by the overlay supervisor to determine the segment to be loaded when a segment not in the current path is referred to. <u>A note list</u>. A note list gives the location of each overlay segment in the output module library. If there are many RLD items for the previous text, there may be several RLD records preceding the next text record. The last of these is a control/RLD record. If there are no RLD items for the last text record, the control record that precedes the text contains the EOS or EOM indication. If there are RLD items, the EOS or EOM follows the text record (see Figure 3 on page 9). Figure 4. Linkage Editor Processing for the Scatter Load and TEST Attribute Figure 4 shows the module structure when the scatter load and TEST attributes are requested. With these attributes, the output load module contains: - SYM records - A composite ESD - IDR records - A scatter/translation record used by program fetch to compute the relocated addresses required for scatter loading the module into storage. The record contains a scatter table and a translation table. The scatter table is a list of control section addresses; the translation table correlates the CESD entry for each control section with the address indicated in the scatter table. (When a load modul in scatter format is processed again by the linkage editor, this information is ignored.) (When a load module - Text for each control section, preceded by a control or control/RLD record describing it. - RLD or control/RLD records containing any RLDs pertaining to the preceding text record. - An EOM indication that marks the end of the module. The appendix "Input Conventions and Record Formats" contains the format of each record type. # INPUT/OUTPUT FLOW Four data sets must be specified for linkage editor processing; their ddnames and functions are: SYSLIN. This is the "primary input data set," containing object modules and control statements. All input from SYSLIN must be in 80-column card image format, unblocked or blocked from 1 to 40 records per block. The SYSLIN source may be a card reader, magnetic tape, a direct access device, or a concatenation of data sets from different types of input devices. - 2. SYSPRINT. This is the "diagnostic output data set." Diagnostic messages as well as any diagnostic options requested, such as a module map or cross-reference table, are written on SYSPRINT. It is a sequential data set and may be partitioned. The SYSPRINT device may be a printer, magnetic tape, terminal, or a direct access device. - SYSUT1. This is the "intermediate data set." The linkage editor uses this data set for temporary storage of text and RLD items being processed. SYSUT1 must be on a direct-access volume. Note: SYSUT1 is opened only when twopass processing is in effect. 4. <a href="SYSLMOD">SYSLMOD</a>. This is the "output module data set." It is a partitioned data set on a direct-access volume. SYSLMOD contains load modules; their attributes are described in the user's portion of the directory entry for the member. Two additional data sets may be specified for linkage editor processing; their ddnames and functions are: - SYSTERM. This is the "terminal data set." Diagnostic messages are written on SYSTERM if the TERM option was specified. When the linkage editor is being executed in the time-sharing foreground, the SYSTERM device is always the terminal; when the linkage editor is being executed in the background, the SYSTERM device may be a printer, magnetic tape, or a direct-access device. - <u>SYSLIB</u>. This data set is used by the linkage editor if there are any automatic library calls to be processed. SYSLIB can be defined only as a partitioned data set (PDS). The members of SYSLIB can be either load modules or object modules (but object modules and load modules cannot be contained in the same PDS and a data set containing load modules cannot be concatenated with a data set containing object modules). When SYSLIB is opened, the linkage editor determines whether the PDS contains object or load modules by checking the record format field (RECEM) in the data control block (DCB). (The format is fixed (F) for object modules and undefined (U) for load modules. Load module records are of variable length.) If SYSLIB contains object modules, the linkage editor ignores the user's portion of the PDS directory entries for the object modules. Other data sets may be read by linkage editor when it processes INCLUDE or LIBRARY statements specifying ddnames. Data sets referenced with INCLUDE statements may be either sequential or partitioned. SYSLIB and any data sets specified in LIBRARY statements for use by automatic library call must be partitioned. The attributes for the "execute linkage editor" job step are the attributes specified on the EXEC statement. These attributes may be modified if a load module having different attributes is processed. Figure 5 on page 13 shows the input/output flow. During the initial processing, SYSLIN, SYSPRINT, SYSLMOD, and SYSTERM (if the TERM option was specified) are opened. During input processing, the primary input is read from SYSLIN. If an INCLUDE statement is read in the primary input, the data set whose ddname is specified on the statement is opened, and is processed. At the end of all SYSLIN input, SYSLIB and any other data sets whose ddnames are specified on LIBRARY statements are processed through automatic library calls. Figure 5. Input/Output Flow If the TEST attribute has been selected, SYM records are written during input processing; text and RLD items are written sequentially on SYSUT1, except during single pass processing. The location of each text record on SYSUT1 is entered in a <u>text</u> note list. The location of each RLD record on SYSUT1 is entered in a <u>RLD note list</u>. If either note list overflows, it is written out on SYSUT1. The RLD note list may overflow 3 times, the text note list may overflow 11 times. In intermediate processing, the CESD is written on SYSLMOD. If a scatter table, translation table, or SEGTAB is required, it is also written on SYSLMOD. The note list for the text and RLD items on SYSUT1 are read into storage. If a module map was required, the CESD is used in producing the map. If a cross-reference table was requested and all RLDs are in storage, the table is produced during intermediate processing. During second pass processing, text and RLD records are read into storage from SYSUT1 in the order of assigned addresses within each segment (using the note lists to find the records) and are written out on SYSLMOD. In final processing, the member name and any alias names are entered into the PDS directory entry for the output load module through the execution of the STOW macro instruction. If any coded diagnostic messages were written on SYSPRINT during > linkage editor processing, a diagnostic message directory containing error message text is written out on SYSPRINT. cross-reference table was requested and was not produced during intermediate processing. SYSLMOD is opened for input, RLDs are read, and the cross-reference table is produced. At the end of final processing, SYSLMOD is closed (if it was opened for input). All other data sets are then closed and control is returned to the calling program, unless the SYSLIN input during input processing was terminated by a NAME statement. If a NAME statement terminated the primary input, control is returned to initial processing and SYSLMOD is opened for output, if it had been closed during final processing. When multiple load modules are produced in a single execution of the linkage editor, SYSLIN, SYSPRINT, and SYSUT1 remain open for the entire execution. (A pointer in the DCB for SYSUT1 is repositioned to the beginning of the extent of SYSUT1 after each load module is produced.) If neither a module map nor a cross-reference table is requested, or if a cross-reference table is requested and all RLDs are in storage, SYSLMOD remains open for output for the entire linkage editor execution. ## METHOD OF OPERATION This section contains an introduction to the logic of the linkage editor, emphasizing the flow of primary data and control information through tables and buffers, and functional descriptions of its phases. #### LOGIC OF THE LINKAGE EDITOR The linkage editor can be functionally divided into five phases: - Initialization - Input (first pass) processing - Intermediate (first pass) processing - Second pass processing - Final processing Operation diagrams at the end of this section illustrate the functional operation of the linkage editor. The shaded areas of the diagrams correspond to operations described in the text. # Initialization When the linkage editor receives control from the job scheduler or a calling program, it performs initialization functions in preparation for all subsequent processing (see Diagram 3). The operations included in initialization are: - Build the <u>all-purpose table</u> (APT) and enter addresses and descriptions of all other tables and buffers into it. - Analyze the attributes and options passed by the calling program (specified by the programmer) and save them in the all-purpose table. - Initialize DCBs and open data sets to be used during linkage editor processing. - Allocate storage for all tables, buffers, and work areas to be used by linkage editor processing. When all initialization functions are completed, the linkage editor is ready to accept input. # Input Processing All linkage editor input is processed initially during the first pass (see Diagram 4). Object modules from SYSLIN (primary input data set) are read into the <u>SYSLIN buffer</u>. Object modules from SYSLIB or a specified user's library (secondary input data sets) are read into the <u>object module buffer</u>. Text records in load modules from SYSLIB or a user's library are read into the <u>input text buffer</u>; all other load module records are read into the first pass RLD buffer. The various records that constitute these modules are processed as follows. Control Statements: These records, which may precede or follow object modules, contain information that is later used in symbol resolution and that specifies libraries containing secondary input. Depending on the type of control statement, entries are made in either the <u>all-purpose table</u> (APT) or the <u>composite</u> <u>external symbol dictionary</u> (CESD). <u>ESD Records</u>: These records from object modules, and CESD records from load modules, describe symbols that have been defined for external use. Entries for the symbols are made in the CESD. Entries are made in the <u>renumbering table</u> to allow the translation of the input ESD identifiers (IDs) into new CESD IDs. Entries are made in the <u>delink table</u> for symbols that are to be deleted or replaced. TXT Records: These records, containing the instructions and data of the program, are moved from the SYSLIN buffer and object module buffer to the input text buffer (text records from load modules are read directly into the input text buffer). They are arranged in the proper sequence and recorded in the text I/O table and the text note list. When the input text buffer is filled, its contents are written onto SYSUT1; if it does not become filled, text records are retained in the buffer, and "single pass" processing is in effect. Text note list entries contain the location of text records (SYSUT1 address or buffer address) and other descriptive information. Text I/O table entries contain information identifying text records by ESD ID. RLD Records: These records, to be used later in relocating address constants, are moved from the SYSLIN buffer and object module buffer to the RLD buffer. The relocation and position pointers (R and P pointers) are updated, using control information from the renumbering table and the delink table. RLD items are examined and marked for future processing. If V-type (branch-type) address constants are found in overlay programs, entries are made in the call list for use during intermediate processing. When the RLD buffer is full, RLD records are written on SYSUT1, and control information identifying RLD records by size (byte count), P pointer, and location on SYSUT1 is entered in the RLD note list. If the RLD buffer does not become filled, RLD records are retained in the buffer and single pass processing is in effect. SYM Records: These records, which are not involved in linkage editor processing, are gathered in the RLD buffer and are written directly on SYSLMOD, if the TEST attribute has been specified. If TEST has not been specified, SYM records are ignored. <u>IDR Records</u>: These records, which contain data either from an input load module or from an END record or from the linkage editor IDENTIFY control statement, supply information concerning the processing history of the modules in which the IDRs occur. If the data is from an input load module, control is passed to the IDR processor HEWLFIDR. If the data is from an END record, the data refers to the compiler that created the object module. The compiler or translator data is passed in a parameter list to the IDR processor. The user data, supplied via the linkage editor IDENTIFY control statement, is converted into a parameter list and passed to the IDR processor. When all input records have been processed (all external symbols have been entered into the CESD), control is passed to intermediate processing. ## Intermediate Processing The operations included in intermediate processing (see Diagram 5) have two primary objectives: (1) to assign relative storage addresses to symbols in the CESD, and (2) to write some of the records to be included in the output load module on the SYSLMOD data set. The MAP and XREF options may also be processed during intermediate processing. Address Assignment: Entries that require no further processing are deleted from the CESD; all other CESD symbols are assigned temporary linked addresses. Relocation constants are determined for all control sections, and the relocation constant table (RCT) is built. > For all programs in overlay, additional processing is required. The calls list is used to determine ENTAB entries to be placed in the CESD, and the <u>downward calls list</u> is built. The <u>segment</u> <u>length table</u> (SEGLGTH) is built, and segment relocation constants are computed. Temporary linked addresses in the CESD and entries in the relocation constants are computed. Temporary linked addresses in the CESD and entries in the relocation constant table are adjusted for overlay by adding to them the segment relocation constants. > Temporary linked addresses and relocation constants are combined to determine final linked addresses for symbols, and the results are placed in the CESD. The alias table is built from alias symbols in the CESD. At this point, CESD processing is complete. > MAP/XREF Processing: If the MAP option has been specified, a module map, containing sorted CESD items, is built and written on SYSPRINT. If the XREF option has been specified and all RLDs are in storage, a <u>cross-reference table</u> is built from RLDs (in the RLD buffer) and written on SYSPRINT. If all RLDs are not in storage, the cross-reference table is not built, but is deferred until final processing. > <u>Intermediate Output</u>: The principal function of this section of intermediate processing is to write the CESD on the <u>output load</u> module data set (SYSLMOD). The <u>half ESD</u> (HESD), containing control information from CESD entries, is built and held in storage for use during second pass processing. The text I/O The text I/O table is reorganized according to the sequence in the order table and scanned to determine the ID of the last control section containing text in the program (or in each segment of an overlay program); this information is placed in the $\underline{\text{high ID}}$ table (HIID), and noted in the HESD for use during second pass processing. For a program in overlay, the segment table (SEGTAB), which defines the relationships among segments, is built and written (with a control record) on SYSLMOD. For a program that is to be scatter loaded in the OS environment (MFT or MVT), a <u>scatter table</u> and a <u>translation table</u> are built from information in the CESD, and scatter/translation records are written on SYSLMOD. The IDRs are written out on the output load module data set (SYSLMOD). #### Second Pass Processing The objectives of second pass processing (see Diagram 6) are relocating address constants in the text and writing on the SYSLMOD data set the remaining records that constitute the output load module. Text records are read from **SYSUT1** (intermediate data set) into the second pass text buffer, using the $\underline{\text{text I/O}}$ table and the $\underline{\text{text note list}}$ to locate the records on SYSUT1. The $\underline{\text{text I/O}}$ table is also used to determine the order in which text records are to be processed. RLD records associated with the text being processed are read into the <u>second pass RLD input buffer</u>, using the <u>RLD notelist</u> to locate the required records. <u>Single Pass Processing</u>: If the linkage editor did not write text or RLD records on SYSUT1, single pass processing is in effect for these records. The records are accessed directly in the input text buffer and the RLD buffer, which are physically the same storage areas as the second pass RLD input buffer. If text records or RLD records were written on SYSUT1, they are read back into the same locations. <u>Relocation</u>: Address constants described by RLD items are moved from the second pass text buffer to a work area, where relocation is performed. The manner in which each address constant is relocated depends on whether it is a V-type (branch-type) or an A-type (nonbranch-type) address constant, or a pseudo register (type 1 or type 2). The V-type address constant can refer to a named location in some other control section (branch type address constant). The value field of such a V-type address constant always contains a zero because the address was not known at compilation time. During second pass processing, the linkage editor address (absolute relocation factor) that was assigned to the symbol and saved in the HESD is inserted in the value field. This is called absolute relocation. If the V-type address constant is in an overlay program, the address of an ENTAB entry for the symbol and the segment number of the current text is inserted in the value field. (ENTABs are created in the second pass RLD buffer from information in the HESD and the entry list, which contains an entry for each V-type address constant in the path of a referred-to symbol.) The value field of an A-type address constant that refers to a named location in the <u>same</u> input module (nonbranch-type address constant) contains an address assigned by the language translator. During second pass processing, this address is modified by adding or subtracting the relative relocation factor that was determined for the symbol referred to by the address constant. Relative relocation factors are saved in the relocation constant table. This process is called <u>relative</u> relocation. When each address constant is relocated, it is placed back in the text, and the address field of the associated RLD item is updated. The RLD item is then moved to the second pass RLD output buffer. When all address constants in the text buffer are relocated, the text is written on SYSLMOD, followed by the associated RLD items. A control record pertaining to the next text record is written on SYSLMOD following the RLD records. If the output load module is structured for overlays, a <a href="ITEL IIST">ITEL IIST</a>, containing the address of the first control record of each segment (for the first segment, the list contains the address of the first text record), is also created and retained in virtual storage. Second pass processing continues until all segments in the output module are processed. The last control record contains end of module indicators. Control is then passed to final processing. #### Final Processing The objectives of final processing (see Diagram 7) include writing remaining output to SYSLMOD, producing certain optional output, and "cleanup" functions. The partitioned data set directory for SYSLMOD is completed, including modifications for ALIAS symbols (found in the <u>ALIAS</u> <u>table</u>), and a STOW macro is issued. The TTR list, containing the address of the first text record in each segment, is written on SYSLMOD for overlay programs. The <u>error logging map</u>, produced as errors are encountered throughout linkage editor processing, is scanned and an <u>error diagnostic directory</u> is built and written on SYSPRINT. If the TERM option was specified, the error diagnostic directory is also written on SYSTERM. Storage allocated to the linkage editor is released. If the XREF option is specified and was not processed during intermediate processing, RLD records are read from SYSLMOD, and a <u>cross-reference table</u> is built and written on SYSPRINT. > At the completion of linkage editor processing, control is returned to the calling program. # **INITIALIZATION** The initialization phase comprises modules HEWLFINT, HEWLFOPT, and HEWLFDEF. When the linkage editor begins processing, it readies the all-purpose table, analyzes control information, opens necessary data sets, and allocates space to buffers and tables. #### PREPARING THE ALL-PURPOSE TABLE (APT) The linkage editor maintains the all-purpose table as the common communication area for all internal functions (see Figure 27 for the contents of the all-purpose table). The basic information in the all-purpose table is added to during initialization as operating conditions are learned. This information includes the results of the control information analysis and descriptions of the tables and buffers built by the linkage editor. #### ANALYZING CONTROL INFORMATION When the linkage editor receives control from the job scheduler, or from another program via a CALL macro instruction, control information may be passed to it. This information includes the options that control linkage editor processing and the attributes to be assigned to the output load module. A calling program may also provide a substitute list of ddnames to be used in place of the standard names, and a PDS directory name for the output load module. During initialization, the specified attributes and options are interpreted, checked for validity against an attribute-option table, and recorded in the all-purpose table. When options with associated values are recognized, the linkage editor also saves the value in the all-purpose table. (For example, the SIZE option gives user-chosen values to be used instead of the default values.) Besides being checked for valid specification, the attributes and options are also checked to ensure that they are requested only in allowable combinations. When mutually exclusive attributes or options are noted, the dominant attribute or option is retained; the other is ignored (see Figure 6 on page 20). IDR Records: These records, which contain data either from an input load module, from an END record, or from the linkage editor IDENTIFY control statement, supply information concerning the processing history of the modules in which they occur. If the data is from an input load module, control is passed to the IDR processor, HEWLFIDR. If the data is from an END record, the data refers to the compiler that created the object module. compiler or translator data is passed in a parameter list to the IDR processor. The user data supplied via the linkage editor IDENTIFY control statement is converted into a parameter list and passed to the IDR processor. **Note:** An X indicates incompatible attributes; the attribute that appears lower on the list is ignored. For example, to check the compatibility of XREF and NE, follow the XREF column down and the NE row across until they intersect. Because an X appears where they intersect, they are incompatible attributes. NE is ignored. Figure 6. Incompatible Module Attributes and Program Options #### **OPENING DATA SETS** After the standard ddnames (or passed ddnames) have been entered into the proper DCBs, the data sets always required for linkage editor operation are opened. These are the SYSLIN, SYSPRINT, and SYSLMOD data sets. If the TERM option was specified, the SYSTERM data set is also opened. **Note:** SYSLIB is opened during input processing if automatic library calls or INCLUDE statements are recognized. SYSUT1 is opened only for twopass processing. When SYSLIN is opened, the "unlike attributes" indicator in the associated DCB is set to signify that SYSLIN may be a concatenation of data sets with varying blocking factors. In preparation for the opening of the SYSLMOD data set, the linkage editor obtains storage for the JFCB for the data set and reads the JFCB into that storage. From the JFCB, the linkage editor obtains the data set disposition and the block size, in case the DCBS option is specified. The block size in the JFCB is zeroed in order to obtain the DSCB block size when the data set is opened. In addition, a DEVTYPE macro instruction is issued to obtain the maximum block size for the type of device on which the SYSLMOD data set resides. The value obtained will be used subsequently in determining the output block size. > If the SYSLMOD data set resides on a shared device and if the data set is not a temporary data set, the linkage editor reserves the shared device for the duration of the job step. the SYSLMOD data set does not reside on a shared device but a disposition of SHR was specified for it on the SYSLMOD DD statement, the linkage editor enqueues the SYSLMOD data set for the duration of the job step. The SYSLMOD data set is opened with an OPENJ macro instruction, specifying the JFCB previously read and modified. During the opening of the SYSLMOD data set, the block size to be used for output to the data set is determined in the open exit routine. The appropriate block size is selected considering the following factors: The value obtained from the DEVTYPE macro instruction, establishing the absolute maximum block size; the block size in the DSCB for an existing data set, which can be increased but not decreased; the block size from the SYSLMOD DD statement, when the DCBS option is used; the implied maximum block size of 1024, when the DC option is used; the implied minimum block size of 1024, when the SCTR option is used; the absolute minimum block size of 256. #### ALLOCATING VIRTUAL STORAGE To obtain storage for buffers and tables, the linkage editor issues the GETMAIN macro instruction specifying the minimum amount of additional virtual storage required for operation. The minimum provides for overlay or hierarchy tables if these options are selected, and, for an area, a 12K-byte block of storage that is returned by means of a FREEMAIN macro instruction, for use by system and data management functions. The minimum also includes the added space required for the primary input buffer when the SYSLIN data set contains blocked records. If the minimum is not available, control is not returned to the linkage editor; instead, a system abnormal termination occurs. # Buffer Allocation When the supervisor returns virtual storage space, the linkage editor determines whether the area is sufficient to use maximum lengths for the SYSLIN, SYSPRINT, and object module buffers. If the space is not sufficient, intermediate or, when necessary, minimum buffer lengths are used. The RLD and text buffers are then assigned storage. The default text buffer length (48K bytes) is used unless a specific allocation was requested via the SIZE parameter. The RLD buffer is also assigned the minimum length unless the SIZE parameter allows it to be given additional space. In this case, the increased length depends on the amount of storage remaining after the text buffer has been allocated. Note: Space allocated for buffers is not released until linkage editor processing is completed. #### Table Allocation Following buffer allocation, the linkage editor assigns storage to its fixed-length and variable-length tables. In initial allocation, the linkage editor determines the minimum storage required by each table. The size of each table and the number of entries in each table are saved in the all-purpose table. Storage is then reallocated. The storage in excess minimum required for all the tables is determined. The storage in excess of the The excess is used to expand proportionately the variable-length tables. Then, the size of each table and the number of entries per table are calculated. This information and the newly assigned table addresses are saved in the all-purpose table. When all linkage editor processing is completed, all table space is released. #### INPUT PROCESSING The input processing phase comprises modules HEWLFINP, HEWLFINC, HEWLFSCN, HEWLFESD, HEWLFSYM, HEWLFRAT, HEWLFEND, HEWLFIDR, and HEWLFRCG. The operations performed during input processing depend on the nature of the input; special processing is required for each input record type. Each input record is read, using one of two read blocks. The first read control block contains the address of the SYSLIN buffer, the address of the SYSLIN DCB, and the block size and logical record length. The second read control block contains the address of the buffer for library records (object module buffer or load module buffers), the address of the library DCB, and the block size and logical record length. A pointer is used to indicate which read control block is to be used for the input record. Initially, the pointer is set to the SYSLIN read control block. The type of input processing required is determined by the following conditions: - For all object module records whose first column character is a blank, control statement scanning is required, provided that the record is not encountered "in module." (Control statements encountered within a module cause an error indication.) - Either object module processing or load module processing is required, depending on the type of input module. Only object modules are read from SYSLIN. Input modules from libraries are identified by record format. (Fixed format (F) indicates object modules; undefined format (U) indicates load modules.) - When an INCLUDE control statement is detected during normal processing, "include" processing is initiated. At end-of-input from the specified include library, normal processing resumes. If an INCLUDE control statement is detected during "include" processing, "include" processing is reinitiated for the new include library. - At end-of-input from SYSLIN, automatic library call processing is required if the NCAL option (no automatic library calls) was not selected. If the NCAL option was selected, input processing is complete. - At end-of-input from SYSLIB during automatic library call processing, automatic library call processing is reinitiated. - If a NAME statement, which may indicate a multiple execution of the linkage editor, is detected during control statement scanning, processing proceeds as if an end-of-input has occurred on SYSLIN (automatic library call processing is performed). - If an end-of-input occurs on SYSLIN but no valid input was received, linkage editor processing is terminated. ## Reading Blocked Input The linkage editor can accept blocked card image input from the SYSLIN data set and blocked object module records from the SYSLIB data set (or from a user's library). Generally, the record format, block size, and logical record length are established either when the data set is created, or when they are specified on the DD statement for the data set in an execution of the linkage editor. If the BLKSIZE field is not specified, the linkage editor assumes a block size of 80. The logical record length (LRECL) is fixed at 80. If the block size specified on primary input exceeds the allowable maximum or is not a multiple of the logical record length, an error message (IEW0594) is issued and linkage editor processing is terminated; if the invalid block size is specified on input from a library, the data set is ignored, but processing is not terminated. The block size specified by the user is used as the read count; if a short block is read, the linkage editor determines (via an exit at SYNAD) whether the length of the short block is valid (a multiple of the logical record length) and the number of the logical records it contains. If SYSLIN is a concatenation of data sets, the input processor reexamines the block size fields whenever a data set boundary is crossed to determine whether their values have changed. # Record Lengths for SYSPRINT In determining record lengths for SYSPRINT, the linkage editor first checks the block size unless time sharing is in effect. If the BLKSIZE is not specified by the user, it is set equal to 121. If the block size exceeds the allowable maximum or is not an integral multiple of 121, linkage editor processing is terminated and a condition code of 16 is returned. If the block size is a multiple of 121, it is not changed and the logical record length for output to SYSPRINT is set equal to 121. If time sharing is in effect, both the block size and the logical record length for SYSPRINT are set equal to 81. When the linkage editor is being executed in the time-sharing foreground, header messages are printed only once and all line-counting functions are ignored. Note: If SYSPRINT is a member of a partitioned data set and the DSCB is changed (by setting the logical record length or changing the block size), it may be impossible to use the information in the other members of the PDS. # Record Lengths for SYSTERM The block size and the logical record length for output to SYSTERM are set equal to 121 unless time sharing is in effect. If time sharing is in effect, the block size and the logical record length are set equal to 81. Note: If SYSTERM is a member of a partitioned data set and the DSCB is changed (by setting the logical record length or changing the block size), it may be impossible to use the information in the other members of the PDS. #### Control Statement When an input record is found to be a control statement (a blank in column 1), it is scanned to detect format errors and continuation of comments or operands. A vector table is scanned to determine the appropriate processor; separate processing is required for each type of control statement (INCLUDE, REPLACE, LIBRARY, CHANGE, INSERT, OVERLAY, ENTRY, ALIAS, NAME, SETSSI, IDENTIFY, HIARCHY, ORDER, PAGE, SETCODE, EXPAND, and MODE). Diagram 8 illustrates general processing of each control statement type. The general format for linkage editor control statements is shown in Figure 7. The control statement scanner interprets symbols enclosed in parentheses as "level 1" symbols; symbols not enclosed within parentheses are "level 0." ENTRY, ALIAS, INSERT, HIARCHY, SETSSI, and PAGE control statement operands contain only level 0 symbols. CHANGE, IDENTIFY, SETCODE, EXPAND, and MODE statement operands always contain both a level 0 symbol and a level 1 symbol. Figure 7. Control Statement Scanner Operation The operands of REPLACE, INCLUDE, OVERLAY, NAME, and ORDER control statements contain level 0 symbols, or both level 0 and level 1 symbols. LIBRARY statement operands may contain level 1, or both level 0 and level 1 symbols. The operation to be performed depends on the operand format. The control statement scanner searches a vector table for the operation symbol to determine the associated control statement processor. It then analyzes the operands using two work areas, "OPD1" and "OPD0", and two pointers, "P1" and "P2". OPD1 is used for level 1 operand symbols; OPD0 is for level 0 operand symbols. P1 points to the operand symbol being analyzed; P2 points to either OPD0 or OPD1, depending on the level of the operand symbol referred to by P1. An operand symbol referred to by P1 is placed by the READ8 routine into the work area referred to by P2. Parentheses and commas control the switching of pointer P2 between the work > areas. For example, when a left parenthesis is encountered, P2 moves to OPD1 because a level 1 operand symbol will follow. When a comma, blank, or right parenthesis is detected, the PROCENTY routine passes control to the control statement processor that was previously found during the search of the vector table. When an IDENTIFY control statement is read by the control statement processor, a switch is set on for the special string option utilized by IDENTIFY. When the switch in the control statement processor is picked up by the READ8 routine, it sets another switch, permitting up to 40 characters to appear in the IDENTIFY operand. This allows any character, including embedded blanks, to appear between single quotation marks. #### **Control Statement Processors** When the operand symbols have been read into work areas OPDO and OPD1, control is passed to the control statement processor at the saved entry point. Scanning of the control statement resumes when the control statement processor returns control. The individual control statement processors are described in the following paragraphs. Figure 8. INCLUDE Statement Processing for a Sequential Data Set INCLUDE STATEMENT PROCESSOR: The INCLUDE statement processor builds a chain in the CESD of items to be included. Each item in the chain contains the address of the next item in the chain (in the chain/address field—bytes 9, 10, and 11). The last item in the chain contains zeros in this field. Chained include items have two kinds of subtypes: "include with pointer" and "include without pointer." In Figure 8, the statement INCLUDE M defines M as a sequential data set. INCLUDE statement processor creates an entry for the ddname M in the CESD with the subtype "include without pointer." In the statement INCLUDE LIBX (A), A is defined as a member of a PDS. The INCLUDE statement processor creates an entry for A in the CESD with the subtype "include with pointer." The pointer is in the chain pointer/chain ID field (bytes 14 and 15); it > contains the CESD line number of the ddname LIBX. A single ddname, such as LIBX, may be referred to by several pointers. Figure 9 describes INCLUDE statement processing with nested members. Figure 9. INCLUDE Statement Processing With Nested Members - The statement INCLUDE TEMP (A, B, C) indicates that A, B, and C are members to be included from library TEMP. - Member B contains the nested statement INCLUDE LIBX (U, V, W); this is the last statement processed in member B. - The CESD is shown at the time when the control statement scanner has read operand V, but not W. The INCLUDE statement processor has created a CESD line for operand V in the LIBX include chain. C is currently the last item in the TEMP include chain. When the control statement scanner reads operand W, the INCLUDE statement processor enters a CESD line for W between V and C; this process is distinct from the one that actually searches the members U, V, and C on the library (see "INCLUDE Processing"). At the time chosen for this example, the data set member B is being read; data set member A has been read and therefore is no longer in the CESD as a member name, but data set members U, V, and C have not yet been read. The chained CESD entries created by the INCLUDE statement processor are later processed by the include processor. > OVERLAY STATEMENT PROCESSOR: The OVERLAY statement processor maintains a record of the current segment number and updates it by one each time a new OVERLAY statement is encountered. relationship of segments in an overlay tree structure is kept in the segment path table (SEGTA1) (see Figure 10). Entry n in SEGTAl contains the number of the segment that precedes the nth segment of the overlay tree structure (the next higher segment in its path). The OVERLAY statement processor creates a chain of overlay items in the CESD and updates <code>SEGTA1</code>. If the level f 1operand (REGION) is detected, the current region number is incremented by one, and a zero is entered as the previous segment number in SEGTA1. Figure 10. Overlay Statement Processing If an OVERLAY statement is encountered that refers to a node point higher in the overlay tree structure, all symbols identifying node points higher in the path are removed from the chain; their CESD lines are marked "null." For example, in Figure 10, when the statement OVERLAY A is encountered after segment 4, the CESD entry for symbol B is marked null and is no longer in the chain. If an OVERLAY B statement was encountered at the end of segment 5, a new node point would be established for B, and symbol B would again be entered in the CESD. HIARCHY STATEMENT PROCESSOR: The HIARCHY routine first determines if the hierarchy number is valid. If it is invalid, the statement is printed; an error message is written and the > remainder of the statement is ignored. If the number is valid, it is converted to binary and saved for the SCAN routine. Processing of the statement continues with the collection of the next symbol, up to a comma or a blank. The CESD is searched for this symbol; the location in the hierarchy table corresponding to this CESD item is set to the hierarchy number specified. (The hierarchy table is built during initialization if HIAR was specified. The hierarchy table consists of one byte per entry in a one-to-one correspondence with the number of items allocated to the CESD. The address of this table is kept in a fullword in the all-purpose table.) If the symbol does not appear in the CESD, the symbol is entered in an unused entry in the CESD, marked external reference, and the hierarchy number is stored in the corresponding entry in the hierarchy table. This procedure is repeated for each additional symbol in the HIARCHY statement. The intermediate output routine uses the hierarchy table to place the hierarchy number associated with each CESD item in the scatter/translation table. INSERT STATEMENT PROCESSOR: The insert statement processor scans the CESD for the symbol indicated in the INSERT statement. If the symbol is found, the segment number field is changed to the number of the segment that contains the INSERT statement. If the symbol is not found in the CESD, a new ER entry in the CESD is created. In either case, the CESD entry is marked "insert" in the subtype field, and the segment number of the INSERT statement is placed in the segment number field. REPLACE AND CHANGE STATEMENT PROCESSORS: The REPLACE and CHANGE statement processors build a chain of CESD entries. Each entry to be replaced, changed, or deleted is so marked in the subtype field. The ESD processor examines the replace/change chain before processing any ESD item. Because a REPLACE or CHANGE statement applies only to the module that immediately follows it in the input, the replace/change chain is removed from the CESD at the end of the module. When a REPLACE statement or a CHANGE statement operand contains two symbols, such as CHANGE A (B), A and B are entered in consecutive lines of the CESD. Only the first line of the pair (the line for A) contains the address (in the chain address field) of the next item in the replace/change chain. NAME STATEMENT PROCESSOR: The NAME statement processor places an entry in the all-purpose table containing the name under which the output load module is to be stowed in the PDS directory. the operand contains the level 1 symbol (R), a bit is set to indicate that the module is to be stowed as a replacement for a module of the same name. Another bit is set to indicate that a NAME statement was encountered; the input processor tests this indicator and terminates input operations if it is set. If NAME statement is received from any input source other than SYSLIN, the error routine is entered; NAME statements are accepted only if they are in the primary input. SETSSI STATEMENT PROCESSOR: The SETSSI statement processor converts the 8 bytes of hexadecimal information specified on a SETSSI statement to a 4-byte field, and enters it into the all-purpose table. During final processing, this information is entered into the <u>system status index</u>, a 4-byte extension of the user data area in the PDS directory. The index contains information describing the status of members in the library and is used for maintenance purposes. ORDER AND PAGE STATEMENT PROCESSOR: The ORDER and PAGE statement processor builds the ORDER table. First, the CESD is searched for a match to the symbol specified in the ORDER or PAGE statement. If the symbol is not found in the CESD, the symbol is entered into the CESD as a "weak external" reference (WX). The ESD identifier of the CESD line is entered into the ORDER > table. When a matching symbol is found in the CESD, and the entry is not a control type ER, the ID of the CESD line is entered into the ORDER table. The appropriate flags are set in the ORDER table entry to indicate if the specified request is either an ORDER or a PAGE statement. The ORDER flags are set when text ordering during output processing is requested. The PAGE flags specify that the linkage editor is to perform page alignment during address assignment. The ORDER flags can be set only when an ORDER control statement is present. The PAGE flags can be set in one of two ways: (1) if P is specified on an ORDER control statement, or (2) if the PAGE control statement is present. Figure 11 for an example of order and page processing. Figure 11. Order and Page Processing Note: In this example, CSECTB must follow CSECTA and CSECTC in the order table. Ordering was not specified for CSECTB. IDENTIFY STATEMENT PROCESSOR: The IDENTIFY statement processor picks up the CSECT name from OPDO, the length of the special string SPECSTR extracted by the READ8 routine, and the identify data placed in SPECSTR by the READ8 routine. This information is placed in storage, and parameters and control are passed to the IDR processor HEWLMIDR at the entry point HEWLCIDR. ENTRY STATEMENT PROCESSOR: The ENTRY statement processor places the symbol specified in an ENTRY statement in the all-purpose table. The symbol will override any symbol specified in an END statement as the entry point for the module. ALIAS STATEMENT PROCESSOR: The ALIAS statement processor creates chained CESD entries for a maximum of 16 alias names specified in ALIAS statements. During address assignment, these entries are used to build the alias table. LIBRARY STATEMENT PROCESSOR: The LIBRARY statement processor creates chained CESD entries for the operands specified in LIBRARY statements; a chain is created for each distinct library. Each chain begins with a library ddname and contains all member names specified for the library (see Figure 12 ). A member name specified in a LIBRARY statement can result in one of two kinds of ER subtypes: "matched library member" or "unmatched library member." If a CESD entry is created for a member name specified in an input ER and also specified in a LIBRARY statement, it is called a "matched library member." However, if the member name was specified only in a LIBRARY statement, the entry subtype is "unmatched library member." | | Symbol | Туре | Chn Addr/<br>Reverse<br>Chain ID | Seg<br>No | Sub<br>Type | Chn Pointer<br>Chain<br>Length/ID | |----------------------------------------------------------------------|--------------------------------------------|----------------------------|----------------------------------|-----------|----------------------------|-----------------------------------| | 01<br>02<br>03<br>04<br>05<br>06<br>07<br>08<br>09<br>0A<br>08<br>0C | JOE<br>LIB2<br>SAM<br>PETE<br>MARY<br>LIB1 | 02<br>02<br>02<br>02<br>02 | 0C<br>00<br>06<br>07<br>04<br>00 | | 03<br>B0<br>02<br>03<br>02 | 0A<br>07<br>08<br>00<br>00 | | | | | Diagram ( | 3 | | | | | Symbol | Туре | Chn Addr<br>/Reverse<br>Chain ID | Seg | Sub<br>Type | Chn Pointer<br>Chain<br>Length/ID | |----------------------------------------------------------------|--------------------------------------------|----------------------------------|----------------------------------|-----|----------------------------|-----------------------------------| | 01<br>02<br>03<br>04<br>05<br>06<br>07<br>08<br>09<br>0A<br>0B | JOE<br>LIB2<br>SAM<br>PETE<br>MARY<br>LIB1 | 00<br>02<br>02<br>02<br>02<br>02 | 00<br>06<br>07<br>0C | | B0<br>02<br>03<br>03<br>B0 | 07<br>08<br>00<br>00 | Diagram C Legend: - The CESD shown in diagram B results from the CESD shown in diagram A after reading in three library cards. A chain with direct and reverse pointers is created for LIB1 and also for LIB2. - JOE and PETE were ERs (subtype 00) and became "matched library member" (subtype 03). - SAM and MARY were not previously in the CESD. They are created as "unmatched library member" (subtype 02). - The CESD shown in diagram C results from the CESD shown in diagram B after reading in an input module containing the ER MARY and the SD JOE. (Only the library chains are shown). - JOE is removed from the chain in diagram C, and the chain pointers are modified. - MARY becomes a "matched" subtype and will be called by the automatic library call processor (unless resolved by other input). - SAM remains "unmatched" and will be ignored by the automatic library call processor (unless matched in other input). Figure 12. Library Statement Processing EXPAND STATEMENT PROCESSOR: The EXPAND statement processor accumulates the expansion length specified and, if necessary, limits that length to 4095 bytes. If the name specified matches the name of a named control section or common section, the length of that control section or common section is updated by the expansion length in the matching CESD entry. A special entry is then made to the text processor to create and save text of the expansion length to be added to the control section or common section. > MODE STATEMENT PROCESSOR: The MODE statement processor verifies that the valid mode keywords, AMODE and RMODE, are specified and that the valid mode specifications are used—24, 31, or ANY for AMODE; 24 or ANY for RMODE. Appropriate values are set in the all-purpose table to indicate the mode(s) specified. SETCODE STATEMENT PROCESSOR: The SETCODE statement processor accumulates the authorization code specified. A limit of 8 digits specifying a value of 0 to 255 is imposed. Once verified, the authorization code is saved in the all-purpose table. ## Object Module Processing If input to be read by the linkage editor consists of object modules (fixed (F) record format indicates object modules), the following operations are performed: - Determine record type - Set up general registers - Perform special event processing The record type is determined by examining columns 2 through 4 of each logical input record. For each record type (SYM, ESD, TXT, RLD, IDR, END), special processing is required. The general registers are loaded with input record information to be used in the required processing, as described in Figure 13. | Input<br>Record Type | 3 | 4 | 5 | 6 | |----------------------|--------------------------------------------------------|-----------------------------------------------------------------------|---------------------------------------------|-----------------------------------------------| | SYM | | SYM record byte count | | Address of SYM<br>record in<br>buffer | | ESD | | Number of bytes<br>of ESD<br>information | ESD ID of first<br>ESD item on<br>record | Address of<br>first byte of<br>ESD in buffer | | TXT | Assigned<br>address of<br>first byte of<br>text | Number of bytes<br>of text<br>information | ESD ID of CSECT<br>to which text<br>belongs | Address of<br>first byte of<br>text in buffer | | RLD | | Number of bytes<br>of RLD<br>information | | Address of<br>first byte of<br>RLD in buffer | | END | Absolute<br>address of<br>entry point<br>on END record | Length of CSECT<br>for which no<br>length was<br>given in ESD<br>item | ESD ID CSECT<br>containing<br>entry point | | Figure 13. General Register Information-Object Module Processing Following is a description of special event processing: When end-of-input is detected, any data still contained in the input RLD buffer or the input text buffer is written out on SYSUT1, if necessary. See the appendix "Input Convention and Record Formats." - If the TEST attribute is selected, the SYM records from the object module are blocked 3-to-1 in the input RLD buffer and written out on SYSLMOD. When the first TXT record in a module is encountered (or, if no text record has been encountered, when the END record is detected), remaining SYM records in the input RLD buffer are written out on SYSLMOD. - When processing of an ESD record is completed, indicators in the all-purpose table are examined to determine if: - A control section (SD, PC, or common) was indicated on the ESD record. - The TEST attribute was specified. If both conditions are met, the ESD record is blocked 3-to-1 in the input RLD buffer and written out on SYSLMOD. - If a control statement continuation is expected and an object module record is read, an error condition occurs, and a coded diagnostic message is produced. Normal object module processing is then performed on the record. - If, during object module processing, a record is encountered that is not one of the six acceptable types (SYM, ESD, TXT, RLD, IDR, or END), an error condition occurs and a diagnostic message is produced. The input record is then ignored. ### Load Module Processing Load modules included as input to the linkage editor are processed in the following manner: - The input record type is determined by an identification field (byte 1 of the record), as shown in Figure 14 on page 33. Special processing is performed for each record type. - The parameter registers are loaded with input record information to be used in the required processing, as described in Figure 15 on page 33. - If the record is not identified as a TXT, CESD, IDR, scatter/translation, SYM, or CTL/RLD record, an error condition occurs, and a diagnostic message is printed out. The input record is otherwise ignored. - If the TEST attribute was not specified, all SYM records are ignored. - If an end-of-module indication is found in a CTL or RLD record, cleanup functions are performed. - When a CTL record is detected, the following TXT record is immediately read into the input text buffer if it is not to be deleted. - If the TEST attribute was specified and a SYM record is received, the record is written out as text translation data from the RLD input buffer. | Record Type | Identifier<br>(in Hexadecimal) | |---------------------|----------------------------------------| | TXT | Identified by preceding control record | | CESD | '20' | | IDR | '80' | | Scatter/Translation | '10' | | SYM | 1401 | | CTL | "01" | | CTL/RLD | *03 | | RLD | '02' | ### If end-of-segment indicator is on: | CTL | 1051 | |---------|------| | CTL/RLD | '07' | | RLD | '06' | ## If end-of-module indicator is on: | CTL | '0D' | |---------|------| | CTL/RLD | '0F' | | RLD | '0E' | Figure 14. Input Record Types—Load Module | Load Module<br>Record Type | 3 | 4 | 5 | 6 | |----------------------------|-------------------------------------------------|-------------------------------------------|-------------------------------------------|-------------------------------------------------------| | SYM | | Zero | | | | CESD | | Byte count of<br>ESD items in<br>record | ESD ID of first<br>CESD item on<br>record | Address of<br>first byte of<br>CESD item in<br>buffer | | CTL (TXT) | Assigned<br>address of<br>first byte of<br>text | Number of<br>entries in<br>ID-length list | ESD ID CSECT to which text belongs | | | RLD | | Byte count of<br>RLD items in<br>record | | Address of<br>first RLD item<br>in buffer | Figure 15. General Register Information—Load Module Processing > The following describes the special processing performed, during object and load module processing, for the ESD, IDR, TXT, RLD, and END records. ## **ESD Record Types** Every object module in the input to the linkage editor must contain at least one ESD item. An ESD item is created by a language translator whenever it finds a symbol that is defined for external use. An ESD item is created to define the beginning of each control section, common areas, entry point names, and external references. Each ESD item has a type assigned to it that indicates its function. The ESD types are: - Section Definition (SD). Defines the beginning of a named control section. - <u>Private Code (PC)</u>. Defines the beginning of an unnamed control section. - Label Definition (LD). Defines a label (symbol) whose location is defined relative to the location of the control section in which it is contained. An LD type ESD item contains the ESD ID of the control section that contains the label. - Common (CM). Defines a common area for which a virtual storage address is assigned during linkage editor processing. The area may be named or unnamed; an unnamed area is referred to as a "blank common" area. - <u>Pseudo Register (PR)</u>. Defines an area external to the output module, but referred to by it, for which virtual storage space is allocated at execution time. The linkage editor treates PR symbols as a block that is external to the program. The value assigned to each symbol is a displacement within this block. - External Reference (ER). Specifies a symbol that is referenced but not defined within an input module. - Weak External Reference (WX). Specifies an external reference that is not to be resolved by automatic library call. A WX entry is processed as an ER entry with a "weak call" flag. ### CESD Record Types and Subtypes A load module in the input to the linkage editor contains at least one CESD record unless the module is marked not editable (NE). The CESD record types are the same as for ESD records, with the following additions: - Null Type. This indicates that the item is to be ignored in any reprocessing of the module by the linkage editor. - Label Reference (LR). This defines a label (symbol) within a control section. An LR type CESD entry is numbered; it contains the ESD ID of the control section entry in the ID/length field. An LR may be referenced directly by an RLD item in the same module, whereas an LD may not. All LD items are changed to LR items during linkage editor processing (LDs are contained only in object modules, never in load modules). - <u>Private Code (PC) Marked Delete</u>. This is a CESD item created only for ENTABs and SEGTABs. PC-delete entries are placed in the renumbering table, indicating that associated TXT and RLD information is to be deleted. #### ESD Processing The main function of ESD processing is symbol resolution. Individual ESDs in the input to the linkage editor are combined into a composite ESD, which contains all symbols in the input that were not changed, deleted, or replaced. A chained replace/change list (produced by the control card scanner) specifies which ESD items are to be changed, deleted, or replaced. A renumbering table (RNT) is also produced during ESD processing; it is used during TXT, RLD, and END processing to translate the ESD IDs of the input ESD items to CESD IDs. Diagram 9 provides a general illustration of several types of ESD processing. At the beginning of ESD processing, control information from the ESD record is saved: the ESD ID of the first ESD item in the record (other than an LD); the number of bytes of ESD information; and the type field of the first ESD item. If the OVLY option has been specified for the output load module, the following occur: - The current segment number is placed in the ESD, unless the entry type is PR (PRs have an alignment value in the segment number field). - The RMODE for the load module is forced to 24. - If automatic library call processing is being performed, the segment number is forced to 1 (all automatically called modules are placed in the root segment of the overlay structure). If the OVLY option has not been specified for the output load module, - If the current ESD item is from a load module in overlay format, the AMODE/RMODE data is forced to 24/24. - Otherwise, the content of byte 12 is interpreted as AMODE/RMODE data. The ESD item is then processed according to its type, in the following manner: - If the ESD item is an ER, bytes 10, 11, and 12 are set to zero in the input buffer (either the object module buffer, the SYSLIN buffer, or the first pass RLD input buffer). Byte 10 must be cleared because automatic library call processing uses it to indicate whether automatic library calls have been processed. Bytes 11 and 12 must be cleared because any nonzero data (including blanks) will be entered in the delink table if delinking is required for the symbol. If the input item is an ER item from an object module, the CESD subtype field is also reset to zero to indicate that there are no modifiers in the subtype field. - If a REPLACE/CHANGE function has been requested for the input module, the replace/change chain that was built in the CESD by the control statement scanner is examined and the appropriate modifications are made. For example, if the scanner received the statement CHANGE A(B), the CESD contains a line for A, marked as a change statement item in the subtype field; the next line contains the symbol B. The input ESD item symbol is changed from A to B during ESD processing. - If the ESD item is a PC, the CESD is not searched, because each PC entry is treated as a unique entry. The PC is placed in the next available CESD line and is processed in the same manner as an SD. - If the ESD item is a null item, the renumber routine is entered. (This routine is described under "Nonresolution Processing.") - If the ESD item is an LD, it is changed to an LR. The item is then processed as an LR. (There are some minor differences in processing LDs that have been changed to LRs; for this reason, an internal indicator is set when the type is changed to LR.) - If the ESD item is a PC or SD, the AMODE/RMODE data is checked for a valid combination. If an invalid combination is found, an error message is issued and the RMODE for the output load module is forced to 24. After the ESD type is determined, the CESD is scanned for a matching symbol. If no match is found, nonresolution processing is performed. If the input ESD symbol matches a symbol in the CESD, resolution processing is performed. Resolution processing results in only one CESD entry for each unique input ESD symbol; multiple occurrences of the same input ESD symbol are listed in the renumbering table (RNT) with pointers to the single CESD entry. NONRESOLUTION PROCESSING: If no matching symbol is found in the CESD, the input ESD item is processed as described below. $\frac{\text{SD Items}}{\text{A}}$ : If the input ESD item is an SD (see Diagram 9, area - The freeline routine selects an empty line in the CESD. The line following the current line is chosen unless a previous CESD line is marked null. (Whenever possible, null lines are used to save space.) - If automatic library calls are being processed, an indicator is set in the type field of the selected CESD line. (If a module map was requested, this indicator is checked during module map processing. If the indicator is set, the control section is marked with an asterisk in the module map or cross-reference table to indicate that it was obtained from a library during automatic library call processing.) - If the load module is in overlay structure, then those routines brought into the load module via the automatic library call are placed in the root segment of the load module. - A "write" indicator is set in the all-purpose table to note that SDs, PCs, or CMs were encountered in the input record. When ESD processing is completed, the write indicator is tested. If it is on and the TEST attribute was specified, ESD records containing SDs, PCs, or CMs are saved, blocked 3-to-1 in the input RLD buffer and written out on SYSLMOD. - In any input object module, the CESD line number of the first SD entry whose length is zero is saved. END processing uses this CESD line number to enter the length specified on the END card. - The enter routine creates a CESD entry for the input ESD item; it moves the symbol length, segment number, ID, and type into the selected CESD line. In addition, the enter routine accumulates the residence mode for the output load module. Initially, the residence mode is ANY. As each control section (SD or PC) is allocated in the output load module, its residence mode is included in the accumulation. If all control sections allocated in the output load module have a residence mode of ANY, the output load module has a residence mode of ANY; if any control section allocated in the output load module has a residence mode of 24, the output load module has a residence mode of 24. (The residence mode accumulated from the ESD data may be overridden by the residence mode specifications in the PARM field or the MODE control statement.) • The renumber routine places the line number of the new CESD entry into the renumbering table to provide a means of translating the input IDs to the new CESD IDs. For example, if the input ESD item has a line number (ESD ID) of 3 but the item is placed into the CESD at line 5, a 5 is placed in the third line of the renumbering table. (For each input ESD line, except LD lines, there is a corresponding RNT line. The RNT contains information for the current module; it is set to zero at the end of each input module.) <u>ER Items</u>: If the input ESD item is an ER, it is entered in the CESD and renumbered as described above; no special processing is required. <u>WX Items</u>: If the input ESD item is a WX, it is entered in the CESD and renumbered as described above; no special processing is required. CM Items: If the input ESD item is CM (see Diagram 9, area E), a "common" indicator is set and the item is treated as a delete item. If the address that was assigned to the CM item by the language translator is not zero, it is saved in the delink table for later use. (Two CM items with the same identifying symbol may have different assigned addresses; therefore, the assigned address in the input must be subtracted from all address constants that refer to the CM items so that they are returned to their displacement value before relocation.) The CM item is then renumbered and entered into the CESD. LR (or LD) Items: If the input ESD item is an LR or LD (see Diagram 9, area C): - When processing an LR, the label routine determines whether the SD for the control section has been processed. If the SD has not been received, any LRs that refer to that SD are chained together in the CESD until the SD is received. (The SD might be marked replace; therefore, the LR cannot be processed until the SD is received.) When the SD is received, all dependent LRs are processed. Each LR ID field is renumbered, using the renumbering table, so that it refers to the CESD ID of the SD. - LDs are not renumbered, because they are not referred to by RLDs and are not numbered in language translator output. The enter routine places them directly in the CESD. If an LD is received before the SD to which it belongs, it is handled as an LR. <u>PR Items</u>: If the input ESD item is a pseudo register, the current segment number is not entered in column 12 of the ESD item. Column 12 of a PR item contains an alignment value, which indicates that the PR must be aligned to a halfword, fullword, or doubleword boundary. The PR is then processed by the freeline, enter, and renumber routines, as described above. **RESOLUTION PROCESSING:** If a matching symbol is found in the CESD, the type fields of the input item and the matching CESD item are compared and resolution processing is then performed. The following conventions are observed during resolution processing: - Input PR items may match only PR entries in the CESD. If an input PR item matches a non-PR item in the CESD, it is not treated as a match; the CESD search for a matching PR item continues. - If the matching CESD item is marked "chained," resolution is performed on the item to which it is chained. - If the CESD line is marked null, the match is ignored and the search continues. > If the CESD item is an ER produced from a REPLACE, CHANGE, OVERLAY, or ALIAS statement, or from the ddname field of an INCLUDE or LIBRARY statement, the match is ignored and the search continues. Matching items are processed in the following manner: - If the input ESD item is CM, SD, or LR and it matches an ER in the CESD, the input type replaces the type indicated in the CESD item (see Diagram 9, area B). Nonresolution processing is then performed on the input item. - If the input ESD item is an LR and it matches a CM, SD, or LR in the CESD, a "match" bit is set, indicating that a double symbol definition is possible. If the SD for the control section has been entered in the CESD and is marked for deletion, the Label routine deletes the label; if it is not marked for deletion, a "double symbol definition" message is produced. If the SD for the control section is not in the CESD, the LR is chained to the matching LR; when the SD is received, the LR is deleted or a double symbol definition message is produced, depending on whether or not the SD is being deleted. - If an input PR matches a PR in the CESD (Diagram 9, area D), the greater length and the most "constrictive" boundary alignment are placed in the CESD entry. (A doubleword alignment is more constrictive than fullword alignment; fullword is more constrictive than halfword; etc.) The input PR entry is then renumbered to the updated PR entry in the CESD. - If an input SD item matches an SD entry in the CESD, automatic replacement of the control section occurs. input SD item is entered in the CESD as a delete type and is chained to the matching SD entry. (During second pass processing, the assigned address of the control section being replaced will be subtracted ("delinked") from the addresses of any nonbranch-type address constants that refer to the SD-delete entry.) The SD-delete item remains chained only while the module is being processed; END processing will change the chained items to null entries (see "Delinking Nonbranch-Type Address Constants"). - If an input SD item matches a CM entry in the CESD and the length of the SD item is greater than or equal to the length of the CM item, the length of the SD item is entered in the CESD. If the program is in overlay, the common path routine scans the <u>segment path table</u> (SEGTA1) to find the segment in the overlay structure that is common to both items and places the segment number in the SD entry. The SD item is then written over the CM line and renumbered. (This is referred to as "automatic promotion of common.") - If an input SD or CM item matches an LR in the CESD, a "double symbol definition" message is produced and the SD or CM item is entered in the CESD as a delete type and is chained to the matching LR entry, causing the SD or CM to be replaced. - If the input item is CM, it may be "blank common." Blank common may match a PC item in the CESD because both contain blanks in the symbol field. In such a case, the match is ignored and the search continues. - If an input CM item matches a CM item in the CESD (Diagram 9, area F), the greater of the two lengths is entered in the CESD. If the module is being processed for overlay, the segment number of the segment common to both the input item and the CESD item is also entered in the CESD item (automatic promotion of common). - If an input CM item matches an SD item in the CESD, and the length of the SD item is greater than or equal to the length > of the CM item, the length of the SD item is entered in the CESD. The CESD type is not changed. If the module is being processed for overlay, the segment number of the segment common to both the input item and the CESD item is also entered in the CESD item (automatic promotion of common). - Whenever an input ER item matches an ER in the CESD, both the type and subtype fields are examined; the ER items are then resolved in the following manner: - If the subtype fields of both ER items are not marked, the input item is not entered in the CESD; the matching ER remains in the CESD and a pointer to it is placed in the renumbering table entry for the input item. - If both items are marked "delete," the new ER is entered in the CESD and the old item remains there so that they can be delinked individually (in this case, the CESD may contain two ER items for the same symbol). Delinking is described in "Second Pass Processing." - If the input ER item is marked for deletion, but the ER item in the CESD is not marked delete, the input ER is chained to the matching ER in the CESD. The chained ER item remains in the CESD until end-of-module is detected so that the delink value can be saved. - If the input ER item is not marked for deletion and the ER item in the CESD is marked "delete" or "replace," the delete bit in the subtype field is cleared (delete is changed to replace) and the item is renumbered. matching ER item in the CESD is marked "no call" or "library member," it is marked "matched" before renumbering. - If the input ER item is marked in the subtype field, but is not marked "delete" or "replace," it is assumed to be "never call"; if the matching ER item in the CESD is "library member," the CESD item is removed from the chain of library members and the input ER item is entered in the CESD and renumbered. - If an input WX matches a WX in the CESD, no change is made to the CESD. If the matching entry in the CESD is not a WX or a control card entry, the input WX is changed to an ER. - If an input ESD item that is not a WX matches a WX in the CESD, the CESD item is changed to an ER. In all cases, processing continues normally. ## IDR Processing The manner in which CSECT identification records (IDR) are processed depends on the type of IDR input records or control statements being processed. The input records or control statements are: - Object module END records - Load module IDRs - IDENTIFY control statements An object module END record contains only translation data; however, load module IDRs may contain four different types of IDR data: - HMASPZAP-supplied data - Linkage editor data - Translator-supplied data #### User-supplied data Load module IDR processing is dependent upon the type of data present in the IDR record. The IDENTIFY control statement contains only user-supplied data. Before any IDR data processing begins, the type of IDR input is determined either by the input processor HEWLFINP or, if the data is from the IDENTIFY control statement, by the control statement processor HEWLFSCN. HEWLFINP passes control to HEWLFIDR at the entry point HEWLFIDR. HEWLFSCN passes control to HEWLFIDR at the entry point HEWLCIDR. ## Processing Object Module END Records Containing IDR Data When byte 33 of an object module END record has an EBCDIC 1 in it, one IDR item follows in bytes 34 through 52. If an EBCDIC 2 appears in byte 33, two IDR items follow in bytes 34 through 71. A blank in byte 33 indicates that the record contains no IDR data. IDR data is present only on an object module END record if the translator that produced the object module contains IDR support. The renumbering table is scanned to determine the correct ESD identifiers of the CSECTs to which the translator data applies. If any of the CSECTs are marked delete in the renumbering table, they are not identified in the IDR output. If the input object module contains at least one CSECT that is not marked delete, the translator data is removed from the END record and placed in the IDR translator data table (IDRTRTAB) and the IDR translator ID table (IDRTITAB). These two tables contain the ESD identifier of the CSECT to which the translator data applies, the translator identification, the version and modification level of the translator, and the date of translation. A comparison is made with the other entries in the IDRTRTAB for a duplicate entry. If a duplicate entry is found, the incoming data is combined with that of the previous entry to avoid repetition of data. #### Processing Load Module IDRs The subtype of the load module IDR is scanned for the type of IDR data. If the subtype is 02, the data is from the linkage editor; these records are ignored by IDR input processing. When the input data is from HMASPZAP (subtype 01), bits 2 through 7 of the flags and count field are scanned to determine the number of HMASPZAP entries in the record (from 1 to 19 entries are possible). The entry in the renumbering table corresponding to the ESD identifier of the CSECT processed by HMASPZAP is examined. If the entry in the renumbering table is marked delete, then the IDR data associated with that CSECT is deleted. However, the data that is not deleted is placed at the end of the IDR HMASPZAP data table (IDRZPTAB). IDRZPTAB contains the ESD identifier of the CSECT processed by HMASPZAP, the date of the HMASPZAP processing, the data specified during HMASPZAP processing (this may be a PTF number or up to 8 bytes of variable user data specified on an HMASPZAP control statement). If the IDRZPTAB overflows, an error message is written and processing is terminated. When the input data is translator-supplied data (subtype 04), the renumbering table entry corresponding to each ESD identifier in the string preceding a translator description is examined. If the entry is marked delete, the corresponding ESD identifier is deleted from the string; otherwise, the input ESD identifier is replaced by the renumbered identifier. If at least one ESD identifier remains on the string, a check is made among the table entries in the IDR translator data table (IDRTRTAB) to see whether an identical description has already been entered into IDRTRTAB. If an identical description does exist in IDRTRTAB, the CSECTs associated with the incoming translator description are combined with the existing translator data item to form a single table entry in order to avoid needless repetition of data. If it does not exist, a new entry is added for the input data. When the input data is user data (subtype 08), the renumbering table entry corresponding to the ESD identifier of each input user data item is examined. If it is marked delete, the user data is ignored. If not, the input ESD identifier is replaced by the renumbered identifier and the user data is entered at the end of the IDR user data table (IDRUDTAB). The IDRUDTAB entries contain the ESD identifier of the CSECT to which the user data applies, the date the data was supplied to the module via the linkage editor IDENTIFY function, the number of characters in the user data field, and the user data. In the case of input load module IDRs containing translator or user-supplied data, an individual data item may span more than one record. When this occurs, the incomplete portion of the item is saved in either IDRTRTAB or IDRUDTAB. The item is processed after the next input record has been read, and the continued portion of the item is combined with the saved portion to form a complete data item. ## Processing IDENTIFY Control Statement Data The control statement processor, HEWLFSCN, passes control to the IDR processor at the entry point, HEWLCIDR. The CESD is searched for an SD type entry matching the CSECT name to be identified. If the name is not an SD, an error is logged and processing is terminated. If the CESD line is an SD marked delete, the data is ignored. If the CESD line is an SD not marked delete, the ESD identifier of the matched SD name is saved. A check is made to see whether there was any user-supplied data previously associated with the CSECT. If there was, the old data is replaced with the new incoming data. If no earlier data exists, the incoming data is added to the end of the table IDRUDTAB. ## TXT Processing The manner in which TXT records are processed depends on whether they are part of a load module or an object module or are added using the EXPAND control statement. A load module contains records in a specified order. However, in an object module, the records may not be in the proper sequence because the language translator may have created them out of order (EXPAND data is always identified as out of order text). (The restrictions on linkage editor input are described in "Appendix. Input Conventions and Record Formats.") Diagrams 10 and 11 illustrate processing of TXT records from object and load modules, respectively. Before any address constants can be relocated within a control section of an object module, all TXT records must be placed in the proper order. This is done in the <u>input text buffer</u> (TXTBFBEG), which is variable in length, allowing grouping of data within the buffer. Each "multiplicity" of text is assigned a number as it is moved (or read) into TXTBFBEG. A multiplicity is a portion of text equal in length to the maximum size of a SYSLMOD output record. Within each control section, multiplicity numbers are assigned consecutively, starting at 0. Text records from object modules contain both text data and the control information needed for processing. Text records from load modules contain only text, so the associated control record must also be examined to obtain the required control information. During object module processing, control information is placed in registers; this information allows the object module text to be moved from the object module buffer into TXTBFBEG. For load module text, the assigned address of the first byte of text and a pointer to the ID-length list (in the control record) is determined during load module processing. This information allows the text record to be read directly into TXTBFBEG. ## Processing Object Module Text When text is received from an object module, the text record ID is renumbered, using the renumbering table, so that it refers to the CESD entry for the control section that contains the text. The size of the control section is obtained from the CESD, and a test is made to determine if the whole control section or a multiplicity (whichever is smaller) will fit into the space available in TXTBFBEG. If the control section length was not specified in the CESD entry, only text for the current ID is accepted; see "No-length Control Section," below. If there is sufficient space in TXTBFBEG to accommodate the tabletext I/O table control section or multiplicity, the text is moved into the buffer, and an entry (containing the ID and multiplicity number of the text) is made in the text I/O table. A corresponding entry, containing the location of the multiplicity and the length of the text, is made in the text note list. The text note list entry also contains a displacement field. When text is in order, or on the first occurrence of text for a multiplicity, the displacement field is set to 0; for out-of-order text the displacement field contains the displacement from the beginning of the multiplicity of the first byte of contiguous text. If the SYSUT1 record size is smaller than the multiplicity size, each multiplicity is divided into pieces, each piece having a length equal to the SYSUT1 record size. New text I/O table and text note list entries are made for each piece; the displacement field will contain the displacement of each piece from the beginning of the multiplicity. NO-LENGTH CONTROL SECTION: When text is received for a no-length control section (a control section for which no length is specified in its CESD item), space for one multiplicity is allocated in TXTBFBEG. Entries are made in the text I/O table and the text note list for the multiplicity, and the text is moved into TXTBFBEG. This procedure is repeated for each subsequent multiplicity of text for the no-length control section. If TXTBFBEG becomes full, its contents are written on SYSUT1 as described in "Writing Text on SYSUT1." When the length is received, it is entered in the text note list. PROCESSING OUT-OF-ORDER TEXT: A load module contains records in a definite order. However, records in an object module may not be in the proper sequence because the language translator may have created them out of order (records resulting from the EXPAND control statement are marked out of order). Such records may contain discontinuities in addresses (because of a reorigin or a disjointed control section), or they may not be contiguous (that is, text of a given ID and multiplicity may be interspersed with text of other IDs or multiplicities). Records of contiguous text must be built on SYSUI1 so that during second pass processing, the text can be placed into its proper position, within its ID and multiplicity, in the second pass text buffer. The first occurrence of a given ID and multiplicity is read into the input text buffer as it is received. Discontinuities and noncontiguous text are of no consequence at the first occurrence of an ID and multiplicity. However, once text of a given ID and multiplicity has been written out on SYSUT1, any subsequent text of that ID and multiplicity must be contiguous to be written out on SYSUT1 within each text record. > Text of a previously written ID and multiplicity is read into the input text buffer until a discontinuity, or text of a different ID or multiplicity, is encountered. The contiguous text in the buffer is then written out on SYSUT1. The discontinuous (or noncontiguous) text is then placed in the buffer. If this text represents the first occurrence of an ID and multiplicity, the buffer is loaded without regard for discontinuities or noncontiguous text. If the text belongs to a previously written ID and multiplicity, the text processor will again place only continuous text of that ID and multiplicity in the buffer. > A record that contains noncontiguous text is called a <u>loose</u> record; a record that contains contiguous text is called <u>dense</u>. The text note list entry for a dense record usually has a nonzero value in the displacement field. When the text is read back from SYSUT1 into the second pass text buffer, during second pass processing, this displacement is used to place the text in its proper position within its ID and multiplicity. #### Processing Load Module Text Because text records from load modules are ordered and well-defined, they require little further processing by the text processor. The information in the <u>ID-length list</u> (in the control record) is scanned, and each ID is renumbered and checked to determine whether it is to be deleted. If all IDs are to be deleted, the record is ignored, and control is returned to the input processor. When an ID that is to be processed is found, the text record containing the ID must be read into TXTBFBEG. The text record length is obtained from the associated control record and compared against the free space available in TXTBFBEG. sufficient space is available, the text record is read into the buffer; otherwise, the contents of the buffer are written on SYSUT1 to ensure sufficient space, and the record is read. Text is processed in the buffer in the order specified by the ID-length list. IDs that are to be deleted are overlaid by IDs that are to be processed. The text is divided into multiplicities, and entries are made in the text I/O table and the text note list. When all text identified by the ID-length list is processed, text processing is completed. ## Writing Text on SYSUT1 When no more control sections can be accommodated in TXTBFBEG, the contents of the buffer must be written on the <u>intermediate</u> data set (SYSUT1). The text I/O table is scanned to determine the order in which control sections are to be written. length of the first control section (that is, corresponding to the first text I/O table entry) is obtained from its corresponding ESD ID; if the length is less than the size of the SYSUT1 record, the text I/O table entry for the control section is marked "written." Each subsequent control section is similarly processed, and its length added to the sum of the lengths of previously processed control sections. When the sum of control section lengths reached the limit of a SYSUT1 record, the entire group of control sections is written on SYSUT1. The relative track address (TTR) is placed in the text note list entry corresponding to the last text I/O table entry that was processed. When a single control section is larger than a SYSUT1 record, the multiplicities of the control section are grouped, up to the limit of the SYSUT1 record size, and written.<sup>6</sup> When control sections or multiplicities are grouped on SYSUT1, the multiplicities must be in ascending, consecutive order. If the overlay attribute has been specified, no grouped control sections are permitted on SYSUT1. NOTE: Each time an entry is made in the text note list during text processing, a check is made to determine whether the list is full. If it is full, the contents of TXTBFBEG are grouped (if possible) and written on SYSUT1, and the TTRs are placed in the text note list. The list is then written on SYSUT1, and its address is noted in the <a href="I/O control table">I/O control table</a>. The text note list may be written a maximum of 11 times. If neither TXTBFBEG nor the text note list becomes full during text processing, no text is written on SYSUT1. The text is retained in the buffer, and <u>single pass processing</u> is in effect for text records. #### **RLD Processing** RLD processing basically consists of: - Updating each set of relocation and position pointers (R and P Pointers) - Processing each flag and address (FA) in the input item until the end of the record or the next item with an R and P pointer is detected RLD records from object modules and load modules are processed in the same manner. RLD information is grouped in the RLD buffer by P pointer. Each P pointer of an input RLD record refers to the ESD entry in the input module for the control section that contains the address constant. Each time a new P pointer (one referring to a different ESD ID) is detected, an entry is made in the RLD note list for the RLD set (a set being an unbroken sequence of RLD items having the same P pointer). The RLD note list entry contains the following information for each set: - The renumbered P pointer to which these RLDs refer. - The lowest multiplicity of text to which these RLDs refer. - The number of bytes of RLDs. - The storage address of the first byte of RLD data if all RLDs remain in virtual storage. If RLDs are written on SYSUT1, this field contains the accumulated byte count for intermediate chains or the TTR of the record on SYSUT1. All adjacent RLD items containing the same P pointer are referred to by only one RLD note list entry. Adjacent RLD items containing the same R and P pointers are chained, with the R and P pointers appearing only once, at the beginning of the chain. The remaining RLDs in the chain are compressed by setting the flag indicating continuation and discarding the four bytes containing the R and P pointers. Each R pointer of an input RLD record refers to the ESD entry in the input module upon whose value the address constant depends. The R and P pointers are updated, using the renumbering table. Before renumbering, the R and P pointers refer to ESD entries of the input module that contains the RLD items. The pointers are renumbered so that they point to the proper entries in the CESD being created for the output load module. If the R pointer refers to a deleted ESD entry, delinking may be performed. If If the SYSUT1 record size is smaller than the SYSLMOD record size, no grouping is permitted. the assigned address of the symbol referred to by the address constant is zero, the address constant is not delinked. (Normal relocation is performed.) When delinking is necessary, an entry is placed in the delink table (a function of ESD processing). The delink table entry contains the address (delink value) of the symbol being deleted and the CESD entry number of the identically named symbol that is to replace the deleted symbol. The ID of the delink table entry for the deleted symbol is saved in the renumbering table, and a "delink value saved" indicator is set. The ID of the identically named symbol and the ID of the new delink table entry are saved because they are later used to complete the delinking operation. The R pointer of the RLD item must be modified to refer to the delink table entry for the deleted symbol, but the original R pointer is needed to process any V-type address constants referred to in the RDL item. (V-type address constants do not require delinking, but may be in a FA string with A-type address constants that do require delinking.) Therefore, the R pointer is not modified until the string of flag-address (FA) fields following the R and P pointers has been processed as described below. At that time, if the module is to be structured for overlay and it contains V-type address constants that refer to the deleted symbol, the ID of the identically named symbol is inserted into the calls list. Each FA field of the RLD record is processed as follows: - The high-order bit of the flag field is set to zero. - entry referred to by the R pointer is checked to determine whether it is marked as a PR type. If it is a PR, the RLD flag field is also marked PR (because second pass processing must handle PRs in a special manner). If the renumbering table entry is not an ER or marked delete, the RLD flag field is marked for relative relocation. This indicates to second pass processing that the difference between the origin of the control section in the input and the origin assigned by the linkage editor is to be used as a relocation factor for the value of the address constant. If the RNT entry is an ER or marked delete, the RLD flag field is not marked. This indicates to second pass processing that the address constant is to be relocated by absolute relocation; second pass processing uses the linkage editor assigned address of the symbol in the output module as a relocation factor for the value of the address constant. (This procedure is described in "Second Pass Processing.") - If the address constant is a 4-byte V-type ("branch-type") and the program is in overlay, an entry is placed in the calls list, provided that the address constant refers across control sections (R not equal to P). The calls list is used during address assignment processing to determine which segments require ENTABs and the number of entries each ENTAB must contain. - For both A-type and V-type address constants, the text multiplicity of the address field is determined and is saved in the RLD note list if it is lower than any previous multiplicity in the RLD record. If two pass processing is in effect, the RLD note list is used during second pass processing to read back RLD data from SYSUT1 (each RLD note list entry contains the relative track location (TTR) of an RLD record on SYSUT1). The second pass processor uses the multiplicity field of the RLD note list entry to determine whether the associated RLD record should be read back from SYSUT1 for a given multiplicity of text. - When the last FA field in the string has been processed, all items in the string have been checked to determine whether they require delinking. If any A-type address constants in the string required delinking, the R pointer for the string is modified to refer to the associated delink table entry. Figure 16 shows the actions performed during RLD processing for each input flag format, and the format of the flags after RLD processing. (The "output" column shows the flag formats that are passed as input to the Relocation routine of second pass processing; see Figure 27 on page 69.) After all FA fields have been processed, the next RLD record processed. If the RLD buffer becomes full, its contents must be written on the <u>intermediate data set</u> (SYSUT1). The RLD buffer is allocated with a maximum length less than or equal to the size of a SYSUT1 record, so the entire buffer may always be written. As many consecutive RLD sets as possible are grouped in a SYSUT1 record. | Input | | | Output | | | |-----------------------------------------|-------------------------------------------|---------------------------------------------------------------------------------------------------------------|------------------------------------|------------------------------|--| | Flagl | Type | Action Performed | Flag | Type | | | OOOOLIST | Not PR,<br>ER, WX,<br>CM, or<br>delete | Marked for relative relocation | 1000LIST | Relative | | | OOOOLIST | ER ('02'<br>in renum-<br>bering<br>table) | Marked for absolute relocation | 0000LIST | Absolute | | | 0000LIST | Delete or<br>CM ('05') | Marked for absolute relocation if assigned address of input item is zero | 0000LIST | Absolute | | | 0000LIST | PR('06') | Marked as PR (displacement value) | 0010LIST | Pseudo<br>Register<br>Type 1 | | | OOOOLIST | Delete or<br>CM | Marked "delink value saved" if assigned address of input item is not zero | High-order<br>bit of P<br>pointer | Delink | | | 0001LIST | Type is<br>not<br>checked | RLD is marked branch-type | 0001LIST | Branch | | | 0001LIST<br>or<br>1001LIST <sup>2</sup> | Delete | Marked "delink value saved and other FA items in string exist that are nonbranch-type" and are being delinked | High-order<br>bit of P<br>pointer. | Delink | | | 0010LIST | Pseudo<br>Register<br>Type 1 | None. Remains as a PR<br>(displacement value) | 0010LIST | Pseudo<br>Register<br>Type 1 | | | 0011LIST | Type is<br>not<br>checked | Marked as PR (cumulative length) | 0011LIST | Pseudo<br>Register<br>Type 2 | | Figure 16. RLD Flag Field Processing ## Notes to Figure 16: - Refer to "RLD Input Record (Card Image)" and "Relocation Dictionary Record (Load Module)" in "Appendix. Input Conventions and Record Formats." - Internal types processed during second pass. > The RLD note list entry for each RLD set in the group contains a "grouped" indicator; the note list entry for the last RLD set in the group also contains the relative track address (TTR) of the group. > RLD sets whose lengths exceed that of a SYSUT1 record (requiring more than one output record) are not grouped. RLD note list entries for RLD sets that are not grouped contain the relative track location (TTR) of the SYSUT1 record and a "nongrouped" indicator. > Each time an entry is made in the RLD note list, a check is made to determine whether the list is full. If it is full, the RLD sets in the RLD buffer are grouped and written on SYSUT1, and the TTR is placed in the appropriate RLD note list entry. The RLD note list is then written on SYSUT1 and its address is noted in the "I/O control table." The RLD note list may be written a maximum of three times. Note: If neither the RLD buffer nor the RLD note list becomes full during RLD processing, no RLDs are written on SYSUT1. The RLD information is retained in the RLD buffer, and <u>single pass</u> <u>processing</u> is in effect for RLDs. ### END Processing When an END record or the end of an input load module is detected, END processing is required. The functions of END processing include: - Resetting tables (such as the renumbering table) that were involved in the processing of the input module - Processing entry point information - Deleting any CESD lines marked CHAIN or DELETE, and keeping track of deleted lines - Entering in the CESD the length of a control section for which no length was specified in the ESD item (if the length is contained on the END record) - Setting flags in the ORDER table for each entry matched by an entry in the CESD and resetting the flag for formerly matched entries - Placing the data from END records in object modules created by a translator that supports IDR into the IDR translator ID and data tables, IDRTRTAB, and IDRTITAB ### Include Processing Include processing is required when: - The control statement scanner has detected an INCLUDE statement and the INCLUDE statement processor has built an include chain. - End-of-input has been detected, and the "more includes" indicator in the all-purpose table (APT) is on. Include processing consists of preparatory functions (OPEN, BLDL, FIND) required before the module to be included can be read. These functions include: - An input pointer to the <u>library read block</u> is set. - The SYSLIB DCB is closed (unless it is open for a partitioned data set currently being used). - Each entry in the include chain is examined sequentially. > SEQUENTIAL DATA SETS: If an include chain entry specifies a sequential dat set, the data set organization field of the DCB is changed from partitioned to physical sequential, and the ddname field is updated. The DCB is then opened, and the module is read in. > PARTITIONED DATA SETS: If an include chain entry specifies a member of a partitioned data set, the member name is entered into the <u>BLDL list</u>, and the next entry is examined. If the next entry specifies a different data set name, the partitioned data set is opened and a BLDL macro instruction is executed for the single member name. > If the next entry specifies another member of the same partitioned data set, the member name is added to the BLDL list and the next entry in the include chain is examined. Member names are added to the BLDL list until a different data set name is encountered, the BLDL list becomes full, or the end of the include chain is reached. Because the BLDL list must be in collating sequence, each member name is inserted into its proper position, moving other entries as necessary. Because included modules must be read in the order in which they appear in the INCLUDE statement (without regard to the collating sequence), a separate table, indicating the order of processing BLDL list entries, is maintained. > When the BLDL list is completed, the partitioned data set is opened and the record format field (RECFM) in the DCB is tested to determine whether the included modules are load modules (undefined format) or object modules (fixed format). If they are load modules, the "load module" indicator is set in the APT. This indicator is tested when each module is read in. A BLDL macro instruction is then executed for the member names in the list. The list is then examined in the order specified in the INCLUDE statement to obtain the attributes of each included module (if it is a load module); the attributes of the output load module may be "downgraded" accordingly in the APT. > If the BLDL macro instruction was successful for a particular member, the member is read in. The FIND macro instruction and the directory entry obtained from BLDL are used to set a pointer in the DCB to the first record of the member. If the BLDL was not successful for a particular member, a diagnostic message is printed. The INCLUDE processor checks the PDS directory information returned by BLDL for an included load module to determine whether the load module is in overlay format. If it is, an indicator is set in the all-purpose table so that the ESD processor can interpret byte 12 of each ESD item as a segment number rather than as AMODE/RMODE data. An example of INCLUDE processing is given in Figure 17 on page 49. The input pointer is set to the address of the library read block. The address of the current include item is contained in the APT. Assuming that no includes have yet been processed. A will be the first item examined. The subtype 'D0' indicates that A is a member of a partitioned data set, so A will be entered into the BLDL list. The pointer 000D refers to the data set DATASETX. The next item in the include chain, B, is also a member of DATASETX, so it is added to the BLDL list. The next item in the chain, M, is a sequential data set (subtype CO), so the BLDL list is completed with two entries (A and B). Assuming that DATASETX is not currently open and the SYSLIB DCB is not opened for another data set, the SYSLIB DCB is opened for DATASETX. (The RECFM field of the data set DSCB is merged into the DCB.) Assuming that the RECFM field indicates undefined (U) format, a load module indicator is set in the APT, and a pointer to the load module buffer is placed in the library read block. The attributes of A and B are obtained, using the BLDL macro instruction, and the attributes previously specified are updated accordingly. (The attributes of the output load module may be downgraded as a result.) A pointer in the DCB is then set to the first record of member A, using the FIND macro instruction, and the "include initiated" indicator is set in the APT. Figure 17. Include Processing Member A is read using the input pointer and library read block. Module A is then processed. When the end of module A is reached, item A is deleted from the chain and the CESD line is marked null. Member B is then read and processed. When the end of module B is reached, item B is deleted from the chain, the CESD line is marked null, and the remainder of the chain is processed. ## Automatic Library Call Processing Automatic library call processing is required: - At the end of SYSLIN input when unresolved ERs still exist, and the NCAL option was not specified - When a NAME statement has been detected (provided that the NCAL option was not specified and no more entries in the include chain are to be processed) Automatic library call processing consists of two series of CESD scans. The first series of scans operates on unresolved ERs specified on LIBRARY statements. It finds the first ddname that contains a pointer in the chain pointer field (bytes 14 and 15). Such an entry is the first item in a chain of members associated with this ddname; there is a distinct chain for each ddname that was specified on a LIBRARY statement. Chained member names for a particular ddname are entered into a <u>BLDL list</u>, which is processed as previously described under "INCLUDE Processing." The scan of the CESD continues until all ddname chains have been processed. A second scan of the CESD then searches for ERs not specified on LIBRARY statements and attempts to resolve them by calling members of the same name from SYSLIB.<sup>7</sup> An example of automatic library call processing is given in Figure 18 on page 51. Diagram A shows two library chains that were built in the CESD by the library statement processor. In Figure 17 on page 49, Diagram B, an SD item for JOE has been entered in the CESD, resolving the reference to JOE. (JOE was removed from the chain by ESD processing, and the LIB1 chain ID now points to the line containing TOM.) Automatic library call processing operates on the library chains, as modified by ESD processing (Diagram B). In the first series of scans, the CESD is searched for a ddname (type 02, subtype B0) with a chain pointer. The ddname item LIB1 is found; its chain ID points to TOM. Because TOM is unmatched (subtype 02), it is not called and because TOM is the last item in the chain (0 in the chain ID field), the scan is resumed for another ddname with a chain pointer. LIB2 is found; its chain ID points to SAM. No call is issued for SAM, because it is unmatched. The chain ID of SAM points to PETE, which is matched (indicating that PETE is an external reference, and not just an operand of a LIBRARY statement). PETE is entered in the BLDL list; because PETE is the last item in the chain, the list is completed with one entry. LIB2 is opened and the BLDL macro instruction is used to obtain the attributes of PETE (the attributes of PETE are not obtained if the format is fixed (F)). A "BLDL attempted" indicator is set for the CESD entry for PETE so that no other search for PETE will be made in the event of an unsuccessful BLDL or nonresolution of the ER for PETE by the member PETE. The FIND macro instruction is used to set a pointer in the SYSLIB DCB to the member PETE. PETE is then read in. When processing for PETE is completed, the scan for ddnames resumes at the beginning of the CESD, rather than at the CESD line where the scan was interrupted, because additional ddname items may have been entered at any available line in the CESD. (Object modules with additional LIBRARY statements may have been read in.) When the last line of the CESD is reached, the second series of scans is begun. <sup>5</sup>YSLIB is the standard library whenever the linkage editor is executed as a job step. If another program links to the linkage editor, the ddname of the standard library is passed in a parameter list. | | | gram | _ | | Sub- | | | |------------------------------|----------------------------------|-----------|-----------------------------|----|-----------------------|----------|---------------------------------------| | CESD | | Туре | | | Type | | | | 0 | | 8 | | 12 | 13 | | _ | | LIBI | | 02 | 00 | + | ВО | 04 | ᅴ. | | | | + | | + | - | | | | JOE | | 02 | 02 | | 03 | 0A | | | SIMPLE | | 02 | | | 00 | | | | LIB2 | | 02 | 00 | | ВО | 07 | _ - | | SAM | | 02 | 06 | | 02 | 08 | | | PETE | | 02 | 07 | + | 03 | 00 | | | TOM | | 02 | 04 | + | 02 | 00 | ٦, | | | | | | 1 | | | 7 | | | | | | | | | | | | | <u> </u> | L | | | L | | | | | | | | | | | | | Diag | ram | В | | | | | | CESD | <del></del> | | - | | | | | | CESD<br>0 | Diog<br>8 | gram<br>9 | 10 | 12 | 13 | 14 | 15 | | 0 | 8 | | 10 | 12 | | | | | | <del></del> | | - | 12 | 13<br>B0 | | 15 | | 0 | 8 | | 10 | 12 | ВО | | | | LIBI | 8 02 | 9 | 10 | 12 | ВО | | | | O<br>LIBI<br>JOE | 02 | 9 | 10 | 12 | B0<br>012<br>00<br>B0 | | \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ | | JOE<br>SIMPLE<br>LIB2<br>SAM | 02<br>00<br>00<br>02<br>02<br>02 | 9 | 10<br>00<br>273<br>00<br>06 | 12 | 012<br>00<br>80<br>02 | 1E3 | | | LIBI JOE SIMPLE LIB2 | 02<br>00<br>00<br>02<br>02 | 9 | 10<br>00<br>273 | 12 | B0<br>012<br>00<br>B0 | 1E3 | | | JOE<br>SIMPLE<br>LIB2<br>SAM | 02<br>00<br>00<br>02<br>02<br>02 | 9 | 10<br>00<br>273<br>00<br>06 | 12 | 012<br>00<br>80<br>02 | 7<br>1E3 | | Figure 18. Automatic Library Call Processing During the second series of scans, the CEDS is searched for "unmarked" external references (type 02, subtype 00). These are ER items not specified on LIBRARY statements. In Diagram B, the scan finds SIMPLE. Assuming that SYSLIB is the ddname for the standard library, SIMPLE is called from SYSLIB in the same way that PETE was called from LIB2. Every time automatic library call processing is resumed after a module is read, the second series of scans resumes at the beginning of the CESD (because ER items from a library member may have been entered in any available CESD line). When the second series of scans is finished, input processing is complete. ## INTERMEDIATE PROCESSING The intermediate processing comprises modules HEWLFADA, HEWLFOUT, HEWLFENS, HEWLFENT, and (optionally) HEWLFMAP. When all input processing is completed, the second phase of the linkage editor (intermediate processing) begins operation. The two major functions of the second phase are address assignment and intermediate output. ### ADDRESS ASSIGNMENT At the conclusion of input processing, address assignment processing is required (see Diagram 13). Address assignment includes the following operations: - Delete CESD entries for ER items marked included, called, ddname, or overlay in the subtype field. These lines are marked null and are deleted if the module is processed again in a subsequent execution of the linkage editor. - Compute, for programs in overlay, the size of SEGTAB,<sup>8</sup> enter the size in the all-purpose table, and place a private code delete entry for the SEGTAB in the CESD. The PC-delete entry is deleted from the module if it is processed again by the linkage editor (see Diagram 13, area A). - Determines whether the first text record of a load module is not assigned to address 0. If it is not assigned to address 0, a private code delete entry of one byte is created in the CESD. The PC-delete entry is deleted from the module if the module is later reprocessed by the linkage editor. - Enter segment numbers for label references in the CESD. If the program is in an overlay structure, the calls list (built during RLD processing) is also scanned, and pointers from one chain of calls to the next chain are entered (area B); the number of ENTAB bytes for each segment is determined; and a PC-delete entry is placed in the CESD for each ENTAB (see "ENTAB Size Determination"). - Assign temporary linked addresses to SD, PC, and CM entries in the CESD (area C). SDs and CMs that have entries in the ORDER table are addressed first in the order of their appearance in the table. The remaining control sections are then assigned addresses to the SDs, PCs, and CMs that have no entries either in the ORDER table or the text I/O table. To avoid assigning addresses to any SD or CM more than once, a "processed" bit (bit 4 of the 'type' byte in the CESD) is set in each CESD entry when it is first processed. The bit is reset to zero in the final scan of the CESD. - Consider each segment to be at zero origin. The temporary starting address of each control section is computed with consideration for its location in the segment, relative to the zero origin (plus any adjustments for boundary alignment). These addresses are temporary because the starting addresses of the segments must later be relocated with respect to their positions in the overlay tree. If the program is not in overlay (consists of a single segment), the addresses are final, because no further relocation by address assignment is necessary. - Perform page alignment while assigning temporary linked addresses if the program is not in overlay. The ORDER table is searched for a match of the CESD ID of the SD or CM being processed. When a match is found, and page alignment is specified, the assigned address is forced to a 4K-byte boundary. If the ALIGN2 option is taken, the address is forced to a 2K-byte boundary. - Compute the temporary relocation constant for each control section (the difference between the temporary linked address and the assigned address in the relocation constant table (RCT) (area D). If the program is not in overlay, these are the final relocation constants (relative relocation factors). SEGTAB size = $24 + (4 \times number of segments)$ . <sup>9</sup> ENTAB size = 12 + (12 x number of unique downward calls per was segment). - Accumulate the length of each segment in the leftmost 3 bytes of an entry in the segment length table (SEGLGTH). The boundary alignment factor of the first control section in the segment is placed in the fourth byte of the entry. - Determine the address of each PR entry in the CESD, using the total length of all PRs previously encountered, plus the boundary alignment factor. This address is placed in the CESD entry for the PR. The length of this PR is then added to the cumulative PR length. - Process the SEGLGTH table (if the program is in overlay) to determine the starting address of each segment, relative to the beginning of the program (area E). SEGTA1 is checked to find the proper location of each segment in the tree. SEGLGTH at this time contains the length of each segment. To determine the starting address of a segment, the length of all previous segments in the same path are added, together with any adjustments for boundary alignment. (Boundary alignment adjustment is determined by the last ${f 3}$ bits of the address of the first control section in a segment.) This sum, minus the boundary alignment factor for the segment, is the <u>segment relocation constant</u> (SRC). SRC is then placed in the rightmost 3 bytes of the SEGLGTH table. The sum of the SRC, the boundary alignment factor, and the segment length is placed in the leftmost 3 bytes of the SEGLGTH table entry for the segment. It is the length of the path of the segment (including the segment itself). At the completion of this process, the entry in SEGLGTH for each segment contains the cumulative length of its path; the longest of these lengths is the program length. - Perform a second scan of the CESD if the program is in an overlay structure. The segment relocation constant in the SEGLGTH table is added to the temporary linked address in the CESD entry for the control section; this sum is the final linked address. The SRC is also added to the temporary relocation constant table; this sum is the final relocation constant for the control section. - Assign final linked addresses in ascending order of segments if page alignment is specified for any SD or CM type symbol. For each segment, three cycles of scanning are performed. First, SDs and CMs having entries in the ORDER table are processed. The final address is calculated by adding the SRC and the temporary linked address, and is aligned on a page boundary, if required. A cumulative count of any increment within a segment caused by page alignment is kept, in order to assign correct addresses to the unprocessed SDs, PCs, and CMs. Next, the text I/O table is scanned for the remaining SDs and PCs in the segment. These SDs and PCs are assigned final addresses. Finally, a scan of the CESD gives addresses to all unprocessed SDs, PCs, and CMs in the segment. For every processed SD, its entry in the relocation constant table is calculated. Before going on to the next segment, the length of the segment just processed and the SRC of the next segment are updated. - Make a final scan of the CESD to assign a final linked address to each label reference. - The CESD entry for each LR contains a reference to the The relocation control section in which it resides. constant for that control section is located in the RCT and is added to the temporary linked address in the CESD entry for the LR. This sum, the final linked address for the LR, is placed in the CESD. - Mark the program as not executable if there are still unresolved ERs and if neither the NCAL option nor the LET option has been specified. Unresolved WXs do not inhibit program execution. > Build the alias table and compute an entry point for the program (see "Entry Processing"). #### ENTAB Size Determination ENTAB size determination consists of computing the size of ENTABs so that the size of each segment in an overlay program can be determined and relative relocation factors can be computed for use by second pass processing. The size is determined by the number of downward calls, or calls across regions, to symbols that are not referred to by segments higher in the path of the calling segments. An example of ENTAB size determination is given in Figure 19 on page 55. The overlay tree structure shown in the illustration consists of nine segments residing in two regions; all references between segments are made using V-type address constants. Functions of ENTAB size determination are: - Scanning the CESD for LR entries and entering their segment numbers. In Figure 19, item 6 is an LR item; its ID/length field points to the CESD entry for the control section in which it resides (line 3). The segment number contained in line 3 (segment number 3) is entered in the segment number field of the LR item. - Scanning the calls list, inserting chaining values that point from one group of R and P pointers to the next. - Scanning the calls list for each segment (starting with segment 1), and finding symbols referred to by that segment. For each reference found, the type of call (upward, downward, or exclusive) is determined. If an ENTAB is required for the segment, its size is determined and a PC-delete entry for the ENTAB is made in the CESD. Referring to Figure 19, the segments are processed in the following manner: - 1. The calls list is scanned for P pointers that refer to control sections in segment 1. If one is found, the associated R pointers (which refer to referenced symbols) are examined to determine the segment in which each referenced symbol resides. In Figure 19, the fifth P pointer refers to line 7 of the CESD, which contains an SD entry for a control section in segment 1. The associated R pointers refer to line 6 (symbol B in segment 3) and line 4 (symbol C in segment 5). For each reference, the type of call (upward, downward, or exclusive) is determined, using SEGTA1 and the segment numbers of the calling and called segments. In Figure 19, SEGTA1 indicates that segment 1 is in the path of segments 3 and 5; therefore, the calls from segment 1 to B and C are downward calls. This is noted in the downward calls list by entering segment number 1 in the lines referred to by the R pointer (lines 6 and 4). Since segment 1 is the root segment, it must have an ENTAB; the size of the ENTAB is determined and a PC-delete entry for it is created in the CESD. - When the scan for segment 1 is completed, the calls list is scanned for P pointers that refer to segment 2. In Figure 19, the third P pointer in the calls list refers to CESD line 6, which contains segment number 3. In this case, however, no entry is made in the downward calls list because it indicates a call to B in segment 3 from segment 1, which is higher in the path of the calling segment (segment 2). No ENTAB is required for segment 2 because the reference to symbol B in segment 2 can be resolved through the ENTAB entry in segment 1. - 3. The calls list is scanned for P pointers that refer to segment 3. In Figure 19, the fourth P pointer in the calls list refers to CESD line 3 (segment 3). The R > pointer refers to CESD line 8 (segment 8). SEGTA1 indicates that the call from 3 to 8 is downward, across regions, and the call is noted in the downward calls list. Segment 3 requires an ENTAB, because it contains a downward call to a symbol not referred to by a segment in the path of the calling segment; the ENTAB size is determined, and a PC-delete entry for the ENTAB is created in the CESD. The calls list is scanned for P pointers that refer to segment 4. In Figure 19, the first P pointer in the calls list refers to CESD line 9 (segment 4). The R pointers refer to line 2 (segment 2) and line 8 (segment 8). SEGTA1 indicates that the call from 4 to 2 is upward, while the call from 4 to 8 is downward, across The upward call is ignored, because the address constant can be resolved directly to the referenced symbol. The downward call from 4 to 8 is noted in the downward calls list, replacing the previous entry for segment 3 (because no segment with a segment number greater than 4 can have segment 3 in its path). Because an ENTAB is required, the size is determined and a PC-delete entry is created in the CESD. This process continues until all segments have been processed. The required ENTABs are built during second pass processing (see "ENTAB Creation" and "Relocation of V-Type Address Constants in Overlay"). Figure 19. ENTAB Size Determination #### Entry Processing Entry processing includes the following operations: - entering in the alias table any alias symbols that were chained together and saved in the CESD by the ALIAS statement processor. Each entry in this table consists of an 8-byte symbol field and a 2-byte ESDID field. For each saved alias symbol, the entry processor scans the CESD for a matching SD or LR entry. If no match is found, a zero is placed in the ESDID field of the alias table entry for the symbol. If a matching SD or LR entry is found, the ESD ID of the alias entry in the chain is placed in the ESDID field of the alias table entry for the symbol (see Figure 20 on page 57). The address assigned by linkage editor to the matching SD or LR and the ESD ID of its control section are placed in the CESD entry for the chained symbol, and the type of the chained symbol is changed to null. - Determining whether the entry point was specified as an address on an END record, or as a symbol on an ENTRY statement or END record: - 1. If the entry point was specified as an address on an END record, the assigned address is determined by either absolute or relative relocation. If the ID on the END record referred to an ER which was resolved with an SD or LR, the address assigned by the linkage editor to the SD or LR is added to the address from the END record (absolute relocation). If the ID on the END record referred directly to an SD or PC, the relocation constant for the SD or PC is added to the address from the END record (relative relocation). - If a symbolic entry point was specified on an ENTRY statement or END record, the CESD is scanned for a matching SD or LR symbol. The address of the matching symbol is used as the entry point. - 3. If no entry point was specified, the starting address of the SD or PC control section (not marked delete) with the lowest assigned address is chosen as the entry point. The entry point associated with the main name (not an alias) and all alias entry points must be in segment 1 if the program is in overlay. - Assigning the addressing mode for the main entry point into the output load module. If the load module is in overlay format, the addressing mode is 24; otherwise, the addressing mode is obtained from the CESD entry that defines the SD or PC that contains the entry address. The addressing mode, along with the entry address and the ESDID of the SD or PC, is saved in the all-purpose table. ## INTERMEDIATE OUTPUT PROCESSING Intermediate output processing includes the following operations: - Writing out the CESD on SYSLMOD in groups of 15 entries per record. The last record may consist of less than 15 entries. In writing CESD records on to SYSLMOD, the intermediate output processor sets a flag in the control information indicating the content of byte 12 in the CESD entries in the record. If the CESD entries contain segment numbers (that is, the load module is in overlay format), the flag is off; if the CESD entries contain AMODE/RMODE data, the flag is on. - Building and writing out the IDRs from the IDR tables (IDRTRTAB, IDRTITAB, IDRUDTAB, and IDRZPTAB) onto SYSLMOD. The linkage editor IDR is also built and written on to SYSLMOD. - Building a half ESD (HESD), consisting of the last 8 bytes of each CESD entry. (The symbol is deleted from each CESD entry to conserve virtual storage space during second pass processing.) The HESD is not complete at this time. (The ID of each label reference is used in building the scatter and translation tables.) - Building and writing out the segment table (SEGTAB), preceded by a control record describing it, if the program is in overlay. SEGTAB contains information required by the overlay supervisor. - Building and writing a one byte text record if the first load module text record does not begin at address 0. The 1-byte text record is preceded by a control record describing it. - Building a scatter table and a translation table for a program that is to be scatter loaded and writing out scatter/translation records in a form acceptable to program fetch at execution time. The scatter/translation information is written out on SYSLMOD in 1024-byte records. Figure 20. Processing of Alias Symbols by the Entry Processor > The first 4 bytes of each record are used to identify the records as scatter/translation information. If the length of scatter/translation information is greater than 1020 bytes, the last 1020 bytes (plus 4 bytes of header information) are written out as the first scatter/translation record. The data in the last record may be 1020 bytes, or less (see Figure 21). In creating the scatter table entries, the RMODE/RSECT data is obtained from the HESD entries (byte 4) and inserted into the flag byte. Figure 21. Writing Scatter/Translation Records - Reading the TXT and RLD note lists into virtual storage if they were placed on SYSUT1 during TXT and RLD processing. The text note list may have been written a maximum of 11 times and the RLD note list a maximum of 3 times on SYSUT1 for a large program. The TTRs pointing to the locations of note list information are contained in the input/output control table in the all-purpose table. - Determining the control section containing the last text in the program (or in each segment, if the program is structured for overlay) and the highest segment number of the segments that contain text. (This information is necessary so that second pass processing can determine when to set the end-of-segment or end-of-module indicator.) The highest ESD ID is determined by scanning the text I/O table for the ESD IDs of control sections that contain text. ESD ID is entered into the <u>high ID</u> (HIID) table along with its associated segment number. - Determining, via bits in the <u>all-purpose table</u> (APT), if the MAP option has ben specified or if the XREF option has been specified and all RLDs are in storage. If either of these conditions exists, the module map and/or the cross-reference table are produced. If the XREF option is specified and all RLDs are not in storage, XREF processing will be done as part of final processing. - If the ORDER option has been invoked during input processing, the text I/O table and the text note list II (formed after merging all text note lists from SYSUT1) are sorted according to the ORDER table. The sorting, however, preserves the original order for those control sections that do not have entries in the ORDER table. #### MAP/XREF Processing When MAP/XREF processing is performed as part of intermediate output processing, a table address is obtained from the APT, and a table of 2-byte entries pointing directly to the CESD is constructed. The CESD records for the current segment are gathered and sorted by address. The module map is then printed out; the map lists, in ascending order according to their assigned origins, all control sections contained in the output module and the entry points within the control sections. Control sections in an overlay output module are grouped by segment. If XREF processing is done during intermediate output processing, RLD items are incompletely relocated; their addresses are relative to the origins of their respective CSECTs rather than the origin of the load module, and the address of each RLD must be added to the linkage editor assigned address of its corresponding control section before the cross-reference table is produced. The cross-reference table includes a module map and a list of all references within a given segment that refer across control section boundaries. Each entry in the list contains the address of the reference, the symbol to which it refers, and the name of the control section in which the symbol is defined. For overlay programs, each item in the list also contains the number of the segment in which the symbol is defined. If the MAP and XREF options are processed during intermediate output processing, disposition messages and the diagnostic message directory are printed after the module map and cross-reference table. If the cross-reference table is produced during final processing, the disposition messages and the diagnostic message directory are printed before the cross-reference table. ### SECOND PASS PROCESSING Second pass processing comprises modules HEWLFSCD and HEWLFREL. After intermediate processing is completed, the third phase of the linkage editor (second pass processing) begins operation (see Diagram 14). The major functions of second pass processing include: - Relocating address constants contained in the text. - Creating control/RLD records. - Writing TXT and control/RLD records on SYSLMOD in a format that can be loaded by program fetch. Included in the control information of the control or control/RLD record that precedes each text record is a count of the RLD and control/RLD records that follow the text record. This count is used by program fetch to build optional channel programs when loading the load module. - Creating ENTABs and associated RLD items for overlay modules. SINGLE PASS PROCESSING: Indicators residing in virtual storage in the text I/O table and the RLD note list are checked to determine whether text and RLD records have been written on SYSUT1 or have been retained in the input text buffer and the RLD buffer. If either text or RLD records have been retained in storage, single pass processing is in effect for that record type. If two pass processing is in effect, the records are read into the buffers from SYSUT1. ORDERING OF TEXT: In two pass processing, the ID sequence in the text I/O table is used to determine the order in which CSECTs are to be read into the second pass text buffer (which is physically the same storage area as the input text buffer). text I/O table entry for each ID and the corresponding text note list entry are used to locate text on SYSUT1 (see Diagram 14, area A). Text is read into the buffer one multiplicity at a time, using the displacement field in the text note list to determine where within the buffer the text must be placed. Information about the text is entered into the <u>second pass text</u> control table, which is used to control subsequent processing of the text (area B). SECOND PASS RLD BUFFERS: When the required text is in the text buffer, the corresponding RLDs are read into the RLD input buffer, using the RLD note list to locate the RLD records (area C). The RLD input buffer can contain two RLD records from SYSUT1; for each RLD input buffer area, an RLD input control block is maintained (area D). The RLD output buffer is 768 bytes long and is divided into three buffer areas (the maximum RLD output record is 256 bytes long); for each RLD output buffer area, an <u>RLD output control block</u> is maintained (area F). text is being relocated, the control record for that portion of text occupies one of the output buffers; the other two output buffers contain the relocated RLDs for the text being processed (area E). If the relocated RLDs exceed two buffers, the control record is written on SYSLMOD; relocated RLDs may then be moved into the third output buffer. When all three RLD output buffers and the RLD input buffers are filled and additional RLDs are required to relocate the text currently being processed, the contents of the output buffer must be written out. However, to maintain the required TXT/RLD sequence in the output module (area G), the associated text must precede the RLD record. Space for the text is reserved in the output module by writing the incompletely relocated text; the contents of the RLD output buffer may then be written, and processing can continue. When the text is completely relocated, it is written over the space reserved for it, using the XDAP ("execute direct access program") macro instruction. GROUPING SYSLMOD OUTPUT: As many CSECTs as will completely fit in one SYSLMOD record (up to a maximum of 60) are grouped and written as one record. RLDs are grouped to correspond to the grouping of their associated text. If the overlay attribute is specified, only CSECTs belonging to the same segment will be grouped. If a CSECT is larger than the SYSLMOD record size, the CSECT is divided into multiplicities, each multiplicity being equal to the SYSLMOD record size. The length of the last multiplicity may be less than the SYSLMOD record size. Each multiplicity is written as a record, followed by RLDs associated with only that multiplicity. Note: If the downward compatible attribute (DC) or the scatter format attribute (SCTR) is specified, CSECTs will not be arouped. END-OF-MODULE: When control sections for all segments of the output load module have been processed (determined via the "high ID" indicator in the HESD type field and the "last segment with text" field in the all-purpose table), indicators are set in the last control/RLD record to mark it as the end of the module. The control/RLd record is written out on SYSLMOD, and second pass processing is completed. Note: If the output load module is to be structured for overlay, a list of relative track addresses (TTR list) is created to be used by program fetch when it loads the segments into virtual storage for execution. The TTR list contains one entry for each segment in the overlay load module. Each entry contains the relative track address of the first record (control record) of a segment, except for the first segment, which contains the relative track address of the first text record. PC-delete control section that contains ENTAB entries in each segment where the text requires them and the RLD records required by program fetch to relocate address constants contained in the ENTAB entries are also created. #### Relocation of Address Constants There are two types of relocatable address constants: - Branch-type, such as DC V(X) - Nonbranch-type, such as DC A(X) The value of a branch-type or nonbranch-type address constant depends on a symbol in the CESD. To adjust an address constant to its proper value in the output load module, the linkage editor uses an absolute or relative relocation factor. absolute relocation factor is the address assigned by the linkage editor to the symbol on which the value of the address constant depends. The relative relocation factor is the difference between the address assigned to the symbol by the linkage editor and the address of the symbol in the input module. The relative relocation factor may be positive or negative. 10 The absolute and relative relocation factors of each symbol in the CESD are computed during address assignment and are saved in the half ESD (HESD). # Relocation of Nonbranch-Type (A-Type) Address Constants A <u>relative relocation factor</u> is used for a nonbranch-type address constant if the symbol on which its value depends is in the same input module as the control section that contains the address constant. (The address constant and the symbol it refers to were assembled or compiled together, or were previously processed together by the linkage editor.) An example of relative relocation of nonbranch-type address constants is shown in Figure 22 on page 62. Because the address of DICK is known, the language translator places it in the value of the address constant. DICK is a known value prior to linkage editor processing (not an external reference in the input); therefore, a relative relocation factor (+1000) is used to relocate DICK during linkage editor processing. If it is negative, an indicator is set in the HESD to note that it is in complement form. Figure 22. Nonbranch-Type Address Constants—Relative Relocation An <u>absolute relocation factor</u> is used for a nonbranch-type address constant if the symbol referred to by the address constant does not have a defined value within the same input module. (The R pointer of the RLD item refers to an external reference.) An example of absolute relocation of a nonbranch-type address constant is shown in Figure 23 on page 63. In this example, the value of SAM is unknown when input module 1 is processed by the language translator; therefore, zeros are placed in the value of the address constant. Dur second pass processing, the absolute relocation factor (the During linkage editor assigned address) is used to relocate the address constant. - \* Language translator inserts zeros because value of SAM is unknown. - + Actual address of SAM in the output module (0500) is added to value of address constant. Figure 23. Nonbranch-Type Address Constants—Absolute Relocation Figure 24 on page 64 shows the use of both a relative relocation factor and an absolute relocation factor in relocating a symbol. Two input modules are to be processed by the linkage editor. Input module 1 contains a nonbranch-type address constant whose value depends on the symbol PETE; PETE is an external reference in the same module. The language translator has assigned a value of +10 to the address constant. The R pointer of the RLD item refers to the ER entry for PETE in the ESD; this entry contains zeros in the origin and length fields. The P pointer refers to the SD entry for the control section that contains the address constant. Input module 2 contains two control sections, BOB and PETE. contains a nonbranch-type address constant whose value depends on PETE; because PETE has a defined value of (300) in the same module, the language translator has used that value to compute the value of the address constant (PETE + 10 = 310). pointer of the RLD item refers to the SD entry for PETE in the ESD; the P pointer refers to the SD entry for BOB (the control section that contains the address constant). During linkage editor processing, the ER and SD entries for PETE are merged into one CESD entry; the R pointers of both RLD items in the output module will refer to that entry. The RLD P pointer for the address constant in control section BILL will refer to the SD entry for BILL; the P pointer for the other address constant will refer to the SD entry for BOB. In the In the output load module, both address constants will contain the same value. Because the R pointer of the RLD item in input module 1 refers to an ER entry in the ESD in that module, it is marked for absolute relocation; the absolute relocation factor for PETE (+500) is added to the value (+10) assigned by the language translator. Because the R pointer of the RLD item in input module 2 refers to an SD entry in the ESD in module 2, it is marked for relative relocation; therefore, the relative relocation factor for PETE (+200) is added to the value (+300) assigned by the language translator. The relocated value for both address constants is 510. Relocation of all nonbranch-type address constants requires an addition or subtraction of the relocation factor to or from the value of the address constant in the text of the input module. (Addition or subtraction is specified in the flag field of the RLD item for the address constant.) Figure 24. Nonbranch-Type Address Constants—Absolute and Relative Relocation > DELINKING NONBRANCH-TYPE ADDRESS CONSTANTS: A relative relocation factor cannot be used to relocate an A-type address constant that refers to a symbol in a control section being Because the address constant has been previously replaced. relocated (by a language translator or by the linkage editor), it contains the value of a symbol being replaced; therefore, the value of that symbol must be subtracted from the value of the address constant. This process is called <u>delinking</u>. delinking, an address constant is reduced to the value it would have contained if it referred to an external reference in the input module. After delinking, the address constant contains the value required for proper relocation, should the replaced symbol appear later in the input, in another control section. Delinked address constants are treated as address constants whose values depend on external references. (Absolute relocation factors are used in relocating them.) Delinking of an A-type address constant is shown in Figure 25. Input load modules A and B both contain control section SAM. During linkage editor processing, the first occurrence of control section SAM is accepted, while the second occurrence is deleted through automatic control section replacement. Figure 25. Example of Delinking > Control section BILL in module B contains a reference to symbol JOHN in control section SAM. Because SAM in module B will be deleted, the address constant A (JOHN+50) in module B must be delinked so that it may be properly resolved with the symbol JOHN in module A. In delinking, the old value of JOHN is subtracted from the value of the address constant in BILL (120-70=50). The absolute relocation factor for JOHN (1**850)** is then added to the delinked value of JOHN (50+1850=1900). > DELINKING COMMON CONTROL SECTIONS: Common control sections (either blank common or named common) must be "delinked" by the linkage editor. All references to common control sections are made by means of nonbranch-type address constants. If the assigned address of a common control section in the input to the linkage editor is not zero, all such references must be delinked. Delinking is necessary, because during linkage editor processing all blank common control sections are collected into a single control section. All identically named common control sections are gathered into individual control sections; references to them from different input modules must be delinked so that they can be properly relocated with respect to the locations of the common control sections in the output module. Delinking adjusts the value of each address constant in a common control section so that it contains its correct displacement from the control section origin. The values of such address constants are then relocated so that they refer to the linkage editor-assigned addresses, using absolute relocation factors. ### Relocation of Branch-Type (V-Type) Address Constants Only absolute relocation factors are used to relocate branch-type address constants. Because a displacement is not allowed in the value of a V-type address constant, the absolute relocation factor is inserted in the value field during relocation. (It is not added to or subtracted from in value assigned by the language translator, as described for A-type address constants.) Because the value of a V-type address constant is inserted, delinking is never necessary for such address constants. Relocation of V-type address constants in an overlay structure is discussed in the following paragraph. RELOCATION OF V-TYPE ADDRESS CONSTANTS IN OVERLAY: If the output of the linkage editor is to be overlay load module, a 4-byte11 branch-type address constant in the path of the symbol it refers to (but in a different segment), or in a different region, will be relocated in a special manner. The value field of the address constant will contain the address of an ENTAB entry. The ENTAB entry will contain the address assigned by the linkage editor to the symbol referred to by the value of the address constant. An ENTAB entry is created for each V-type address constant. An initial entry is created for each v-type address constant that is in the path of the symbol it refers to (but is not in the same segment), or located in a different region, provided that the symbol is not referred to in a segment higher in the path of the calling segment. (Such address constants are resolved so that they refer to the ENTAB entry previously created for the symbol in the higher segment.) ENTAB entries are not created for address constants that refer to symbols higher in the path. Whenever an ENTAB entry is created, it is noted in an entry list; each item in the entry list contains the entry number of the referenced symbol in the HESD, the segment number of the calling segment, and the address assigned to the ENTAB entry by the linkage editor. The ENTAB creation routine Any address constant must be 4 bytes, because the high-order byte is used by the overlay supervisor during execution. The number of the segment containing the address constant will be placed in the high-order byte of any V-type address constant resolved to an ENTAB entry. (The high-order byte must be zero if it is not resolved to an ENTAB entry.) uses the entry list to build ENTAB entries (see "ENTAB Creation"). When second pass processing begins to process a segment, the entry list is modified so that is contains only entries for segments higher in the path of the current segment. (In Figure 26, segment 4 is being processed; the entry for segment 3 is removed, because it is not higher in the path of segment 4.) Figure 26. Entry List Processing During relocation, each V-type address constant is examined to determine if an ENTAB entry must be created for it. The R pointer of the RLD item for the address constant is used to find the associated HESD entry; this entry contains the segment number of the symbol referred to by the address constant. relationship of this segment to the current segment is then determined, using SEGTA1. Depending on the relationship in SEGTA1, the address constant is relocated in one of three ways: - If the segment that contains the symbol is higher in the path of the current segment, the call is upward and the address constant is resolved directly. (The absolute relocation factor of the symbol is inserted in the value of the address constant.) - If the current segment is higher in the path of the segment that contains the symbol, the call is downward. The entry list is checked to determine if an ENTAB entry was previously created for the symbol in this segment or in a segment higher in the path of this segment. If an ENTAB entry for the symbol exists, its address (contained in the entry list) is placed in the value field of the address constant. If no ENTAB entry exists for the symbol, a new entry is placed in the entry list, and an ENTAB entry will be created by the ENTAB creation routine (see "ENTAB Creation"). The ENTAB entry will contain the address Creation"). The ENTAB entry will contain the address assigned to the symbol by the linkage editor, and the address of the ENTAB entry will be placed in the value of the address constant and in the entry list item. - If neither of the two segments is higher in the path of the other, the call is either exclusive or across regions. the two segments are in different regions, and no ENTAB entry already exists for the symbol in the entry list, an ENTAB entry will be created and an entry is made in the entry list; the value field of the address constant is relocated to the address of the ENTAB entry, which in turn contains the relocated address of the symbol. If the two segments are in the same region, the call is exclusive. there is an entry in the entry list for the symbol, the address constant is resolved through its ENTAB entry; if there is no entry for the symbol in the entry list, the call is an invalid exclusive call and the address constant is resolved directly to the symbol. (This usually leads to incorrect results during execution of the module.) ### **ENTAB Creation** The ENTAB creation routine uses the size field in the HESD to determine the number of ENTAB entries to be created for a given segment. The entry list is scanned for all entries that were created for the current segment; each of these entries contains the HESD entry number for the corresponding symbol. The value and segment number of the symbol are obtained from the HESD and are entered in the ENTAB entry, along with standard information shown in the table format (see "Table Layouts"). ENTAB creation is shown in Figure 28 on page 70. The V-type address constants referring to SAM and BILL in segment 1 meet the requirements for building ENTAB entries. The ESD and RLD input to the second pass processor, and the overlay tree structure are shown in Diagram A. During relocation, entries are created for SAM and BILL in the entry list (see Diagram B); each entry contains the address of the ENTAB entry created for the address constant. In segment 1, location 136 of control section JOE contained a call to control section SAM before relocation. After relocation, location 136 contains the address of the ENTAB entry for SAM, and the high-order byte of the address constant contains the segment number of the calling segment. An ENTAB entry is created, in like manner, for BILL in segment 1. In segment 2, the address constant referring to BILL does not meet the requirements for building an ENTAB entry. (It is not in the path of the segment containing the symbol.) Therefore, no ENTAB is created in segment 2. The call for segment 2 to BILL in segment 3 is an exclusive call. Because a call to the same symbol appears in a higher segment common to 2 and 3 (segment 1), the address constant may refer to the ENTAB entry for BILL in segment 1. (This is determined by scanning the entry list for the HESD entry corresponding to the symbol BILL.) If a call to BILL was not contained in a common segment, the address constant DC V (BILL) in segment 2 would be resolved using the value assigned by the linkage editor to the symbol BILL, which results in an error. In segment 3, the address constant is an upward call and is resolved directly. ### Relocation Routine The relocation of address constants is performed by the relocation routine; the routine operates on the following input data: - The address of the RLD input buffers that contain RLD records. - The address of the RLD note list entry for the RLDs being processed. - The address of the next available entry in the RLD output buffer. The buffer relocation constant (BRC) where: BRC = starting buffer address of current text + relative relocation constant of current control section - address assigned to current control section by the linkage editor multiplicity size x current multiplicity number. | Input | | Output | | tput | |----------|-------------------------------------------------------|-----------------------------------------------------------------------------|----------|----------------------------------------| | Flag | Type | Action Performed | Flag | Type | | 0000LLST | Absolute | Absolute relocation factor is added to value of address constant | OOOOLLST | A-type | | 0001LLST | Branch | Absolute relocation factor is inserted into value of address constant | 0001LLST | V-type | | 0010LLST | PR displacement<br>value<br>(PR type 1) | Absolute relocation factor is inserted into value of address constant | 0010LLST | PR displacement<br>value | | 0010LLST | PR cumulative<br>displacement<br>value<br>(PR type 2) | PR length from all purpose table is inserted into value of address constant | 0011LLST | PR cumulative<br>displacement<br>value | | 1000LLST | Relative | Relative relocation<br>factor is added to<br>value of address<br>constant | 0000LLST | A-type | Figure 27. Relationship of RLD Flag Field to Relocation ### Notes to Figure 27: - If S (sign) in LIST is 1, subtraction is performed, rather than addition. - In delink type, the delink value is added or subtracted according to the opposite of the sign; the absolute relocation factor is added to or subtracted from the address constant according to the indicated sign. - 3. If an RLD item refers to an undefined symbol, the associated address constant is not relocated. (It may have been delinked.) The high-order bit of the RLD item flag field is set to one (1000LLST for an A-type constant, 1001LLST for a V-type constant) and no relocation will be performed when the module is loaded into virtual storage for execution. - 4. Delinking is noted in the high-order bit of the P pointer. Figure 28. ENTAB Creation The relocation routine operates in the following manner: - The size of the RLD set<sup>12</sup> and the displacement from the beginning of the buffer are determined from the RLD note list. - 2. Each RLD item in the current RLD set is scanned to determine whether: - a. It describes an address constant for the current text being processed (BRC + address contained in the RLD address field falls within the text buffer boundaries of the current text.) - b. The address constant is either a valid 2-, 3-, or 4-byte address constant. (The only valid 2-byte address constants are defined by pseudo register symbols.) - 3. Each address constant whose RLD meets the above requirements is moved from the text into a computation area. The address constant associated with the RLD item is then relocated according to the information in the flag field of the RLD item (see Figure 27 on page 69). In relocating 4-byte address constants (VCONs), the high-order bit in the address constant before relocation is reproduced in the address constant after relocation. The relocated address constant is then placed back into the text. - The RLD address field is updated using the relative relocation factor for the control section being processed. (The control section referred to by the P pointer of the RLD item). - 5. The RLD is moved into the RLD output buffer if space is available. If space is not available, the contents of the RLD output buffer are written out on SYSLMOD. See "Second Pass RLD Buffers" under "Second Pass Processing." - 6. Steps 2 through 5 are repeated until all RLD items have been scanned in the RLD set being processed. The multiplicity number in the RLD note list is updated if unprocessed RLDs remain in the set. - 7. If there are more RLD sets in the input buffer to be processed, the address of the next record is determined and steps 1 through 6 are performed. Note: To minimize the number of times RLD records are read from SYSUT1, RLD records for a control section are held in the input RLD buffer, when possible, until all RLD records in the buffer have been processed (because each RLD record may pertain to many multiplicities of text). After each set of RLDs is scanned, the multiplicity number in the RLD note list is updated to reflect the multiplicity of the remaining unprocessed RLD records in the set. An RLD record is removed from the buffer when: - All RLD items in the record have been processed. (Their associated address constants have been relocated.) - Another RLD record must be read into the buffer and space is not available. When all records in the input RLD buffer have been scanned, the relocation routine determines if more RLD records for the current multiplicity of text are to be read in. (The RLD read routine sets an indicator when it encounters such a record but cannot read it into the buffer because the buffer is full.) When both buffers are full, the second buffer is freed, and a bit is set in the corresponding RLD note list entries which indicates that the RLDs are not in virtual storage. The records An RLD set is a group of RLDs referred to by a particular RLD note list entry. to be read in are then placed in the second RLD buffer; these records are processed in the same manner as those already residing in the first buffer. This process is repeated until all records that contain RLD items pertaining to the current multiplicity of text have been scanned and processed. When all RLDs in a buffer are processed, the buffer is marked "free" in the RLD control block. When a new multiplicity of text is to be relocated, the RLd note list is scanned sequentially (on ID and multiplicity number) from the first entry. If an entry indicates that the record is "in virtual storage" and the record contains RLD items pertaining to the new multiplicity of text, it is processed. ### FINAL PROCESSING (HEWLFFNL) Final processing comprises modules HEWLFFNL, HEWLFBTP, and (optionally) HEWLFMAP. The fourth phase of the linkage editor (final processing) performs "cleanup" functions, and is the last operation of the linkage editor processing. Functions of final processing include: - Writing the TTR note list, created during second pass processing, on SYSLMOD if the output load module is to be used in overlay. The TTR list contains the relative track address of the first record of each segment of the overlay load module. It is used by the overlay supervisor to find the segments when it loads them into virtual storage for execution. - Placing each entry in the proper format for the partitioned data set directory, modifying it if there are alias symbols, and issuing a STOW macro instruction<sup>13</sup> for the member name and each alias. - Checking attributes (reusable, reenterable, and refreshable). If the attributes have become more restrictive, a message describing the change in attributes is printed out. (For example, the input module was specified as "reusable" and is now "not reusable.") - Printing out a directory of logged errors. - Producing a cross-reference table if the XREF option is specified, and the cross-reference table was not produced during intermediate output processing. - Printing a diagnostic message if the module has been marked "not executable." - Reinitiating linkage editor processing, beginning with initialization, if a NAME statement terminated SYSLIN input. - Completing linkage editor processing if end-of-file terminated SYSLIN input; releasing virtual storage and returning control to the caller. ### Error Logging Whenever an error condition is detected during linkage editor processing, an indicator is set in an error logging map and a coded diagnostic message is printed out. During final processing, the error logging map is scanned. When an indicator The STOW macro instruction is not issued if there was no valid input, if there were no ESDs, if nothing was written out on SYSLMOD, or if the run was terminated by a severity 4 error. > is found "on" in the map, an associated list is used to build a diagnostic message. Note: An example of error logging is given in Figure 29. Each entry in the list contains a length indicator and a pointer to a phrase to be assembled into the message. (Phrases are stored to save virtual storage space; complete messages would require additional space because of repetition of identical phrases.) The diagnostic directory is then printed out, one or two lines to a message. This directory is normally directed to the SYSPRINT data set. However, if the TERM option was specified, diagnostic messages are directed to both the SYSPRINT and SYSTERM data sets. Figure 29. Building Error Messages All error messages produced by the linkage editor are identified by a message ID having the format: ### I EWDMMS where: identifies the message as a linkage editor error message. D contains a zero. is the message number. is the severity code. The module in which an error message occurred is identified by the message number (MM; see Figure 68 on page 189). ### Cross-Reference Table If the XREF option is specified, and the cross-reference table was not produced during intermediate output processing, the RLD records are read back from SYSLMOD, and the cross-reference table is built, as described in the discussion of intermediate processing. 74 This document contains restricted materials of IBM. $\odot$ Copyright IBM Corp. 1972,1983 LY26-3921-0 # DIAGRAM 1. OVERVIEW OF LINKAGE EDITOR # DIAGRAM 3. INITIALIZATION # DIAGRAM 5. INTERMEDIATE PROCESSING PROCESSING # DIAGRAM 6. SECOND PASS PROCESSING SECOND PASS PROCESSING (HEWLESCD) | | CSECT | LABEL | FLOWCHART | | |---|----------|---------------------|-----------|--| | 1 | SCDENTAB | SGENDI | FA | | | 2 | HEWLFREL | SCDOVLY | FE | | | 3 | HEWLFREL | RELOC20<br>RELOC100 | SE<br>FE | | | 4 | WRTTXT | | FD | | | 5 | WRTCRRLD | | FA | | | 6 | HEWLCPTH | | FE | | Method This document LY26-3921-0 contains restricted materi ia15 o<del>f</del> IBM. 0 Copyright IBM Corp. 1972,1983 ### **DIAGRAM 8. CONTROL STATEMENT PROCESSING** DIAGRAM 9. ESD PROCESSING DIAGRAM 11. PROCESSING LOAD MODULE TEXT RECORDS # First Pass RLD Buffer 01 05CA 3 Control Records 01 0640 **SYSLIB** SYSUTI Input Text Buffer (TXTBFBEG) 7C60 TXT 4 Text Data **TXTBFBEG** Text Data TXT Contents Written When Buffer Is Full Text Records Text Data ### Legend: - The ID in the first control record is renumbered. The third line of the RNT contains a 4, so the ID is renumbered to refer to the fourth line of the CESD (CSECT DD). - Assuming CSECT DD (CESD ID 4) is not to be deleted, its length (in the control record) is checked. - If the entire CSECT or a complete multiplicity will fit in TXTBFBEG, the record containing text for DD is read into TXTBFBEG, and entries are made in the text I/O table and the text note list\*. - Each subsequent control record is processed. Text records are read into TXTBFBEG until it becomes full, at which time its contents are written onto SYSUT1. - In the two text records in this example, the multiplicity number is 0, because they are the first text records for their respective control sections. ### Renumbering DIAGRAM 12. RLD PROCESSING ### Legend: - Register 6 initially points to the first RLD input record. - RLD records are grouped in the RLD buffer by P pointer. In this example, the first and second, and third and fourth RLD records are grouped. - R and P pointers are renumbered, using the renumbering table, as RLD records are moved into the buffer. - Entries for each RLD set are made in the RLD note list. Length and displacement fields refer to the first record of the set. - When the contents of the RLD buffer are written, the displacement field of the RLD note list entry for the last set included in the output record is replaced by the relative track address (TTR) of the SYSUT1 record. ## DIAGRAM 13. ADDRESS ASSIGNMENT ### PROGRAM ORGANIZATION The following text and the flowcharts at the end of this section describe the processors (code modules, control sections, and routines) that accomplish the functions of the linkage editor. The organization of this section corresponds to the organization of the linkage editor; descriptions of all processors that constitute a phase of the linkage editor are grouped together. For each processor, the symbolic name is given to facilitate use of program listing (see "Microfiche Directory") and the descriptive name is given to facilitate reference to "Method of Operation." Figure 31 on page 96 shows the overall organization of the linkage editor; this illustration is designed to help determine relationships among the processors described in this section. ### INITIALIZATION AND INPUT PROCESSING ### Initial Processor—HEWLFINT (Chart BA) <u>Entrance</u>: HEWLFINT is entered from HEWLFROU at the beginning of linkage editor processing. Operation: HEWLFINT performs initialization functions, including building the all-purpose table (APT), analyzing attributes and options passed by the calling program, opening data sets, and allocating virtual storage for buffers and work areas. Routines Called: HEWLFINT calls the attributes and options processor (HEWLFOPT) and the allocation routine (ALLOO1). The HEWLFINT routine is recalled immediately upon returning from the first call of the allocation routine (ALLOO1). <u>Exits</u>: When initialization is completed, HEWLFINT passes control to the input processor (HEWLFINP). ### Attributes and Options Processor-HEWLFOPT Entrance: HEWLFOPT is entered from the initial processor. <u>Operation</u>: HEWLFOPT analyzes the options requested and the attributes specified by the calling program, and notes this information in the APT. If a valid authorization code is found, it is converted to binary and stored in both the default field and the PDS entry field of the APT. Routines Called: None Exits: When attribute and option processing is completed, HEWLFOPT returns control to the initial processor (HEWLFINT). ### Allocation Processor—ALL001 (Chart BA) Entrance: HEWLFOPT is entered from the initial processor. Operation: ALL001 issues the GETMAIN macro instruction and assigns storage to buffers. Routines Called: ALL001 calls the table allocation processor (HEWLFALK) to allocate storage for fixed-length and variable-length tables. <u>Exits</u>: When allocation processing is completed, ALLOO1 returns control to the initial processor (HEWLFINT). ### Table Allocation Processor—HEWLFALK (Chart BB) Entrance: HEWLFALK is entered initially from ALL001 after storage has been allocated for the buffers. It is entered a second time for reallocation of tables. Operation: HEWLFALK assigns storage to the internal tables. In initial allocation, HEWLFALK assigns only the minimum required storage to the tables. A note is made of the highest address used in the initial allocation. Reallocation occurs unconditionally. HEWLFALK determines the amount of storage in excess of the minimum required. This excess is used to expand proportionately the variable-length tables. Routines Called: None Exits: When table allocation processing is completed, HEWLFALK returns to the calling routine. ### Input Processor—HEWLFINP (Chart CA) Entrance: HEWLFINP receives control from the initial processor when all initialization functions are completed. Operation: HEWLFINP reads and initially processes all linkage editor input. Input type (object module or load module) and input conditions are determined, and control is passed to appropriate processors. Routines Called: HEWLFINP calls the following processors: - Control statement scanner (HEWLFSCN) when a control statement is detected (blank in column 1) - Object module processor (HEWLFMDI) when object module input is detected (SYSLIN input or fixed (F) format input from SYSLIB) - Load module processor (INP270) when load module input is detected (undefined (U) format input from SYSLIB) - Include processor (HEWLFINC) at end-of-input if more modules must be included - Automatic library call processor (HEWLCAUT) at end-of-input on SYSLIN if the NCAL option is <u>not</u> specified Exits: When input processing is completed, HEWLFINP passes control to the address assignment processor (HEWLFADA), if valid input was received. If no valid input was received, control is passed to the final processor (HEWLFENL) to terminate linkage editor processing. ### Object Module Processor—HEWLFMDI (Chart CB) Entrance: HEWLFMDI is entered from the input processor when object module input is detected. Operation: HEWLFMDI determines the input record type (SYM, TXT, RLD, ESD, END), loads input record infromation into general registers, and passes control to the appropriate processors. Routines Called: Depending on input record type, HEWLFMDI calls the following processors: - SYM processor (HEWLFSYM) ESD processor (HEWLFESD) END processor (HEWLFEND) - Text and RLD processor (HEWLFRAT) - IDR processor (HEWLFIDR) <u>Exits</u>: When object module processing is completed, **HEWLFMDI** returns control to the input processor. ### Load Module Processor—INP270 (Chart CC) <u>Entrance</u>: INP270 is entered from the input processor when load module input is detected. <u>Operation</u>: INP270 determines the input record type (TXT, CESD, scatter/translation, SYM, CCW, CCW/RLD, RLD, IDR), loads input record information into general registers, and passes control to the appropriate processors. <u>Routines Called</u>: Depending on input record type, INP270 calls an associated processor, as shown in Figure 30. <u>Exits</u>: When load module processing is completed, INP270 returns control to the input processor. | Record Type | Processor | |------------------------------------------------------|--------------------------------------------------------------------------| | TXT CESD Scatter/translation SYM CCW CCW/RLD RLD IDR | HEWLFRAT HEWLFESD (Ignored) HEWLFSYM HEWLFRAT HEWLFRAT HEWLFRAT HEWLFRAT | If end-of-module indicator is on: | CCW/RLD HEWLFEND | CCW<br>CCW/RLD<br>RLD | HEWL FEND<br>HEWL FEND<br>HEWL FEND | |------------------|-----------------------|-------------------------------------| |------------------|-----------------------|-------------------------------------| Figure 30. Load Module Record Types and Associated Processors ## SYM Processor—HEWLFSYM (Chart CD) Entrance: HEWLFSYM is entered from the object module processor when SYM records have been detected and the TEST attribute has been specified. If TEST is not specified, SYM records are ignored. <u>Operations</u>: HEWLFSYM gathers SYM records in the RLD input buffer, and writes the buffer contents on SYSLMOD when the first TXT record of a module is detected. Routines Called: None <u>Exits</u>: When SYM processing is completed, HEWLFSYM returns control to the object module processor. ### ESD Processor—HEWLFESD (Chart CE) Entrance: HEWLFESD is entered from the object module processor when an ESD record is detected, and from the load module processor when a CESD record is detected. Operation: HEWLFESD combines ESDs in the linkage editor input into a composite ESD. Matching input symbols are resolved, and specified operations (replace, change, delete) are performed on the symbols. A renumbering table (RNT) is produced to allow input ESD IDs to be translated into CESD IDs. Exits: When ESD processing is completed, HEWLFESD returns control to the routine from which it was entered (object module processor or load module processor). ### Text and RLD Processor—HEWLFRAT (Chart CF) Entrance: HEWLFRAT is entered from the object or load module processors when a text or RLD record is detected. Operation: HEWLFRAT determines record type (TXT or RLD), checks for error conditions (input record larger than buffer), and passes control to the appropriate processor. Routines Called: Depending on the record type, HEWLFRAT passes control to either the text processor (HEWLFTXT) or the RLD processor (RLD001). Exits: When text and RLD processing is completed, HEWLFRAT returns control to the object or load module processor. ### Text Processor—HEWLFTXT (Chart CG) Entrance: HEWLFTXT is entered from the text and RLD processor when a text record is detected. Operations: HEWLFTXT operation depends on whether text input is from object or load modules. Object module text is moved from the object module buffer to the input text buffer, and must be arranged in the proper order. Load module text input is already ordered, so HEWLFTXT reads it directly into the input text buffer. In either case, the input text ID is renumbered to refer to the CESD ID of the appropriate control section. When the input text buffer becomes full, its contents are written on SYSUT1. Routines Called: When the input text buffer is full, HEWLFTXT calls the text write routine (TXTBUF—Chart CH) to write the buffer contents on SYSUT1. Exits: When text processing is completed, HEWLFTXT returns control to the text and RLD processor. ### RLD Processor—RLD001 (Chart CJ) Entrance: RLD001 is entered from the text and RLD processor when an RLD record is detected. Operation: RLD001 groups RLD items in the RLD buffer and renumbers the R and P pointers to refer to appropriate CESD entries. Each RLD item is processed according to its flag and address (FA) field. RLD001 also creates an RLD note list, with entries for each set of RLDs (a set being all RLDs having the same P pointer). If either the RLD buffer or the RLD note list becomes full, the contents of the buffer and the note list are written on SYSUT1. Routines Called: When the RLD buffer or the RLD note list is full, RLD001 calls the RLD write routine (RLDBUF—Chart CK) to write the note list and the buffer contents on SYSUT1. <u>Exits</u>: When RLD processing is completed, RLD001 returns control to the text and RLD processor. ### End Processor—HEWLFEND (Chart CL) <u>Entrance</u>: HEWLFEND is entered from the object or load module processor when an END record or the end of a load module is detected. Operation: HEWLFEND resets tables involved in input processing, processes entry point information, deletes CESD lines marked "chain" or "delete," and enters in the CESD the length of control sections for which no length was previously indicated. Routines Called: None <u>Exits</u>: When end processing is completed, HEWLFEND returns control to the object or load module processor. ## CSECT Identification Record (IDR) Processor—HEWLFIDR (Chart CQ) Entrance: HEWLFIDR is entered from the input processor, HEWLFINP, to process object module END records and load module identification records. It is also entered from HEWLFSCN for processing IDENTIFY control statements. Operation: HEWLFIDR takes IDR information from the input records and enters this data in the appropriate IDR table. <u>Routines Called</u>: Error and informative messages are processed by calling HEWLFLOG. <u>Exits</u>: When IDR processing ends, HEWLFIDR returns to the calling program. ### Control Statement Scanner—HEWLFSCN (Chart CS) <u>Entrance</u>: HEWLFSCN is entered from the input processor when a control statement is detected. <u>Operation</u>: Depending on the type of control statement being processed, the control statement scanner makes entries in the APT, SEGTA1, and/or the CESD. This information is used to control subsequent linkage editor processing. <u>Routines Called</u>: HEWLFSCN calls the READ8 routine (Chart CT) to process control statement operands. Exits: When control statement processing is completed, HEWLFSCN passes control to the include processor (HEWLFINC), if an INCLUDE control statement was processed (include chain built in the CESD). Ohterwise, HEWLFSCN returns control to the input processor. ### Include Processor—HEWLFINC (Chart CU) <u>Entrance</u>: HEWLFINC is entered from the input processor when "more includes" are indicated at end-of-input, and from the control statement scanner when an INCLUDE statement has been processed. Operation: HEWLFINC examines the include chain in the CESD and selects the next module to be included. It opens the data set, determines the attributes of the module to be included, and initializes the DCB to allow the module to be read. Routines Called: If a module for which the REPLACE/CHANGE function has been requested is not contained in the specified library, HEWLFINC calls HEWLFEND to delete the corresponding CESD lines. > Exits: When include processing is completed, control is returned to the input processor. ### Automatic Library Call Processor—HEWLCAUT (Chart CV) <u>Entrance</u>: HEWLCAUT is entered from the input processor at the end of SYSLIN input, or when a NAME statement has been detected (provided that the NCAL option was <u>not</u> specified). <u>Operation</u>: HEWLCAUT first scans the CESD for unresolved ERs specified on LIBRARY statements. It attempts to resolve these ERs by searching the PDS directories of ddnames included in library chains, allowing the members found to be read. A second CESD scan attempts to resolve ERs not specified on LIBRARY statements by attempting to call them from SYSLIB. <u>Routines Called</u>: After the first series of CESD scans, HEWLCAUT returns control to the input processor to read the members. Exits: After the second series of CESD scans, HEWLCAUT passes control to the address assignment processor (HEWLFADA). ### INTERMEDIATE PROCESSING ### Address Assignment Processor—HEWLFADA (Chart DA) Entrance: HEWLFADA is entered from the input processor when input processing is completed Operation: HEWLFADA assigns linked addresses to all CESD entries, determines the size of SEGTAB if the program is in overlay, determines if the first text record does not begin at address 0, determines the number of ENTAB bytes required for each segment, builds the alias table, and determines an entry point for the program. Routines Called: HEWLFADA calls the ENTAB size determination routine (HEWLFENS—Chart DB) to compute the size of ENTAB, and calls the entry processor (HEWLFENT—Chart DC) to build the alias table and determine an entry point. Exits: When address assignment processing is completed, HEWLFADA passes control to the intermediate output processor (HEWLFOUT). ### Intermediate Output Processor—HEWLFOUT (Chart EA) <u>Entrance</u>: HEWLFOUT is entered from HEWLFADA when address assignment processing is complete. Operation: HEWLFOUT writes the following on SYSLMOD; CESD, SEGTAB (for programs in overlay), and scatter/translation records (for programs to be scatter loaded). If a HIARCHY statement is specified, storage hierarchy designations are included in the scatter/translation records. If the MAP option has been specified, a module map is produced and written on SYSPRINT; if the XREF option has been specified and all RLDs are in storage, a cross-reference table is produced and written on SYSPRINT. If the TXT and RLD note lists were placed on SYSUT1 during TXT and RLD processing, HEWLFOUT reads them back into storage, and builds the high ID table (HIID). The half ESD (HESD) is also built, after the CESD has been written. Routine Called: HEWLFOUT calls the MAP/XREF processor (HEWLFMAP) to produce and write the module map and cross-reference table, if requested. <u>Exits</u>: When intermediate output processing is completed, control is passed to the second pass processor (HEWLFSCD). ### SECOND PASS PROCESSING ### Second Pass Processor—HEWLFSCD (Chart FA) <u>Entrance</u>: HEWLFSCD is entered from HEWLFOUT when intermediate output processing is completed. Operation: HEWLFSCD performs the following functions: - Reads text from SYSUT1. - Relocates address constants contained in the text. - Creates control/RLD records. - Writes text and control/RLD records on SYSLMOD in a format that can be loaded by program fetch. - Creates ENTABs and associated RLD items for overlay modules. <u>Routines Called</u>: During second pass processing, HEWLFSCD calls the following routines: - Control section search routine (GETIDMUL—Chart FB) to determine the next ID and multiplicity to be processed. - Text and RLD read routines (RDTXT, RDRLD—Chart FC) to read required text and RLDs from SYSUT1. - Text write routine (WRTTXT—Chart RD) to write text on SYSLMOD (HEWLMSIO). - Control/RLD record write routine (WRTCRRLD) to write RLDs and control records on SYSLMOD (HEWLFSIO). - Second pass initialization routine (HEWLFREL—Chart FE) to initialize text and RLD control blocks. - Relocation routine (RELOCATE—Chart FE) to relocate address constants (branch-type and nonbranch-type) in the text. - Common path routine (HEWLCPTH) to determine common segments in an overlay path. - ENTAB creation routine (SCDENTAB) to create ENTAB items for each segment. <u>Exits</u>: When second pass processing is completed, control is passed to the final processor (HEWLFFNL). ### FINAL PROCESSING ### Final Processor—HEWLFFNL (Chart GA) <u>Entrance</u>: HEWLFFNL is entered from HEWLFSCD when second pass processing is completed. Operation: HEWLFFNL performs the following "cleanup" functions: - Writes the TTR list for overlay modules on SYSLMOD - Places entries in the partitioned data set directory and issues a STOW macro instruction - Prints a directory of logged errors - Checks for more restrictive module attributes - Produces a cross-reference table if it was requested and not produced during intermediate processing <u>Routines Called</u>: During final processing, HEWLFFNL calls the following routines: - Diagnostic message directory print routine (HEWLFBTP), which scans the error logging map produced throughout linkage editor processing by the error logging routine (HEWLFLOG-Chart GC); HEWLFBTP builds and prints a directory of error messages. - MAP/XREF processor (HEWLFMAP—Chart EB), which produces a cross-reference table if it was not produced during intermediate processing. Exits: If end-of-file was not detected on a SYSLIN input, HEWLFFNL returns control to the initial processor (HEWLFINT), and linkage editor processing is repeated. Otherwise, linkage editor processing is terminated, and control is returned to the control program. ### SYNAD Routine-HEWLCR01 (Chart GB) Entrance: The SYNAD routine may be entered from the following routines: - From the control program when any input/output error has been detected - From the second pass processor if an error is found after executing the XDAP macro instruction Operation: Following are SYNAD considerations for the linkage editor: - The SYNAD fields of the DCBs in HEWLFROU contain the address of the appropriate SYNAD entry point for the access method used with the data set. - If the SYNAD routine is entered from the input processor because of incorrect length, the length of the incorrect input block is checked. If a valid short block (integral multiple of (LRECL) is found, control is returned to the supervisor to continue processing; if not, processing is terminated with an error message and completion code of 16. - If the SYNAD routine is entered while writing to the SYSPRINT data set, control is passed to the final processor, and execution is abnormally terminated with a condition code of 16. - When the include processor opens the DCB for SYSLIB, the address of the appropriate SYNAD entry (for either BSAM or BPAM access methods is moved into the SYNAD field. - If the second pass processor finds an error after executing the XDAP macro instruction, it loads register 1 with the IOB address, loads register 15 with the SYNAD entry point for the EXCP macro instruction, and branches on register 15. contains restri cted materials ٥ţ IBM. 0 Copyri ght IBM Corp. Figure 32. Sample Flowchart Symbols ### CHART AA. LEVEL MAJOR DIVISIONS ### CHART BA. INITIAL PROCESSOR (HEWLFINT) #### CHART BB. TABLE ALLOCATION PROCESSOR (HEWLFALK) ### CHART CA. INPUT PROCESSOR (HEWLFINP) #### CHART CB. OBJECT MODULE PROCESSOR (HEWLFMDI) #### CHART CC. LOAD MODULE PROCESSOR (INP270) This document contains restricted materials of IBM. $\odot$ Copyright IBM Corp. 1972,1983 LY26-3921-0 # CHART CD. SYM PROCESSOR (HEWIFSYM) # CHART CE. ESD PROCESSOR (NEWLFESD) (PART 1 OF 3) # CHART CE. ESD PROCESSOR (NEWLFESD) (PART 2 OF 3) #### CHART CE. ESD PROCESSOR (NEWLFESD) (PART 3 OF 3) # CHART CF. TXT AND RLD PROCESSOR (HEWLFRAT) ### CHART CG. TXT PROCESSOR (HEWLFTXT) ### CHART CH. TXT WRITE ROUTINE (ON SYSUT1) (TXTBUF) # CHART CJ. RLD PROCESSOR (RLD001) (PART 1 OF 2) # CHART CJ. RLD PROCESSOR (RLD001) (PART 2 OF 2) This document contains restricted materials of IBM. © Copyright IBM Corp. 1972,1983 LY26-3921-0 #### CHART CK. RLD WRITE ROUTINE (RLDBUF) #### CHART CL. END PROCESSOR (HEWLFEND) #### CHART CM. CSECT IDENTIFICATION RECORD PROCESSOR (HEWLFIDR) ### CHART CN. IDR TRANSLATOR DATA PROCESSOR (HEWLFIDR) ### CHART CP. IDRSPZAP DATA PROCESSOR (HEWLFIDR) ### CHART CQ. IDR IDENTIFY DATA PROCESSOR (HEHLFIDR) ### CHART CR. IDR USER DATA PROCESSOR (HEWLFIDR) ### CHART CS. CONTROL STATEMENT SCANNER (HEWLFSCN) (PART 1 OF 2) This document contains restricted materials of IBM. © Copyright IBM Corp. 1972,1983 LY26-3921-0 # CHART CS. CONTROL STATEMENT SCANNER (HEWLFSCN) (PART 2 OF 2) #### CHART CT. READS ROUTINE ### CHART CU. INCLUDE PROCESSOR (HEWLFINC) # CHART CV. AUTOMATIC LIBRARY CALL PROCESSOR (HEWLCAUT) (PART 1 OF 2) # CHART CV. AUTOMATIC LIBRARY CALL PROCESSOR (HEWLCAUT) (PART 2 OF 2) #### CHART DA. ADDRESS ASSIGNMENT PROCESSOR (HEWLFADA) ### CHART DB. ENTAB SIZE DETERMINATION ROUTINE (HEWLFENS) ### CHART DC. ENTRY PROCESSOR (HEWLFENT) (PART 1 OF 2) ### CHART DC. ENTRY PROCESSOR (HEWLFENT) (PART 2 OF 2) #### CHART EA. INTERMEDIATE OUTPUT PROCESSOR (HEWLFOUT) #### CHART EB. MAP/REF PROCESSOR (HEWLFMAP) ### CHART EC. IDR WRITE ROUTINE (HEWLFOUT) (PART 1 OF 2) # CHART EC. IDR WRITE ROUTINE (HEWLFOUT) (PART 2 OF 2) ### CHART FA. SECOND PASS PROCESSOR (HEWLFSCD) (PART 1 OF 2) #### CHART FA. SECOND PASS PROCESSOR (HEWLFSCD) (PART 2 OF 2) This document contains restricted materials of IBM. © Copyright IBM Corp. 1972,1983 LY26-3921-0 #### CHART FB. GETIDMUL ROUTINE #### CHART FC. TXT READ ROUTINE (RDTXT), RLD READ ROUTINE (RDRLD)-HEWLFSIO #### CHART FD. TEXT WRITE ROUTINE (ON SYSLMOD) (WRTTXT)-HEWLFSIO # CHART FE. RELOCATION ROUTINE (HEWLFREL) (PART 1 OF 3) ### CHART FE. RELOCATION ROUTINE (HEWLFREL) (PART 2 OF 3) #### CHART FE. RELOCATION ROUTINE (HEWLFREL) (PART 3 OF 3) #### CHART GA. FINAL PROCESSOR (HEWLFFNL) This document contains restricted materials of IBM. © Copyright IBM Corp. 1972,1983 LY26-3921-0 ## CHART GB. SYNAD ROUTINE (HEWLCRO1) #### CHART GC. ERROR LOGGING ROUTINE (HEWLFLOG) This document contains restricted materials of IBM. © Copyright IBM Corp. 1972,1983 LY26-3921-0 #### MICROFICHE DIRECTORY The microfiche directory, Figure 33, is designed to help you find named areas of code in the program listing, which is on microfiche. Microfiche cards are filed in alphameric order by object module name. If you wish to locate a control section or entry point on microfiche, find the name in column one and note the associated CSECT name. A description of the control section is also given. This section also contains a module-CSECT cross-reference table (see Figure 34 on page 148). | Symbol | Туре | CSECT | Description | Referenced By | |----------|-------------|-----------|-------------------------------------------------|--------------------| | APTEND | Entry point | HEWLFROU | See HEWLEPNT | | | APTEXLST | Label | HEWL FROU | Open exit list for SYSLIN, SYSPRINT, and SYSLIB | HEWLFINT, HEWLFINC | | APTXLIST | Label | HEWL FROU | Open exit list for<br>SYSLMOD | HEWLFINT, HEWLFMAP | | APT000 | Entry point | HEWLFAPT | SYNAD exit routine for SYSPRINT | | | CHECKRD | Entry point | HEWLFSI0 | Routine to check reads on SYSUT1 | HEWLFREL | | CHECKWRT | Entry point | HEWLFS10 | Routine to check writes on SYSLMOD | HEWLFREL | | ENQNAME | Label | HEWLFROU | Major name by which<br>SYSLMOD is enqueued | HEWLFINT, HEWLFFNL | | GETIDMUL | Entry point | HEWLFSCD | Text LOOK AHEAD/READ<br>AHEAD routine | HEWLFREL | | HEWLCADA | Label | HEWLFROU | Not used | | | HEWLCAD1 | Entry point | HEWLFADA | Routine to make CESD entries for ENTABS | HEWLFENS | | HEWLCAUT | Entry point | HEWLFINC | Automatic library call processing | HEWLFINP | | HEWLCDCN | Entry point | HEWLFRCG | Library DECHAIN routine | HEWLFESD | | HEWLCDLK | Entry point | HEWLFINP | DELINK routine | HEWLFESD, HEWLFRAT | | HEWLCEOD | Entry point | HEWLFINP | END-OF-DATA routine for SYSLIB | HEWLFINC, HEWLFROU | | HEWLCEOI | Entry point | HEWLFFNL | | HEWLFROU | | HEWLCE30 | Entry point | HEWLFESD | Return point to avoid<br>ESD processing | HEWLFRCG | | HEWLCFAB | Entry point | HEWLFFNL | Termination processing | HEWLFROU | | HEWLCFNI | Entry point | HEWLFFNL | Immediate termination processing | HEWLFINP, HEWLFROU | Figure 33 (Part 1 of 4). Microfiche Directory This document contains restricted materials of IBM. © Copyright IBM Corp. 1972,1983 LY26-3921-0 | Symbol | Type | CSECT | Description | Referenced By | |-----------|-------------|-----------|--------------------------------------------------------------------------------|------------------------------------------------------------| | HEWLCICA | Label | HEWLFINP | Pointer to include processor | | | HEWLCIDR | Entry point | HEWLFIDR | IDR user data from<br>IDENTIFY statement<br>processor | HEWLFSCN | | HEWLCINP | Entry point | HEWLFINP | See HEWLFINP | HEWLFTXT | | HEWL CMDB | Label | HEWLFROU | DCB for SYSLMOD | HEWLFFNL, HEWLFINT, HEWLFMAP, HEWLFOUT, HEWLFSIO, HEWLFSYM | | HEWLCPDB | Label | HEWLFROU | DCB for SYSPRINT | HEWLFAPT,<br>HEWLFFNL, HEWLFINT | | HEWLCPTH | Entry point | HEWL FRCG | COMMON PATH routine | HEWLFESD | | HEWLCRBB | Label | HEWLFAPT | DECB for SYSLIB | | | HEWLCRBN | Label | HEWLFAPT | DECB for SYSLIN | | | HEWLCRID | Label | HEWLFESD | ESD ID of item currently in process | HEWLFRCG | | HEWLCR01 | Entry point | HEWLFROU | END-OF-DATA routine for SYSUT1; SYNAD routine for SYSUT1, SYSPRINT, and SYSLIN | HEWLFINC | | HEWLCR02 | Entry point | HEWL FROU | END-OF-DATA routine for SYSLMOD | HEWLFINC | | HEWL CRO3 | Entry point | HEWLFROU | I/O ERROR routine for SYSLMOD | HEWLFSIO | | HEWLCSDB | Label | HEWLFROU | DCB for SYSLIN | HEWLFAPT,<br>HEWLFFNL, HEWLFINT | | HEWLCSNX | Entry point | HEWLFFNL | Termination processing after SYNAD exit | HEWLFROU | | HEWLCTTY | Label | HEWLFESD | Type flags for current<br>ESD item | HEWLFRCG | | HEWLCUDB | Label<br>• | HEWLFROU | DCB for SYSUT1 | HEWLFFNL, HEWLFINT, HEWLFOUT, HEWLFRAT, HEWLFSIO | | HEWLEEON | Entry point | HEWLFINP | END-OF-DATA routine for SYSLIN | HEWL FROU | | HEWL ENAM | Entry point | HEWLFINT | Reentry into<br>initialization for<br>multiple link-edits | HEWLFROU, HEWLFFNL | | HEWLEPNT | Entry point | HEWLFROU | SYSPRINT OUTPUT routine | HEWLFBTP,<br>HEWLFFNL,<br>HEWLFINT,<br>HEWLFMAP, HEWLFOPT | | HEWLERDM | Entry point | HEWLFINP | PRIMARY INPUT READ routine | HEWLFTXT | Figure 33 (Part 2 of 4). Microfiche Directory This document contains restricted materials of IBM. © Copyright IBM Corp. 1972,1983 LY26-3921-0 | Symbol | Type | CSECT | Description | Referenced By | |-----------|-------------|-----------|------------------------------------------------------|----------------------------------------------| | HEWLFADA | CSECT | HEWLFADA | Address assignment | HEWLFINC,<br>HEWLFINP, HEWLFROU | | HEWLFALK | Entry point | HEWLFROU | TABLE ALLOCATION routine | HEWLFAPT | | HEWLFAPT | CSECT | HEWLFAPT | All Purpose Table<br>(Communications Area) | HEWLFINT | | HEWL FAPX | Entry point | HEWLFMAP | RECOVERY routine after SYNAD exit | HEWLFROU | | HEWLFBTP | CSECT | HEWLFBTP | Error message printing | HEWLFFNL | | HEWLFDEF | CSECT | HEWLFDEF | Default size values | HEWLFINT,<br>HEWLFOPT, HEWLFOUT | | HEWLFEND | CSECT | HEWLFEND | End record processing | HEWLFINC, HEWLFINP | | HEWLFENS | CSECT | HEWLFENS | ENTAB size<br>determination | HEWLFADA | | HEWLFENT | CSECT | HEWLFENT | Entry statement processing | HEWL FADA | | HEWLFESD | CSECT | HEWLFESD | ESD record processing | HEWLFINP | | HEWLFFNL | CSECT | HEWLFFNL | Final processing | HEWLFOUT,<br>HEWLFROU,<br>HEWLFSCD, HEWLFADA | | HEWLFIDR | CSECT | HEWLFIDR | IDR record processing | HEWLFINP | | HEWLFINC | CSECT | HEWLFINC | Include statement processing | HEWLFINP, HEWLFSCN | | HEWLFINP | CSECT | HEWLFINP | Input processing | HEWLFINC,<br>HEWLFINT, HEWLFROU | | HEWLFINT | CSECT | HEWLFINT | Initialization | HEWL FROU | | HEWLFLDB | Label | HEWL FROU | DCB for SYSLIB | HEWLFAPT,<br>HEWLFFNL.<br>HEWLFINC, HEWLFADA | | HEWLFLOG | Entry point | HEWL FROU | ERROR LOGGING routine | HEWLFAPT | | HEWL FMAP | CSECT | HEWLFMAP | MAP/CROSS-REFERENCE processing | HEWLFFNL,<br>HEWLFOUT, HEWLFROU | | HEWLFOPT | CSECT | HEWLFOPT | Options processing | HEWLFINT | | HEWLFOUT | CSECT | HEWLFOUT | Intermediate output | HEWL FADA | | HEWLFRAT | CSECT | HEWLFRAT | RLD record processing | HEWLFINC,<br>HEWLFINP, HEWLFSCN | | HEWL FRCG | CSECT | HEWLFRCG | REPLACE/CHANGE statement processing | HEWLFESD | | HEWLFREL | CSECT | HEWLFREL | Relocation/second pass initialization | HEWLFSCD | | HEWL FROU | CSECT | HEWLFROU | Miscellaneous<br>routines/LOAD module<br>entry point | | Figure 33 (Part 3 of 4). Microfiche Directory This document contains restricted materials of IBM. © Copyright IBM Corp. 1972,1983 LY26-3921-0 | Symbol | Туре | CSECT | Description | Referenced By | |-----------|-------------|----------|----------------------------------------------------|--------------------| | HEWLFSCD | CSECT | HEWLFSCD | Second pass (LOAD module) output | HEWLFOUT, HEWLFROU | | HEWLFSCN | CSECT | HEWLFSCN | Control statement processing | HEWLFINP | | HEWLFSI0 | CSECT | HEWLFSCD | Second pass<br>input/output | HEWLFSCD | | HEWLFSYM | CSECT | HEWLFSYM | SYM record processing | HEWLFSYM | | HEWLFTXT | CSECT | HEWLFRAT | TXT record processing | HEWLFRAT | | HEWL TMDB | Label | HEWLFROU | DCB for SYSTERM | HEWLFFNL, HEWLFINT | | HEWLXIT2 | Entry point | HEWLFINT | Open exit routine for SYSLMOD | HEWLFROU | | HEWVLDCK | Entry point | HEWLFROU | Member and alias name validity check routine | HEWLFFNL, HEWLFSCN | | INDDNAME | Label | HEWLFROU | DDNAME for primary<br>input data set | HEWLFINT, HEWLFSCN | | INRLDCB1 | Label | HEWLFREL | Input RLD control block<br>#1 | HEWLFSCD | | INRLDCB2 | Label | HEWLFREL | Input RLD control block<br>#2 | HEWLFSCD | | JFCBADDR | Label | HEWLFMAP | JFCB for SYSLMOD | HEWLFFNL | | MAINGOT | Label | HEWLFINT | Address of storage obtained from GETMAIN | | | MINOR | Label | HEWLFROU | Minor name by which<br>SYSMOD is enqueued | HEWLFFNL, HEWLFINT | | MSGFOUR | Label | HEWLFINT | Pointer to (optional)<br>heading message | HEWL FROU | | OTRLDCB1 | Label | HEWLFREL | Output RLD control<br>block #1 | HEWLFSCD | | OTRLDCB2 | Label | HEWLFREL | Output RLD control<br>block #2 | HEWLFSCD | | OTRLDCB3 | Label | HEWLFREL | Output RLD control<br>block #3 | HEWLFSCD | | RELOCATE | Entry point | HEWLFREL | Address constant relocation routine | HEWLFSCD | | SCDENTAB | Entry point | HEWLFREL | Routine to create<br>ENTABS and ENTAB RLDs | HEWLFSCD | | SEGLNTAB | Label | HEWLFADA | Pointer to Segment<br>Length Table | HEWLFOUT | | WRTCRRLD | Entry point | HEWLFSI0 | Routine to write CTL or CTL/RLD records on SYSLMOD | HEWLFREL | | WRTTXT | Entry point | HEWLFSI0 | Routine to write text records on SYSLMOD | HEWLFREL | Figure 33 (Part 4 of 4). Microfiche Directory This document contains restricted materials of IBM. © Copyright IBM Corp. 1972,1983 LY26-3921-0 | Module Name | CSECT Name | |-------------------------------------------------------------------------|-----------------------------------------------------------------------------------| | HEWLFADA | HEWLFADA | | HEWLFAPT | HEWLFAPT | | HEWLFBTP | HEWLFBTP | | HEWLFDEF | HEWLFDEF | | HEWLFEND | HEWLFEND | | HEWLFENS | HEWLFENS | | HEWLFENT | HEWLFENT | | HEWLFESD | HEWLFESD | | HEWLFFNL | HEWLFFNL | | HEWLFIDR | HEWLFIDR | | HEWLFINC | HEWLFINC | | HEWLFINP HEWLFOPT HEWLFMAP HEWLFINT HEWLFOUT HEWLFRAT HEWLFRCG HEWLFREL | HEWLFINP HEWLFOPT HEWLFMAP HEWLFINT HEWLFOUT HEWLFRAT, HEWLFTXT HEWLFRCG HEWLFREL | | HEWL FROU | HEWLFROU | | HEWL FSCD | HEWLFSCD, HEWLFSIO | | HEWL FSCN | HEWLFSCN | | HEWLFSYM | HEWLFSYM | Figure 34. Module/CSECT Cross-Reference Table #### TABLE LAYOUTS This section provides detailed layouts of internal tables used during Linkage Editor processing. Figure 35 indicates the modules in which tables are initialized and used or modified. Tables described in this section are included alphabetically except for the All-Purpose Table (see Figure 36 on page 151). | Table | Built by | Used and/or Modified by | |------------------------------------------------|----------|--------------------------------------------------------------------------------------| | Alias Table | HEWLFENT | HEWLFFNL | | All-Purpose Table (APT) | HEWLFINT | 1 | | Calls List | HEWLFRAT | HEWLFENS | | Composite External Symbol<br>Dictionary (CESD) | HEWLFESD | HEWLFRAT, HEWLFSCN, HEWLFINC,<br>HEWLFADA, HEWLFENS, HEWLFENT,<br>HEWLFOUT, HEWLFTXT | | Delink Table | HEWLFESD | HEWLFRAT, HEWLFSCD | | Downward Calls List | HEWLFENS | 2 | | Entry List | HEWLFSCD | 2 | | Entry Table (ENTAB) | HEWLFSCD | 2 | | Half ESD (HESD) | HEWLFOUT | HEWLFSCD | | Half ESD Prefix | HEWLFSCD | 2 | | High ID Table (HIID) | HEWLFOUT | 2 | | IDR Translator Table (IDRTRTAB) | HEWLFIDR | HEWLFOUT | | IDR IMASPZAP Table (IDRZPTAB) | HEWLFIDR | HEWLFOUT | | IDR User Data Table (IDRUDTAB) | HEWLFIDR | HEWLFOUT | | ORDER Table | HEWLFSCN | HEWLFOUT, HEWLFADA | | Relocation Constant Table (RCT) | HEWLFADA | HEWLFOUT, HEWLFSCD | | Renumbering Table (RNT) | HEWLFESD | HEWLFRAT, HEWLFTXT | | RLD Input Control Blocks | HEWLFSCD | 2 | | RLD Note List | HEWLFRAT | HEWLFOUT, HEWLFSCD | | RLD Output Control Blocks | HEWLFSCD | 2 | | Second Pass Text Control Blocks | HEWLFSCD | 2 | | Segment Length Table (SEGLGTH) | HEWLFADA | 2 | | Segment Path Table (SEGTA1) | HEWLFOUT | HEWLFSCD | | Text I/O Table | HEWLFTXT | HEWLFOUT, HEWLFSCD | | Text Note List | HEWLFTXT | HEWLFOUT, HEWLFSCD | | TTR List (Text I/O Control<br>Table) | HEWLFSCD | HEWLFSCD | Figure 35. Table Construction and Usage This document contains restricted materials of IBM. © Copyright IBM Corp. 1972,1983 LY26-3921-0 ### Notes to Figure 35: - Major communications area throughout linkage editor processing. - Built and processed entirely within one routine. | Offset<br>Decimal | Hex | Length | Symbol | Description | |-------------------|-----|--------|--------|------------------------------------------------------------------------| | 8 | 8 | 8 | PDSE1 | Member or alias name of module being created | | 16 | 10 | 3 | PDSE2 | Relative disk address (TTR) of first record of module | | 19 | 13 | 1 | PDSE3 | Flags | | | | | | Bit O Alias indicator | | | | | | Bits 1-2 Number of TTRs in user data | | | | | | Bits 3-7 Length of user data in half words | | 20 | 14 | 4 | PDSE4 | Relative disk address (TTR) of first text record of module | | 24 | 18 | 3 | PDSE5 | Relative disk address (TTR) of note list or scatter/translation record | | 27 | 1 B | 1 | PDSE6 | Number of TTRs in note list, if present | | 28 | 1C | 1 | PDSE7 | Flags (module attributes #1) | | | | | | Bit O Reenterable | | | | | | Bit 1 Reusable | | | | | | Bit 2 Overlay | | | | | | Bit 3 Test | | | | | | Bit 4 Only loadable | | | | | | Bit 5 Block/scatter format | | | | | | Bit 6 Executable | | | | | | Bit 7 Module contains 1 text record and no RLD's | | 29 | 1 D | 1 | PDSE8 | Flags (module attributes #1) | | | | | | Bit 0 Output load module not downward compatible | | | | | | Bit 1 Origin of first text record is zero | | | | | | Bit 2 Entry point assigned by linkage editor is 0 | | | | | | Bit 3 Module contains no RLD items | | | | | | Bit 4 Module can be reprocessed by linkage editor | | | | | | Bit 5 Module does not contain SYM records | | | | | | Bit 6 Module was created by link editor F | Figure 36 (Part 1 of 10). All-Purpose Table (APT) | Offset<br>Decimal | Hex | Length | Symbol | Description | |-------------------|-----|--------|--------|------------------------------------------------------------------| | | | | | Bit 7 Refreshable | | 30 | 1E | 3 | PDSE9 | Total contiguous storage requirement for load module | | 33 | 21 | 2 | PDSE10 | Length of first text record | | 35 | 23 | 3 | PDSE11 | Entry point address | | 38 | 26 | 3 | PDSE12 | Editor assigned origin of first text record | | 38 | 26 | 1 | | Flags (1) (Module attributes #2) | | | | | | Bit 0 Load module built by OS/VS linkage editor | | | | | | Bit 1 Not used | | | | | | Bit 2 Page alignment required for load module | | | | | | Bit 3 SSI present in directory entry | | | | | | Bit 4 Directory entry contains authorization code | | 39 | 27 | 1 | | Flags (2) (Module attributes #2) | | | | | | Bits 0-2 Not used | | | | | | Bit 3 Load module residence mode | | | | | | Bits 4-5 Alias entry point addressing mode | | | | | | Bits 6-7 Main entry point addressing mode | | 40 | 28 | 1 | | Count of RLD and CTL/RLD records following the first text record | | 41 | 29 | 2 | PDSE13 | Number of bytes in scatter list | | 43 | 2B | 2 | PDSE14 | Number of bytes in the Translation Table | | 45 | 2D | 2 | PDSE15 | ESDID of the first text record | | 47 | 2F | 2 | PDSE16 | ESDID of the control section containing the entry point | | 49 | 31 | 3 | PDSE17 | Entry point of main member name | | 52 | 34 | 8 | PDSE18 | Member name of module | | 60 | 3C | 72 | REGSA | Register save area for data management | | 132 | 84 | 56 | IOCT | I/O Control Table | | 188 | ВС | 1 | APT0 | Flags | | | | | | Bit 0 NCAL | | | | | | Bit 1 XREF | | | | | | Bit 2 MAP | | | | | | Bit 3 LET | Figure 36 (Part 2 of 10). All-Purpose Table (APT) This document contains restricted materials of IBM. $\circledcirc$ Copyright IBM Corp. 1972,1983 LY26-3921-0 | Offset<br>Decimal | Hex | Length | Symbol | Description | |-------------------|-----|--------|--------|-----------------------------------------------------------------------------------| | | | | | Bit 4 LOG | | | | | | Bit 5 XCAL | | | | | | Bit 6 TXT/RLD | | | | | | Bit 7 A library statement was read | | 189 | BD | 1 | APT1 | Flags | | | | | | Bit 0 More include input to come | | | | | | Bit 1 Automatic library call in operation | | | | | | Bit 2 Object or load module | | | | | | Bit 3 Delete indicator | | | | | | Bit 4 Entry point received | | | | | | Bit 5 Symbolic or absolute entry | | | | | | Bit 6 Entry statement received | | | | | | Bit 7 ESD write indicator | | 190 | BE | 1 | APT2 | Flags | | | | | | Bit 0 No length received | | | | | | Bit 1 No length indication | | | | | | Bit 2 First text record | | | | | | Bit 3 Status indicator received | | | | | | Bit 4 Include previously initiated | | | | | | Bit 5 I/O overlap bit | | | | | | Bit 6 In module indicator | | | | | | Bit 7 Card continuation | | 191 | BF | 1 | APT3 | Flags | | | | | | Bit 0 End of file | | | | | | Bit 1 Name statement received-end of inpu-<br>for load module | | | | | | Bit 2 End of SYSLIN input | | | | | | Bit 3 To stow as replacement | | | | | | Bit 4 First text of load module | | | | | | Bit 5 First text of segment | | | | | | Bit 6 RLDs for group | | | | | | Bit 7 SYSLIB opened | | 192 | CO | 4 | CTTR | Relative disk address (TTR) of first CESD record, if MAP or SREF option specified | Figure 36 (Part 3 of 10). All-Purpose Table (APT) This document contains restricted materials of IBM. © Copyright IBM Corp. 1972,1983 LY26-3921-0 | Offset<br>Decimal | Hex | Length | Symbol | Description | |-------------------|-----|--------|----------|--------------------------------------------------------------------| | 196 | C4 | 2 | CSNO | Current segment number | | 198 | C6 | 2 | CRNO | Current region number | | 200 | С8 | 4 | PRAL | Pseudo register cumulative length | | 204 | СС | 4 | FLCD | Address of first deleted CESD entry | | 208 | D0 | 4 | RCCE | Address of replace/change chain end | | 212 | D4 | 4 | RCCB | Address of replace/change chain beginning | | 216 | D8 | 4 | ALCB | Address of alias chain beginning | | 220 | DC | 4 | OVCMBGAD | Address of overlap chain beginning | | 224 | E0 | 4 | SGT1 | Address of SEGTAB1 - 1 | | 228 | E4 | 4 | CLLT | Address of Calls List Table | | 323 | E8 | 4 | TNT1 | Address of text note list 1 | | 236 | EC | 4 | RNT1 | Address of RLD note list 1 | | 240 | F0 | 4 | RLDINPAD | Address of RLD input buffer, 1st pass | | 244 | F4 | 4 | RECNT | Address of Relocation Constant Table - 4/<br>Renumbering Table - 4 | | 248 | F8 | 4 | TXTIO | Address of Text I/O Table | | 252 | FC | 4 | ALAS | Address of Alias Table | | 256 | 100 | 4 | DLKT | Address of DELINK Table - 5 | | 260 | 104 | 4 | CHESD | Address of composite ESD - 16 | | 264 | 108 | 4 | SELST | Address of second pass entry list | | 268 | 10C | 4 | TNLS2 | Address of text note list 2 | | 272 | 110 | 4 | RNLS2 | Address of RLD note list 2 | | 276 | 114 | 4 | TTRLIST | Address of TTR list | | 280 | 118 | 4 | RLDOUTBF | Address of output RLD buffer, 2nd pass | | 284 | 11C | 4 | HIARADD | Address of Hierarchy Table | | 288 | 120 | 4 | ORDRADR | Address of Order Table | | 292 | 124 | 4 | INCBRKPT | Address of breaking point in include chain | | 296 | 128 | 4 | CRRTINCL | Address of currently included ESD item | | 300 | 12C | 2 | ENRNX | Maximum number of entries in RNT Table | | 302 | 12E | 2 | ENCDX | Maximum number of entries in C/HESD Tables | | 304 | 130 | 2 | ENT1X | Maximum number of entries in text note list 1 | | 306 | 132 | 2 | ENR1X | Maximum number of entries in RLD note list 1 | | 308 | 134 | 2 | ENT2X | Maximum number of entries in text note list 2 | Figure 36 (Part 4 of 10). All-Purpose Table (APT) This document contains restricted materials of IBM. © Copyright IBM Corp. 1972,1983 LY26-3921-0 | Offset<br>Decimal | Hex | Length | Symbol | Description | |-------------------|-----|--------|----------|------------------------------------------------------------------| | 310 | 136 | 2 | ENR2X | Maximum number of entries in RLD note list 2 | | 312 | 138 | 2 | ENTOX | Maximum number of bytes in Text I/O Table | | 314 | 13A | 2 | ENCLX | Maximum number of bytes in calls list | | 316 | 13C | 2 | ENDTX | Maximum number of entries in DELINK Table | | 318 | 13E | 2 | EN\$1X | Maximum number of segments | | 320 | 140 | 2 | BUFSIZ | Size of load module input buffer | | 324 | 144 | 4 | HESD | Address of HESD Table - 8 | | 328 | 148 | 2 | ENELTX | Maximum number of entries in 2nd pass entry<br>list | | 330 | 14A | 2 | ENT1X1 | Maximum number of entries in text note list<br>1, pre-reallocate | | 332 | 14C | 2 | ENR1X1 | Maximum number of entries in RLD note list 1, pre-reallocate | | 334 | 14E | 2 | IDRTRLEN | Maximum length of IDR Translator Data Table | | 336 | 150 | 2 | IDRTILEN | Maximum length of IDR Translator ID Table | | 338 | 152 | 2 | IDRUDLEN | Maximum length of IDR User Data Table | | 340 | 154 | 2 | IDRZPLEN | Maximum length of IDR AMASPZAP Data Table | | 344 | 158 | 4 | IDRTRTAB | Starting address of IDR Translator Data Table | | 348 | 15C | 4 | IDRTITAB | Starting address of IDR Translator ID Table | | 352 | 160 | 4 | IDRUDTAB | Starting address of IDR User Data Table | | 356 | 164 | 4 | IDRZPTAB | Starting address of IDR AMASPZAP Data Table | | 360 | 168 | 4 | IDRTREND | Address of next available byte in IDR<br>Translator Data Table | | 364 | 16C | 4 | IDRTIEND | Address of next available byte in IDR<br>Translator ID Table | | 364 | 16C | 4 | IDRTIEND | Address of next available byte in IDR<br>Translator ID Table | | 368 | 170 | 4 | IDRUDEND | Address of next available byte in IDR User<br>Data Table | | 372 | 174 | 4 | IDRZPEND | Address of next available byte in IDR<br>AMASPZAP Data Table | | 376 | 178 | 2 | ENRL D2X | Maximum size of input RLD buffer, 1st pass | | 378 | 17A | 2 | ENSPX | Save area | | 380 | 17C | 4 | LSTS | Last segment in each region (region 1-4) | | 384 | 180 | 8 | EPSM | Entry point symbol or end card address/symbol | | 392 | 188 | 2 | ENT1C | Current number of entries in text note list 1 | | 394 | 18A | 2 | ENR1C | Current number of entries in RLD note list 1 | Figure 36 (Part 5 of 10). All-Purpose Table (APT) This document contains restricted materials of IBM. $\odot$ Copyright IBM Corp. 1972,1983 LY26-3921-0 | Offset<br>Decimal | Hex | Length | Symbol | Description | |-------------------|------|--------|----------|-----------------------------------------------------------------| | 396 | 18C | 2 | ENITC | Current number of bytes in TXT I/O CNTL Table | | 398 | 18E | 2 | ENIRC | Current number of bytes in RLD I/O CNTL Table | | 400 | 190 | 2 | ENTOC | Current number of bytes in TXT I/O Table | | 402 | 192 | 2 | ENCLC | Current number of bytes in calls list | | 404 | 194 | 2 | ENS1C | Current number of entries in SEGTAB1 | | 406 | 196 | 2 | ENASC | Current number of entries in Alias Table | | 408 | 198 | 2 | ENDTC | Current number of entries in DELINK Table | | 410 | 19A | 2 | ENRNC | Current number of entries in RNT Table | | 412 | 19C | 2 | ENCDC | Current number of entries in H/CESD Table | | 414 | 19E | 2 | ENELTC | Current number of entries in 2nd pass entry<br>list | | 416 | 1A0 | 2 | ENT2C | Current number of entries in TXT note list 2 | | 418 | 1A2 | 2 | ENR2C | Current number of entries in RLD note list 2 | | 420 | 1A4 | 2 | ENSPC | Highest segment number with text | | 424 | 1A8 | 2 | IDRTRCUR | Current number of bytes in IDR Translator<br>Data Table | | 428 | 1AC | 2 | IDRTICUR | Current number of bytes in IDR Translator ID<br>Table | | 432 | 1B0 | 2 | IDRUDCUR | Current number of bytes in IDR User Data<br>Table | | 436 | 184 | 2 | IDRZPCUR | Current number of bytes in IDR AMASPZAP Data<br>Table | | 438 | 1B6 | 2 | ORDRCUR | Current number of bytes in Order Table | | 440 | 1B8 | 2 | ORDRMAX | Maximum number of bytes in Order Table | | 444 | 1BC | 8 | BITMAP | Bit switches denoting error messages logged (error msgs 64-1) | | 452 | 104 | 8 | BITMAP2 | Bit switches denoting error messages logged (error msgs 128-65) | | 460 | 100 | 2 | LINECHT | Number of lines output for current page | | 462 | 1CE | 2 | HISEV | Highest severity message logged | | 464 | 1D0 | 8 | SYSRTN | Save area for registers 13 and 14 from INVOKER | | 472 | 1 D8 | 72 | SPACES | Register save area | | 544 | 220 | 4 | ERDIG | Address of HEWLFLOG, error logging routine | | 548 | 224 | 4 | ERDIGA | Address of HEWLFALK, table allocation routine | | 552 | 228 | 4 | SSI | System status indicator (for APT) | | 556 | 22C | 4 | FFCADR | Highest address retained from gotten storage | Figure 36 (Part 6 of 10). All-Purpose Table (APT) This document contains restricted materials of IBM. $\circledcirc$ Copyright IBM Corp. 1972,1983 LY26-3921-0 | Offset<br>Decimal | Hex | Length | Symbol | Description | | | |-------------------|-----|--------|---------|----------------------------------------------------------|--|--| | 560 | 230 | 8 | LIBNAME | Name of library for automatic library call | | | | 568 | 238 | 8 | LIBOPEN | Name of library currently open | | | | 576 | 240 | 2 | APT000 | SYNAD routine for SYSPRINT data set | | | | 578 | 242 | 3 | SAVATS | Attributes save area | | | | 581 | 245 | 1 | APTSWS | Switches | | | | | | | | Bit 0 TSO task | | | | | | | | Bit 1 Not used | | | | | | | | Bit 2 Absolute/relocatable | | | | | | | | Bit 3 DCBS override | | | | | | | | Bit 4 Bit map processed | | | | | | | | Bit 5 Linkage editor input received | | | | | | | | Bit 6 SYM received | | | | | | | | Bit 7 ESD received | | | | 582 | 246 | 1 | NEWSW | Flags | | | | | | | | Bit 0 If off indicates 1st time in INT | | | | | | | £ | Bit 1 MAP/XREF entered from intermediate/final processor | | | | | | | | Bit 2 All RLDs in storage/not in storage | | | | | | | | Bit 3 MAP/XREF in control/not in control | | | | | | | | Bit 4 Normal printing on SYSPRINT/ABORT without printing | | | | | | | | Bit 5 HIERARCHY | | | | | | | | Bit 6 Not used | | | | | | | | Bit 7 Indicates purge to TXT/RLD processor | | | | 583 | 247 | 1 | NEWSW2 | Flags | | | | | | | | Bit 0 More RLDs exist for current ID | | | | | | | | Bit 1 Split RLD in output buffer | | | | | | | | Bit 2 R and P pointer have been saved | | | | | | | | Bit 3 Relative/absolute relocation factor needed | | | | | | | | Bit 4 Split RLD has been saved in HESD prefix | | | | | | | | Bit 5 No RLDs exist for last text of segment/module | | | | | | | | Bit 6 Split RLD is preceded by R and P pointers | | | Figure 36 (Part 7 of 10). All-Purpose Table (APT) This document contains restricted materials of IBM. © Copyright IBM Corp. 1972,1983 LY26-3921-0 | Offset<br>Decimal | Hex | Length | Symbol | Description | on | |-------------------|-----|--------|----------|-------------|-----------------------------------------------------| | | | | | | R and P pointers for current chain are in buffer | | 584 | 248 | 1 | APTSW2 | Flags | | | | | | ,b | Bit 0 | SYSLMOD enqueued | | | | | | Bit 1 | Not used | | | | | | Bit 2 | SYSLMOD shared DASD | | | | | | | First/not first time through<br>initialization | | | | | | Bits 4-7 | Not used | | 585 | 249 | 1 | APTSW3 | Flags | | | | | | | Bit O E | Expand statement encountered | | | | | | | Included load module was in overlay<br>format | | | | | | Bits 2-7 | Reserved | | 586 | 24A | 1 | APTSW4 | Switches | _ | | 587 | 24B | 1 | IDRSWS | Flags | | | | | | | Bits 0-2 | Not used | | | | | | Bit 3 l | Last IDR item processed not complete | | | | | | Bit 4 I | Double IDR entry on object module record in process | | | | | | Bit 5 | Identify control card in process | | | i. | | | Bit 6 0 | Object module end card in process | | | | | | Bit 7 L | oad module IDR in process | | 588 | 24G | 1 | APT4 | Flags | | | | | | | Bit 0 | Tables initially allocated | | | | | | Bit 1 | Tables reallocated | | | | | | Bit 2 | Intermediate pass processing | | | | | | Bit 3 S | Second pass processing | | _ | | | | Bit 4 ( | Ordering required | | | | | | Bit 5 | Page boundary alignment required | | | | | | Bit 6 | Align on 2K-byte page boundary | | | | | | Bit 7 | Not used | | 590 | 24E | 2 | MAXBF | Maximum bl | locking factor | | 592 | 250 | 28 | HEWLCRBB | SYSLIB cor | ntrol block | Figure 36 (Part 8 of 10). All-Purpose Table (APT) This document contains restricted materials of IBM. $\ensuremath{\text{©}}$ Copyright IBM Corp. 1972,1983 LY26-3921-0 | Offset<br>Decimal | Hex | Length | Symbol | Description | | |-------------------|-----|--------|----------|-----------------------------------------------|--| | 592 | 250 | 4 | | Address of SYSLIB DECB | | | 596 | 254 | 4 | | 1st library buffer | | | 600 | 258 | 4 | | 2nd library buffer | | | 604 | 25C | 2 | | BLKSIZE | | | 606 | 25E | 2 | | LRECL | | | 608 | 260 | 2 | | BLKFCTR | | | 610 | 262 | 2 | | Number of records left in buffer | | | 612 | 264 | 4 | | Address of current record | | | 616 | 268 | 4 | | READSW set to first read | | | 620 | 26C | 28 | HEWLCRBN | SYSLIN control block | | | 620 | 26C | 4 | | Address of SYSLIN DECB | | | 624 | 270 | 4 | | 1st SYSLIN buffer | | | 628 | 274 | 4 | _ | 2nd SYSLIN buffer | | | 632 | 278 | 2 | | BLKSIZE | | | 634 | 27A | 2 | | LRECL | | | 636 | 27C | 2 | | BLKFCTR | | | 638 | 27E | 2 | | Number of records left in buffer | | | 640 | 280 | 4 | | Address of current record | | | 644 | 284 | 4 | | READSW set to first read | | | 648 | 288 | 28 | HEWLCWBB | SYSPRINT control block | | | 648 | 288 | 4 | | Address of SYSPRINT DCB | | | 652 | 28C | 4 | | 1st SYSPRINT buffer | | | 656 | 290 | 4 | | 2nd SYSPRINT buffer | | | 660 | 294 | 2 | | BLKSIZE | | | 662 | 296 | 2 | | LRECL | | | 664 | 298 | 2 | | BLKFCTR | | | 666 | 29A | 2 | | Number of records left in buffer | | | 668 | 29C | 4 | | Address of current record | | | 672 | 2A0 | 4 | | WRITESW set to first write | | | 676 | 244 | 4 | RLDOUT1 | Address of first RLD output buffer, 1st pass | | | 676 | 244 | 4 | RLDINBF1 | Address of first RLD input buffer, 2nd pass | | | 680 | 2A8 | 4 | RLDOUT2 | Address of second RLD output buffer, 1st pass | | | 680 | 2A8 | 4 | RLDINBF2 | Address of second RLD input buffer, 2nd pass | | Figure 36 (Part 9 of 10). All-Purpose Table (APT) This document contains restricted materials of IBM. $\circledcirc$ Copyright IBM Corp. 1972,1983 LY26-3921-0 | Offset<br>Decimal | Hex | Length | Symbol | Description | |-------------------|-----|--------|----------|---------------------------------------------| | 684 | 2AC | 4 | TXTBFBEG | Address of start of text buffer | | 688 | 2B0 | 4 | TXTBFEND | Address of end of text buffer | | 692 | 284 | 4 | MULTSIZE | Size of SYSLMOD multiplicity or record | | 696 | 2B8 | 4 | UT1SIZE | Size of SYSUT1 record | | 700 | 2BC | 4 | SZSYSUT1 | Maximum number of bytes per track on SYSUT1 | | 704 | 200 | 4 | RLDSIZE | Size of each input RLD buffer, 1st pass | | 708 | 204 | 4 | VALUE1 | Size value 1 (maximum allowable storage) | | 712 | 2C8 | 4 | VALUE2 | Size value 2 (load module buffer) | | 716 | 200 | 4 | MSGONE | Pointer to 1st heading message | | 720 | 2D0 | 4 | MSGTWO | Pointer to 2nd heading message | | 724 | 2D4 | 4 | MSGTHREE | Pointer to 3rd heading message | | 728 | 2D8 | 4 | HEWLCLAC | Address of current read block | | 732 | 2DC | 20 | | DECB for SYSLIN | | 752 | 2F0 | 20 | | DECB for SYSLIB | | 772 | 304 | 4 | COREADR | Address of storage obtained through GETMAIN | | 776 | 308 | 4 | CORELEN | Length of storage obtained through GETMAIN | | 780 | 30C | 64 | BRNCHSV | Save area | | 844 | 34C | 1 | APTAPFCT | Default length of authorization code | | 845 | 340 | 1 | APTAPFAC | Default authorization code | | 846 | 34E | 1 | PDSAPFCT | Length of authorization code assigned | | 847 | 34F | 1 | PDSAPFAC | Authorization code assigned | | 848 | 350 | 1 | MODEAMOD | Addressing mode from mode control statement | | 849 | 351 | 1 | MODERMOD | Residence mode from mode control statement | | 850 | 352 | 1 | PARMAMOD | Addressing mode from PARM field | | 851 | 353 | 1 | PARMRMOD | Residence mode from PARM field | | 852 | 354 | 1 | MEMBAMOD | Addressing mode for main entry point | | 853 | 355 | 1 | ESDARMOD | Residence mode accumulated from ESDs | Figure 36 (Part 10 of 10). All-Purpose Table (APT) Figure 37. Alias Table Figure 38. Calls List (As Built by RLD Processor) Figure 39. Calls List (As Altered and Used by ENTAB Size Determination Routine) Figure 40. Composite External Symbol Dictionary (CESD)-Internal Format This document contains restricted materials of IBM. $\circledcirc$ Copyright IBM Corp. 1972,1983 LY26-3921-0 # See Figure 41 for normal combination of internal CESD types. | CESD Entry Type | Type Field<br>(byte 8) | Chain Address<br>Chain ID<br>(bytes 9-11) | AMODE/RMODE/RSECT<br>Data or Segment Number<br>(byte 12) | ER Subtype<br>(byte 13) | ddname Pointer/<br>Chain ID/Length<br>(bytes 14–15) | |--------------------------------------------------|------------------------|-------------------------------------------|----------------------------------------------------------|-------------------------|-----------------------------------------------------| | Section Definition | ×××× ×000 | | (5) | Length of | control section | | Private Code | ×××× ×100 | | (5) | Length of | control section | | Common | ×××× ×101 | | (6) | Length of | common area | | Pseudo Register | xxxx x110 | | Alignment<br>value (1) | Length of p | pseudo register | | External Reference | xxxx 0010 | Hex 00 or 80 | | 0000 0000 | | | Weak External Reference | xxxx 1010 | Hex 00 | | 0000 0000 | | | Label Reference | xxxx x011 | | (6) | | CESD entry no. of SD or PC (ID) | | NULL | 0000 0111 | | | | | | Replace | xxx1 xxxx | | | 0000 0000 | | | Insert | xxlx xxxx | | - | | | | Chain | xlxx xxxx | | | | | | Мар | lxxx xxxx | | | | | | Delete | xxx1 xxxx | | | 0000 1000 | | | ER – Unmatched Lib-<br>rary Member Name | 0000 0010 | Reverse chain ID | | 0000 0010 | CESD entry no. of next item (ID) | | ER – Matched Library<br>Member Name | 0000 0010 | Reverse chain<br>ID (2) | | 0000 0011 | CESD entry no. of next item (ID) | | ER - Unmatched No<br>Call Name | 0000 0010 | | | 0000 0100 | | | ER - Matched No Call | 0000 0010 | | | 0000 0101 | | | ER - Never Call | 0000 0010 | | | 0000 0110 | | | ER - Overlay Control<br>Statement | 0000 0010 | Address of next item in the chain | | 1001 0000 | | | ER - Alias Control<br>Statement | 0000 0010 | Address of next item in the chain | | 1010 0000 | | | ER – ddname from<br>Library or Include Statement | 0000 0010 | | | 1011 0000 | Forward chain<br>PTR (Library only) | | ER - Include Control<br>Statement w/o Pointer | 0000 0010 | Address of next item in the chain | | 1100 0000 | | | ER – Include Control<br>Statement with Pointer | 0000 0010 | Address of next item in the chain | | 1101 0000 | Pointer to i-<br>brary's ddname | | ER - Replace Control<br>Statement (3) | 0000 0010 | Address of next item in the chain | | 1100 0000 | | | ER - Control Delete (4) | 0000 0010 | Address of next item in the chain | | 1110 1000 | | | ER – Change Control<br>Statement (3) | 0000 0010 | Address of next | | 1111 0000 | | Figure 41 (Part 1 of 2). Normal Combination of Internal CESD Types | 00 = byte alignment 01 = baltword alignment 03 = fullword alignment 07 = doubleword alignment 07 = doubleword alignment 2. BLDL has been issued for this member nome if bit 64 is set to 1. 3. Two CESD entries are made for each Replace or Change control statement, one entry for each symbol. 4. This entry results from a Replace or Change control statement that contains only a single symbolic name. 5. If segment number, 1 to 255. 1f AMODE/AMODE/IRSECT data: xxxx not used R. RESECT information 0 = not read-only 1 = read-only R. MODE data 0 = 24 1 = ANY AA AMODE data 00 = 01 = 24 10 = 31 11 = ANY 5. If segment number, 1 to 255. Otherwise, zero or blank. Figure 41 (Part 2 of 2). Normal Combination of Internal CESD Types | |-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1. Alignment Value — Specifies boundary alignment of the pseudo register 00 = byte alignment 03 = fullword alignment 07 = doubleword alignment 08 = fullword alignment 09 fure sead on the full of | | 00 = byte alignment 01 = halfword alignment 03 = fullword alignment 07 = doubleword alignment 07 = doubleword alignment 08 = MLDL has been issued for this member name if bit 64 is set to 1. I wo CESD entries are made for each Replace or Change control statement, one entry for each symbol. This entry results from a Replace or Change control statement that contains only a single symbolic name. If segment number, 1 to 255. If AMODE/RMODE/RSECT data: xxxx not used RSECT information 0 = not read-only 1 = read-only 1 = read-only 0 = 24 1 = ANY AA AMODE data 0, 01 = 24 10 = 31 11 = ANY If segment number, 1 to 255. | | 30 = fullword alignment 77 = doubleword alignment 8 LDL has been issued for this member name if bit 64 is set to 1. 8 LT wo CESD entries are made for each Replace or Change control statement, one entry for each symbol. 8 This entry results from a Replace or Change control statement that contains only a single symbolic name. 9 If segment number, 1 to 255. 16 AMDDE/RMODE/RSECT data: | | 9. BLDL has been issued for this member nome if bit 64 is set to 1. 9. Two CESD entries are made for each Replace or Change control statement, one entry for each symbol. 9. This entry results from a Replace or Change control statement that contains only a single symbolic name. 9. If segment number, 1 to 255. 9. If AMODE/RMODE/RSECT data: ***xxx*** not used ** R. RSECT information 0 = not read-only 1 = read-only 1 = read-only 1 = ANY AA AMODE data 00, 01 = 24 10 = 31 11 = ANY 9. If segment number, 1 to 255. Otherwise, zero or blank. 9. Pelink Table wilt by RLD Processor (Delink Routine), | | 2. BLDL has been issued for this member name if bit 64 is set to 1. 3. Two CESD entries are made for each Replace or Change control statement, one entry for each symbol. 4. This entry results from a Replace or Change control statement that contains only a single symbolic name. 5. If segment number, 1 to 255. If AMODE/RMODE/RSECT data: xxxx not used R RSECT information 0 = not read-only 1 = read-only R. RMODE data 0 = 24 1 = ANY AA AMODE data 00, 01 = 24 10 = 31 11 = ANY 5. If segment number, 1 to 255. Otherwise, zero or blank. Figure 41 (Part 2 of 2). Normal Combination of Internal CESD Types Delink Table wilt by RLD Processor (Delink Routine), | | i. Two CESD entries are made for each Replace or Change control statement, one entry for each symbol. This entry results from a Replace or Change control statement that contains only a single symbolic name. If segment number, 1 to 255. If AMMODE/RMODE/RSECT data: xxxx | | i. This entry results from a Replace or Change control statement that contains only a single symbolic name. i. If segment number, 1 to 255. If AMODE/RMODE/RSECT data: xxxx | | is if segment number, 1 to 255. If AMODE/RMODE/RSECT data: xxxx | | xxxx not used RSECT information 0 = not read-only 1 = read-only 1 = read-only 1 = ANY AA AMODE data 0, 01 = 24 10 = 31 11 = ANY i. If segment number, 1 to 255. Otherwise, zero or blank. Figure 41 (Part 2 of 2). Normal Combination of Internal CESD Types | | R RSECT information 0 = not read-only 1 = read-onlyR. RMODE data 0 = 24 1 = ANYAA AMODE data 00, 01 = 24 10 = 31 11 = ANY S. If segment number, 1 to 255. Otherwise, zero or blank. Figure 41 (Part 2 of 2). Normal Combination of Internal CESD Types | | 0 = not read-only 1 = read-only 0 = 24 1 = ANY AMODE data 0 = 24 1 = ANY 0, 01 = 24 10 = 31 11 = ANY If segment number, 1 to 255. Otherwise, zero or blank. Figure 41 (Part 2 of 2). Normal Combination of Internal CESD Types Delink Table uilt by RLD Processor (Delink Routine), | | 1 = read-onlyR. RMODE data 0 = 24 1 = ANYAA AMODE data 00, 01 = 24 10 = 31 11 = ANY i. If segment number, 1 to 255. Otherwise, zero or blank. Figure 41 (Part 2 of 2). Normal Combination of Internal CESD Types | | R. RMODE data 0 = 24 1 = ANYAA AMODE data 00, 01 = 24 10 = 31 11 = ANY i. If segment number, 1 to 255. Otherwise, zero or blank. Figure 41 (Part 2 of 2). Normal Combination of Internal CESD Types Delink Table uilt by RLD Processor (Delink Routine), | | 0 = 24 1 = ANYAA AMODE data 00, 01 = 24 10 = 31 11 = ANY i. If segment number, 1 to 255. Otherwise, zero or blank. Figure 41 (Part 2 of 2). Normal Combination of Internal CESD Types Delink Table wilt by RLD Processor (Delink Routine), | | 1 = ANY AMODE data 00, 01 = 24 10 = 31 11 = ANY If segment number, 1 to 255. Otherwise, zero or blank. Figure 41 (Part 2 of 2). Normal Combination of Internal CESD Types Delink Table wilt by RLD Processor (Delink Routine), | | AA AMODE data 00, 01 = 24 10 = 31 11 = ANY i. If segment number, 1 to 255. Otherwise, zero or blank. Figure 41 (Part 2 of 2). Normal Combination of Internal CESD Types Delink Table uilt by RLD Processor (Delink Routine), | | 00, 01 = 24 10 = 31 11 = ANY i. If segment number, 1 to 255. Otherwise, zero or blank. Figure 41 (Part 2 of 2). Normal Combination of Internal CESD Types Delink Table wilt by RLD Processor (Delink Routine), | | 10 = 31 11 = ANY 5. If segment number, 1 to 255. Otherwise, zero or blank. Figure 41 (Part 2 of 2). Normal Combination of Internal CESD Types Delink Table puilt by RLD Processor (Delink Routine), | | 11 = ANY 5. If segment number, 1 to 255. Otherwise, zero or blank. Figure 41 (Part 2 of 2). Normal Combination of Internal CESD Types Pelink Table uilt by RLD Processor (Delink Routine), | | Otherwise, zero or blank. Figure 41 (Part 2 of 2). Normal Combination of Internal CESD Types Delink Table uilt by RLD Processor (Delink Routine), | | Otherwise, zero or blank. Figure 41 (Part 2 of 2). Normal Combination of Internal CESD Types Delink Table Solit by RLD Processor (Delink Routine), | | Delink Table Fullt by RLD Processor (Delink Routine), | | <u>Velink Table</u> uilt by RLD Processor (Delink Routine), | | | | | | \(\tag{\tag{\tag{\tag{\tag{\tag{\tag{ | | | | | | | | | | | | | | Address - assigned to the symbol being deleted (3 bytes) | | Audiess - dissigned to the symbol being defered (5 bytes) | | CESD carry combon (ID) as the releasting or interest on BLD them refer in the the combot the combon of the second | | CESD entry number (ID) - the relocation pointer of an RLD item referring to the symbol that is | | replacing the identically named symbol (or symbols) to be deleted (2 bytes) | | igure 42. Delink Table | | | | | | | | | | | | | | | | Downward Calls List | | | | Built by and referred to by ENTAB Size Determination Routine (HEWLFENS) | | 7 1 1 1 1 1 1 1 1 1 | | | | | | | | | | | | Segment number – entries are one for one with those of the CESD. If a | | Segment number – entries are one for one with those of the CESD. If a downward call is made to a symbol, the segment's number from | | downward call is made to a symbol, the segment's number from which the call is made is entered in the downward calls list | | downward call is made to a symbol, the segment's number from which the call is made is entered in the downward calls list at an entry corresponding to the ESDID of the symbol in the | | downward call is made to a symbol, the segment's number from which the call is made is entered in the downward calls list | | downward call is made to a symbol, the segment's number from which the call is made is entered in the downward calls list at an entry corresponding to the ESDID of the symbol in the | | downward call is made to a symbol, the segment's number from which the call is made is entered in the downward calls list at an entry corresponding to the ESDID of the symbol in the CESD. The list is initially zero. (1 byte) | | downward call is made to a symbol, the segment's number from which the call is made is entered in the downward calls list at an entry corresponding to the ESDID of the symbol in the | | downward call is made to a symbol, the segment's number from which the call is made is entered in the downward calls list at an entry corresponding to the ESDID of the symbol in the CESD. The list is initially zero. (1 byte) | Figure 44. Entry List #### Entry Table (ENTAB) **Built by Second Pass Processor** | Unconditional branch to le<br>entry-BC 15, DISP (15,0) | ost | Address of referred | "to" seg | Previous Caller | |---------------------------------------------------------------|-----|-------------------------------|------------------|-------------------------------------| | Cimity De Not Bills Mayor | | Address of referred to symbol | | (zero initially) | | | | | | | | Unconditional branch to le<br>entry-BC 15, DISP (15,0) | ast | Address of referred | "to" seg | Previous Caller<br>(zero initially) | | SVC 45 L 15, 4 (0,15) loads GR15 with the value of the adcon | | h BCR 15,15 | "from"<br>seg no | Address of segment table (SEGTAB) | DISP -- is the displacement, in bytes, of this entry from the last entry. "to" segment number -- is the number of the segment containing the symbol being referred to. "from" segment number -- is the number of the segment that contains this entry table. Figure 45. Entry Table (ENTAB) Figure 46. Half External Symbol Symbol Dictionary (HESD) Figure 47. High ID Table (HIID) Figure 48. Virtual Storage Allocation Table Figure 49. Partitioned Organization Directory Record (As Received from BLDL) #### Module Attributes 1 | Bit Numb | er Attributes | Bit Setting | Indication | |----------|---------------|-------------|----------------------------------------------------------------------------------------| | 0 | RENT | 0<br>1 | Not reenterable<br>Reenterable | | 1 | REUS | 0<br>1 | Not reusable | | 2 | OVLY | 0 | Reusable<br>Not an overlay module | | 3 | TEST | 0 | Overlay module<br>Not under test | | 4 | LOAD | 0 | Under test<br>Not only loadable | | 5 | Format | 1<br>0 | Only loadable <sup>1</sup><br>Block format | | 6 | Executable | 1<br>0<br>1 | Scatter format<br>Not executable | | 7 | Format | 0 | Executable Module contains more than one text record and/or RLD record(s) | | | | 1 | Module contains only one text | | 8 | Compatibility | 0 | record and no RLD record Module can be reprocessed by all | | | | 1 | levels of linkage editor<br>Module cannot be reprocessed by<br>linkage editor E | | 9 | Format | 0 | Linkage editor E<br>Linkage editor assigned origin of<br>first text record is not zero | | | | 1 | Linkage editor assigned origin of first text record is zero | | 10 | Format | 0 | Linkage editor assigned entry point is not zero | | | | 1 | Linkage editor assigned entry point is zero | | 11 | Format | 0<br>1 | Module contains RLD record(s) Module does not contain an RLD | | 12 | Editability | 0 | record Module can be reprocessed by | | 12 | Lateability | 1 | linkage editor<br>Module cannot be reprocessed by | | 13 | Format | 0 | linkage editor Module does not contain TESTRAN | | 13 | i oi ma c | 1 | symbol records Module contains TESTRAN symbol | | 14 | Compatibility | 1 | records Module created by linkage editor F | | 15 | REFR | Ö | Module is not refreshable | #### Note: Figure 50 (Part 1 of 2). Module Attributes Module can be loaded only with the LOAD macro instruction. When the module is in virtual storage, it is entered directly, not through the use of an XCTL, LINK, or ATTACH macro instruction. ### Module Attributes 2 | Bit Number | Bit Setting | Indication | |---------------|-------------|--------------------------------------------------------| | 0 | 1 | Module has been processed by OS/VS linkage editor | | 2 | U | Reserved - Unused | | <u>د</u><br>۲ | † | Page alignment required for load module<br>SSI present | | 4 | i | Authorization code present in last 2 bytes of | | | | directory entry | ### AMODE/RMODE Information | xxx<br>R | Not Used<br>RMODE for Load Module<br>0 = 24 | |----------|-----------------------------------------------------------------------------| | AA | 1 = ANY<br>AMODE for the True Alias or Alternate Entry Point<br>00 = 24 | | AA | 10 = 31<br>11 = ANY<br>AMODE for the Main Entry Point<br>00 = 24<br>10 = 31 | | | 11 = ANY | Figure 50 (Part 2 of 2). Module Attributes | wilt b | y linkage editor | | | | | | | | |----------|--------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------|-----------------------------------------|--|--|--|--| | 0 4 | | Name of load module | (member or alias name) | | | | | | | 8 | | Relative (to beginning of data set)track address of module (TTR) | | | | | | | | 12 | | Relative (to beginning of data set)track address of first text record (TTR) | | | | | | | | 16 | | eginning of data set)track address of not<br>/translation record (TTR) | e | Number of entries in note list* | | | | | | 20 | | 1 (see Figure 50)<br>7, 8, 9, 10, 11, 12, 13, 14, 15 | Total contiguous vir | tual storag <b>e</b> required | | | | | | 24 | for the module | Length (in bytes) of | first text record | Module's linkage | | | | | | 28 | editor assigned ent | ry point address | Module Attributes 2<br>(see Figure 50) | AMODE/RMODE information (see Figure 50) | | | | | | 32 | RLD count | Authorization Code Length** | Authorization Code** | | | | | | | | | F | or load modules in scatter format ad | d: | | | | | | | | Length of transla- | | | | | | | | 36 | tion table (in bytes) | ESDID (CESD entry num<br>section name) for first to | ESDID (CESD entry<br>number of control | | | | | | | 40 | section name) cont—<br>aining entry point | Authorization Code Length** | Authorization Code** | | | | | | | | | F | or load modules with alias names ad | d: | | | | | | | | Entry | point address of the member name | | | | | | | 44<br>48 | | Membe | r name | | | | | | | 52 | Authorization Code Length** | Authorization Code** | | | | | | | | | | F | For load modules with SSI bytes: | | | | | | | | | SSI bytes – Aligned on a halfword bo record. | undary at the end of the PDS | | | | | | | | Authorization Code Length** | Authorization Code** | | | | | | | | | Legend:<br>Alias indicat<br>Bi<br>(<br>1,<br>3- | O signifies none I signifies alias number of relative track ad | ldresses (TTR) in user data field<br>n halfwords) | | | | | | | | Fo<br>BI<br>So<br>*This byte co<br>**The authori | catter 44 (with alias names, 54 b<br>ote: For SSI, add 4 bytes to sizes give<br>ontains a zero if load module is not in<br>zation code fields will appear only onc<br>y record. The size of the directory det | n above.<br>verlay.<br>e. They are always the last fields o | f | | | | | Figure 51. Partitioned Organization Directory Record (As Built by Linkage Editor) Figure 52. Relocation Constant Table (RCT) Figure 53. Renumbering Table (RNT) <sup>\*</sup> There is a control block for each of two input buffers. Figure 54. RLD Input Control Block <sup>\*</sup> There is a control block for each of three RLD output buffers. Figure 55. RLD Output Control Block Figure 56. RLD Note List \* There are two text control blocks - - one for current text being processed, another for next text to be processed or text just processed. Figure 57. Second Pass Text Control Block # Segment Length Table (SEGLGTH) Built and referred to by Address Assignment Processor Appearance of table after assignment of control section addresses Highest ID or ENTAB Entry Count for Segment (2 bytes) Flag (1 byte) Bits 0 through 3 not used Bit 4 = 0 --- next two bytes contain the highest ID of the segment = 1 --- next two bytes contain the number of ENTAB entries for this segment Bits 5,6,7 - The low-order three bits of the previously assigned address of the first control section of this segment Cumulative Segment Length - in bytes, of control sections in this segment (including the ENTAB, if present) (3 bytes) Appearance of table after segment addresses are determined Segment Relocation Constant - for the segment that corresponds to this entry (3 bytes) Path Length - in bytes, of this segment, including this segment and its ENTAB (3 bytes) Figure 58. Segment Length Table (SEGLGTH) ### Segment Table (SEGTAB) Built by Intermediate Output Processor | Address of date | control block (DCB) used to load modu | ule | * | |--------------------------------------------|----------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | Address of note list | | • | | Highest segment no. | Last segment<br>number of region 2 | | | | Highest segment no.<br>in storage-region 3 | Last segment<br>number- of region 4 | | | | (N | lot used in the Fixed-Task Supervisor) | | • | | (N | lot used in the Fixed-Task Supervisor) | | | | | Zero | | Status<br>indicate | | | | * | Status<br>indicate | | • | | | | | | | * | Status<br>indicate | | | Highest segment no. in storage-region 1 Highest segment no. in storage-region 3 (N Address o chain exi | Address of note list Highest segment no. in storage-region 1 Highest segment no. in storage-region 3 Last segment number of region 2 Last segment number- of region 4 (Not used in the Fixed-Task Supervisor) (Not used in the Fixed-Task Supervisor) | Highest segment no. in storage-region 1 Highest segment no. in storage-region 1 Highest segment no. in storage-region 3 (Not used in the Fixed-Task Supervisor) Zero Address of entry table entry (when caller chain exists) Address of entry table entry (when caller | Legend: TEST indicator -- specifies that this module is "under test" using TESTRAN. Bit 1 is initialized by program fetch. Highest segment no. in storage -- is initially set to 00 except for region 1 which is initially set to 01 by linkage editor. Status indicator -- indicates the status of this segment with the two last bits of the entry table address field as follows: Meaning segment is in virtual storage as a result of a branch to the segment. Bits 00 10 segment is in virtual storage; no caller chain exists. 01 segment is not in virtual storage, but is scheduled to be loaded. 11 segment is not in virtual storage. Note: The status indicator for segment 1 is initially set to 10; all the rest are initially set to 11. \* Set to zero by linkage editor. Figure 59. Segment Table (SEGTAB) Figure 60. TABLE and LIST (Referred to by HEWLFBTP) Figure 61. Text I/O Table Figure 63. XAD2CESD Table (Built and Referred to by Cross-Reference Table Routine) Figure 64. ORDER Table (Built by HEWLFSCN) ### **DIAGNOSTIC AIDS** This section contains information that may be useful in diagnosing difficulties with the linkage editor program. Included are: register contents at major entry points (Figure 65), charts describing buffer (see Figure 66 on page 187) and table allocation (Figure 67 on page 188), and an error message—module cross-reference table (Figure 68 on page 189). | Module<br>Entry Point | Reg | Contents | | | | | | | |-----------------------|-----|-------------------------------------------------------|--|--|--|--|--|--| | HEWLCIDR | 1 | Pointer to parameter list | | | | | | | | | 2 | Address of all-purpose table | | | | | | | | | 13 | Address of save area | | | | | | | | | 14 | Return address | | | | | | | | | 15 | Entry point address | | | | | | | | HEWLFADA | 2 | Address of all-purpose table | | | | | | | | HEWLFBTP | 2 | Address of all-purpose table | | | | | | | | | 14 | Return address | | | | | | | | | 15 | Entry point address | | | | | | | | HEWLFEND | 2 | Address of all-purpose table | | | | | | | | | 4 | Length of any no-length control section | | | | | | | | | 5 | ID of the assembled address of the module entry point | | | | | | | | | 13 | Address of save area | | | | | | | | | 14 | Return address | | | | | | | | | 15 | Entry point address | | | | | | | | HEWLFENS | 2 | Address of all-purpose table | | | | | | | | | 13 | Save are address | | | | | | | | | 14 | Return address | | | | | | | | HEWLFENT | 2 | Address of all-purpose table | | | | | | | | | 13 | Save area address | | | | | | | | | 14 | Return address | | | | | | | Figure 65 (Part 1 of 5). General Register Contents at Major Entry Points | Module | | | | | | | |-------------|-----|-------------------------------------------|--|--|--|--| | Entry Point | Reg | Contents | | | | | | HEWLFESD | 2 | Address of all-purpose table | | | | | | | 4 | Byte count of ESD information | | | | | | | 5 | ID of first ESD item to be processed | | | | | | | 6 | Address of first ESD item to be processed | | | | | | | 13 | Save area address | | | | | | | 14 | eturn address | | | | | | | 15 | Entry point address | | | | | | HEWLFFNL | 2 | Address of all purpose table | | | | | | HEWLFIDR | 1 | Pointer to parameter list | | | | | | | 2 | Address of all-purpose table | | | | | | | 13 | Address of save area | | | | | | | 14 | Return address | | | | | | | 15 | Entry address | | | | | | HEWLFINC | 2 | Address of all-purpose table | | | | | | | 12 | Return address | | | | | | | 15 | Entry point address | | | | | | HEWLFINP | 2 | Address of all-purpose table | | | | | | | 15 | Entry point address | | | | | | HEWLFINT | 1 | Address of parameter list | | | | | | | 13 | Save area address | | | | | | | 14 | Return address | | | | | | | 15 | Entry point address | | | | | | HEWL FMAP | 2 | Address of all-purpose table | | | | | | | 14 | Return address | | | | | | | 15 | Address of entry point | | | | | | HEWLFOPT | 1 | Address of parameter list | | | | | | | 2 | Address of all-purpose table | | | | | | | 14 | Return address | | | | | | _ | 15 | Entry point address | | | | | | HEWLFOUT | 2 | Address of all-purpose table | | | | | Figure 65 (Part 2 of 5). General Register Contents at Major Entry Points | Module<br>Entry Point | Reg | Contents | | | | | | |-----------------------|-----|---------------------------------------------------------------------------------------------|--|--|--|--|--| | HEWLFRAT | 2 | Address of all-purpose table | | | | | | | | 4 | Byte count of RLD input | | | | | | | | 6 | Storage address of RLD input | | | | | | | | 14 | Return address | | | | | | | HEWLFRCG | 2 | Address of all-purpose table | | | | | | | | 6 | Address of ESD item being processed | | | | | | | | 10 | Address of beginning of replace/change chain | | | | | | | | 13 | Entry point address | | | | | | | HEWLFREL | 1 | HESD address of either first ENTAB entry (if overlay) or<br>last HESD entry + 8 | | | | | | | | 2 | Address of all-purpose table | | | | | | | | 14 | Return address | | | | | | | | 15 | Entry point address | | | | | | | HEWLFROU | 1 | Address of parameter list | | | | | | | | 13 | Address of save area | | | | | | | | 14 | Return address | | | | | | | | 15 | Entry point address | | | | | | | HEWLEPNT | 2 | Address of all-purpose table | | | | | | | | 14 | Return address | | | | | | | | 15 | Entry point address | | | | | | | HEWLFLOG | 0 | Error Code | | | | | | | | 1 | Address of first symbol (optional) | | | | | | | | 2 | Address of all-purpose table | | | | | | | | 13 | Address of second symbol (optional) | | | | | | | | 14 | Return address | | | | | | | | 15 | Entry point address | | | | | | | HEWLFALK | 2 | Address of all-purpose table | | | | | | | | 14 | Return address | | | | | | | | 15 | Entry point address | | | | | | | HEWLFSCD | 1 | Address of first ENTAB entry in HESD, if overlay; otherwise, address of last HESD entry + 8 | | | | | | | | 2 | Address of all-purpose table | | | | | | Figure 65 (Part 3 of 5). General Register Contents at Major Entry Points | Module<br>Entry Point | Reg | Contents | | | | | |-----------------------|-----|---------------------------------------------------|--|--|--|--| | GETIDMUL | 0 | Indicator: 0 - prime read; = lookahead | | | | | | | 1 | Text control block address | | | | | | | 14 | Return address | | | | | | HEWLFSCN | 1 | Address of column 1 of input record | | | | | | | 2 | Address of all-purpose table | | | | | | | 15 | Entry point address | | | | | | HEWLFSI0 | 2 | Address of all-purpose table | | | | | | CHECKRD | 10 | Base register of HEWLFSIO | | | | | | | 12 | Address of HEWLFSCD | | | | | | | 14 | Return address | | | | | | | 15 | Address of HEWLFRLD | | | | | | CHECKWRT | 10 | Base register of HEWLFSIO | | | | | | | 12 | Address of HEWLFSCD | | | | | | | 14 | Return address | | | | | | | 15 | Address of HEWLFRLD | | | | | | WRTCRRLD | 1 | Address of control block for buffer to be written | | | | | | | 10 | Base register of HEWLFSIO | | | | | | | 12 | Address of HEWLFSCD | | | | | | | 14 | Return address | | | | | | | 15 | Address of HEWLFRLD | | | | | | HEWLFSYM | 2 | Address of all-purpose table | | | | | | | 13 | Save area address | | | | | | | 14 | Return address | | | | | | | 15 | Entry point address | | | | | | HEWLFTXT | 2 | Address of all-purpose table | | | | | | | 3 | Assembled address of first byte of text | | | | | | | 4 | Byte count of TXT input | | | | | | | 5 | ID of current text record | | | | | | | 7 | Base register of HEWLFTXT | | | | | | | 12 | Base register of HEWLFRAT | | | | | | | 14 | Return address | | | | | Figure 65 (Part 4 of 5). General Register Contents at Major Entry Points | Module<br>Entry Point | Reg | Contents | | | | |-----------------------|-----|------------------------------------------------|--|--|--| | HEWLCAUT | 2 | Address of all-purpose table | | | | | | 12 | Return address | | | | | | 15 | Entry point address | | | | | RELOCATE | 2 | Address of all-purpose table | | | | | | 3 | Address of text control block for current text | | | | | | 14 | Return address | | | | | | 15 | Address of HEWLFREL | | | | Figure 65 (Part 5 of 5). General Register Contents at Major Entry Points | Initial and Input Processing | Intermediate Processing | Second Pass Processing | |------------------------------|------------------------------------------------------------------------------|------------------------| | | Object Module Buffer 1 3200 bytes (max.) or 800 bytes or 400 bytes (min.) | | | | Object Module Buffer 2<br>3200 bytes (max.) or 800 bytes or 400 bytes (min.) | | | | SYSLIN Buffer 1 3200 bytes (max.) or 800 bytes or 400 bytes (min.) | | | | SYSLIN Buffer 2<br>3200 bytes (max.) or 800 bytes or 400 bytes (min.) | | | | Print Buffer 1<br>4840 bytes (max.) or 1216 bytes or 608 bytes (min.) | | | | Print Buffer 2<br>4840 bytes (max.) or 1216 bytes or 608 bytes (min.) | | | | RLD Buffer Area<br>1024 bytes | | | | Text Buffer Area<br>102400 bytes (max.) or 6144 bytes (min.) | | Figure 66. Buffer Allocation | | Allocated for Overlay | | | | P | resent l | n | | | Size (in b | ytes) | |-------------------------------------------------------|-----------------------|------------------------|-----------------|--------|---------------|---------------|-------------|--------|--------|------------|-------| | Table Name | Link-Edit<br>Only | Order of<br>Allocation | Bytes/<br>Entry | Weight | Inp.<br>Proc. | Int.<br>Proc. | 2nd<br>Pass | Prefix | Align. | Min. | Max. | | Alias Table | No | 2 | 1 | 0 | No | Yes | Yes | No | Dblwd | 160 | 160 | | Calls List | Yes | 17 | 1 | 96 | Yes | Yes | No | No | Dblwd | 1536 | 3 | | Composite ESD | No | 3 | 16 | 288 | Yes | No | No | Yes | Dblwd | 4608 | 3 | | Delink Table | No | 10 | 5 | 24 | Yes | Yes | Yes | Yes | Dblwd | 384 | 3 | | Entry List | Yes | 18 | 6 | 96 | No | No | Yes | No | Dblwd | 1536 | 3 | | Half ESD | No | 5 | 8 | 144 | No | Yes | Yes | No | Dblwd | 2304 | 3 | | Half ESD<br>Prefix | No | 4 | 1 | 0 | No | Yes | Yes | No | Dblwd | 8 | 8 | | HIERARCHY1 | No | 15 | 1 | 18 | Yes | Yes | No | Yes | Dblwd | 288 | 3 | | IDRTRTAB <sup>2</sup> | No | 18, 20 | 1 | 12, 45 | Yes | Yes | No | No | Dblwd | 192, 208 | 3, 3 | | IDRUDTAB | No | 22 | 1 | . 88 | Yes | Yes | No | No | Dblwd | 960 | 3 | | IDRZPTAB | No | 23 | 1 | 44 | Yes | Yes | No | No | Dblwd | 455 | 3 | | Order | No | 14 | 1 | 28 | Yes | Yes | No | No | Dblwd | 456 | 3 | | First Pass<br>RLD Buffer | No | 1 | 1 | 0 | Yes | No | No | No | Dblwd | 256 | 256 | | Second Pass<br>RLD Buffer | No | 11 | 1 | 0 | No | No | Yes | No | Dblwd | 768 | 768 | | Relocation<br>Constant Table/<br>Renumbering<br>Table | No | 9 | 4 | 72 | No<br>Yes | No | No | Yes | Dblwd | 1152 | 3 | | RLD Note | No | 13 | 9 | 14 | Yes | Yes | No | No | Dblwd | 232 | 3 | | RLD Note | No | 7 | 9 | 58 | No | Yes | Yes | No | Dblwd | 928 | 3 | | SEGTA1 | Yes | 16 | 1 | 0 | Yes | Yes | Yes | Yes | Dblwd | 256 | 256 | | Text I/O<br>Table | No | 8 | 1 | 144 | Yes | Yes | Yes | No | Dblwd | 2304 | 3 | | Text Note<br>List I | No | 12 | 7 | 21 | Yes | Yes | No | No | Dblwd | 336 | 3 | | Text Note<br>List II | No | 6 | 7 | 252 | No | Yes | Yes | No | Dblwd | 4032 | 3 | <sup>&</sup>lt;sup>1</sup> Not used in virtual systems Figure 67. Table Allocation <sup>&</sup>lt;sup>2</sup>Table allocated in two parts. <sup>&</sup>lt;sup>3</sup> Maximum is determined by storage availability. Figure 68 contains a list of error messages and the routines and CSECTs in which they originate. Each message contains a severity code in the final position of the message code. These severity codes are defined as follows: - Indicates a condition that will not cause an error during execution of the link-edited program. - Indicates a condition that may cause an error during execution of the link-edited program. - Indicates an error that can make execution of the link-edited program impossible. - 3 Indicates an error that will make execution of the link-edited program impossible. - 4 Indicates an unrecoverable error. Such an error causes termination of linkage editor processing. | Error | | Issu | er | |-------------------|------------------------------------------------------------------------------------------------------------------|----------------------|----------------------| | Message<br>Number | Error Message Text | Routine | CSECT | | IEW0000 | Control statement | HEWLFSCN | HEWL FSCN | | IEW0012 | ERROR—Input contains invalid 2-byte relocatable address constant; constant has not been relocated. | HEWLFREL | HEWLFREL | | IEW0022 | ERROR—Input contains invalid V-type address constant; constant has not been relocated. | HEWLFREL | HEWLFREL | | IEW0033 | ERROR—Invalid entry point from END card; no entry point assigned. | HEWLFENT | HEWLFENT | | IEW0043 | ERROR—Input contains invalid external symbol ID. | HEWLFENT | HEWLFENT | | IEW0053 | ERROR—Entry statement symbol printed is invalid (not an external name); no entry point assigned. | HEWLFENT | HEWLFENT | | IEW0063 | ERROR—END card symbol printed is invalid (not an external name); no entry point assigned. | HEWLFENT | HEWLFENT | | IEW0073 | ERROR—Entry statement symbol printed is not in root segment of overlay structure; no entry point assigned. | HEWLFENT | HEWLFENT | | IEW0083 | ERROR—END card symbol printed is not in root segment of overlay structure; no entry point assigned. | HEWLFENT | HEWLFENT | | IEW0093 | ERROR—END card entry point address printed is not in root segment of overlay structure; no entry point assigned. | HEWLFENT | HEWLFENT | | IEW0102 | ERROR—Invalid entry point on END card; entry point ignored. | HEWL FEND | HEWLFEND | | IEW0113 | ERROR—Output module contains no control sections in root segment of overlay structure; no entry point assigned. | HEWLFENT | HEWLFENT | | IEW0123 | ERROR—No ESD entries; execution impossible. | HEWLFINP<br>HEWLFADA | HEWLFINP<br>HEWLFADA | Figure 68 (Part 1 of 5). Error Message/Issuer Cross-Reference Table | Error | | Issuer | | |-------------------|--------------------------------------------------------------------------------------------|-------------------------------------|-------------------------------------| | Message<br>Number | Error Message Text | Routine | CSECT | | IEW0132 | ERROR—Symbol printed is an unresolved external reference. | HEWLFADA | HEWLFADA | | IEW0143 | ERROR—No text. | HEWL FOUT<br>HEWL FINP | HEWL FOUT<br>HEWL FINP | | IEW0152 | ERROR—Invalid overlay structure; no calls or branches made from root segment. | HEWLFENS | HEWLFENS | | IEW0161 | Warning—Exclusive call from segment number printed to symbol printed - XCAL was specified. | HEWLFENS | HEWL FENS | | IEW0172 | ERROR—Exclusive call from segment number printed to symbol printed. | HEWLFENS | HEWLFENS | | IEW0182 | ERROR—Invalid exclusive call from segment number printed to symbol printed. | HEWLFENS | HEWLFENS | | IEW0191 | Warning—Main storage requirements for output load module have exceeded 512K bytes. | HEWLFADA | HEWLFADA | | IEW0201 | Warning Overlay structure contains only one segment - overlay option cancelled. | HEWLFADA | HEWLFADA | | IEW0212 | ERROR—Expected continuation card not found. | HEWLFINP | HEWLFINP | | IEW0222 | ERROR—Card printed contains invalid input from object module. | HEWLFESD<br>HEWIFINP<br>HEWLFRAT | HEWLFESD<br>HEWLFINP<br>HEWLFRAT | | IEW0234 | ERROR—Input from load module is invalid. | HEWLFRAT<br>HEWLFINP<br>HEWLFESD | HEWLFRAT<br>HEWLFINP<br>HEWLFESD | | IEW0241 | Warning—External symbol printed is doubly defined - ESD type definitions conflict. | HEWLFESD | HEWLFESD | | IEW0254 | ERROR—Table overflow - too many external symbols in ESD. | HEWL FESD<br>HEWL FADA<br>HEWL FSCN | HEWL FESD<br>HEWL FADA<br>HEWL FSCN | | IEW0264 | ERROR—Table overflow - input load module contains too many external symbols in ESD. | HEWLFESD | HEWLFESD | | IEW0272 | ERROR—Load module from library specified unacceptable to level F. | HEWLFINC | HEWLFINC | | I EW0284 | ERROR—DDname printed cannot be opened. | HEWLFINT<br>HEWLFRAT | HEWLFINT<br>HEWLFRAT | | IEW0294 | ERROR—DDname printed had synchronous error. | HEWLFROU<br>HEWLFFNL | HEWL FROU<br>HEWL FFNL | | IEW0302. | ERROR—Invalid statement - scan terminated. | HEWLFSCN | HEWLFSCH | | IEW0314 | ERROR—Maximum number of regions (4) exceeded. | HEWLFSCN | HEWLFSCN | | IEW0324 | ERROR—Maximum number of segments exceeded. | HEWLFSCN | HEWLFSCN | | IEW0332 | ERROR—Maximum number of aliases (16) exceeded, excess ignored. | HEWLFSCN | HEWLFSCN | Figure 68 (Part 2 of 5). Error Message/Issuer Cross-Reference Table | Error | | Issuer | | |-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|----------------------| | Message<br>Number | Error Message Text | Routine | CSECT | | IEW0342 | ERROR—Library specified does not contain module. | HEWLFINC | HEWLFINC | | IEW0354 | ERROR—Table overflow - too many calls between control sections. | HEWLFRAT | HEWLFRAT | | IEW0364 | ERROR—Table overflow - input text exceeded maximum or too many changes of origin in input. | HEWLFRAT<br>HEWLFOUT | HEWLFTXT<br>HEWLFOUT | | IEW0374 | ERROR—Table overflow - input contains too many relocatable address constants or too many control sections containing such constants. | HEWLFRAT | HEWLFRAT | | IEW0382 | ERROR—Text record ID is invalid; card ignored. | HEWL FRAT<br>HEWL FADA | HEWLFTXT<br>HEWLFADA | | IEW0394 | ERROR—Member not stored in library - permanent device error. | HEWLFFNL | HEWLFFNL | | IEW0404 | ERROR—Member not stored in library - no space<br>left in directory. | HEWLFFNL | HEWLFFNL | | IEW0412 | ERROR—Alias not stored in library - no space<br>left in directory. | HEWLFFNL | HEWLFFNL | | IEW0421 | Warning—Member not stored in library - identical name in directory; will try to store under 'TEMPNAME.' | HEWLFFNL | HEWLFFNL | | IEW0432 | ERROR—Library name printed cannot be opened; DD card may be missing. | HEWLFINC | HEWLFINC | | IEW0444 | ERROR—Table overflow - too many downward calls. | HEWLFREL | HEWLFREL | | IEW0454 | ERROR—Table overflow - segment contains too many downward calls. | HEWLFADA | HEWLFADA | | IEW0461 | Warning—Symbol printed is an unresolved external reference; NCAL was specified, or the reference was marked for restricted no-call or never-call | HEWLFADA | HEWL FADA | | IEW0472 | ERROR—Invalid alias entry point in overlay structure. | HEWLFENT | HEWLFENT | | IEW0484 | ERROR—Table overflow - too many external symbols affected by relocation. | HEWLFINP | HEWLFINP | | IEW0492 | ERROR—Invalid name card found in library; card ignored. | HEWLFSCN | HEWLFSCN | | IEW0502 | ERROR—Alias not stored in library - permanent device error. | HEWLFFNL | HEWLFFNL | | IEW0512 | ERROR—INCLUDE statement syntax conflicts with record format of specified data set - DDname printed. | HEWLFINC | HEWLFINC | | IEW0522 | ERROR—Specified data set has unacceptable record format - DDname printed. | HEWLFINC | HEWLFINC | | IEW0532 | ERROR—Blocksize of library data set exceeded maximum - DDname printed. | HEWLFINC | HEWLFINC | Figure 68 (Part 3 of 5). Error Message/Issuer Cross-Reference Table | Error<br>Message | | Issu | Issuer | | |------------------|---------------------------------------------------------------------------------------------------------------------------------|----------------------|----------------------|--| | Number | Error Message Text | Routine | CSECT | | | IEW0543 | ERROR—Identical name in directory. | HEWLFFNL | HEWLFFNL | | | IEW0552 | ERROR—Common printed exceeded size of control section with identical name. | HEWLFESD | HEWLFESD | | | IEW0564 | ERROR—Invalid text origin, linkage editor processing terminated. | HEWLFSCD | HEWLFSCD | | | IEW0572 | ERROR—Common printed and subroutine have identical name. | HEWLFESD | HEWLFESD | | | IEW0581 | Warning—Invalid member name; will try to store under 'TEMPNAME.' | HEWLFFNL | HEWLFFNL | | | IEW0594 | ERROR—Input data set blocksize is invalid. | HEWLFINP<br>HEWLFINT | HEWLFINP<br>HEWLFINT | | | IEW0602 | ERROR—Input from object module is invalid - END card missing. | HEWLFINP | HEWLFINP | | | IEW0614 | ERROR—Length not specified for external symbol printed. | HEWLFRAT | HEWLFTXT | | | IEW0622 | ERROR—Address constant references null unnamed control section. | HEWLFRAT | HEWLFRAT | | | IEW0630 | ERROR—DDname printed had synchronous error -<br>XREF aborted. | HEWLFROU | HEWLFROU | | | IEW0642 | ERROR—Symbol printed appeared on control statement but was not matched. | HEWLFADA | HEWLFADA | | | IEW0652 | ERROR—Conflict in order specified for symbol printed. | HEWLFSCN | HEWLFSCN | | | IEW0670 | The specified identify data has been added to the IDR for the control section name printed. | HEWLFIDR | HEWLFIDR | | | IEW0682 | ERROR—Control section name on an IDENTIFY control statement is incorrect or the statement is misplaced - IDENTIFY data ignored. | HEWLFIDR | HEWLFIDR | | | IEW0694 | ERROR—Table overflow - SIZE value specified not large enough for CSECT IDR input - Linkage Editor processing terminated. | HEWLFIDR | HEWLFIDR | | | IEW0704 | Unrecoverable error detected in CSECT IDR input - linkage editor processing terminated. | HEWLFIDR | HEWLFIDR | | | IEW0714 | ERROR—Member not stored in library - STOW workspace unavailable. | HEWLFFNL | HEWLFFNL | | | IEW0722 | ERROR—Invalid alias name. | HEWLFSCN | HEWLFSCN | | | IEW0731 | Warning—Alias matches member name - alias<br>ignored. | HEWLFFNL | HEWLFFNL | | | IEW0740 | The indicated action was taken for an EXPAND request. | HEWLFSCN | HEWLFSCN | | | IEW0751 | Warning—Invalid AMODE/RMODE combination found in MODE control statement - ignored. | HEWLFFNL | HEWLFFNL | | Figure 68 (Part 4 of 5). Error Message/Issuer Cross-Reference Table | Error | | Issuer | | |-------------------|---------------------------------------------------------------------------------------------------|----------|----------| | Message<br>Number | Error Message Text | Routine | CSECT | | IEW0761 | Warning—Invalid AMODE/RMODE combination found in PARM field - ignored. | HEWLFFNL | HEWLFFNL | | IEW0771 | Warning—AMODE/RMODE data in MODE control<br>statement incompatible with OVLY option -<br>ignored. | HEWLFFNL | HEWLFFNL | | IEW0781 | Warning—AMODE/RMODE data in PARM field incompatible with OVLY option - ignored. | HEWLFFNL | HEWLFFNL | | IEW0791 | Warning—Invalid AMODE/RMODE combination in ESD data for the named CSECT - ignored. | HEWLFESD | HEWLFESD | | I EWO 984 | ERROR—SYSPRINT blocksize exceeds maximum -<br>linkage edit processing terminated. | HEWLFINT | HEWLFINT | | I EW0 9 9 4 | ERROR—SYSPRINT DD card missing - linkage editor processing terminated. | HEWLFINT | HEWLFINT | Figure 68 (Part 5 of 5). Error Message/Issuer Cross-Reference Table ### APPENDIX. INPUT CONVENTIONS AND RECORD FORMATS This section contains linkage editor input conventions and record formats (see Figure 69 on page 195 through Figure 82 on page 204). ### INPUT CONVENTIONS Input modules (object or load) to be processed in a single execution of the linkage editor must conform with a number of input conventions. Violations of the following are treated as errors by the linkage editor: - All text records of a control section must follow the ESD record containing the SD or PC entry that describes the control section. - The end of every input module must be marked by an end indication (END record in an object module; EOM flag in a load module). - Each input module may contain only one no-length control section (a control section whose length field in its SD or PD entry in the ESD contains zeros). The length must be specified on the END record of any module that contains a no-length control section. - After processing the first text record of a no-length control section, the linkage editor will not accept a text record of a different control section within the same input module. - Any RLD item must be read after the ESD items to which it refers; if it refers to a label within a different control section, it must be read after the ESD item for that control section. - The language translators must gather RLD items in groups of identical position pointers. No two RLD items having the same P pointer can be separated by an RLD item having a different P pointer. - Each record of text<sup>14</sup> and each LD or LR entry in the ESD record must refer to an SD or PC entry in the ESD. - The position pointer of every RLD item must point to an SD or PC entry in the ESD. - No LD or LR may have the same name as an SD or CM. - All SYM records must be placed at the beginning of an input module. The ESD for an input module containing test translator statements must follow the SYM records and precede TXT records. - The linkage editor accepts TXT records that are out of order within a control section, even though linkage editor processing may be affected. TXT records are accepted even though they may overwrite previous text in the same control section. The linkage editor does not eliminate any RLD items that correspond to overwritten text. - During a single execution of the linkage editor, if two or more control sections having the same name are read in, only A common (CM) control section cannot contain text or external references. the first control section is accepted; the subsequent control sections are deleted. - The linkage editor interprets common (CM) entries in the ESD (blank or with the same name) as references to a single control section whose length is the maximum length specified in the CM items of that name (or blank). No text may be contained in a common control section. - Within an input module, the linkage editor does not accept an SD or PC entry after the first RLD item is read. To avoid unnecessary scanning and input/output operations, input modules should conform with the following conventions. Although violations of these rules are not treated as errors, avoiding them will improve the efficiency of linkage editor processing. - Within an input module, no LD or SD may have the same name as an ER. - Within an input module, no two ERs may have the same name. - Within an input module, TXT records may be in the order of the addresses assigned by the language translator. (If TXT records are not in address sequence, each reorigin operation may require additional linkage editor processing time.) - SYSUT1 record size should be at least as large as SYSLMOD. ### RECORD FORMATS SYM Input Record (Card Image) Blank 12-9-2 (0000 0010) SYM Figure 69 through Figure 82 on page 204 are the card image and load module record formats for the Linkage Editor. ### 1 2-4 5-10 11,12 13-72 73-80 Not used Figure 69. SYM Input Record (Card Image) - TESTRAN data Number of bytes of TESTRAN data Figure 70. ESD Input Record (Card Image) Figure 71. Text Input Record (Card Image) Figure 72. RLD Input Record (Card Image) Figure 73. END Input Record—Type 1 (Card Image) <u>Blank</u> END Input Record - Type 2 (Card Image) <u>Blank</u> --- <u>END</u> - 12-9-2 (0000 0010) - END - 12-9-2 (0000 0010) ## 1 2-4 5-16 17-24 25-28 29-32 33-80 See Below Control section length for control section whose length was not specified in SD ESD item Symbolic entry point name (optional) Figure 74. END Input Record—Type 2 (Card Image) Figure 75. IDR Data in an Object Module End Record ### CESD Data (Load Module) Figure 77. CESD Record (Load Module) - a control record 0000 0001 - the control record that precedes the last text record of this overlay segment 0000 0101 (EOS) - the control record that precedes the last text record of the module 0000 1101 (EOM) Figure 79. Control Record (Load Module) Figure 80. Relocation Dictionary Record (Load Module) Notes: For detailed descriptions of the data fields see Relocation Dictionary Record and Control Record. The record length varies from 20 to 256 bytes. Figure 81. Control and Relocation Dictionary Record (Load Module) Figure 82 (Part 1 of 3). Record Format of Load Module IDRs <sup>\*</sup>May be a PTF number or up eight bytes of variable user data specified on an HMASPZAP IDRDATA control statement. Figure 82 (Part 2 of 3). Record Format of Load Module IDRs Figure 82 (Part 3 of 3). Record Format of Load Module IDRs ### INDEX of virtual storage 21, 22, 168 initialization 15 allocation processor (ALL001) 88 APT A-type address constant delinking of 65 relocation of 61 See all-purpose table attributes and options processor (HEWLFOPT) 88 RLD processing for attributes, module absolute relocation 18 analysis of (HEWLFOPT) 88 descriptions 6-8 See also absolute relocation factor, relocation incompatible (table) examples 63 processing examples 8-11 in entry processing 56 use of 6-8 absolute relocation factor authorization code See also absolute relocation in partitioned organization director definition 62 record 172 determination of 45 authorization code (AC) use in relocating delinked address automatic library call constants 62 See also automatic library call use in relocating V-type address processor constants 66 function automatic library call processor adcon See address constant (HEWLCAUT) additional call libraries description of 50-51 See LIBRARY statement charts 120, 124 additional input sources See INCLUDE statement 93 synopsis automatic promotion of common 38 address assigment 59 automatic replacement 65 See also address assignment processor function 2-3 general description 16 in cross-reference table 59 of first text record as zero 7 В of main entry point 56 address assignment processor (HEWLFADA) blank common description of 52-54 See also common definition of 34 delinking of 66 chart 126 synopsis 93 operation diagram 86 in resolution processing 37 address constant 2 BLDL list, making an entry in 48, 50 See also A-type address constant, BLDL macro instruction 47, 48 block format attribute 7 pseudo register, V-type address blocked input on SYSLIB on SYSLIN constant computing the value of 4 delinking 45, 66 in RLD processing 45 blocked output purpose 2 on SYSPRINT 23 relocation 61, 71 boundary alignment factor See also address assignment branch-type address constant addressing mode See V-type address constant addressing mode (AMODE) 8 buffer allocation 21, 187 ALIAS statement general description of processing 23 operation diagram 81 C processor 29 alias table construction of 56 format 161 call library introduction to See automatic library call, SYSLIB ALIGN2 format attribute data set all purpose table (APT) format 150 calls downward 54, 67 exclusive 54, 67 indicators for MAP, XREF options 58 introduction to 15 making an entry in 88 invalid exclusive 68 upward 54, 67 preparation of 19,88 calls list allocation format 161 of buffers and tables 21-22 making entries in 16, 45 This document contains restricted materials of IBM. © Copyright IBM Corp. 1972,1983 LY26-3921-0 scanning 52-55 control statement scanner (HEWLFSCN) calls, automatic library See automatic library call processing 23 synopsis control/RLD dictionary record 10 See also control/RLD record write See composite external symbol dictionary contents 10 CESD entry number 27, 82 CESD identifier 35-37, 92 creation of format 204 59, 94 control/RLD record CESD record format 200 See control/RLD dictionary record in input load module 32, 34 control/RLD record write routine CESD record types 34 (WRTCRRLD) 94 CHANGE statement cross-reference between control operation diagram 81 sections 2-3 processing 23 processor 28 cross-reference table 59 See also options XREF option See common See also options, XREF option combining object modules 1 contents 59 common (CM) detailed description of See also blank common production 59 in program organization 93, 95 CSECT identification record (IDR) contents 1, 16 definition 34 delinking of 66 non-resolution processing 36 data types resolution processing 37 Common path routine (HEWLCPTH) See IDR data types automatic promotion of common 38 description 9-10 in program organization 94 formats 204 IDENTIFY control statement 41 communication area in load module 16, 39-40, 41 in object module END records 39-40 See all purpose table composite dictionaries 4, 5 processing (HEWLFIDR) See also composite external symbol dictionary, relocation dictionary description of 39-41 composite ESD operation diagrams program processing history See composite external symbol written out on SYSLMOD 17 dictionary composite external symbol dictionary (CESD) contents 9 definition 34 D internal format 162, 164 introduction to making an entry in 15, 92 written out on SYSLMOD 56 making an entry in data control block initializing 15, 92 concatenated data sets used to determine module type 12 on SYSLIB 12 on SYSLIN 11, 23 See downward compatible attribute 3 DCB control dictionaries See also external symbol See data control block DCBS option purpose 3 when generated 3-5 control information processing function delink table contents analyzing 19 format 164 description of 19 operation diagram 81 making an entry in 45 control record delinking contents 10 definition 65 in input module 32 control section (CSECT) 2 example 65 in RLD processing 46 See also no-length control section of A-type (nonbranch-type) address assigning addresses to 2-3 delinking of 66 constants 65 of common control sections 66 grouping on SYSLMOD 60 of external symbols 65 replacement 38, 65 control section search routine dense record 43 determining ESD type 34 (GETIDMUL) chart 136 diagnostic aids in program organization 94 buffer allocation 187 control statement error message-module cross-reference format 23 table 189 operands 23 operation diagram register contents at entry to module 183 pointers (P1, P2) 24 processing 15, 23-31 work areas (OPDO, OPD1) 24-25 table allocation 188 diagnostic directory print routine (HEWLFBTP) in program organization LIST used during processing 180 TABLE used during processing 180 diagnostic messages construction 72 See also error logging diagnostic output data set See SYSPRINT data set diagrams, operation 15, 74-87 directory, microfiche 145 downward call 54, 67 downward calls list format 164 introduction to 16 downward compatible attribute (DC) definition 7 grouping control sections 60 downward reference 54, 67 # E end of module (EOM) indicator 3 See also END record description of 3 in control record 10 in END processing 92 in input load module setting 60 end of segment (EOS) indicator in control record 10 setting 58 END processing (HEWLFEND) description of chart 114 synopsis 92 END record containing IDR data 39-40 format 198 in entry processing END record (continued) in object module 31 ENTAB See entry table enter routine 36 entry list contents 18 format 165 relocation 18 use of 67 entry point 8 See also ENTRY statement assigned by linkage editor 8 in END processing 47 processing 56 entry processor (HEWLFENT) description of 56 charts 128 ENTRY statement general description of processing 24 operation diagram 81 29 processor entry table (ENTAB) See also entry table creation routine entries in CESD 16 format 165 introduction to PC-delete entry for 34, 52 used in relocating V-type address constants 68 entry table creation routine (SCDENTAB) description of 68 in program organization 94 entry table size determination routine calls list format processing 54-55 processing chart 127 EOM See end of module indicator See external reference error logging description of routine (HEWLFLOG) chart 144 table and list used 180 error message/issuer-module cross-reference table 189 error messages See diagnostic messages error processing See diagnostic directory print routine See error logging **ESD** See external symbol dictionary ESD ID See ESD identifier ESD identifier definition entry in high ID table in entry processing in ESD processing in text processing 43 ESD record definition 16 format 196 in object module 31 operation diagram processing 35-39 ESD record types 34 exclusive call 54, 67 See also options, XCAL option executable attribute EXPAND statement general description of processing 23 EXPAND statement processor 30 external dummy section See pseudo register external reference (ER) definition 2, 34 entry processing 35 non-resolution processing 37 resolution processing 34, 38 unresolved ER processing 53 unresolved ER processing 53 external symbol definition 3 external symbol dictionary (ESD) contents 3 entry types identifier 34 See ESD identifier introduction to processing (HEWLFESD) description of 35-39 description of chart 105 description of synopsis 91 operation diagram 82 LY26-3921-0 F final linked address 53 final processing (HEWLFFNL) description of 18, 72 charts 143-144 94 synopsis objective 18 operation diagram 80 overview 13 final relocation constant 53 first pass RLD buffer See RLD buffer formats, record 195-206 freeline routine functions of the linkage editor 1-2 G general registers, contents of 33 Н half ESD table (HESD) contents 17 format 166 in ENTAB creation 68 production of 57, 93 HESD See half ESD table HEWLCPTH See Common path routine HEWLCR01 See SYNAD routine **HEWL FADA** HEWLFAUT **HEWL FEND** See End processing HEWLFENT See entry processor HEWLFESD See external symbol dictionary saving relocation factors in 61 See address assignment processor See automatic library call processor processing HEWLFFNL See final processing HEWLFIDR See CSECT identification record HEWLFINC See include processing HEWLFINP See input processing HEWLFINT See initialization processing **HEWLFLOG** See error logging, routine **HEWL FMAP** See MAP/XREF processor **HEWLFMDI** See object module processing **HEWL FOPT** See attributes and options processor **HEWL FOUT** See intermediate output processor HEWLFRAT See text and RLD processor **HEWL FREL** See RLD control block, second pass text control block format **HEWLFROU** See linkage editor, entry point **HEWLFSCD** See second pass processing HEWLFSCN See control statement scanner **HEWLFSIO** See second pass processing HEWLFSYM See symbol record, processor **HEWL FTXT** See text record, processing **HEWLMBTP** See diagnostic directory print routine HIARCHY See hierarchy format attribute **HIARCHY** statement general description of processing 23 processor 27-28 hierarchy format attribute (HIAR) 7, 23 hierarchy table high ID table (HIID) construction of contents 17 format 167 making an entry in 58 40 HMASPZAP data See also IDR data types processing (HEWLFIDR) chart 118 description of 40 I I/O control table, address of text note list on SYSUT1 43, 47 ordering of text 59 I/O flow 11-14 ID-length list 43 identification record See CSECT identification record IDENTIFY statement 23 See also CSECT identification record general description of processing 23 81 operation diagram processing data chart 118 processor 29 IDR See CSECT identification record IDR data types 39 IMASPZAP-supplied data processing linkage editor data processing 40-41 translator-supplied data processing 39, 40 chart 116 user-supplied data See also IDENTIFY statement processing 41 chart 119 processing IDR tables 56 See also CSECT identification record written onto SYSLMOD translator data table (IDRTRTAB) 47 contents entry 41 non-resolution processing 37 user data table (IDRUDTAB) resolution processing 38 contents 41 label routine 38 include processing (HEWLFINC) 9, 92, language translators 1 123 See label definition LET option 6 INCLUDE statement 23 See also include processing general description of processing 23 level 0 symbol in input processing 20 See also control statement operation diagram 81 processor 25 operands level 1 symbol 24 See also control statement incompatible module attributes 20 initialization processing (HEWLFINT) operands description of 15, 19 synopsis 88 library calls function 1 library read block 48 LIBRARY statement operation diagram 76 input See automatic library call, SYSLIN in automatic library call processing 50, 51 data set input conventions 194 See also automatic library call input data set in input processing 12 operation diagram 81 processor 29 line number 4, 36 See also CESD identifier, ESD See SYSLIN data set input entry types See input record types input processing (HEWLFINP) description of 15-16, 22 identifier chart 101 linkage editor synopsis 89 data operation diagram 77 See IDR data types overview 11-14 input record types data sets 11 description 2-3 associated processors 90 formats 195-206 design points 1-2 entry point (HEWLFROU) 88 general register contents for 33 processing 22, 32 input text buffer (TXTBFBEG) functions 1 method of operation 15 options 5-6 general description of use 10 in single pass processing 59 16, 17 organization 88-144 overlay structures 1 in text processing 41, 43 purpose 1-2 minimum length 21 input/output flow 11-14 relationship to the operating system INP270 linkage editor assigned address of first See load module processing text record as zero INSERT statement linking object modules 2 LIST option general description of processing 23 operation diagram 81 processor 28 load module attributes 6,8 intermediate output processor (HEWLFOUT) See also attributes, module description of 16-17, 56 synopsis 93 data set See SYSLMOD data set definition 3 processing (INP270) use of hierarchy table 28 intermediate processing description of 32 description of 16-17, 51-56charts 126, 131 description of chart 103 synopsis 93 objectives 16 description of synopsis 90 record types 32 operation diagram 78 overview 13 See also input record types structure 3-5, 6-11, 16-18 text processing 43 See also text record processing logical record length (LRECL) for SYSLIB 23 L for SYSLIN for SYSPRINT 2 for SYSTERM 23 label definition (LD) definition 34 loose record 43 entry processing 34 non-resolution processing 37 label reference (LR) See label reference LRECL This document contains restricted materials of IBM. © Copyright IBM Corp. 1972,1983 LY26-3921-0 definition 34 See logical record length M MAP option 6 See also MAP/XREF processor function general description of processing 16-17 in intermediate output processing 58 MAP/XREF processor (HEWLFMAP) description of 59 chart 131 in program organization 93 map, module 17 See also MAP option, MAP/XREF processor, options contents 17, 58 production of 13, 58 chart 131 in program organization 93 member name for SYSLMOD data set 12-14 messages 13 See also diagnostic aids microfiche directory 145 MODE statement general description of processing 23 MODE statement processor 31 module origin 2 structure 2-5 module attributes See attributes, module module map See map, module module—CSECT cross-reference table 148 multiplicity in relocating address constants read into input text buffer 41 writing on SYSLMOD 60 writing on SYSUT1 42 N NAME statement general description of processing 23 in final processing 72 in input processing 22, 50 operation diagram 81 processor NCAL option See also automatic library call function in input processing 22, 50 NE (not editable attribute) no-length control section 42, non-resolution processing 36-37 not editable attribute (NE) note list (for overlay segments) null type changing CESD entries to 52 definition 34 entry processing 36 0 object module definition processing (HEWLFMDI) description of description of?synopsis 89 record types 31 See also input record types structure 3-5 text processing 42, 43 See also text record processing object module buffer 15, 42 OL (only loadable attribute) opening data sets 20 operation diagrams 15, 74-87 options analysis of (HEWLFOPT) 19,88 diagnostic output 5, 6 See also LIST, MAP, TERM, XFER options introduction to processing 5, 6 See also LET, NCAL, XCAL options space allocation 6 See also DCBS, SIZE options cification of 5 specification of ORDER statement and ALIGN2 attribute 7 processor 28 ORDER table creation 28 diagrams 77 in address assignment 52, 53 in END processing in intermediate output diagram layout 182 out of order text 42 use during text processing output load module data set See SYSLMOD data set overlay format attribute (OVLY) module characteristics 7 overlay module processing 1 See also OVERLAY statement description relocating V-type address constants 66 OVERLAY statement general description of processing 23 operation diagram 81 27 processor See overlay format attribute P P (position) pointer definition 4 in entry table size determination 54 updating 16 PAGE statement and ALIGN2 attribute 7 general description of processing 23 processor 28 partitioned data set (PDS) directory entry for SYSLMOD 18, 72 generating a load module in 2, 6 include processing for 48-50 SYSLIB data set 12 SYSLMOD data set 12, 13 PC See private code **PDS** See partitioned data set position pointer See P pointer See pseudo register private code (PC) definition 34 entry processing 34, 35 marked delete 34, 52 ICENTY routine 25 PROCENTY routine program organization 88-144 processing history 1 pseudo register address assignment 18 computing cumulative PR length 53 definition 34 in RLD processing 44, 71 purpose of the linkage editor 1 ## R R (relocation) pointer definition in entry table size determination 54 updating 16, 44 RCT See relocation constant table RDRLD See RLD read routine RDTXT See text read routine read control block for SYSLIN 22 read only control section 8 READ8 routine chart 122 in control statement processing 25 in program organization 92 record See also ESD record dense (contiguous) formats 195-206 loose (noncontiguous) 43 types See input record types record types LIST used in construction on SYSPRINT data set 12, 13 See also SYSPRINT data set on SYSTERM data set 12 See also SYSTERM data set TABLE used in construction recovery management routine and refreshable attribute 6 reenterable attribute (RENT) REFR See refreshable attribute refreshable attribute (REFR) registers, contents of 31-33 load module processing 33 object module processing 31 relative relocation definition 18 in entry processing 56 marking RLD item for 44 relative relocation factor determination of 45, 54 general description of use 18 use in determining buffer relocation constant 71 See also relocation constant table RELOCATE routine See relocation routine relocation of address constants 16-17, 61 See also address assignment processor, address constant of RLD items during intermediate output processor 59 relocation constant 16, 17, 18 relocation constant table (RCT) contents 16, 17 format 173 making an entry in relocation dictionary (RLD) and text processor (HEWLFRAT) 91 See also text and RLD processor contents introduction to 4 processing (RLD001) description of 44-47 description of chart 111 description of synopsis 91 operation diagram 85 record See RLD record relocation pointer See R pointer Relocation routine (RELOCATE) description of in program organization RENT (reenterable attribute) renumbering table (RNT) contents 16 format 173 production of 35-39, 91 use of 35, 40 REPLACE statement general description of processing 23 processor 28 replace/change chain in the CESD See also CHANGE statement, REPLACE statement residence mode residence mode (RMODE) resolution processing 37-39 REUS (reusable attribute) reusable attribute (REUS) RLDSee relocation dictionary RLD buffer first pass 16 general description of use 16, 17 in single pass processing RLD control block initialization (HEWLFREL) input control block format 170, 174 output control block 60 format 174 RLD flags in relocation address constants (table) 45-47 RLD input buffer See second pass RLD input buffer RLD note list format 176 introduction to 13 making entries in 16, 44-47 reading from SYSUT1 60, 93 RLD Processor 91 use in locating RLD records 60 use in relocating address constants 72 RLD output buffer See second pass RLD output buffer RLD pointers 4, 91 See also P pointer, R pointer RLD read routine (RDRLD) processing chart 137 in program organization 94 RLD record created for overlay 60 203 format in load module 31, 32 in object module processing (RLD001) 16, 44, 47 See also relocation dictionary processing RLD set definition 71 use in relocating address constants 71 written on SYSUT1 44, 46, 47 RLD write routine (on SYSUT1) (RLDBUF) chart 113 in program organization 91 RLD/control record See control/relocation dictionary record RLDBUF See RLD write routine RLD001 See relocation dictionary, processing RNT See renumbering table root segment in overlay module 10 ## S scatter format attribute (SCTR) grouping control sections in processing example 11 module characteristics scatter loading See scatter format attribute scatter table format 201 introduction to 11 production of 17, 57 scatter/translation record format 201 function introduction to 11 written on SYSLMOD 57, 93 **SCDENTAB** See entry table creation routine SCTR See scatter format attribute See section definition second pass processing (HEWLFSCD) description of charts 134 94 synopsis 90 objectives 17 operation diagrams 79, 87 overview 13 second pass RLD input buffer reading RLD records into 17, 60 use in relocating address constants 72 second pass RLD output buffer entering RLD items in 18, 60 use in relocating address constants 71 second pass text buffer, reading text records into 60 second pass text control block format 177 initialization (HEWLFREL) second pass text control table, making an entry in 60 section definition (SD) definition 34 non-resolution processing resolution processing 38 SEGLGTH 178 format introduction to processing 53 segment path table (SEGTA1) in entry table size determination 54 making an entry in 92 processing 53 purpose 27 scanning by common path routine use in entry table creation segment relocation constant (SRC) definition 53 introduction to segment table (SEGTAB) determining the size of format 179 introduction to 10 PC-delete entry for 34, 53 production of 16 SEGTAB See segment path table SEGTA1 See segment path table serially reusable attribute (REUS) 6 SETCODE statement general description of processing 23 SETCODE statement processor SETSSI statement general description of processing 23 operation diagram 81 processor 28 single pass processing description of 17, 59 occurrence 17, 44 SIZE option function - 6 requesting additional buffer space 21 special event processing 31, 32 See segment relocation constant storage allocation 15, 21, 22 See also allocation STOW macro instruction entering name in PDS 13, 18 72, 94 issuing SYM record See symbol record symbol (SYM) record format 195, 199 in output load module 8, 16 processor (HEWLFSYM) chart 104 synopsis 90 special event processing for 31 SYNAD routine (HEWLCR01) chart 139, 143 synopsis use of 23 95 SYSLIB data set definition 12 in input processing 15 opening 20 opening DCB in include processing 48 resolving ERs from 51 with automatic library call processing 20, 50 SYSLIN buffer 16 SYSLIN data set opening 20 processing after termination of input 72 with automatic library call processing 22, 50 SYSLMOD data set definition 12 in program organization 90, 93 member name 12 opening and determining block size 20 writing on 56, 72 SYSPRINT data set definition 12 directing diagnostic messages to opening 20 output block size 23 writing cross-reference table on 93 system status index 28 SYSTERM data set definition 12 device requirement 12 writing text on 43 T table allocation 21, 188 temporary linked address 52 temporary relocation constant added to SRC 52 computation of 52 TERM option function 6 in final processing 73 processing 18 terminal data set See SYSTERM data set TEST attribute function in input processing 13, 90 in object module processing in processing example 11-13 testing symbol dictionary See also symbol record text (TXT) record contents 10 dense 43 format 197 in load module 32 in object module 31 loose 43 processing (HEWLFTXT) chart 109 description of 16 operation diagrams 83, 84 synopsis 91 RLD processor (HEWLFRAT) 91 See\_also text and RLD processor text and RLD processor (HEWLFRAT) See also relocation dictionary processing chart 108 91 synopsis text buffer See input text buffer text control block See second pass text control block text I/O control table See text I/O table text I/O table contents 16, 17 format 180 making an entry in 42, 43 use during address assignment 52 use during intermediate output processing 58 use during processing 10 use in ordering text 59 16-17 use in reading from SYSUT1 58 text note list format 181 making an entry in 42, 43 reading from SYSUT1 59, 93 use during text processing 42, 43 use of 17 Text read routine (RDTXT) chart 137 in program organization 94 Text write routine (on SYSLMOD) (WRTTXT) chart 138 in program organization Text write routine (on SYSUT1) (TXTBUF) chart 110 synopsis 91 translation of input IDs 35 translation table format 201 introduction to production of 57 translator-supplied data 40 See also IDR data types processing 40 chart 116 TTR list contents 18, 60 creation of 60 writing on SYSLMOD 72, 94 two pass processing TXT record See text record **TXTBFBEG** See input text buffer U unlike attributes indicator 20 upward calls 54 user-supplied data 41 See also IDR data types processing 41 chart 119 V V-type address constant description of 18 entered in calls list 16 in RLD processing 45 relocation of 61, 66 virtual storage allocation description of 15, 21 release of 72 virtual storage allocation table 168 M weak external reference (WX) definition 34 non-resolution processing 37 resolution processing 39 weight factor 168, 188 See also virtual storage allocation WRTCRRLD See control/RLD record write routine WRTTXT See text write routine on SYSLMOD WX See weak external reference X XAD2CESD table 181 See also cross-reference table table used in the production of 181 XCAL option 6 XDAP macro instruction 60 XREF option function 6 general description of processing 17 in final processing 72 in intermediate output processing 93 | • | | | | |---|---|--|--| | | • | | | Restricted Materials of IBM Corporation LY26-3921-0 MVS/370 Linkage Editor-Logic (File No. S370-31) Printed in U.S.A. LY26-3921-0 IBM<sup>®</sup> This manual is part of a library that serves as a reference source for systems analysts, programmers, and operators of IBM systems. You may use this form to communicate your comments about this publication, its organization, or subject matter, with the understanding that IBM may use or distribute whatever information you supply in any way it believes appropriate without incurring any obligation to you. Your comments will be sent to the author's department for whatever review and action, if any, are deemed appropriate. Note: Copies of IBM publications are not stocked at the location to which this form is addressed. Please direct any requests for copies of publications, or for assistance in using your IBM system, to your IBM representative or to the IBM branch office serving your locality. ### List TNLs here: If you have applied any technical newsletters (TNLs) to this book, please list them here: Previous TNL \_\_\_\_\_\_\_Previous TNL \_\_\_\_\_\_ Fold on two lines, tape, and mail. No postage stamp necessary if mailed in the U.S.A. (Elsewhere, an IBM office or representative will be happy to forward your comments or you may mail directly to the address in the Edition Notice on the back of the title page.) Thank you for your cooperation. ### Reader's Comment Form Fold and tape Please do not staple Fold and tape **BUSINESS** MAII REPLY FIRST CLASS PERMIT NO. 40 ARMONK, N.Y. POSTAGE WILL BE PAID BY ADDRESSEE **IBM Corporation** P.O. Box 50020 **Programming Publishing** NO POSTAGE NECESSARY IF MAILED IN THE UNITED STATES San Jose, California 95150 Fold and tape Please do not staple Fold and tape This manual is part of a library that serves as a reference source for systems analysts, programmers, and operators of IBM systems. You may use this form to communicate your comments about this publication, its organization, or subject matter, with the understanding that IBM may use or distribute whatever information you supply in any way it believes appropriate without incurring any obligation to you. Your comments will be sent to the author's department for whatever review and action, if any, are deemed appropriate. Note: Copies of IBM publications are not stocked at the location to which this form is addressed. Please direct any requests for copies of publications, or for assistance in using your IBM system, to your IBM representative or to the IBM branch office serving your locality. ### List TNLs here: If you have applied any technical newsletters (TNLs) to this book, please list them here: Previous TNL Previous TNL Fold on two lines, tape, and mail. No postage stamp necessary if mailed in the U.S.A. (Elsewhere, an IBM office or representative will be happy to forward your comments or you may mail directly to the address in the Edition Notice on the back of the title page.) Thank you for your cooperation. MVS/370 Linkage در المامة (File No. S370-31) Printed in U.S.A. LY26-3921-0 Reader's Comment Form Fold and tape Please do not staple Fold and tape BUSINESS REPLY MAIL FIRST CLASS PERMIT NO. 40 ARMONK, N.Y. POSTAGE WILL BE PAID BY ADDRESSEE IBM Corporation P.O. Box 50020 Programming Publishing San Jose, California 95150 NO POSTAGE NECESSARY IF MAILED IN THE UNITED STATES Fold and tape Please do not staple Fold and tape