PRIMOS CONCEPTS & TUNING (CE1025) PRIMOS PRINCIPLES & TUNING (SADS32) PRIMOS Revision 20.2 Date: December 10, 1986 Copyright (c) 1986, Prime Computer, Inc., Natick, MA 01760 Protection of Copyright (c) 1986 by Prime Computer, Inc. Prime Park Natick, MA 01760 This document discloses subject matter in which Prime Computer, Inc. has profrietary rights. Neither receipt nor possession of this document either confers or transfers any right to copy, reproduce, or disclose the document, any part of such document, or any information contained therin without the express written consent of a duly authorized representative of Prime Computer, Inc. The information in this document is subject to change without notice and should not be construed as a commitment by Prime Computer, Inc. Prime Computer, Inc. assumes no responsibility for any errors which may appear in this document. PRIME and PRIMOS are registered trademarks of Prime Computer, Inc. All correspondence on suggested changes to this document should be directed to: Prime Technical Education Center Prime Computer, Inc. Prime Park Natick, MA 01760 ## Contents | Comp | uter Concepts | 1 | | |------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|---------------------------------------------------------| | • | Computer Components - Hardware | 1 - | | | | Some Components of the CPU | 1 - | - 3 | | | Registers and the PC | 1 - | | | | Computer Components - Operating System | 1 - | - 5 | | | Software Operation | 1 - | - 6 | | | · | | • | | Memo | ory Management | 2 | Vi | | | Cache Functional Diagram | 2 - | - 2 | | | Effective Memory Access Time | 2 . | - 3 | | | Interleaving | 2 - | - 4 | | | Wide word memory | 2 - | - 5 | | | Cache Benefit Example | 2 . | - 6 | | | Virtual Memory | 2 . | - 8 | | | Virtual Memory Delineation | 2 . | - 10 | | | Segment Descriptors | 2 . | - 12 | | | Page Map Table (HMAP) | 2 . | - 13 | | | Address Translation | | - 14 | | | Memory Map | - · | - 16 | | | Paging | 5. | - 17 | | | Paging | | - 18 | | | STLB & Cache Validation | | - 20 | | | Fluching the William | | | | | Toballing the Greek that the same of s | | | | EXE | RCISE | | | | | RCISE | . 2E | | | | cess Exchange and Scheduling | . 2E | | | | cess Exchange and Scheduling | . 2E<br>3<br>3 | - 2 | | | cess Exchange and Scheduling | . 2E<br>3<br>3<br>3 | - 2<br>- 2 | | | CISE cess Exchange and Scheduling Process Exchange Process State Diagram Process Control Block (PCB) | . 2E<br>3<br>3<br>3 | - 2<br>- 2<br>- 4 | | | CISE | . 2E<br>3<br>3<br>3 | - 2<br>- 2<br>- 4<br>- 5 | | | CESS Exchange and Scheduling | . 2E<br>3333333 | - 2<br>- 2<br>- 4<br>- 5 | | | CISE | 2E 3333333 | - 2<br>- 2<br>- 4<br>- 5<br>- 7 | | | CISE | . 2E 333333333 | - 22<br>- 4<br>- 5<br>- 7<br>- 8 | | | CISE | . 2E | - 2<br>- 4<br>- 5<br>- 7<br>- 8<br>- 19 | | | CISE | 2E 333333333333333333333333333333333333 | - 2<br>- 4<br>- 5<br>- 7<br>- 8<br>- 19<br>- 20 | | | cess Exchange and Scheduling Process Exchange Process State Diagram Process Control Block (PCB) Ready List Priorities Wait Lists (Semaphores) System Locks Ready List Example Interrupts Scheduling Process State Diagram | 2E | - 2<br>- 2<br>- 5<br>- 7<br>- 8<br>- 19<br>- 20<br>- 20 | | | cess Exchange and Scheduling Process Exchange Process State Diagram Process Control Block (PCB) Ready List Priorities Wait Lists (Semaphores) System Locks Ready List Example Interrupts Scheduling Process State Diagram | 2 | - 2<br>- 2<br>- 5<br>- 6<br>- 19<br>- 20<br>- 22 | | | cess Exchange and Scheduling Process Exchange Process State Diagram Process Control Block (PCB) Ready List Priorities Wait Lists (Semaphores) System Locks Ready List Example Interrupts Scheduling Process State Diagram Backstop Process | 2 | - 2<br>- 2<br>- 5<br>- 7<br>- 8<br>- 19<br>- 20<br>- 20 | | | cess Exchange and Scheduling. Process Exchange. Process State Diagram. Process Control Block (PCB). Ready List Priorities. Wait Lists (Semaphores). System Locks. Ready List Example. Interrupts. Scheduling. Process State Diagram. Backstop Process. Scheduling Example. | 2 | - 2<br>- 4<br>- 5<br>- 7<br>- 8<br>- 19<br>- 20<br>- 23 | | Pro | ress Exchange and Scheduling. Process Exchange. Process State Diagram. Process Control Block (PCB). Ready List Priorities. Wait Lists (Semaphores). System Locks. Ready List Example. Interrupts. Scheduling. Process State Diagram. Backstop Process. Scheduling Example. EXERCISE. | 2 | - 2<br>- 4<br>- 5<br>- 7<br>- 8<br>- 19<br>- 20<br>- 23 | | Pro | ress Exchange and Scheduling. Process Exchange. Process State Diagram. Process Control Block (PCB). Ready List Priorities. Wait Lists (Semaphores). System Locks. Ready List Example. Interrupts. Scheduling. Process State Diagram. Backstop Process. Scheduling Example. EXERCISE. | 2 | - 2<br>- 4<br>- 5<br>- 7<br>- 8<br>- 19<br>- 20<br>- 23 | | Pro | cess Exchange and Scheduling. Process Exchange. Process State Diagram. Process Control Block (PCB). Ready List Priorities. Wait Lists (Semaphores). System Locks. Ready List Example. Interrupts. Scheduling. Process State Diagram. Backstop Process. Scheduling Example. EXERCISE. | 2 | - 2 4 5 6 7 8 9 - 2 2 3 - 2 2 3 - 2 | | Pro | cess Exchange and Scheduling. Process Exchange. Process State Diagram. Process Control Block (PCB). Ready List Priorities. Wait Lists (Semaphores). System Locks. Ready List Example. Interrupts. Scheduling. Process State Diagram. Backstop Process. Scheduling Example. EXERCISE. ect Memory Access Input/Output. DMx Overview. | 2E 333333333333333 444 | - 2 2 4 5 6 7 8 9 7 9 2 2 2 3 2 3 2 3 | | Pro | cess Exchange and Scheduling. Process Exchange. Process State Diagram. Process Control Block (PCB). Ready List Priorities. Wait Lists (Semaphores). System Locks. Ready List Example. Interrupts. Scheduling. Process State Diagram. Backstop Process. Scheduling Example. EXERCISE. | 2E 3333333333333333 444 | - 2 4 5 6 7 8 9 - 2 2 3 - 2 2 3 - 2 | | Prod | Cessor ( Common Produc TTL vs ECL Pr Exerci | Fea<br>t Li<br>ECL<br>oces | ture<br>ne<br>sor | s<br><br>Feat | <br>ture | <br><br> | | | | | <br><br> | <br>· · · | <br> | <br> | 5<br>5<br>5<br>5 | _<br> | 2<br>6<br>6<br>7 | |------|----------------------------------------------------------------------------|--------------------------------------------------|-----------------------------------------------------------------|-------------------------------------------------------------|--------------------------------|----------------------------|--------------------|---------------------|-------------------------|-----------|----------|-----------|------|------|------------------|--------|----------------------------------------------------| | Dis | Input<br>Disk C<br>Disk I | once | pts. | | | | | | | | | <br> | <br> | <br> | 6 | _ | 2<br>4 | | LOCA | ATE Mec<br>Descri<br>LOCATE<br>LOCATE<br>The Di | ptio<br>exa<br>& F | n of<br>mple<br>ile | F LO(<br>€<br>I/O. | CATE | · · · · | | | | | <br> | <br>· · · | <br> | <br> | 7<br>. 7<br>. 7 | | 2<br>3<br>4<br>5 | | File | System Disk State Sequen Direct Contig Segmen Unit To Disk Gunt To EXERCI: | truc ecor ory: tial Acc uous t Di able uota able | ture<br>d He<br>Stru<br>ess<br>Acc<br>rect<br>sex | es eader uctur ess Meti ess tory ample | re<br>Met<br>nod<br>Met<br>For | hod<br>(DAM<br>hod<br>mat. | (SA<br>(SA<br>(CA | <br>M)<br>ile<br>M) | Fil<br>Fil<br>Fo<br>Fil | e <br>rm | For | <br>t | | | | -<br>- | 2<br>4<br>6<br>7<br>8<br>9<br>10<br>12<br>14<br>15 | | Prog | Si<br>Proced<br>S<br>S<br>B<br>Vi<br>D<br>C | sing<br>t Us<br>Arch<br>ure<br><br>efau<br>EG L | Moder Rited and 1t Load Call call call call call call call call | des Regis turc Lin Load Map (PC Ins CDyn Map Map Shar: EPFs | sterek Ar | ctic | <br><br><br>on<br> | | | | | | | | 999999999999 | | | | Exception Ha | indling | | | | | | | | | | | 10 | | | |--------------|-------------------------------------|----------|------------|---------|------------|----------|-------|-------|-------|-------|-------|------|------|----| | Exception | ns | | | | | | | | | , | | 10 | | 2 | | Checks | | | | | | | | | | | | 10 | | 4 | | Faults | | | | | | | | | | | | 10 | - | 6 | | Dur | namic Lin | kina. | | | | | | | | | | 10 | _ | 8 | | Condition | n Mechan | ism. | | | | | | | | | | 10 | - | 10 | | Asynchronous | and Ter | mina | l Ina | out/ | Outp | ut | | | | | | 11 | | | | The GAMI | C/ICS Dr | iver | (AMI | DIM | /ASY | NDM : | ) | | | | | 11 | | 2 | | | .C operat | | | | | | | | | | | | | 2 | | AMI | DIM | | J | | | | | | | | | | | 3 | | Figurina | Buffer | Giza | <i>.</i> . | | | | • • • | | | | | | | 4 | | Figuring | ) buffer<br>Overflow | Cond | | | | | | • • • | • • • | • • • | | | | 5 | | DUTTER C | ferences. | Coma | 1 0 1 0 1 | 13 | | | | • • • | • • • | • • • | • • • | 11 | | 6 | | 108 0171 | rerences.<br>ring User | | <br>£anc | | | | | | | | • • • | _ | | 7 | | Configur | ing User | | Ters. | AMI | <br>C | | | | | | | | | 8 | | How to/a | end not t | o se | с ор | MIT | <b>C</b> | | | | | | | | | _ | | EXERCISE | | • • • • | | | | | | | | | • • • | 1.1 | | | | Tuning the S | Scheduler | <b>.</b> | | | | | | | | | | 12 | | | | Basic of | jectives | | | | | | | | | | | 12 | - | 2 | | CHAP | | | <i>.</i> | | | | | | | | | 12 | | 3 | | Remardia | ng/Punish | ino | Proc | esse | s | | | | | | | 12 | - | 4 | | Response | e time ve | . th | roug | hput | | | | | | | | 12 | - | 6 | | • | | | | | | | | | | | | | | | | USAGE | | | | | | | | | | | | . 13 | | _ | | System T | uning O∨€ | ervie | ₩ | <b></b> | | | | | | | | . 13 | | 2 | | Ident | ifuina Wo | rklo | ad | | | | | | | | | . 13 | **** | 3 | | Monit | orina the | Sus | tem. | | | | | | | | | . 13 | | 4 | | USAGE | | | | | | | | | | | | . 13 | - | 5 | | Analu | zino Data | a | | | | | | | | | | . 13 | _ | 7 | | Perom | mendina 9 | Solut | ions | | | | | | | | | . 13 | | 8 | | USAGE - | CPU Meter | ٠5 | | | | | | | | | | . 13 | - | 10 | | CPU B | ottleneck | <b>(</b> | | | | | | | | | | . 13 | | 12 | | USAGE - | Virtual N | iemor | u Me | ters | <i>.</i> . | | | | | | | . 13 | _ | 14 | | Memor | u Bottler | neck. | | | | | | | | | | 13 | | 16 | | Peduc | ing Wire | d Mem | อาน | | | | | | | | | . 13 | | 17 | | Li | red Memor | | CONF | IG T | )ire | tiv | es. | | | | | . 13 | _ | 18 | | W I | red Memor | L11 | Prod | uct | Real | uire | men. | ts. | | | | . 13 | | 20 | | WI<br>Lii | red Memor | ru | Sust | em l | Jsaoi | · •<br>e | | | | | . , | 13 | - | 21 | | AA 1 | , , , _ , , , , , , , , , , , , , , | . 🛥 | | | | | | | | | | | | | continued on next page | MAXSCH (Backstop Revisited) | . 13 | - 22 | |---------------------------------|------|------| | Tuning MAXSCH | | | | USAGE - Disk Information | 13 | - 26 | | Tuning Disk I/O | | | | Disk Tuning | | | | USAGE - LOCATE Information | | | | LOCATE review with %'s | | | | NLBUF | | | | LOCATE Tuning | | | | USAGE - ROAM Buffer Information | | | | EXERCISE | | | | APPENDICES | | | | Acronum List for this course | Δ | | # Lesson 1 - Computer Concepts Objective: Upon successful completion of this lesson, students will be able to: - Describe some main components of the CPU and define related terminology. - Define what registers are and how they are organized and used on Prime computers. - Describe the basic components of the operating system and how they relate to the hardware. # Computer Components Hardware # 50 Series Backplane | | Main Memory ==================================== | |------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------| | MEMORY POWER SUPPLY | CPU | | Central<br>Processing<br>Unit | <ul> <li>Performs logical operations</li> <li>Performs arithmetic operations</li> <li>TTL or ECL logic</li> <li>High speed memory components</li> </ul> | | CPU POWER SUPPLY INPUT/OUTPUT CONTROLLERS | I/O Controllers ==================================== | | CONTROLLER POWER SUPPLY INPUT /OUTPUT CONTROLLERS CONTROLLER SUPPLY | - Data input and output | | INPUT/OUTPUT////////////////////////////// | | | CONTROLLER POWER SUPPLY | | | POWER DISTRIBUTION UNIT | | BUS 51 200 5 Some Components of the CPU BRA+BPO = 16 BIT TTL-9 BMA= 22BIT -> \$MD = 16 BIT CCL-75MA = 23 BIT + 15m0 =32 617 9955-4-73M9 = 24 BIT BMO = 32 BIT MRIN MEMDRY BUSS -m shory 8 - PSQIPHERAL R - Appross C 吗. - OATA K - CONTROL & PBIT **BMC** BMA BMD P € > bir L A D 4 N 68 C 6B L P 5 2 U 7 3 BPC 4 861 **BPD BPA** INPUT / OUTPUT CONTROLLER DENICE 16-64 KB 1. CALME FRAME REFERENCE /LAST INSTRUCTION BEKELVIED 2. STLB VM > PHYSICAL NOM \$5 - WIGE WORD, INTRUSTVED LOADS ٢ 3 LOTLB DISKREWED -> MEMORY APORESS 4. PROGRAM COUNTER 5. ROLISTOR FILE 6. д MICROODE IN CLUDGE CORE ROUTINGS LIKE STORCP. B DECOPER 7 ALU # Registers and the PC - o Registers High speed memory locations (on the CPU board) used as work areas for the CPU. Each register contains 32 bits. They are organized into Register Sets (RSx), each containing 32 registers. All of the register sets together constitute the register file. - o The Register File: | | RSO | RS1 | RS2 | RS3 | |------------------------|-----------------------|--------------|--------------------------------------|------| | 2250<br>750<br>850 (2) | Micro code<br>scratch | DMA channels | Current Register Set #0 (CRSO) | CRS1 | | older | | | | | | | RS4 | RS5 | RS6 . | RS7 | | 9950<br>9750 | | | i<br>! | | | 9755 | | ! | : | | | 9955 | | i | • | | | 9955-II | | 1 | : | | | | | | <u> </u> | | | | RSB | R59 | RS10 | RS11 | | 2350 | | 1 | ; | | | 2450 | | 1 | <b>!</b> | | | 2550 | | | i<br>, | | | 2655<br>9650 | i<br>• | i i | i<br>t | | | <b>フロコリ</b> | ŧ | 1 | | | 9655 # Computer Components Operating System Memory Management - Physical - Virtual 512 MB Process Exchange - Scheduling Program Environment - PCL PROGRAM CALL LOAD - Addressing modes - Exception handling DMx Disk I/D - Locate mechanism Async Terminal I/ #### Software Operation - o In order for a program to execute on a computer, all languages must be broken down into machine level (binary) information. This information can be divided into three main components. - INSTRUCTIONS - DATA - ADDRESSES - <u>Instructions</u> Instructions tell the machine to do something. They usually affect a register or a memory location. - Data Data is information stored in memory for use by a program. It can be numeric (integer, floating point, etc) or character (ASCII, EBCDIC). - Addresses An address points to either an instruction, data, or another address. Addresses are usually calculated by the CPU from information supplied by an instruction. The end result is called the Effective Address (EA). Instructions, data, and addresses are distinguished by the way in which they are used. ## Lesson 2 - Memory Management Objectives: Upon successful completion of this lesson, students will be able to: - Explain how Cache Memory reduces the effective memory access time for memory reference instuctions. - Describe how interleaving and wide-word memory fetches work, and the benefits of each. - Explain how virtual memory is organized. - Explain how a virtual address is translated into a physical address. - Describe the function of the STLB. # Cache Functional Diagram Cache Hit Rate Delegatines Bt 1. SIZE OF CACHE 2. LOCKITY OF REFERENCE 3. FETCH SIZE # Effective Memory Access Times Effective Memory Access Time: - Cache Hit-rate - Cache Access Time - Main Memory Access Time #### Assuming: - same locality of reference on all systems. - all memory boards are interleaved. - main memory access times are the same on all systems. | 1 | cache ! | fetch | 1 | hit | ; | cache | 1 | effective memory | |-------------------------------------|---------|-------|---------------|-------|---|--------|---|------------------| | • | size | size | ŀ | rate | ; | speed | ; | access time | | 2250 l | 2 KB ! | 32 | 1 | 85% | ; | 80 ns. | ı | 230 ns. | | 2350 | 16 KB | 64 | 1 | 95% | 1 | 80 ns. | 1 | 180 ns. | | 2450 | 16 KB | 64 | 1 | 95% | ; | 80 ns. | 1 | 132 ns. | | 2655 | 16 KB | 64 | ŀ | 95% | i | 80 ns. | 1 | 132 ns. | | 9655 | 16 KB | 64 | 1 | 95% | ; | 80 ns. | 1 | 132 ns. | | <del>7833 </del><br>975 <b>0 </b> | 16 KB | 64 | ; | 95% | 1 | 40 ns. | 1 | 105 ns. | | 9755 | 16 KB | 64 | 1 | 95%+ | ; | 40 ns. | 1 | 84 ns. | | 9955 | 64 KB 1 | 64 | <u> </u> | 98% | 1 | 40 ns. | i | 58 ns. | | 9955-II | 64 KB : | 64 | <del></del> - | 98%+ | 1 | 32 ns. | 1 | 46 ns. | | 9950 | 16 | 64 | | 90-95 | | 40 Ns | | | #### Interleaving EVEN addresses ODD addresses - Interleaving is implemented using two identical boards. - The same location is fetched off of both boards resulting in 32 bits transfered to cache for one memory fetch. - | MB+memory boards are self-interleaving. IF CONFIGURED CORESCILY (1 MB IS # Wide-word Memory Addresses # WIDE WORD - The word (16 bits) requested is sent to cache via the data bus. - The next word (16 bits) is sent to cache via the address bus. - The 9750,9755,9950,9955, and 9955-II do not use wide-word. They all have a 32 bit data bus. - Wide-word and interleaving result in 4 words (64 bits) in cache from a single fetch. WIDE WORD /INTERLETUE ## Cache Benefit Example Here is an example of a FTN program fragment: INTEGER\*2 ARRAY(3), MAX, INDEX DATA ARRAY/10,5,15/ /\* INITIALIZE ARRAY VALUES DATA MAX/O/ /\* O IS SMALLEST NON-NEG INTEGER DO 100 INDEX = 1,3 /\* FOR ALL 3 ARRAY VALUES 100 IF (ARRAY(INDEX). GT. MAX) MAX = ARRAY(INDEX) PRINT \*, MAX The expanded generic assembly language might look like this: | | | | _ | NONE | | :YES-32 | 1YES-64 | 4 | |-----|---------|------------------------------------------|------------|-------------|-----------|-----------------------------------------------|-----------------------------------------------|----------| | | | | _ | | BIT FETCH | | | | | 92 | | | | <u> </u> | ! | ! 1 | 1 1 | 1 | | 93 | A-regis | ster = 1 | | 1 | 1 1 | 1 0 | 1 0 | 1 | | 94 | INDEX : | = A-register | | 1 | : 1 | : 1 | : 0 | | | 95 | Go To | instruction at 98 | | 1 | 1 1 | : 0 | 1 0 | | | 96 | INDEX : | = <u>INDEX</u> + 1 | | 3 | 1 1 | ; 1 | 1 1 | | | 97 | A-regi | ster = INDEX | _ | : 3 | 1 1 | 1 0 | 1 0 | | | 98 | If A-r | egister <= <u>3</u> , Skip | | : 4 | ; 1 | ! 1 | 1 0 | | | 99 | Go To | instruction at 105 | | 1 1 | 1 1 | 1 0 | 1 0 | <u> </u> | | 100 | X-regi | ster = A-register | | : 3 | ! 1 | ! 1 | 1 1 | | | 101 | A-regi | ster = $ARRAY-1 + X-1$ | register . | : 3 | ! 1 | 1 0 | 1 0 | 1 | | 102 | If A-r | egister <= <u>MAX</u> , Ski <sub>l</sub> | | <u>: 3 </u> | ! 1 | 1 1 | 1 0 | | | 103 | MAX = | A-register | | 1 2 | : 1 | 1 0 | 1 0 | | | 104 | Go To | instruction at 96 | | 1 3 | 1 1 | <u> 1 </u> | 1 1 | _1 | | 105 | Print | <u>MAX</u> | | 1 1 | : 1 | 1 0 | 1 0 | | | | | | | <u> </u> | <u> </u> | <u> </u> | <u> </u> | | | 200 | 3 | [constant 3: | ָ . | 1 4 | 1 1 | ! 1 | 1 1 | | | 300 | | [INDEX] | | 10 | 1 4 | 4 | 1 4 | | | 400 | 0 | [XAM] | | : 6 | 1 3 | 1 3 | <u> 3 </u> | <u>:</u> | | 401 | 10 | [ARRAY(1)] | | : 1 | ! 1 | ; 0 | 1 0 | | | 402 | 5 | [ARRAY(2)] | | 1 1 | 1 1 | ! 1 | 1 0 | <u>:</u> | | 403 | 15 | [ARRAY(3)] | | 1 1 | 1 1 | 1 0 | : 0 | 1 | | | | | renort of | 52 | 24 | 16 | 12. | | | | | | MCCBASE | • | | | | | # Cache Memory Example - continued W = memory reference Write R = memory reference Read I = Instruction D = Data | | | 1st | time | | _ = | nd t | ime | | 3T C | tim | <u>ie</u> | _4 | th | time | |-----|---|-----|------------|---|-----|------|-----------------------|---|------|------------|-----------|----|----|-----------| | R | I | | | | | | | | | | | | | | | R | I | 94 | | | | | | | | | | | | | | W | D | 300 | [INDEX] | | | | | | | | | | | | | R | I | 95 | (Jump) | | | | | _ | - | <b>~</b> / | | R | T | 96 | | | | | | R | Ι | 96 | | R | 1 | 96 | | | - | | | | | | | R | D | 300 | [INDEX] | R | D | 300 | | R | | 300 | | | | | | W | D | 300 | [INDEX] | W | D | 300 | | W | ע | | | | | | | R | I | 97 | | R | I | 97 | | R | T. | 97 | | | | | | R | D | 300 | [INDEX] | R | D | 300 | | R | Ď | 300 | | R | I | 98 | (skip) | R | 1 | 98 | (skip) | R | I | 98 | (skip) | R | Ī | <b>78</b> | | R | D | 200 | | R | D | 200 | | R | D | 200 | | R | D | 200 | | • • | _ | | | | | | | | | | | R | I | 99 (Jump) | | R | T | 100 | | R | I | 100 | | R | I | | | | | | | R | T | 101 | | R | I | 101 | | R | I | 101 | | | | | | R | D | 401 | [ARRAY(1)] | R | D | 402 | [(2)] | R | D | 403 | [(3)] | | | | | R | T | 102 | | R | _ | 102 | (skip) | R | I | 102 | | | | | | R | Ď | | [MAX] | R | D | 400 | • | R | D | 400 | | | | | | R | T | 103 | | | | | | R | I | 103 | | | | | | W | D | | [MAX] | | | | | W | D | 400 | | | | | | • • | T | | (lnwb) | R | 1 | 104 | (Jump) | R | I | 104 | (lnwb) | R | I | 105 | | R | 1 | 104 | / Joinh / | • | • | | • <b>y</b> = <b>F</b> | | | | | | | | # <u>Virtual Memory</u> # a PAGE is a manageable piece of data PHYSICAL MEMORY PAGE = 1024 (16 BIT) WORDS DISK RECORD (DATA) = 1024 (16 BIT) WORDS # 50-Series Virtual Memory Space DESCRIPTOR THBLE APPRESS REGISTER | | 3 0 0 0 0 11 0 0 0 | <del></del> | |--------|--------------------|-------------| | 81255 | our osc | ome | | 1520,2 | 1717=464 | 0 | | | 765 = 502 | ì | | | 1777=512 | 2 | | | 114=12 | ~ | # VIRTUAL ADDRESS USER "SEES": SEGMENT 4003 WORD 4 # VIRTUAL ADDRESS HARDWARE "SEES": DTAR 2 SEGMENT 0003 PAGE 0 WORD 4 This page for NOTES #### Segment Descriptors SDT - SEGMENT DESCRIPTOR TABLE: A LIST THE OF L SDW - SEGMENT DESCRIPTOR WORD: INFORMATION ABOUT A PARTICULAR SEGMENT. IT SHOWS: - IF THE SEGMENT IS USED OR UNUSED - THE ACCESS RULES FOR THE SEGMENT - POINTER TO A LIST OF THAT SEGMENT'S 64 PAGES ### Page Map Table PMT - PAGE MAP TABLE: A LIST OF ALL 64 PAGES IN A SPECIFIC SEGMENT. A PMT IS ALSO KNOWN AS AN HMAP. 32BHS WIDE = 256 BYTES LONG HARDWARE MAP PMT ENTRY - CONTAINS INFORMATION ABOUT A SPECIFIC VIRTUAL PAGE. IT SHOWS WHERE THE PAGE IS; PHYSICAL MEMORY AND/OR DISK IF THE PAGE IS IN PHYSICAL MEMORY, THE PMT ENTRY ALSO SHOWS: - HOW OFTEN THE PAGE IS USED 1650 9T - WHETHER OR NOT IT IS PAGEABLE WILLSO BIT - IF IT HAS BEEN MODIFIED MODIFIED BIT - THE PHYSICAL PAGE NUMBER PMT FOR SEGMENT 4003 | PMT ENTRY - PAGE 0 | |---------------------| | PMT ENTRY - PAGE 1 | | | | PMT ENTRY - PAGE 17 | | ••••• | | PMT ENTRY - PAGE 36 | | | | PMT ENTRY - PAGE 55 | | | | PMT ENTRY - PAGE 63 | # Address Translation 4003/4 # This Page for Notes # Memory Map | Pa | YC | t | r | |----|----|---|---| | Γ | | | 1 | # MMAP | ppn 1 | FULL | |--------|-------| | ppn 2 | FULL | | ppn 3 | FULL | | | | | ppn 11 | FULL | | | | | ppn 17 | EMPTY | | | | | | | #### Paging # STLB & Cache Validation 4003/4 UN = DMR Z SEGNONT 3 PAGE & WORD 4 # MAIN MEMORY | 0000000000 | 00000 | 000000000 | |------------|-------|-----------| | PG 17 0 | | 00000000 | | | | | | 000000 | | | | 1000000 4 | HI | | | | | | | | | | | 116 | | | | | | | | | | | | 1023 | | | | | | | | | | | | | | | | | | | $\mathsf{CPU}$ | | CPO | | |----|--------------------------------------------------------------------|--------| | | XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX | 了<br>? | | | | ļ | | | | Į, | | | DT AR 2 SEGMENT 0003 PAGE 0 PPN 17 | Į. | | | | Į. | | | | | | \\ | | ٠ | | | ////////////////////////////////////// | 1 | | | | | | K | ///////////// PPN 17 -WORD 4 HI ////////////////////////////////// | 1 | | | | | | | | 1 | # This page for NOTES #### Flushing the STLB ## VIRTUAL ADDRESS | DTAR 2 | SEGMENT 0003 | PAGE 0 | WORD 4 | | |--------|--------------|--------|--------|--| | | | | | | # **STLB** | DTAR 2 | SEGMENT 0003 | PAGE 0 | <br>PHYSICAL PAGE 17 | | |--------|--------------|--------|----------------------|--| | | | | | | | | | | | | | | | | <br> | | ( NJCKS THAT THE POINTER IN STLB MATCHES THE REQUESTED PAGE 15 THE ONE POINTED TO IF SO IT (AN BE USED, IF NOT, THE SYSTEM MUST GET THE CORRECT TAKE. IF IT HIS HAPPENS 17 ALSO FLUENS THE ENTIRE STLB. | 50000000000000000000000000000000000000 | |----------------------------------------| | | | | | | | | | 1023 | | | | | | | | | | | | | MONORY REPORTING E IN CHECK STLB -- MOT IN STRB IN PORTING CHECK PRIME (HECK MONORY -- INT IN - USE IF WALLO USE, WENTER CAMB.) (NEE I FNOT VILLO, FIND IT, FLUSH STAB 4015 FUSICACIE PAT ... #### Memory Management Exercise DIRECTIONS: Circle the best answer to each question. - 1. Which factor does <u>not</u> affect the cache hit rate? - A. Size of cache. - (B) Number of users. - C. "Locality of reference." - D. Size of memory fetch. - 2. The fast speed of cache and the cache hit rate improve performance by: - A. Increasing the effective memory access time. - P. Reducing the effective memory access time. - C. Increasing the address translation time. - D. Reducing the address translation time. - 3. The main reason for interleaved memory is: - A To increase the size of a memory fetch. \* SPEED - B. To pair up memory boards. - C. To increase the locality of reference. - D. To ship data up the address bus. - E. None of the above. - 4. Which of the following statements about virtual memory is NOT true? - A. It is divided into segments. - B. It is implemented using paging and address translation. - C. It is the memory addressing range available to programmers. - D. It allows the combined size of all executing programs to be larger than main memory. - (E) It is entirely allocated at coldstart. - 5. The maximum number of segments PRIMOS Rev 20.2 can support is: - A. 128. - B. 1022. - C. 4096. - (D) 8192. - 6. Page faults are detected during: - Cache hits. A. - B. STLB hits. - C. Process exchange - Address translation - E. All of the above - 7. A page fault (with PREPAG = 3) can result in: - Ø. O to 4 actual disk I/Os. - B. 1 to 4 actual disk I/Os. - C. Always 2 disk I/Os. - D. Always 4 disk I/Os. - 8. The CONFIG directive NSEG: - A. Specifies how big the SDTs will be. - Specifies the range of DTAR2 segments for all users. Will allocate NSEG number of total segments. Will put a limit on the number of PMTs which can be allocated on the system. - 9. An SDT describes: - A. All the enabled segments on the system. Box All the enabled segments within a DTAR. - . All the pages within a segment. - D. None of the above. - 10. Wiring a page: - A. Means it cannot be shared. - B. Is accomplished in the STLB. - C. Means it is never paged. - D. Removes an entry from the MMAP. - E. Both (B.) and (C.) are true. #### Lesson 3 - Process Exchange and Scheduling. Objectives: Upon successful completion of this lesson, students will be able to: - Describe the basic states of a process. - Describe the operation of the Dispatcher and process exchange. - Describe how an external interrupt can put a process into operation. - Describe the purpose of the HOLD queues and the operation of the Scheduler. #### Process State Diagram THE YOU ARE EXECUTING ARED A HILLING PRIORITY PROCESS GUTCHS REMOVE QUEUE, YOU ARE PRESEMPTED + PUT BYCH ON READY JEST, PARANT = PROCESS ABOUT - NETTOL & KAUSTINE ETMET MATTOL OR MINOR TIME SLICE YOU MEE PUT "ON HOLD" MASOR SLICE TO EDEVLOWER #### Process Exchange | 3 Data Structures | 2 Instructions | |-------------------------------------------------------------------------------------------|------------------------------------------| | 1) PCB PROESS CONTROL BLOCK ALLEGINGS | 1) WAIT | | 2) REMOY UST | 2) Nother | | 3) WAIT LIST -SOMAPHORES | | | | | | 2 MECAMNISMS | | | DISPATCHSQ - HARDWARE - DOBS PROCESS GRUM, STAVES YOUR REGISTER SCHEDING. - SCHEDIPMA | NGE<br>5 - <b>PB</b><br>23<br>24<br>6545 | #### Process Control Block (PCB) CHAP TUNES MAJOR TIME SLICE TPRIORITY PCBS MRE IN SEGY 1001000 + USER NUMBER\* 100 or pegranusme 2 = 584 4/100200 READIFIES 15 IN SERV #### Ready List Priority Order | PRIORITY | | |----------|--| |----------|--| | PRIURITY | 16 B175 WIFE | _ | |-----------------|------------------------------------------------------------|-------------------| | highest | Reserved for system use WAS NETMAN | 1 | | • | CLOCK PROCESS / FNTSTOP - 350's LNO BACKSTOP | Inch YOPAT | | | : AMLC PROCESS (AMLDIM, ASYNDM) | 17. Ance 7. 454HC | | | SMLC PROCESS (SLCDIM, SLXDIM) SMLC/MOLC | 1 % SLE 3 IDON'T | | | I IPQIPC, IPQBSP PROCESSES ROTHER - INTOLPROSESS COMO ON K | 185+MC TRUST | | | : MPC PROCESSES (MPCDIM, MP2DIM) | 19-MPC | | | VERSATEC PROCESS, MPC-4 | +90CPBI | | | RING NET CONTROLLER PROCESS | 180 PMC | | | DISK PROCESS DIPICIOSHDIO | 17,055 | | - | NETMAN | 1 | | | 1 SUPERVISOR PROCESS - CONSOLE | ; | | | USER LEVEL 3 | _ | | | USER LEVEL 2 | 1 | | | USER LEVEL 1 (DEFAULT LEVEL) | 1 | | | USER LEVEL 0 | 1 | | | I IDLE LEVEL | 1 | | | SUSPEND LEVEL | | | 1 <b>70</b> 2st | BK1PCB (BACKSTOP 1) / BK2PCB (BACKSTOP 2) | 1201011 | | | END OF READY LIST = 1 | _ I | DIM = DEVICE INTERNAL MODDIE MPL = MULTPURPOSE COMMOUSE : URC = UNIT REGIRD CONINGEORE AMLL LASTLINE = CTI - CHARACTOR TIME INTERRUPT 1/CHAR 9600 = 960 INT/SEC #### Wait List (Semaphore) NOTIFY Semaphore name> access semaphore count = count - 1 first PCB --> Ready List #### System Locks Each lock consists of the following data structure: | COUNTER | READER'S Wait Semaphore | COUNTER | WRITER'S Wait Semaphore | USAGE Counter | PRIORITY | Locks will allow N readers or 1 writer. A writer will wait on the writers semaphore if there are any active readers or an active writer. A reader will wait on the readers semaphore if there is an active writer or if a writer is waiting. When the USAGE counter is equal to - O the lock is free (available) - +N there are N active readers - -1 there is one active writer Priority is used to force an order to avoid deadly embrace situations. ## Ready List Example 2 THIS IS A PROGMPTION OF EXAMPLE I | PPA | CLOCK | CLKPCB PP | B DISK | DSKPCB : | |----------|-------------------------|-----------------------|-----------------|----------| | | ^ | CLKPCB | | | | CLOCK | I_CLKPCB _ <br>I_CLKPCB | CLOCK | | | | AMLC | O_ <br> <u>amlpcb</u> | ~ ~ | | | | SMLC | _ | | | | | DISK | DSKPCB <br> DSKPCB | DSKPCB DISK DISK DOLL | | | | LEVEL 2 | <br> 0 | USER 2 | USER 16 | USER 19 | | LEVEL 1 | _USER 2_ <br> USER 19 | LEVEL 1 : USER 16 : | LEVEL 1 USER 19 | LEVEL 1 | | LEVEL 0 | - 0 - | ~ | ~ ~ | ~ ~ | | IDLE | _ 0 - | | | | | SUSPEND | _ 0 _ | BKSTP1 | BKSTP2 | | | BACKSTOP | BKSTP1<br>BKSTP2 | BKSTOP : BKSTP2 : | BKSTOP | | # Ready List Example 3 CLOCK FINISH OF DESK RESERVED TO SECULION | | | G14 00 ((- | | | | |----------|--------------------------|------------------------|-------|----------|---------| | PPA | : DISK : | DSKPCB : | PPB | LEVEL 1 | USER 2 | | | ~ ~ | | | | | | CLOCK | O <br> _CLKPCB | | | | | | AMLC | | | | | | | SMLC | 0 - | | | | | | DISK | I_DSKPCB_!<br>I_DSKPCB_! | DSKPCB<br>DISK<br>DISK | | | | | LEVEL 2 | - 0 - | USER 2 | | USER 16_ | USER 19 | | LEVEL 1 | USER 2 <br> USER 19 | LEVEL 1 | _<br> | LEVEL 1 | LEVEL 1 | | LEVEL 0 | 0 - | ~ | ~ · | ~ | ~ | | IDLE | _ 0 _ | | | | | | SUSPEND | 0 - | BKSTP1 | | BKSTP2 | | | BACKSTOP | BKSTP1 BKSTP2 1 1 | BKSTOP<br>BKSTP2 | | BKSTOP I | | | PPA | LEVEL 1 1 | JSER 2 | PPB : LEVEL | 1 USER 16 | |----------|---------------------|------------------|-------------|--------------------------| | | ~ ~ | | | | | CLOCK | IOI<br>I_CLKPCBI | | | | | AMLC | O _ <br> AMLPCB _ | | | | | SMLC | | | | | | DISK | DSKPCB | | | | | LEVEL 2 | <br> 0 | USER 2 | USER 1 | 6 USER 19 | | LEVEL 1 | USER 2 | LEVEL 1 | LEVEL | 1 LEVEL 1 <br>9 0 | | LEVEL 0 | _ 0 _ | ~ | ~ ~ | | | IDLE | _ 0 _ | | | | | SUSPEND | _ 0 _ | BKSTP1 | BKSTPS | 2 | | BACKSTOP | BKSTP1 | BKSTOP<br>BKSTP2 | BKSTOF | | | PPA | LEVEL 1 | USER 16 | PPB | LEVEL 1 ! | USER 19 | |----------|-----------------------------|-----------------------|---------------|-----------------------|---------| | • | ~ | | | | | | CLOCK | IO_ <br>I_CLKPCB | | | | | | AMLC | I O I | | | | | | SMLC | 0 _ | | | | | | DISK | O I<br>DSKPCB | | | | | | LEVEL 2 | - 0 - | USER 16 | | USER 19 | | | LEVEL 1 | LUSER 16_L | LEVEL 1 | -<br>-!<br>-! | LEVEL 1 | | | LEVEL 0 | 0 _ | ~ <u></u> | | \ <u></u> \ | | | IDLE | 0 - | | | | | | SUSPEND | | DI/OTE 4 | | BUOTEO. | | | BACKSTOP | 0<br> BKSTP1 <br> BKSTP2 | BKSTP1: BKSTOP BKSTP2 | | BKSTP2<br>BKSTOP<br>O | | PREEMPTION | PPA | CLOCK ! C | CLKPCB PPB | LEVEL 1 USE | R 16 | |----------|--------------------------|------------------------|---------------|------| | | ~ ~ | CLKPCB | | | | CLOCK | CLKPCB <br> CLKPCB | CLOCK | | | | AMLC | I O I | ~ | | | | SMLC | _ 0 _ | | | | | DISK | O I<br>DSKPCB | | | | | LEVEL 2 | <br> | USER_16_ | USER 19_ | | | LEVEL 1 | _USER 16_ <br> USER 19_ | LEVEL 1 <br> USER 19 | LEVEL 1 | | | LEVEL 0 | 0 - | ~ ~ | ~ | | | IDLE | _ 0 _ | | | | | SUSPEND | _ 0 _ | BKSTP1 | BKSTP2 | | | BACKSTOP | BKSTP1 | BKSTOP <br> BKSTP2 | BKSTOP I | | CE1025 - SA0S32 PROCESS EXCHANGE | PPA | CLOCK : ( | CLKPCB : | PPB | : DISK | : DSKPCB | |----------|----------------------------------------------|---------------------|-------------------|-------------|-------------| | | | | | | | | CLOCK | I_CLKPCB_I | CLKPCB | _<br>_ i | | | | AMLC | <u>CLKPCB</u> <br> O _ <br> <u>AMLPCB</u> | <u>.</u> 0 | _i<br>~ | | | | SMLC | 1_ 0 _1 | | | | | | DISK | L_DSKPCB_L<br>L_DSKPCB_L | DSKPCB<br>DISK<br>O | -<br>-<br>-<br>- | | | | LEVEL 2 | - 0 - | USER 16 | | USER 19 | | | LEVEL 1 | USER 16_ <br> USER 19_ | LEVEL 1 | -<br>_! !<br>!!!! | LEVEL 1 | 1<br>1 | | LEVEL 0 | | ~ | <u>-</u> ↓ | | ·<br>• | | IDLE | _ 0 _ | | | | | | SUSPEND | _ 0 _ | BKSTP1 | | BKSTP2 | | | BACKSTOP | BKSTP1 | BKSTOP<br>BKSTP2 | | BKSTOP<br>O | !<br>!<br>~ | | PPA | I DISK I | DSKPCB : | PPB | LEVEL 1 ! | USER 16 | |----------|--------------------------|----------------------|--------|------------------|---------| | | ~ ~ | | | | | | CLOCK | <br> O <br> CLKPCB | | | | | | AMLC | CLAPCB | | | | | | SMLC | O | | | | | | DISK | I_DSKPCB _ I | DSKPCB<br>DISK<br>O | :<br>: | | | | LEVEL 2 | _ 0 _ | USER 16 | | USER 19 | | | LEVEL 1 | 4_USER 16_:<br> USER 19 | LEVEL 1 | | LEVEL 1 | | | LEVEL 0 | | | , | \ <u> </u> | | | IDLE | | | | | | | SUSPEND | | DVCTD1 | | DVCTDO | | | BACKSTOP | BKSTP1:<br>BKSTP2: | BKSTP1 BKSTOP BKSTP2 | <br> | BKSTP2<br>BKSTOP | | CE1025 - SA0S32 PROCESS EXCHANGE | PPA | LEVEL 1 L | JSER 16 | PPB | LEVEL 1 | USER 19 | |----------|---------------------|------------------|------------------|---------|-------------| | ~ | ~ | | | | | | CLOCK | I CLKPCB | | | | | | AMLC | I_ O _! | | | | | | SMLC | O | | | | | | DISK | I O I | | | | | | LEVEL 2 | 0 - | USER 16 | | USER 19 | | | LEVEL 1 | USER 16 USER 19 | LEVEL 1 | -<br>-<br>-<br>- | LEVEL 1 | ‡<br>‡ | | LEVEL 0 | 0 - | ~ <u></u> | · | | ·<br>• | | IDLE | 0 - | | | | | | SUSPEND | 0 _ | BKSTP1 | | BKSTP2 | | | BACKSTOP | BKSTP1 | BKSTOP<br>BKSTP2 | - : | BKSTOP | !<br>!<br>~ | | PPA | LEVEL 1 L | JSER 19 | PPB | BKSTOP | : BKSTP1 | |----------|------------------------|------------------|----------------|-------------|-----------------| | | ~ ~ | | | | | | CLOCK | I_ O _! | | | | | | AMLC | | | | | | | SMLC | ! <u> </u> | | | | | | DISK | I O - | | | | | | LEVEL 2 | _ 0 _ | USER 19 | _ | | | | LEVEL 1 | USER 19 <br> USER 19 | LEVEL 1 | _ <br>_ | | | | LEVEL 0 | _ 0 _ | ~ | ~ | | | | IDLE | _ 0 _ | | | | | | SUSPEND | _ 0 _ | BKSTP1 | | BKSTP2 | _ | | BACKSTOP | BKSTP1 | BKSTOP<br>BKSTP2 | -!<br>-:<br>-~ | BKSTOP<br>O | - <br>- <br>- | | PPA | BKSTOP : B | KSTP1 | PPB | BKSTOP | : BKSTP2 | |----------|---------------------------------------------------|----------------------|-----|-----------------|----------| | | ~ ~ | | | | | | CLOCK | | | | | | | AMLC | : <u>CLKPCB</u> :<br>! O _:<br>!_ <u>AMLPCB</u> : | | | | | | SMLC | | | | | | | DISK | O <br>DSKPCB | | | | | | LEVEL 2 | | | | | | | LEVEL 1 | 0 <br> 0 <br> USER 19 | | | | | | LEVEL 0 | 0_1 | | | | | | IDLE | | | | | | | SUSPEND | 0 _ | | | | | | BACKSTOP | 0<br> BKSTP1_ <br> BKSTP2_ <br> 1 | BKSTP1 BKSTOP BKSTP2 | | BKSTP2 BKSTOP | | #### External Interrupts - There are three basic catagories of exceptions: #### Exceptions - 1) Interrupts. - 2) Checks. - Faults. - An external interrupt is a method by which a controller can notify a process to the ready list. - Here is the basic sequence of events: - 1) Controller raises an interrupt request. - 2) CPU acknowledges interrupt. - 3) Controller ships CPU an address on BPA. - 4) CPU will save PC, PB, and KEYS in special registers and load address from controller into PC. 4 saves process intorval finerial connect PCB - 5) CPU will now execute Phantom Interrupt Code (PIC). - 6) PIC usually consists of an INEC instruction which will: - a. tell controller that interrupt is being serviced. - b. notify an interrupt process to the ready list. - c. restore the PC, PB, and keys. INER - INTERRUPT NOTIFY SETERANT CALL ## Process State Diagram Interactive User Processes MACKSTOP PROCESS C'ITHE SCHOOLITE') #### Scheduling Of Users - PRIMOS scheduling is based on two criteria. - PROCESS EXCHANGE - SCHEDULER which consists of: - a. Backstop process - b. SCHED subroutine. - o The Backstop process is responsible for maintaining the 9 HOLD queues. It will bring one process at a time to the ready list. - o SCHED responds to a PABORT subroutine call to place a user PCB on one of 9 HBLD queues after it exhausts it's minor time-slice. - o Here are the 9 HOLD queues: - HIPRIQ, high priority (interactive user finishes a command). - ELIGO, eligibility (major time-slice remaining) But MINGE TIME SICE SAPIRED - 5 LOPRIGs, lew prierity (major time-slice exhausted). - LOPRIE 4, user level 4 (supervisor level). - LEPRIE 3, user level 3 - LOPRIO 2, user level 2 - LEPRIE 1, user level 1 - LEPRIG 0, user level 0 - IDLES, will be examined when no other process is holding. - SUSPQ, will not be examined. USERS WAIT ON BURSON LAND CR. HOW DOES USE OF # O'MERMAN CREOR EM OF RAN AFFECT MONETO HIPRIQ #### Backstop Process LOPRI NOTIFY COUNT #### Scheduling Example HIPRIG: CPU ELIGG: LOPRIG 4: 3: 2: 1: 0: IDLEG: #### Process Exchange and Scheduling Exercise - The backstop process: 1 - Is the same as the dispatcher. - Is what controls paging on the system. - Interrupts the CPU when a WAIT instruction is detected. **C** . - Maintains the STLB. - (E) None of the above. - When in the "wait" circle on the process state diagram, you are 2. waiting for: - The CPU. Α. - A major time-slice end. - Some system resource. - The backstop process. - None of the above. F - When does the backstop process get executed? - A. Right after the clock. - When it issues a NOTIFY. When the Hold queues are empty. When it's the highest priority process on the ready list Every Tuesday, whether we need to or not. - A. Initiates a DMx request. - Indicates a cache and STLB miss. - Netifies the scheduler that a process is in the Hold state. - Indicates a time-slice end. - Can put a process back on the ready list. #### A Beadly Embrace is: - A. More than one process waiting on a semaphore. - A semaphore with a negative counter. - Two processes waiting for resources which the other อพกร. - A NOTIFY to an empty system lock. D. - None of the above Ε. - The dispatcher: - (A). Is responsible for saving and restoring hegister sets. - B. Issues NOTIFYs to processes in the "wait" state. - Maintains the Hold Queues. - D. Is a software process. - E. None of the above. - When a processes minor timeslice expires: - A. It is put on the ready list. - It goes to the ELIGG. C. It goes to one of the LOPRIGS. - ■. It goes to HIPRIQ. - (E) Either (B) or (C.), depending on the major timeslice. - A writer to a system resource: - A. Always preempts active readers. - Always must wait. - Waits if there are active readers. - Can NOTIFY the reader semaphore. He DOESN'T DO 17. Both C & D are true - 9. A PCB does not contain: - A. The current remaining minor timeslice. - B. The addressing mode that the process is running. - C. Flags which show the state of the process. - (D) A WAIT instruction. - A link word to other PCBs. - 10. If we have 25 widgets available on the system, and we want to set up a wait list to guarantee that the 24th process to want a widget will wait, we would initialize the counter to a: - A. 0 - ® -25 - C. 25 - D. -1 - E. none of the above. ### Lesson 4 - Direct Memory Transfer Input/Output Objectives: Upon successful completion of this lesson, students will be able to: - Describe the Prime implementation of Direct Memory Transfer. - Explain the concept of I/O bandwidth. - Explain how burst-mode DMA transfers increase I/O bandwidth. - Explain DMA overruns #### Direct Memory Data Transfers - o On Prime machines, there are two methods employed to transfer data between I/O devices and main memory: - 1) PIO instructions - 2) DMx microcode - o PIO instructions are a group of assembly (PMA) level instructions which can transfer 1 16-bit word to or from controllers, plus perform - control operations. These instructions are used primarily for control purposes. - o DMx microcode is used to do bulk data transfers. When a controller signals a DMx request, the CPU will execute a microcode trap. The trap will suspend the currently executing process and begin to execute DMx microcode. To do the transfer, the CPU must know two pieces of information; the location of the data buffer and the amount of data to transfer. This information is typically stored in a "channel". - o There are four types of DMx: - 1. DMA, Direct Memory Access Disk - 2. DMC, Direct Memory Channel - 3. DMT, Direct Memory Transfer - 4. DMQ, Direct Memory Queue Each method has advantages and disadvantages in terms of speed, volume and control features and so form a comprehensive range of methods. # INTLB Address Translation ■ IMTLB — Since DMx uses virtual addresses when addressing memory, we want to guarantee that the addresses will be pre-translated in order to avoid doing full address translations. The I/O Table Lookaside Buffer is specific for segment O and must be initialized before each DMx transfer is started. ### DMA Transfer - 1. SET UP FOR DMA - 2. CONTROLLER READS FROM DEVICE INTO BUFFER - 3. WHEN BUFFER IS FULL, CONTROLLER RAISES DMX REQUEST - 4. CPU (TRAPS TO DMx U-CODE) ACKNOWLEDGES CONTROLLER - 5. CONTROLLER SHIPS CHANNEL LOCATION TO CPU - 6. CONTROLLER SHIPS 16-BIT WORD OF DATA TO CPU - 7. CPU SHIPS UP TO 'WHERE'; CHECKS 'HOW MUCH' - 8. IF DONE, SENDS END OF RANGE SIGNAL TO CONTROLLER, IF NOT STEP 6 - 9. CONTROLLER SENDS EXTERNAL INTERRUPT SIGNAL TO CPU TO DO NOTIFY ### DMA Flow 5 CE1025 - SADS32 PM: ### DMx Type Information #### DMA Transfers #### Uses: - disk data transfers - tape transfers of less than 4096 16-bit words - PNC controllers #### Advantages: - faster than DMC or DMG - you can chain channels together (scatter-gather) - has the highest bandwidth (using burst mode) #### Disadvantages: - only 32 channels available - maximum of 4096 16-bit words per channel - data buffer must be in segment O #### DMC Transfers #### <u>Uses</u>: - MDLC and SMLC controllers - AMLC and QAMLC for character input - tape transfers of more than 4096 16-bit words - MPC controllers (parallel printers) #### Advantages: - . faster than DMQ - large number of channels available - you can chain channels together - 64KW maximum transfer size (theoretical limit) #### Disadvantages: - slower than DMA and DMT - data buffer must be in segment O # DMx Type Information (cont.) ## DMQ Transfers #### Uses: - QAMLC for character output - ICS1, ICS2, and ICS3 for async character input and output # Advantages: - can read and write from the data buffer simultaneously - data buffer can be in any segment - buffer can be up to 64KW in size # Disadvantages: - slowest of all DMx methods - data buffer must be a power of 2 in size # DMT Transfers #### Uses: - outputting disk channel programs to the controller - AMLC for character output - ICS1, ICS2, and ICS3 for downline loading microcode #### Advantages: - Fastest of the DMx methods ## Disadvantages: - no channel (controller must "control" transfer) - data buffer must be in segment O CE1025 - SAOS32 DM x ### Lesson 5 - Processor Features Objective: Upon successful completion of this lesson, students will be able to: Describe the major features of the various processors and how they relate to overall system performance. #### Common Processor Features - o Multi-user multi-function timesharing systems. - o Microprocessor control unit with process exchange. - o Multiple user register sets. - o 32 bit architecture. - o 255 user processes. - o 512 MB virtual address space. - o Segment Table Lookaside Buffer (STLB). - o Hardware integer arithmetic. - o Cache memory. #### 2250 - PRIME's entry level system. - Designed for the office environment. - Easy-to-use operator interface. - Microcode implementation of floating point and decimal/character business instructions. - Slow system clock rate. - 20% slower disk transfer rate. - Limited configurability - 10 total slots - 2 CPU boards - Maximum 4 MB Main Memory - Maximum 32 users - 1 disk/tape controller board - 1 ICS1 controller - 3 optional slots ### 2350, 2450, 2655 & 9655 - Custom gate array TTL logic. - Larger 16 KB cache. - Wide-word memory. - Burst mode I/O (microcode based, 5.0 MB/sec. bandwidth). - 8 user register sets. - 512 STLB entries, 128 IOTLB entries. - 2 stage instruction pipeline - Decimal arithmetic hardware. - Quad precision floating point hardware. - 48 bit floating point ALU. #### 2350 & 2450 Configurability # 2350 - 4 I/O controller maximum - Maximum 8 MB main memory - 2 board CPU (3 slots) - Up to 16 terminal users - Maximum 4 synchronous lines. - Limited to 2 disk drives (240MB). # <u> 2450</u> - 4 I/O controller maximum - Maximum 8 MB main memory - 2 board CPU (3 slots) - Up to 24 terminal users - Maximum 4 synchronous lines. - Limited to 2 disk drives (240MB). # 2655 & 9655 Configurability # <u> 2655</u> - 7 I/O controller maximum - Maximum 8 MB main memory - 2 board CPU - Up to 64 terminal users - Maximum 8 synchronous lines. - Limited by single 130 amp. power supply. - Limited to 2 disk subsystems (4 drives, 1.2GB). # <u>9655</u> - 10 I/O controller maximum. - Maximum 8 MB main memory. - 2 board CPU. - Up to 128 terminal users. - Maximum 8 synchronous lines. - Limited by 130 amp. I/O power supply. - Up to 4 disk controllers (16 drives, 10.5GB) # TTL vs ECL # ECL Processor Features - o Synchronous Pipeline - 10 stages. - every other stage is occupied. - each stage takes 40 nanoseconds to complete (beat rate). - o Branch Cache - Record the target address for jump and branch instructions. - Predict the next instruction address for the pipeline. - 256 entries. #### 9750, 9755 & 9950 - CPUs uses ECL logic. - Dedicated CPU backplane. - 10 (5) stage synchronous pipeline. - Branch cache (256 entries). - Guad precision floating point hardware. - Environmental sensors to detect, and take action, if overheating occurs. - 4 user register sets. - 40 ns. access time for cache, STLB and registers. - 128 STLB and IOTLB entries. - 9750 configurability - Maximum of 12 MB main memory - 10 I/O controller support - Maximum 192 terminal users - 9755 configurability - Maximum of 16MB main memroy - 10 I/O controller support - Maximum 192 terminal users - 9950 configurability - Maximum 16 MB main memory - 14 I/O controller support - Maximum 254 terminal users #### 9955 & 9955-II - CPU uses ECL logic. - 64 KB cache (98% hit rate). - Branch cache (1024 entries). - 512 STLB and IOTLB entries. - Quad precision floating point hardware. - Environmental sensors. - Multiplier Array board. - Soft Error Recovery (cache, lookaside buffers). - 9955 configurability - Maximum of 16 MB main memory - 14 I/O controllers - 254 terminal users - 9955-II configurability - Maximum of 32 MB main memory - 14 I/O controllers - 254 terminal users <u>Title</u>: 50-Series Processor Features Homework - Describe the features of the various processors. Task: Fill in a table of all processor features Fill in the correct value for each entry in the table. Choose from the values listed in square brackets "[ ]." You do not have to use all of the choices. | | 2250 | 2550 | 9650 | ; 9750 | 1 9950 | : 9955 | |---------------------------|--------------|---------------|--------------|----------|----------------------------------------------|----------| | | ! | | ! | <u> </u> | <u>: </u> | <u> </u> | | n-bit architecture | | | ! | | : | 1 | | [32/16 bits] | ! | , | ! | i | 1 | 1 | | Simultaneous active | ! | <u> </u> | <del>i</del> | <u> </u> | ! | ! | | iprocesses | ! | | : | i | | | | [64, 128, 255] | ! | | ! | ì | | • | | Direct connect | <del> </del> | <u></u> | <u> </u> | İ | 1 | 1 | | terminal users | 1 | | | • | 1 | • | | 1 [32, 48, 64, 96, | | *<br>! | | i | | • | | 128, 175, 196, 254] | 1 | ( | 1 | • | 1 | 1 | | Maximum main memory | !<br>! | : <del></del> | ! | : | 1 | 1 | | [2, 4, 6, 8, 12, 16 MB] | 1 | ! | 1 | ! | 1 | 1 | | STLB size | !<br>! | ! | ! | ŀ | 1 | 1 | | [64, 128, 256, 512] | ! | <b>!</b> | 1 | ! | ! | 1 | | Cache size | !<br>! | ŧ | 1 | 1 | ! | i | | [2,4,8,16,32,64KB] | 1 | <b>!</b> | 1 | 1 | į | l | | :I/O bandwidth | 1 | 1 | 1 | i | 1 | į | | : [2, 2, 5, 5, 8, 9 MB/S] | ; | ! | 1 | 1 | ; | i | | Burst mode I/O | i<br>i | 1 | 1 | 1 | <u> </u> | į. | | :[yes/no] | 1<br>f | ! | 1 | ! | ! | ! | | :Wide-word memory | 1 | t t | 1 | i | i | 1 | | :[yes/no] | 1 | | 1 | 1 | 1 | 1 | | branch cache | 1 | 1 | i | į | 1 | 1 | | :[yes,no] | 1 | 1 | 1 | ! | 1 | <u> </u> | | circuit type | ! | 1 | i | i | 1 | 1 | | [ECL, TTL, gate array] | 1 | 1 | 1 | | 1 | | | luser register sets | 1 | 1 | - | ł | 1 | 1 | | 1[1,2,3,4,8] | 1 | <u> </u> | <u> </u> | | 1 | <u> </u> | | ¦pipeline stages | ! | - | : | ; | 1 | 1 | | [ [0, 1, 2, 3, 4, 5, 10] | ! | ! | ! | 1 | ! | <u> </u> | | !Integer arithmetic | 1 | 1 | 1 | 1 | 1 | 1 | | :[Hardware/Firmware] | 1 | 1 | <u> </u> | 1 | 1 | 1 | | Character/Decimal | 1 | 1 | ţ | <b>{</b> | : | 1 | | [Hardware/Firmware] | <u> </u> | 1 | 1 | <u> </u> | 1 | <u> </u> | | :Floating Point | 1 | 1 | : | ł | 1 | 1 | | :[Hardware/Firmware] | 1 | ! | 1 | <u> </u> | 1 | 1 | | Procedure Call | 1 | ! | : | : | 1 | 1 | | :[Hardware/Firmware] | | <u> </u> | i | _! | <u> </u> | 1 | | iProcess Exchange | 1 | } | 1 | : | i i | : | | [H/F/Software] | <u> </u> | 1 | ! | 1 | ! | <u> </u> | | !Quad precision | ; | 1 | : | ŀ | : | : | | :[H/F/Software] | 1 | ! | 1 | _! | <u> </u> | <u> </u> | # EXTRA CREDIT Do the same for the following old models: 550-II, 750, 850, 250-II, 550-I, 250-I, 500, 400 • # Lesson 6 - Disk Input/Output Objectives: Upon successful completion of this lesson, students will be able to: - Describe the basic layout of the disk subsystem hardware. - Describe the various components of disk I/O time. #### Disk Concepts - The <u>I/O bus</u> connects the CPU to one to four disk controllers (maximum two prior to revision 19.3). - o Each disk controller controls one to four disk drives. - o Each disk drive has a disk data pack and heads. - o The <u>disk data pack</u> consists of a number of platters on a spindle. - o A <u>logical disk</u> contains a number of adjacent platters. - o There is at least one head for each platter surface. - o Each platter is divided into a number of concentric tracks. - o Each <u>track</u> is divided into 9 records. - o Each <u>record</u> magnetically encodes 1040 words of data. \* 32 45 HONGE - o The disk drive spins the disk pack at about 3600 rpm. - All of the heads as a single unit mechanically <u>seek</u> a desired cylinder. - o The head at the desired record reads/writes the data. # Disk Concepts 2048 #### Disk I/O Time o The total time it takes to process an I/O request is described by the following formula: Disk I/O time = wait time + seek time + latency time + transfer time - <u>Wait time</u> is the amount of time it takes from when a process submits a request until it is acted upon by the disk controller. There are two major things you may have to wait for: - To get a Queue Request Block (QRB). There are: - 7 QRBs at Rev 18 - 17 QRBs at Rev 19.1 - 32 QRBs at Rev 19.3 and on - 2) The other processes in the work list for a particular drive which are ahead of you. - Seek time is the amount of time it takes once the controller gets a request for the heads to get "on cylinder". A random seek takes about 40-45 ms. The average seek time can be reduced from this amount by two methods: - Ordering seeks. This is a method of ordering request in ascending order (track #). - Overlapped seeks. A controller can have all drives simultaneously seeking. ## Disk I/O Time con't Disk I/O time = wait time + seek time + latency time + transfer time - o <u>Latency time</u> is the amount of time it takes the disk to rotate into position once the heads are on cylinder. This is strictly a function of the disk drive. - o <u>Transfer time</u> is the amount of time it takes (using DMx) to transfer one disk record into memory. It is possible to have more than one controller transfering a data record at the same time. This is called <u>overlapped transfers</u>. Lesson 7 - The LOCATE Mechanism (Associative Buffers) Objectives: Upon successful completion of this lesson, students will be able to: - Describe the Locate mechanism and where it fits in to the scheme of the disk I/O mechanism. - Describe the process of a disk request from start to finish. #### Associative Buffers - An associative (or LOCATE) buffer is a main memory copy of a disk record. - O Associative buffers are a means of reducing the number of disk accesses needed for logical file access. - o Multiple logical reads to one physical record may require only one disk access. - o Multiple logical writes to one physical record may require only one disk read and one disk write. - o Each user can own $\underline{\text{one}}$ locate buffer. An owned locate buffer is wired in memory. - Previously owned locate buffers remain in memory until they are again owned (wired), or deleted from memory. - O If a locate buffer has been modified, it is written back to the file system disk by user 1 and/or when it is deleted from memory. User 1 copies all modified locate buffers to the file system disk once a minute. # LOCATE Mechanism | • | LOCATE (ASSOCIATIVE) BUFFERS | USE | R #1 | |------|------------------------------|-----|------| | | - · | | | | DISK | | USE | R #2 | | | | | | | | • | · | | File I/O The Driver LOCATE CE1025 - SA0S32 LOCATE CE1025 - SA0S32 FILE SYSTEM # Lesson 8 - The File System Objectives: Upon successful completion of this lesson, students will be able to: - List the various types of data structures on disk. - Describe what a directory looks like and how it works. - Describe the various ways of organizing data files. - Describe what unit tables are and how they are used. - Describe how quotas are implemented. CE1025 - SAOS32 FILE SYSTEM ### Physical Disk Structures A disk drive is divided into one or more partitions where a partition is one or more pairs of heads. Each partition must contain: MFD (Master file directory) 2). DSKRAT (Disk record availability table) 3). BOOT (For initial loading) 4). UFD DOS (Initially empty - not actually required) 5). UFD CMDNCO (Initially empty) 6). BADSPT (If badspots on the disk) Each partition is divided into a number of 1040 word records. The record header is 16 words for storage module devices. The remainder of the record holds data (1024 words). | <u> </u> | HEADER | 1 | | |----------|--------|---|----------------| | 1 | | ŀ | | | } | | 1 | 1040 (decimal) | | ; | | ţ | total | | : | | ł | words | | 1 | | ł | total | | 1 | DATA | | | CE1025 - SADS32 FILE SYSTEM ## Logical Disks - o Master File Directory (MFD) - is the top level directory. - o DiSK Record Availability Table (DSKRAT) - is created by MAKE, and patched (if necessary) by FIX\_DISK. - has a bit to indicate the status of every record in the partition, in use, or free. - linked records are assigned on the same cylinder when possible. - should be as large a practical - o The BADSPoT file (BADSPT) - will be created by MAKE either by manual entry, test, or from a pre-existing BADSPT file. - will hold re-located records detected by COPY\_DISK when a badspot is encountered. - holds all badspots for entire physical disk. - have MAKE conduct the most severe test (takes a long time). - FIX\_DISK can be used to add badspots. #### Record Header Format Record address of this record. RA of the directory entry for this record, or the first record in the file. Number of data words in record. Type of file (only on first record). RA of the next sequential record, or a of the last record. RA of the previous record, or a of the first record. Index level for DAM files. REKTYP O = SAM 1 = DAM 2 = SEGSAM 3 = GEG DAM 4 = UFO 5 = UFO (ACL) 6 = ACCBS CAT 7 = CAM FILES # Disk Record Logical Structure #### Directory Structure - o DIRECTORY HEADER - Password. - Quota information. - Date/time stamp. - Directory hash table (127 16-bit words) - o FILE ENTRY - Pointer to first record of file (BRA). - Protection information (password protection keys, ACL position, RBF flag, etc). - Integrity information (date/time last saved, read/write locks, truncated flag, etc). - Type of file (SAM, DAM, SEGSAM, SEGDAM, SUBUFD) - File or directory name - o ACL ENTRY - Access pairs. - O ACAT ENTRY - Name of ACAT. - Pointer to ACL (within directory). - HOLE (VACANT ENTRY). - Caused by deletion of file object. - Will be re-used if new entry fits. - Eliminated by FIX\_DISK -UFD\_COMPRESSION. SAM Files #### DAM Files MAN MORE THAN 512 PSCORDS ARE MICHARD, A SOCIOM PROPER NECOND (S MOCHTO AND) AMEN INDEX RECORD (S CREATED AT ME NORT LEVEL UP, MUHKA POINTS PO THE TWO / NORT RECORDS THAT POINT TO PATH PSCORDS #### CAM File | Directory<br>Entry | | | | |--------------------|-----|---|--| | 1 | BRA | ī | | | : | | ; | | | ; | | 1 | | | ~ | | ~ | | | ~ | | ~ | | STANDARD RECORD HEADER EXTENT MAP HEADER EXTENT MAP TABLE ENTRIES Ext n Ext n Extn Ext 1 Ext 1 Ext 1 Rcd 3 Rcd 2 Rcd 1 Rcd 1 Rcd 2 Rcd 3 340 GREC/STRATE MAX POR GRENT MAP BLOCK ### SEGSAM Directory Format ## SEGDAM Directory Format CE1025 - SA0S32 FILE SYSTEM #### Unit Tables - Definitions - A <u>unit table</u> (ut) is a list of pointers to unit table entries. - A <u>unit table entru</u> (ute) describes a file system object that is currently in use via the file system. It contains: - The current disk address of the record we last accessed. - The parent directory address. - Access rights. - Read/Write locks. - Current logical position in file. - Quota pointers. - Misl info. - A <u>file system object</u> is a data file, directory or access category. These objects may reside on a <u>local</u> or a <u>remote</u> system. #### Unit Tables - Rev 19.4 #### PRE-19. 4 METHOD - Per-User unit tables allocated/deallocated dynamically. - Maximum of 131 units per user. - 8 units guaranteed per user. - Maximum of 3247 system units available. - Unit table is same size no matter how many active units. - At login, get 131 file units: O system unit 1 - 127 available for user 128 home 129 current 130 IAP #### 19.4 METHOD (and on) - Per-user unit tables allocated/deallocated dynamically. - Maximum of 32,768 units per user. - Users are guaranteed all the units they want. - Maximum of 256,000 system units available. - Unit table dynamically grows as more file units are requested. - Initially, (at login) get 38 file units: - -5 temporary attach - -4 como - -3 IAP - -2 home - -1 current - O system - 1-32 available for user #### Disk Quotas o Quotas are implemented by the use of two data structures: #### DIRECTORY BLOCK (DB) - User count (how many people are using this directory). - BRA of directory. - Quota modified flag. - Number of records used in this directory. #### QUOTA BLOCK (QB) - User count. - BRA of directory. - Pointer to parent UFD's QB. - Guota left in tree. Quota information is stored in these two structures as long as anyone is accessing a particular directory. When the directory not in use, this information is stored in the directory header on disk. O Quota information is ONLY updated when the last user leaves a directory. Thus overhead from quotas is very small. ## Unit Table Allocation | | UT | UTEs | | | |---------------|---------------------------------------|---------------------------------------|------------|------| | | UI | ! | : | GB ; | | ; _ | size of UT | : | : | ! | | <b>-5</b> ¦ | temp | i | <b>!</b> | DB ! | | -4 ¦_ | c omo : | : | <b>!</b> | ! | | -3 | IAP | : | ; | QB : | | -2 :_ | home : | i | ; | | | -1 !_ | current : | : | | DB ! | | 0 :_ | sustem | | <u>;</u> | | | 1 :- | | | ; | QB : | | 5 - | i | <b>.</b> | ;<br>, | i | | 3 4 | · · · · · · · · · · · · · · · · · · · | i | j i | DB | | 5 : | | i | i | QB : | | J . | <b>`</b> | • | ,<br>, | GD ! | | | UT | ;<br>! | !<br>! | DB | | | 01 | · · · · · · · · · · · · · · · · · · · | •<br>• | | | : | size of UT ! | i | • | QB : | | -5 | temp | <b>!</b> | ; | ! | | -4 | como ! | 1 | ; | DB : | | -3 : | IAP ! | 1 | 1 | | | -2 | home : | i | <b>.:</b> | GB : | | -1 <b>!</b> _ | <u>current</u> ! | 1 | 1 | \! | | 0 !_ | <u>system</u> ! | • | 1 | | | 1 !_ | | | | ~ | | 2 !_ | | | • | | | 3 !_ | | | <b>i</b> | | | 4 !_ | | | | | | 5 ! | i | | i | | | ~ | •• | i | i<br>1 | | | | | | , i<br>, i | | | | | i<br>! | 1 | | | | | • | 1 | | | | | | .• | | CE1025 - SA0S32 FILE SYSTEM PRIMOS REV. 20.2 ## Disk, File System and LOCATE Exercise - 1) Logical disks should be as large as possible because: - (Å.) there are more records per cylinder in large partitions. - B. there are more cylinders per surface in large partitions. - C. there are more records per surface in large partitions. - D. none of the above. - 2) BADSPT (badspot) files: - A are not related to system performance. - B) should contain every disk record that has ever had an error. - C. need contain only bad disk records that are detected by MAKE. - D. both (A) and (B) are true. - 3) Programs will take the most advantage of the locate buffering mechanism if they - A have small sequentially processed logical records. - B. process data in sequential disk records. - C. only read from or only write to (not both) a disk record. all of the above. - 4) A locate (associative) buffer is: - A. a collection of pointers to a disk record. B. a main memory copy of a disk record. C. an area in cache set aside for disk I/Os. - - D. wired in memory until a user logs off. - 5) UFDs: - A. are strictly main memory structures. - (B) contain file entries, ACLs, ACATs, directory entries, and holes. - C. are limited to one disk record in size. - D. do not have a standard disk record header. - 6) Unit tables: - (A) are accessed when opening a file. - B. are always accessed through a hash. - C. are pointed at by Quota Blocks and Directory Blocks. - D. contain Unit Table Entries. - 7) A physical disk record is: - A. 1024 decimal 16-bit words. - B. 1040 octal 16-bit words. - 1024 octal 16-bit words. - D) 1040 decimal 16-bit words. - E. As long as the application requires it to be. - 8) SMDIO: - A. Is another name for the LOCATE mechanism. - B. Works only with DAM files - C Sets up for DMA. D Is the disk driver. - Both C & D are true. - 9) The only thing that actually resides in a directory record is: - An ACL A file - C. A directory - ${f 2}$ None of the above All of the above - 10) The DSKRAT is: - A. Another name for the I/O driver. - B. A record header. - C A bit map of the data records on the partition. - D. Located in every UFD on a partition ## Lesson 9 - The Program Environment Objectives: Upon successful completion of this lesson, students will be able to: - Define the four basic addressing modes on Prime. - Describe the PCL mechanism, including stacks, base registers, and ECBs. - Describe how SEG loads programs in memory. - Describe the differences between SEG and EPFs, plus describe the other advantages in the implementation of EPFs. #### Addressing Modes - 168 16 stands for 16KW maximum address space. - S stands for Sector mode (current and sector zero). - Uses absolute <u>physical</u> addresses. - Honeywell compatable mode. - Prime 200-9950. - Store instructions automatically flush 9950 pipeline. - <u>325</u> 32 stands for 32KW maximum address space. - Same as 16S, but only allow one level of indexing. - 32R 32 stands for 32KW maximum address space. - R stands for Relative mode (relative to PC, sector zero). - Prime 300-9950 - Store instructions automatically flush 9950 pipeline. - 64R 64 stands for 64KW maximum address space. - Same as 32R, but only allow one level of indirection. - 64V 64 stands for 64KW address space per segment. - V stands for Virtual mode. - Uses base registers for segment number. - Prime 400-9950. - Pure procedure is assumed, no automatic pipeline flush. - 321 32 stands for 33 bit word length. - I stands for Integer mode (or Immediate). - Uses 8 general registers. - Prime 500-5900 - 321X X stands for extended I-mode. - Prime 2350-9950 - General purpose registers can be used like base registers. - Pure procedure is assumed, no automatic pipeline flush. ## Current User Registers | GRO | | ł . | | |-----|------------------------------------------------------------------------|----------|---| | GR1 | | ł | | | GR2 | A | L | В | | GR3 | | E | | | GR4 | | | | | GR5 | Υ | i | | | GR6 | | ! | | | GR7 | Χ | <u> </u> | | | | | FARO | | | | | FLRO | | | | | FAR1 | | | | ······································ | FLR1 | | | | | PB | | | | | LB | | | | | SB | | | - | | XE | | | | an alang anno anna anakapin i haka annah ya min pah ing ki ay dana kan | DTARG | | | | | DTAR2 | | | | | DTAR1 | | | | | DTARO | | | | KEYS | i<br>i | | | | DINNER | <i>i</i> | | | | | i | | ## Stack Architecture | '6000<br>RO WIRED | '6003<br>Ro unwired | '6002<br>R3 COMMAND | '4XXX<br>PRIVATE PROGRAM | |-------------------|---------------------|---------------------|--------------------------| | FREE PTR | FREE PTR | FREE PTR | FREE PTR | | EXT PTR | EXT PTR | EXT PTR | EXT PTR | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | LOGICAL STACK | | |---------------|---| | | | | | - | | | | | | _ | | | | | | | | | | #### Stack Data Structures #### STACK FRAME - 1 per invocation. - contains: - return pointer (caller's PB+PC). - caller's SB: LB and keys. - argument pointers. - dunamic data. - pointed to by the Stack Base register (SB). ## "STACKS" which are used on Prime: - ring O wired stack (seg 6000). - ring O unwired stack (seg 6003). - $-\operatorname{ring}$ 3 or "command" stack (seg 6002, DTAR2 as needed). - Program stack (seg 4xxx as assigned). #### STACK ROOT HEADER - 1 per "stack". - Free Pointer where the new frame will go in this area. - Extension Pointer where to extend if necessary. #### Procedure and Link Areas Assembly code is divided into two main parts: #### PURE CODE (PROCEDURE AREA) - Contains read-only parts of the program (usually instructions and constants). - Pure code is shareable (only one copy per system is needed). - The segment where the procedure area is located is contained in the PB. - The PC keeps track of the current instruction which is being executed. ## IMPURE CODE (LINKAGE AREA) - Contains static data, address pointers, and the ECB (Entry Control Block). - Every user must have their own copy of linkage when they execute. - The beginning address (both segment and word number) is contained in the LB. #### <u>SEG</u> - o Relocating loader. This means compilers produce addresses relative to beginning of the module. Thus a program will reference an address via a base register (i.e. LDA LB%+23 ). - o Linking loader (checks to see that all references are resolved). - Maps program into SEGSAM directory, stores the notation of where in memory each part should be located. - o Creates "Static mode runfiles". This means that the program will execute using the same addresses every time it is executed. - o Is also used to invoke the programs, restoring program images into the appropriate locations in memory. - o. Advantages of the default load (segment allocation) - -- programmer does not need to understand virtual memory in order to load programs - is needed in order to use DBG. - nothing will get overwritten (i.e loader will always allocated enough space, whereas a programmer may accidently overwrite portions). - can detect stack overflow, which is not always possible in non-default loads. #### SEG Address Assignments — When SEG is used to "load" a program, here are the default address assignments used: #### SEG Maps \*START 4002 000003 \*STACK 4001 001066 \*SYM 000023 SEG. # TYPE LOW HIGH TOP 4001 PROC## 001000 001065 001065 4002 DATA 000000 000075 000075 ROUTINE ECB PROCEDURE ST. SIZE LINK FR. #### 4002 000003 4001 001000 000012 000030 4002 177400 SUB1 4002 000030 4001 001014 000024 000020 4002 177430 SUB2 4002 000050 4001 001024 000020 000026 4002 177450 DIRECT ENTRY LINKS EXIT 4001 001050 TNOU 4001 001056 TNOUA 4001 001062 COMMON BLOCKS OTHER SYMBOLS F192QFP7 4001 001024 ## PCL Mechanism | 0 1 | | Stack header for<br> program stack<br> | | |------|--------------------------------------------------------------------|-------------------------------------------------------------|--| | 1004 | MAINs procedure<br>area<br>PCL<br>LB + 422 | MAINs linkage area EXT pt | | | 1014 | SUBs procedure area ARGT | SUBs linkage area ECB ECB initial LB initial keys | | | | return pointer MAINS SB MAINS LB MAINS keys argument pointers data | SUBs stack frame | | #### PCL Related Instructions ## Entry Control Block (ECB) - State of called procedure: - first executable statement. - size of stack frame. - displacement of first argument. - number of arguments. - LB of called procedure. - initial value for keys. - Usually in the Link frame of the called procedure. ## PCL - Microcoded instruction for fast and powerful processing. - 1. Verify access to ECB. - if none, then ACCESS\_VIOLATION\$. - if pointer fault, $tr\overline{y}$ to link dynamically. - 2. Create a new stack frame, at the top of the stack. - 3. Save the caller's state (PB, LB, SB, keys) in the new stack frame from the user register set. - 4. Load the callee's state (PB, LB, keys) into the register set from the ECP. - 5. Calculate and store the indirect argument pointers. ## ARGT - Argument Transfer instruction. - Will finish an interrupted PCL instruction. - Must be first instruction in any routine which accepts arguments. #### PRTN - Procedure Return instruction. - 1. Erase the old stack frame by reseting the top of stack to the callee's SB. - 2. Restore caller's state (PB, LB, SB, keys) from the stack frame to the register file. ## SHORTCALL Operation | :<br>: | MAINs procedure<br>area | MAINs linkage <br> area | |--------|-------------------------|---------------------------| | 1010 | JSXB<br>LB + 422 | | | 1 | SUBs procedure<br>area | | | 1024 | JMP XR% | XB register | #### SHORTCALL Instruction o A shortcall operation is used for two pruposes: First, to avoid the overhead of a PCL when calling a very simple, small routine. Second, to do various tasks with registers that a PCL would destroy (i.e. changing the value of the keys). Shortcalls are usually based on the JSXB instruction. the JSXB will: - 1. Verify access to subroutine, if none, then ACCESS\_VIOLATION\$. - 2. Save the caller's PB in the XB register. - Transfer control to the procedure (new PB). The JSXB instruction is still "pure" since it stores the return information in the XB (index base) register rather than memory. - o USXR is faster than PCL because: - No new stack frame is allocated. - The LB, SB and keys do not have to be switched. - No return information has to be inserted into the stack frame. - No arguments are transfered - o Shortcalled routines are limited because: - They have no stack frame to help them return, or for data storage - They have no link area for data storage. - The base registers are still filled in for the calling program, and therefore cannot be used. - They must be written in PMA - o The Short Call statement is a Prime extension to standard Fortran and is also used by PLP (example programs are SHORT. FTN and SHORT. PLP in CLASS directory). ## STATIC VS DYNAMIC RUNFILES STATIC DYNAMIC | L SEG. SAVE | I . RUN | |-----------------------------------|---------------------------------------| | ISEG or LOAD loaders | BIND loader | | Uses the same static segments | ! Uses available dynamic segments ! | | for every invocation as | for every invocation as assigned | | lassigned by SEG/LOAD | ! by PRIMOS ; | | Contains virtual addresses | Contain EPF Relocatable Pointers | | 1 | ERPs | | (Contains procedure and linkage | : Contains procedure image and a : | | limages | ! description of the linkage area(s): | | (Entire runfile is read into | Procedure images mapped to memory | | lmemory and paging space | via VMFA, required linkage is | | fallocated | built, and paging space | | ! | allocated for linkage; procedure | | | : read into memory as needed : | | <u>User manages address space</u> | PRIMOS manages address space | | Limited restartability of | : Full restartability of | | lcommand environment | command environment | | Uses private stack (4) /x/ | ! Uses command processor stack ! | ## BIND Load Map ### Map of FACTORIAL START ECB: -0002/000002 Segment Type Low High Top -0002 DATA 000002 000153 000154 +0000 PROC 001000 001375 001376 #### PROCEDURES: | Name | ECB address | Initial PB% | Stack size | Link size | Initial | |----------------|--------------|--------------|------------|-----------|----------| | LB% | -0002/000002 | +0000/001000 | 000012 | 000056 | -0002/17 | | 7400<br>FACT | -0002/000056 | +0000/001046 | 000022 | 000022 | -0002/17 | | 7456<br>TIDEC | -0002/000100 | +0000/001074 | 000032 | 000024 | -0002/17 | | 7500<br>TBUFIN | -0002/000128 | +0000/001174 | 000050 | 000030 | -0002/17 | | 7524 | | | | | | ### DYNAMIC LINKS: | CIIN | +0000/001356 | |-----------|---------------| | ERKL \$\$ | +00000/001362 | | TIOB | +0000/001346 | | TNOU | +00000/001356 | | TNOUA | +0000/001372 | | TONL | +0000/001342 | | TOVFD≢ | +0000/001352 | #### COMMON AREAS: OTHER SYMBOLS UNDEFINED SYMBOLS #### VMFA - VMFA (Virtual Memory file Access) is a method of paging from the file system disks rather than the paging disks. - A program which is to use VMFA must be stored as a "memory image" on disk. With EPFs, the procedure code is stored in this way. - O When a program is "loaded" into memory, only the initial pages are brought into memory... the rest are brought in as needed by the normal paging algorithym when the page is first "touched". - Since with EPFs the procedure code MUST be pure, when a page of memory from a procedure page must be paged out, there is always an accurate copy on disk, and therefore no I/Os to disk are required. - o When EPFs are widely used, paging space requirements will be substantially less. Also, the amount of paging on the system should also decrease. - With a program which has a large amount of procedure and a small amount of linkage, the execution startup time will be substantially lass. # Dynamic Sharing (EPFs) | | SDT | | HMAP / PMT | | |------------|-----------------------------------------|-------------------|----------------|---------------------------------| | USER<br>#6 | | > <br> <br> | | 1<br>1<br>1<br>3<br>1<br>1<br>1 | | | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | : | | ;<br>;<br>; | | | | ; | | ; | | | SDT | | | | | USER<br>#4 | | | | | | | | ;<br>;<br>;<br>; | ACTIVE SEGMENT | TABLE (AST) | | | | | | ;<br>;<br>;<br>; | | | | | | | | | | | <br> | !<br>! | | | | | | | #### Caching EPFs #### The Begment Mapping Table - SMT - Each process using an EPF must keep track of the status and virtual mapping for its use of that EPF. The table dynamically created at invocation time is called a Segment Mapping Table (SMT). There is one SMT for each EPF that a process has mapped into memory, and they are linked together into a list. The SMT contains the following type of information: - Stable information about the EPF that will not change regardless of the number of invocations, such as the number of procedure segments and linkage segments required. - Active information that could change from invocation to invocation, such as the command level. - An address table which keeps track of the virtual addresses being used for the current invocation of the EPF. - The full pathname of the EPF | CLDATA, SMI<br>;<br>;<br>V | T_LIST_PTR | | | | |----------------------------|-------------------|--------------------------------------|--------|------------------| | STABLE | STABLE | !> ! ! ! ! ! ! ! ! ! ! ! ! ! ! ! ! ! | STABLE | Dnull<br> Dnull | | ACTIVE <br> ACTIVE | :<br> ACTIVE<br> | | ACTIVE | ;<br>;<br>;<br>; | #### Invoking EPFs When an EPF is invoked, a cache entry is threaded onto the head of the process' cache list, and then calls the EPF. When the EPF returns, its cache entry is left threaded onto the cache list, but its SMT is marked as being <u>inactive</u>. Another invocation of the EPF, while its cache entry is still threaded on the cache list, will only have to go through a partial initialization (i.e., static data and faulted IPs) of the linkage area. An EPF's cache entry will remain on the cache list until it is removed because: - (1) the cache list has become full, and it is the least recently used entry. - (2) it has been explicitly removed with the Remove\_Epf command, - (3) the user's ring 3 environment has been reinitialized, or - (4) a new command level is pushed. | CLDATA.EPF_CACHE_HD_FTR : : : : : | | CLDATA. EPF_CACHE_TL_PTR<br> <br> | |-----------------------------------|---------------|-----------------------------------| | : A(NEXT ENT) | A (NEXT ENT) | A(NEXT ENT) > null | | A(PREV ENT) | ( A(PREV ENT) | A(PREV ENT) | | I A(SMT) I | A(SMT) | : A(SMT) : | #### Library Classes - o. There are two main classes of EPF Libraries: - Program class - Process class The two library types are differentiated by their initialization requirements. - o A program class library runfile is given a new linkage area (re-initialized) for every program which calls it. - o A process class library runfile has its linkage allocated and initialized once upon initial execution by any program running within a process. This linkage area will be maintained for any other programs using this routine (at any command level). The linkage will be maintained until the user logs out, re-initializes his command environment, or explicitly removes the library. . ## Lesson 10 - Exception Handling <u>Objectives</u>: Upon successful completion of this lesson, students will be able to: - Describe the three types of exceptions which the system will handle. - Describe what the different checks are, how they are caused, and how they are handled. - Describe the difference between the fault mechanism, fault handlers, and the condition mechanism. - Describe how dynamic linking is accomplished. - Describe what constitutes "command depth" ## Exceptions o There are three types of exceptions recognized by the micro-code: | 1) | External | Interrupts | - | A controller is signaling that it | |----|----------|------------|---|------------------------------------| | | | | | needs some work done by a software | | | | | | process. | - 2) Checks A hardware malfunction has occured which was NOT caused by the currently executing process. - 3) Faults A software event has occured which WAS caused by the currently executing software. # Exception Handling Mechanism - o The microcode will handle all three exceptions using the same basic steps: - 1) Microcode detects the exception. - 2) The program counter (PB) and mode (keys) of the executing process are saved. - 3) The address of the exception handler (vector) is obtained from the appropriate source (controller or process' PCB). - 4) The addressing mode is set to 64V. - The exception handling code is executed. - o The only difference between how the various exceptions are handled is where the PB and keys are saved, where the vector is obtained from, and the complexity of the handler. ## Checks and Check Handling - o. There are five types of checks on Prime system: - Power fail (also environmental sensor checks). The check handler will check to see what caused the error and shut down the CPU with various degrees of speed and gracefulness. - Memory parity errors (ECC). Parity errors in the data stored in main memory are detected before reaching the CPU. If a 1 bit error is detected, it will be corrected before being shipped. An Error Correct and Check Corrected (ECCC) signal is then sent and a check will occur. The event will be logged and things will continue. If a two or more bit error is detected, a ECC Uncorrected (ECCU) will be signaled. The check handler will map out the page with the bad memory, log out the user, and halt the CPU. The CPU will then be automatically warmstarted if the directive MEMHLT is set to NO. #### Check Handlers con't. - Machine Checks. Machine checks are parity errors which occur anywhere else aside from main memory data errors. They are handled by halting the system. Missing Memory. Missing memory errors are caused by accessing memory which does not exist. This will cause the machine to halt. - Correctable parity (soft error recovery - 9955, 9955-II only). If a parity error is encountered in the STLB or cache, check handler will cause the entry to re-loaded. #### Fault Mechanism - o A FAULT is an unexpected event which has been detected as a result of the currently running software. The fault mechanism calls a software fault handler on behalf of the running software to process the event. The hardware detects a fault. - o The Fault mechanism microcode: - Saves the PB and keys in the concealed stack from the register file. - 2) Transfers control (sets a new PB) to a CALF entry in the appropriate Fault table. - o The Call Fault Handler (CALF) instruction emulates a PCL by: - 1) Create a new stack frame, at the top of the stack. - 2) Save the caller's state (PB, keys) in the new stack frame from the concealed stack. - 3) Save the caller's state (LB, SB) in the new stack frame from the register file. - 4) Load the callee's state (PB, LB, keys) into the register file from the ECB. #### Fault Handling - o Unimplemented Instruction (UII) - Processor tries to execute an instruction that is not implemented on this machine. - Emulate the hardware instruction with software. - If missing or error in the software routine signal the condition UIIs - o Restricted Instruction - A process operating in ring 3 tried to execute a restricted instruction opcode. - The condition RESTRICTED\_INSTRUCTION\$ will be signalled. - o Access Violation - A process operating in a ring other than tried to access virtual memory which is not set up for that ring. - The condition ACCESS\_VIOLATION\$ will be signalled. - o Stack Overflow - PCL, or CALF instruction does not have enough room between the top of the stack and the end of the segment for the new frame. - If a ring 3 stack overflow try to allocate a stack extension segment (Primos revision 19). - If a ring O stack segment, no dynamic segments available, or no extension segment provided, signal the condition STACK\_OVF\$. - o Process Abort - The processes abort flags are non-zero when the process is dispatched. - The process abort handler (PABORT) will look at the abort flags and decide what abort occurred, and call the appropriate routine. - The various process aborts are: - \* Timeslice end - \* Forced logout (AMLC disconnect). - \* Inactivity timeout. - \* Software Interrupts (^P). -LOAD example, and this time discuss how # Rev 19.4 Dynamic Linking Operation - o Here is a step-by-step description of dynamic linking. - A PCL instruction executes. It accesses a pointer created in the link area which should point at the ECB of the called routine. - 2) The ECB pointer has bit #1 set on. This triggers a pointer fault. A CALF instruction is executed and the pointer fault handler (PFH) is called. - 3) The PFH examines the faulted pointer to see if it contains a valid address (not Os). If it does, the PFH strips the fault bit and accesses that address. - 4) The address should point at a data structure called a DYNT. DYNTs are data structures which contain the name of the called routine plus a character count. - 5) The PFH now calls LN\_SLIB to check through the Ring O library, the Ring 3 library (All Rings Callable) and any of the users own libraries (whether EPF libraries or static libraries) for a match on the name contained in the DYNT. - 6) When a match is found, the correct address of the ECB will be filled into the original faulted pointer. Now the PCL will be re-executed and this time it will call the routine. - 7) If a match is NOT found, the PFH will signal a LINKAGE\_FAULT\$ condition. ### Condition Mechanism - o The Condition Mechanism is a method of suppling event handlers on a process by process basis. Some features are: - Strictly a software mechanism (not related to faults). - Can be used and modified by ring 3 users. - Used by fault handlers to bring a fault to the attention of user software. - The condition mechanism is implemented via a collection of subroutines. Some of the key routines are: - SIGNL\$ records information about the condition and the state of the process at the time the condition was signalled. - ON-UNIT a subroutine designed to handle a specific condition. - RAISE searches the stack frames for an on-unit to handle the condition. ## Condition Mechanism Example | | | | | _ ; | |---|------|------|---|--------------| | | | <br> | | - ; | | | | | | 1 | | | | | | : | | | | | | | | | <br> | | | ; | | | | | | į | | | | | | : | | | | | | 1 | | | <br> | <br> | | <br>- ; | | | | | | | | | | | | , | | | | | | , | | - | <br> | <br> | | <br>-¦ | | | | | | | | | | | | i | | | | | | i | | _ | <br> | <br> | | <br><u> </u> | | | | | | : | | | | | | ł | | | | | | ; | | _ | <br> | <br> | | <br>_ | | | | | | i | | | | | | i | | | | | | ; | | | | | | | | _ | <br> | <br> | | <br>_ : | | | | | | 1 | | | | | | | | | | | | | | - | <br> | <br> | | <br>' | | | | | | , | | | | | | , | | | | | | ! | | _ | <br> | <br> | | <br> | | | | | - | İ | | | | | | | | | | | | | | - | <br> | <br> | | <br> | | | | | | | | | | | | | | | | | | | | | <br> | <br> | | <br> | | | <br> | _ | | | | | | | | | | | | | | | | | | | | | | - | <br> | <br> | | <br> | | | | | | | | | | | | | # Lesson 11 - Asynchronous and Terminal Input/Output Objectives: Upon successful completion of this lesson, students will be able to: - Describe the asynchronous character I/O process used with AMLC and ICS controllers. - Correct asynchronous and terminal data loss with the AMLBUF and AMLIBL configuration directives. CE1025 - SADSD2 TERMINAL I/O # The QAMLC/ICS Driver (AMLDIM/ASYNDM) default setting all AMLC lines to 1200 baud. TTY protocol, except the last line which defaults to 110 baud. EDefaults can wire memory that is never used. - AMEC [PROTOCOL] LINE [CONFIG] [LWORD], operator command ASSIGN AMEC [PROTOCOL] LINE [CONFIG] [LWORD], user command PROTOCOL | - TTY, TTYUPC | terminal pretecel | [Operator should <u>onlu</u> set for terminal users.] | | | | |---------------|-----------------------------------------------|----------------------------------------------------------------|--|--|--| | - TRAN | transparent pretecel | | | | | | - TTYNDP | ignere this line | [Operator should set for <u>all</u> unused and assigned lines] | | | | | - ASP | auto speed detect | <b>,</b> | | | | | - TT8FI7 | 8-bit protocol | | | | | | LINE | physical line number | (octal) | | | | | CONFIG | data set control, bau<br>reverse flow control | d rate, bit pattern, parity, | | | | # Asunchronous Input/Output | <u>User Process</u> | ; | AMLDIM software | } <u>Q</u> , | AMLC hardware | |--------------------------------------------------------|-----|------------------------------|----------------|-------------------------------------| | | ! | line# char. | } | | | · · · · · · · · · · · · · · · · · · · | ,- | 11 ^ | | | | Input Ring Buffer<br>default 128 words<br>2 char./word | 1 / | 4 | \ DMC in | | | (1 per NTUSR + NAML | .0) | 4 | 8 \ | /0<br>/1<br>/2<br>/3 | | set-up for /<br>ECHO / | | Tumble Table (1 per board) | \ | | | | ! | | | [ ] line <br> scan <br> counter | | · · · · · · · · · · · · · · · · · · · | ; | | /<br>/ DMQ out | last QAMLC<br>line is CTI | | Output Ring Buffer default 192 words 2 char./word | | | 1 | | | (1 per NTUSR + NAML | _( | 1 char./word<br>(1 per line) | ş<br>1 | | MANCE TOWNS TABLE HAS 2 SIDES WO CHAR EACH. (AMLIBL) WHOM ONE IS FULL BE STONE SOURCES A SIGNAL FOR STONE TO DUMP PIRST SIDE INTO USER CE1025 - SAOS32 TERMINAL I/O #### Setting Buffer Sizes o DMG Size = characters per second / CTI rate (round up to nearest power of two) #### Exceptions: - If the device has a smaller buffer than the DMQ, the DMQ may have to be configured to a smaller size to prevent device buffer overflow. - o ORB Size = (characters per second / 2) / 2 #### Exceptions: - If the system is very memory bound, you can safely reduce the size of the output buffer. Lower effective character throughput may result. - for applications with large working sets, the 1/2 sec wait may be more damaging to paging than having a large buffer. Therefore the buffer should be large enough to accommodate the whole output flow. - o IRB Size = amount a characters which can be input before the user process can empty the buffer. This is typically determined by three factors: - 1) Tupe ahead - 2) Block mode input - 3) Your processes response time (CPU speed plus number of users) - o Tumble tables Size = number of characters input before AMLDIM can empty 1/2 of buffer CE1025 - SAOS32 TERMINAL 1/0 ## Buffer Overflow Conditions ## Tumble Table Overflow symptom. losing data on multiple lines on the same AMLO board. cause: one or more devices transmitting input faster than AMLDIM can empty half of the tumble table. scenario: block mode terminals, computer links (including microcomputers). solution: increase tumble table size with AMLIBL or ICS INPQSZ directive; move fast input transmit devices to ICS board, balance these devices among boards. #### Input Ring Buffer Overflow - Rev 20 and before symptom: losing data on a line, block mode terminal locks up cause: device transmitting input faster than program software (not AMLDIM) processes the input ring buffer. Block mode lock up caused by missing EOT echo. scenario: block mode terminals, computer links. solution: increase input ring buffer size with AMLBUF directive. NOTE: At Rev 20.2 AMLC controllers are capable of reverse flow control at the Input Ring Buffer, making IRB overflows obsolete. ### Output Ring Buffer Full symptom: none, slower program performance. cause: attempt to put character in output buffer when full, causes one half second pause before trying again. scenario: serial graphics output, computer links. solution increase output ring buffer size with AMLBUF directive #### Device Buffer Overflow symptom: missing output with no input ring buffer overflow. cause: device buffer or buffer window is smaller than QDB buffer. scenario: NEC printers, devices that send XOFF too late. solution, decrease QDB buffer size (minimum '20). CE1025 - SADS32 TERMINAL I/O ## ICS Differences o The ICS boards (ICS1,2,% 3) are down line loaded during PRIMOS cold and warm start. - o. The ICS boards wake up a process called ASYNDM. - The ICS boards use DMQ for input and therefore can handle fast input transmitting devices better. - The ICS boards—have a default CTI of 1/10 second, which can be configured with the ICS INTRPT directive (PRIMOS 19.2.7). - o The ICS controllers can use reverse flow control. If configured, the controller will send an XOFF to a device if it gets 2 successive EOR signals when trying to transfer a character into memory ICSI boards (and some ICS2) do reverse flow control on the Input Ring Buffer only. ICS3 controllers (and some ICS2) can reverse flow control on the IRS and the DMG buffers. CE1025 - SA0932 TERMINAL I/0 # Configuring User Buffers | - | There are three numbers associated with asymphronous input: | |----|-------------------------------------------------------------| | | Line # | | | User # | | | Buffer # | | Ci | The format of the AMLBUF directive is as follows: | | | AMLBUF # IRB ORB DMG | | | This directive really has two functions: | | | 1) AMLBUF | | | 2) AMERUF | # How to Set Up AMLC | AMLC<br>AMLC<br>AMLC<br>AMLC<br>AMLC | 04 | TTY<br>TTY<br>TTYN<br>TTY | 2413<br>2413<br>OF 0<br>2413 | 02000<br>02000<br>02000<br>02000<br>02000 | /BUFFER<br>/BUFFER<br>/BUFFER<br>/BUFFER<br>/BUFFER<br>/BUFFER | # # # | | |--------------------------------------|----|---------------------------|------------------------------|-------------------------------------------|----------------------------------------------------------------|-------|--| | AMLC | 05 | TTY | 2413 | 02000 | /BUFFER | ## | | # How NOT to Set Up AMLC | 00 | TTY | 2413 | 02000 | /BUFFER | # | | |-----|----------------------|----------------------------------------|-------------------------------------------------------------------------|----------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------| | | | | 02000 | /BUFFER | # | | | | | | 02000 | /BUFFER | # | | | * . | | | 02000 | /BUFFER | # | | | | | | 02000 | /BUFFER | # | | | | | | 02000 | /BUFFER | # | | | | 01<br>02<br>03<br>04 | O1 TTS<br>OP TIV<br>OB TIVE<br>O4 TIVE | 00 TTY 2413<br>01 TT; 2413<br>02 TTY 2413<br>03 TTYNOS 0<br>04 TTY 2413 | 01 TT: 2412 02000<br>02 TT: 2413 02000<br>03 TT: 2413 02000<br>04 TT: 2413 02000 | 01 TT: 2412 02000 /BUFFER 02 TT: 2413 02000 /BUFFER 03 TT: 2413 02000 /BUFFER 04 TT: 2413 02000 /BUFFER | 01 TT: 2412 02000 /BUFFER # 02 TT: 2413 02000 /BUFFER # 03 TT: 2413 02000 /BUFFER # 04 TT: 2413 02000 /BUFFER # | <u>Title</u>: Asynchronous Buffer Configuration. Objectives: Upon sucessful completion of this lesson, students will be able to: - Set the AMLBUF configuration directives to minimize wired memory. #### Task: In groups of four, given a description of a system's configuration, define the CONFIG file directive AMLBUF. <u>Conditions</u>: Using any available course documentation. ## Evaluation Standard: Completion of the entire exercise. Class review of the exercise will ensure correct answers. #### The system: ``` - 750 processor - 8 MB memory - one 16 line QAMLC board - one ICS1 board - the terminal lines are as follows 00 9600 baud PT45, FORMS application 9600 baud PT45, FORMS application 01 02 9600 baud PST100, FORMS application 03 9600 baud PST100, FORMS application 04 unused 05 1200 baud modem line 06 1200 baud modem line 07 300 baud modem line 10 9600 baud PST100 11 300 baud QUEM letter qua 12 9600 baud PST100 terminal 300 baud QUEM letter quality printer 13 9600 baud PST100 terminal 14 9600 baud PST100 terminal 15 9600 baud PST100 terminal 9600 baud PRINTRONIX printer 16 17 unused 20 9600 baud PST100 terminal 9600 baud PST100 terminal 21 22 9600 baud PST100 terminal ``` 9600 baud PST100 terminal 1200 baud hardcopy terminal 9600 baud PRINTRONIX printer 1200 baud NEC letter quality printer 23 24 25 26 27 unused Here are the completed AMLC commands for all 24 asynchronous lines. The NTUSR and NAMLC arguments are specified. ``` / 9600 BAUD - FORMS APPLICATION AMLC 00 TTY 2413 020002 / 9600 BAUD - FORMS APPLICATION AMLC 01 TTY 2413 020003 / 9600 BAUD - FORMS APPLICATION AMLC 02 TTY 2413 020004 / 9600 BAUD - FORMS APPLICATION AMLC 03 TTY 2413 020005 / UNUSED LINE AMLC 04 TTYNOP 0 020000 / 1200 BAUD MODEM AMLC 05 TTY 2313 020006 / 1200 BAUD MODEM AMLC 06 TTY 2313 020007 / 300 BAUD MODEM AMLC 07 TTY 2313 020010 020011 / 9600 BAUD AMLC 10 TTY 2413 / 300 BAUD QEM PRINTER AMLC 11 TTYNOP 2213 020000 / 9600 BAUD AMLC 12 TTY 2413 020012 / 9600 BAUD AMLC 13 TTY 2413 020013 / 9600 BAUD AMLC 14 TTY 2413 020014 AMLC 15 TTY 2413 020015 / 9600 BAUD / 9600 BAUD PRINTRONIX PRINTER AMLC 16 TTYNOP 2413 020000 /UNUSED, BAUD RATE 300 AMLC 17 TTYNOP 2213 020000 / 9600 BAUD AMLC 20 TTY 2413 020016 / 9600 BAUD AMLC 21 TTY 2413 020017 / 9600 BAUD AMLC 22 TTY 2413 020020 / 9600 BAUD AMLC 23 TTY 2413 020021 / 1200 BAUD NEC PRINTER AMLC 24 TTYNOP 2313 020000 / 1200 BAUD HARDCOPY TERMINAL AMLC 25 TTY 2313 020022 / 9600 BAUD PRINTRONIX PRINTER AMLC 26 TTYNOP 2413 020000 020000 / UNUSED AMLC 27 TTYNOP O NTUSR 22 (Octal) NAMLC 4 (Octal) ``` 1) The %CPU averages 90.00% and the PF/S averages 6.00. SET THE DMG BUFFER SIZES ACCORDINGLY. AMLC Baud Rate should be \_\_\_\_\_, making the CTI \_\_\_\_\_. The ICS INTRPT should also be set. See the Sys Admin Guide for the appropriate value. | /*<br>AMLBUF | line_number<br>00 | default<br>O | default<br>O | dmq_buffer_size | |--------------|-------------------|--------------|--------------|-----------------| | AMLBUF | 01 | 0 | 0 | | | AMLBUF | 02 | 0 | 0 | | | AMLBUF | 03 | 0 | 0 | | | AMLBUF | 04 | 0 | 0 | | | AMLBUF | 05 | 0 | 0 | | | AMLBUF | 06 | 0 | 0 | | | AMLBUF | 07 | 0 | 0 | | | AMLBUF | 10 | 0 | 0 | | | AMLBUF | 11 | 0 | 0 | | | AMLBUF | 12 | 0 | 0 | | | AMLBUF | 13 | 0 | 0 | | | AMLBUF | 14 | 0 | 0 | | | AMLBUF | 15 | 0 | O | | | AMLBUF | 16 | 0 | 0 | | | AMLBUF | 17 | 0 | 0 | | | AMLBUF | 20 | O | 0 | | | AMLBUF | 21 | O | 0 | | | AMLBUF | 22 | O | 0 | | | AMLBUF | 23 | o | O | | | AMLBUF | 24 | 0 | O | | | AMLBUF | 25 | o | 0 | | | AMLBUF | 26 | o | 0 | | | AMLBUF | 27 | O | 0 | | Specify the AMLBUF commands for the input and output terminal buffers. ``` /* AMLBUF commands setting terminal buffers /* buffer_number = user_number - 2 buffer_number input_buffer output_buffer 00 AMLBUF 01 AMLBUF 02 AMLBUF 03 AMLBUF AMLBUF 04 05 AMLBUF AMLBUF 06 07 AMLBUF 10 AMLBUF AMLBUF 11 AMLBUF 12 AMLBUF 13 AMLBUF 14 15 AMLBUF AMLBUF 16 17 AMLBUF AMLBUF 20 ``` 3) Specify the AMLBUF commands for the assigned line input and output buffers. ``` /* AMLBUF assignments for assigned lines /* The first assigned buffer number = NTUSR - 1 (NRUSR = 0) /* There is a pool of NAMLC lines ``` 4) The %CPU averages 60.00% and the PF/S averages 15.00. SET THE DMQ BUFFER SIZES ACCORDINGLY. AMLC Baud Rate should be \_\_\_\_\_, making the CTI \_\_\_\_\_. The ICS INTRPT should also be set. See the Sys Admin Guide for the appropriate value. | /*<br>AMLBUF | line_number<br>00 | default<br>O | default<br>O | dmq_buffer_size | |--------------|-------------------|--------------|--------------|-----------------| | AMLBUF | 01 | 0 | O | | | AMLBUF | 02 | 0 | O | | | AMLBUF | 03 | 0 | O | | | AMLBUF | 04 | 0 | O | | | AMLBUF | 05 | 0 | O | | | AMLBUF | 05 | 0 | 0 | | | AMLBUF | 07 | 0 | 0 | | | AMLBUF | 10 | 0 | O | | | AMLBUF | 11 | 0 | 0 | | | AMLBUF | 12 | 0 | 0 | | | AMLBUF | 13 | 0 | 0 | | | AMLBUF | 14 | 0 | 0 | | | AMLBUF | 15 | O | 0 | | | AMLBUF | 16 | 0 | O | | | AMLBUF | 17 | 0 | O | | | AMLBUF | 20 | 0 | 0 | | | AMLBUF | 21 | 0 | O | | | AMLBUF | 22 | 0 | 0 | | | AMLBUF | 23 | 0 | 0 | | | AMLBUF | 24 | 0 | 0 | | | AMLBUF | 25 | o | 0 | | | AMLBUF | 26 | o | 0 | | | AMLBUF | 27 | 0 | 0 | | Lesson 12 - Tuning the Scheduler Objectives: Upon successful completion of this section, students will be able to: - Be able to use CHAP to effectively reward or punish a process relative to the remaining processes on the system. - Set ELIGTS to optimize throughput vs. response time appropriate to a systems's application mix. # Tuning the Scheduler - o The basic objectives of tuning the scheduler are as follows: - Punishing or rewarding a process or group of processes in relation to other processes on the system. The CHAP command allows this. - Setting an execution environment to favor either more interactive or more compute bound processes. ELIGTS is used for this purpose. ## The CHAP Command CHAP is used to change the priority level and major time-slice of a process. CHAP has two versions, one must be issued at the system console, and the other is a user version. Here is the system console version: {-userno} {priority [time-slice]} CHAP {-IDLE} {ALL} {-SUSPEND} > Is in the form -nn or ALL. userno Integer 0 to 3 (default = 1). priority Put process(es) into the IDLE state. -IDLE argument will only work on phantom processes. Put process(es) into the SUSPEND state. -SUSPEND Length of major time-slice in tenths of time-slice seconds. O means reset to the system default (2 sec.) If omitted the time-slice is unchanged. If both priority and timeslice are omitted, then priority and time-slice are set to the system default values. Here is the user version: (UP) CHAP {DOWN} {LOWER nn [time-slice]} {IDLE} > Sets user level to the default level. UP Sets user level to 0. DOWN Sets user level down by nn. LOWER Sets major t/s to the value specified. This time-slice will only set the value lower than the current value. Sets user level to IDLE. Can only be issued IDLE from a phantom. # Rewarding and Punishing Processes - o PRIORITY When changing a process's priority, you should consider: - Priority determines which user level on the Ready List the process will go on when NOTIFYed. This is important because a process with a higher priority will ALWAYS pre-empt a lower priority process IMMEDIATELY. - Most semaphores are threaded in priority order. This means if two processes are waiting for the same resource, the higher priority process will be given access to that resource first. - Priority determines which LOPRIQ the process goes on when the major timeslice expires. This affects the time it takes for the process to be NOTIFYed back to the ready list. - o MAJOR TIMESLICE When changing a process's major timeslice, you should consider: - Altering major timeslice has the most effect on compute bound processes (those processes using more than 4 seconds of CPU). It has little if any effect on interactive processes (although it can have a large effect if made short enough). - Altering the major timeslice has the most effect in compute environments. It has little if any effect when there are very few compute bound processes. - Every time you reach a point in a program which asks for character input, you have both your major and minor timeslices reset. - NOTE: If the major timeslice is set to 177777, this will cause SCHED to execute a return when called. Thus, when a minor timeslice end occurs, SCHED will not execute a WAIT on any of the hold queues. This will give unlimited access to the CPU. To prevent the system console from being trapped on a hold queue by a process with a 177777 timeslice, user #1 is also given the same timeslice. # Rewarding or Punishing Processes - con't o To punish a process: | | | SYST<br>compute bound | EM<br>interacti∨e | |---------|-----------------------|--------------------------------|--------------------------------| | PROCESS | compute l'<br>bound l | lower priority lower major t/s | lower priority lower minor t/s | | int | eractive | lower priority | lower priority | o To reward a process: | To reward a process | SYSTEM compute bound | 1<br>interacti∨e | |-------------------------|----------------------------------|-----------------------------------| | PROCESS compute bound | raise priority raise major t/s | raise priority<br>raise minor t/s | | interactive | raise priority | raise priority | # Tuning for Response Time vs. Throughput o <u>ELIGTS</u> - ELIGTS is used to modify the minor time-slice from the system console. This will effect all users equally. ELIGTS {minor\_timeslice} (default = 3/10 sec.) - o MINOR TIMESLICE When changing the minor timeslice, you should consider: - Changing the minor timeslice will allow you to improve either response time or throughput, but at the expense of the other. Lowering the timeslice will cycle more processes through the CPU in a given amount of time, and each process will have to wait less time to execute. However, process exchange overhead will increase, and each process will be able to do less of it's work before being put on ELIGQ. Obviously, the reverse is also true. - Decreasing the minor timeslice can be useful in CPU bound systems to give better response time to interactive users. - When you lower the minor timeslice, you are changing the system's definition of an interactive user. Some tasks which used to finish in one shot at the CPU may take two or three. Therefore some "interactive" processes may actually have worse response time. - A very memory intensive application may find that it cannot get it's working set in memory before it runs out of minor timeslice, if paging is heavy and minor timeslice is set low enough. This process will drive system paging higher and will have very bad throughput. # Tuning for Response Time vs. Throughput - con't - o Interactive environments which may benefit from a decrease in ELIGTS: - word processing - data entry - EMACS, editing - transaction processing - o Compute bound environments which may benefit from an increase in ELIGTS: - CAD (3D modeling) - array processing - advanced math (number crunching) - program compilations - report processing - graphics CE1025 - SADS32 USAGE Lesson 13 - USAGE and Related Tuning Topics Objectives: Upon successful completion of this section, students will be able to: - Using USAGE, effectively monitor the system such that a valid sample of system performance is obtained. - Be able to describe what any given field on a standard USAGE report is measuring. - Determine, from information given in USAGE, when a hardware upgrade is needed. - Identify a memory bottleneck using information given in USAGE, and suggest methods of eliminating it. - Given a list of CONFIG directives, identify those that affect wired memory. - Identify a CPU bottleneck on a system, identify the cause of the bottleneck, and suggest ways of eliminating the bottleneck. - Determine the optimal value of MAXSCH for a given system, based on information given in USAGE, such that the CPU will be fully utilized, and yet page thrashing will be effectivly throttled. - Identify an I/O bottleneck on a system, identify the cause of the bottleneck, and suggest ways of eliminating it. - Set the NLBUF directive to the optimal value for a system, based on information given in USAGE. - Optimize disk seek time, through eliminating fragmentation, optimizing the use of overlapped seeks, and large partitions. - Correctly configure disks and controllers for maximum I/O efficiency. # System Tuning Overview - o In order to successfully tune a system, you must do the following: - 1) Determine the configuration and workload on the system. - 2) Gather information which will indicate how the system is performing. - Analyze the information, and determine what, if any, problems exist on the system. - 4) Recommend possible solutions to the identified problems. # 1 - Identifying Workload - o Information which should be gathered prior to the monitoring: - Hardware configuration. - A. CPU - B. Memory - C. Controllers - D. I/O devices - II. Software configuration. - A. CONFIG file - B. PRIMOS. COMI file - C. PRIMOS Rev. - III. Workload. - A. Summary of applications - B. Operating shifts of users/applications - C. Observed response times - D. Observed throughput times - E. Any observed bottlenecks #### 2 - Monitoring the System - o USAGE is a system metering tool. It can be used by any user at any terminal. The information it generates describes the status and performance of the CPU, main memory, disk subsystems, and other system internals. A sequence of one or more USAGE samples can be generated automatically or manually. - o The format of the USAGE command is: USAGE [options] Some of the more useful options are: - -ALL Display all information, including system, user, and disk - -FREQ n Will generate a sample every n seconds - -TIMES n Will take n samples # <u>USAGE</u> | 05 Aug 85 13:2<br>Up since 05 Au | 9:51.50<br>ig 85 07:3 | dTIME=<br>3:04 Mon | 59.87<br>day ( | CPU=<br>CPUtot= | 47. 00<br>6216. 94 | I/O=<br>I/Otot= | 11. 67<br>4472. 34 | |----------------------------------------------|-------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | %CPU %Id1<br>78.50 14.6 | | | | | | PF/S<br>3. 01 | | | %Clock %FN<br>1.26 0.0 | | | | | | | | | %AMLC %Asyr<br>1.55 0.0 | | | | | _ | Used<br>8190 | Wired<br>480 | | Locate %Mis<br>15748 2.0 | | | | e Loc/S<br>8 263.05 | | | | | Disk Qwait<br>604 | ts %Qwait<br>0 0.00 | | | _ | | | | | | Mem Wire 3455 401 62 1 608 1 58 1 14 1 30 1 35 1 40 1 114 1 11 0 100 1 100 1 100 1 100 1 24 1 48 1 41 1 25 1 53 1 | 209<br>23<br>43 5<br>18<br>18<br>16<br>14<br>19<br>22<br>3<br>11<br>11<br>11<br>11<br>11<br>2<br>12<br>12<br>12 | PUtime<br>97.800<br>55.254<br>87.578<br>31.930<br>14.145<br>56.106<br>11.623<br>16.788<br>6.865<br>4.014<br>49.269<br>49.907<br>16.022<br>234.703<br>5.318<br>74.847<br>277.076<br>6.686 | 0. 086<br>0. 286<br>36. 885<br>1. 463<br>0. 309<br>0. 233<br>0. 206 | 0. 144<br>0. 477<br>1. 611<br>2. 444<br>0. 517<br>0. 390<br>0. 344<br>3. 094<br>0. 530<br>0. 147<br>0. 556<br>0. 159<br>1. 565<br>1. 695<br>0. 027<br>0. 833 | I/Otime<br>255.736<br>43.664<br>105.832<br>7.812<br>6.708<br>44.984<br>13.872<br>16.412<br>6.352<br>8.384<br>60.148<br>59.392<br>67.212<br>7.488<br>0.824<br>172.044<br>405.304<br>2.476 | d1/0 %1/0 0.420 0.702 2.004 3.347 3.352 5.599 0.000 0.000 0.000 0.000 1.148 1.918 0.112 0.187 2.464 4.116 0.016 0.027 0.084 0.140 0.620 1.036 0.164 0.274 0.088 0.147 0.088 0.147 0.036 0.060 0.000 0.000 0.588 0.982 0.000 0.000 0.156 0.261 | | | t %Count | Time %U | | otal Tot | al Avg t | | | | '26 261<br>0 205<br>1 56<br>'27 343<br>0 189 | 43. 21<br>33. 94<br>9. 27<br>56. 79<br>31. 29 | 5. 34 4<br>4. 35 7<br>0. 99 1<br>6. 33 2<br>3. 96 | 3. 46 7<br>7. 27 7<br>1. 66<br>2. 64 2<br>5. 61 1 | 9. 67 0.<br>20. 16<br>.6. 29 1. | 42 18.9<br>88 18.8<br>50 19.0<br>40 22.0 | :2<br>:5 | | | 1 152<br>2 1<br>3 1 | 0.17 | 0. 01 | 0. 01 | 0. 04 0. | 00 11.1 | 8 | | CE1025 - SA0S32 USAGE # Monitoring the System - con't o. How long should the samples be? How long a sample to take depends entirely on what you will do with it. Here are some examples: 30 secs. Good for taking a quick look at what's going on. Although this is the shortest recommended length, if you are interested in CPU, you probably could use 15 secs. If you are monitoring disk, 60 to 120 secs would be better. 60 secs. Good for a quick look at disk utilization. 5 min. For monitoring a longer period of time (i.e. a day), this would be about the maximum granularity you would want. This is also good for monitoring a particular application. 15 min. For monitoring long periods, this is a very good granularity. 60 min. For monitoring over days or weeks, this is probably adequate, although you may want to monitor certain times more closely. o How long should you run samples? To do a full monitoring, you should run samples long enough to cover a full "cycle of activity". This would include a representitive sample of EVERYTHING that is done on your computer. ### 3 - Analyzing Data - o Here are the steps involved in analyzing data: - 1) Identify average values for all the major performance meters. - 2) Identify any peaks or valleys. - 3) Identify any indicators which exceed certain "critical" values. - 4) Identify any major changes from data collected previously (if available). - 5) Identify problems or situations which could account for the collected data. # 4 - Recommending Solutions - o The two main problems which need to be addressed: - I. Response time. - II. System throughput. These are the two most noticed by users, and therefore should be used as the base indicators of system performance. First, they should be defined: Response Time - The amount of time it takes once a command is issued for the computer to respond. <u>System Thoughput</u> — The number of specific tasks which the computer can do in a given amount of time. - o The person performing the tuning should decide which of these is most important to overall performance, as improving one may sometimes degrade the other. All solutions should contain a prediction as to the impact on these two parameters. - A method of presenting solutions should be picked which will result in easy to read, statistically backed recommendations. - o Recommendations can be: - Hardware reconfiguration - Software reconfiguration - Administrative changes - Reprogramming the software - o With all recommendations, you should include a <u>prediction</u> of the effect which the change will have. For your own protection, be CONSERVATIVE. # This Page for Notes # USAGE - CPU Meters | 05 Aug 8<br>Up since | 35 13:2<br>• 05 Au | 29:5<br>19 B | 1.50<br>5 <b>0</b> 7: | dTIME<br>33: 04 | = 5<br>Monda | 9. 87<br>Y | CPUt | PU=<br>ot= | | 47. 0<br>216. 9 | | I/O=<br>Otot= | 11. 4<br>4472. 3 | | |---------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------|---------------|------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------| | %CPU<br>78. 50 | %Idl<br>14.8 | | %Id1:<br>O. O | | ror<br>2.65 | %I /<br>3. <b>2</b> | | %0v1<br>23. 8 | | ID/<br>10. 0 | | PF/S<br>3. 01 | | | | %Clock<br>1.26 | %FN<br>0. 0 | | %MP(<br>0. 0 | | (PNC<br>). 33 | %SL<br>0. 5 | | %GPP<br>0. 0 | | %DS<br>0. 1 | | | | | | %AMLC<br>1.55 | %Asyn<br>0.0 | | %Syn<br>0. 0 | | 11CS<br>0. 00 | Seg<br>281 | | Use<br>162 | | Page<br>819 | | Used<br>8190 | Wired<br>480 | | | Locate<br>15748 | %Mis<br>2.0 | | %Found<br>75.19 | | Same<br>2. 66 | %Shat<br>0. 0 | | Loc/<br>863. 0 | | LM/:<br>5. 4 | | | | ··· | | Disk<br>604 | Qwait | 0 | Qwai<br>O.O | | 7V0V<br>0 | %DMAc | | Hang | s<br>O | %Han<br>0. 0 | | | | | | UST USET 1 SYST 14 SGW 29 AMS 41 JOHA 55 DONA 68 BUD. 79 LARE 87 MARI 93 RICH 102 SLAV 107 SYST 110 SYST 111 SYST 113 NETM 114 RT S 116 FTP 117 FTPX 122 DAVE | TEM 3 ANNA. C ALD K Y C ALC I A. C I C E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M T E M | Mem<br>455<br>608<br>58<br>14<br>30<br>35<br>40<br>114<br>1100<br>100<br>24<br>48<br>41<br>25<br>53 | Wire<br>401<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1 | Segs<br>209<br>23<br>43<br>18<br>16<br>14<br>19<br>22<br>3<br>11<br>11<br>11<br>4<br>9<br>12<br>12<br>8 | 97<br>55<br>587<br>31<br>14<br>56<br>11<br>16<br>49<br>49<br>116<br>234<br>5<br>174<br>277 | time<br>.800<br>.254<br>.578<br>.930<br>.145<br>.106<br>.623<br>.788<br>.865<br>.014<br>.269<br>.907<br>.022<br>.703<br>.318<br>.847<br>.076 | 0.<br>0.<br>36.<br>1.<br>0.<br>0.<br>0.<br>0.<br>0.<br>0. | CPU<br>086<br>286<br>885<br>463<br>309<br>233<br>206<br>852<br>317<br>088<br>333<br>095<br>937<br>015<br>016<br>499<br>698<br>530 | 0.<br>0.<br>61.<br>2.<br>0.<br>0.<br>0.<br>0.<br>0.<br>0.<br>1.<br>1.<br>0. | CPU<br>144<br>477<br>611<br>444<br>517<br>390<br>344<br>094<br>530<br>147<br>556<br>159<br>565<br>695<br>027<br>833<br>167<br>886 | 255.<br>43.<br>105.<br>7.<br>6.<br>44.<br>13.<br>16.<br>6.<br>8.<br>60.<br>59.<br>67.<br>7.<br>0.<br>172.<br>405. | | dI/D 0. 420 2. 004 3. 352 0. 000 0. 000 1. 148 0. 112 2. 464 0. 016 0. 084 0. 620 0. 164 0. 088 0. 036 0. 000 0. 588 0. 000 0. 156 | %1/0<br>0.702<br>3.347<br>5.599<br>0.000<br>0.000<br>1.918<br>0.187<br>4.116<br>0.027<br>0.140<br>1.036<br>0.274<br>0.147<br>0.060<br>0.982<br>0.000<br>0.261 | | Disk | Count | %C | ount | Time | %Uti | | otal<br>ount | | | Avg (ms | | | | | | '26<br>0<br>1 | 261<br>205<br><b>5</b> 6 | | 21<br>94<br>27 | 5. 34<br>4. 35<br>0. 99 | 4. 4<br>7. 2<br>1. 6 | 7 7 | 9. 84<br>0. 17<br>9. 67 | 6 | | 18. ° | | | | | | '27<br>0<br>1<br>2<br>3 | 343<br>189<br>152<br>1 | 31.<br>25.<br>0. | 79<br>29<br>17<br>17 | 6. 33<br>3. 96<br>2. 35<br>0. 01<br>0. 02 | 2. 6<br>6. 6<br>3. 9<br>0. 0 | 1 1<br>2<br>1 | 0. 16<br>6. 29<br>3. 78<br>0. 04<br>0. 04 | 1<br>0<br>0 | . <b>5</b> 0<br>. 40<br>. 00 | 11. | 00<br>18 | | | | #### CPU Meters - con't o %Idl1, %Idl2 %Idl is the best overall indicator of how busy your CPU is. It measures the amount of CPU used by the backstop process. Since the Backstop only runs when the ready list is empty, any amount of time here is unused CPU. o %CPU, CPU This is the amount of CPU used by all USER processes. o CPUtime, dCPU, %CPU These meters tell for each user the amount of CPU used since login, during the sample, and as a percentage of the delta time. o %Clock - %ICS These meters report the amount of CPU used by the various interrupt processes. %Clock The clock process is usually the highest priority process on the Ready List. This means that it will always execute when put on the ready list. It is NOTIFYed via hardware at a very regular interval (usually 1/330 sec). It's only purpose is to increment a number of timers, and NOTIFY other processes if work needs to be done. It should take about .25 - 2% on large systems, and 1 - 6% on smaller systems. - o %AMLC These processes are the asynchronous driver processes. %Async %AMLC is the for the AMLC boards and %Async is for the ICS boards. The sum of these two should be no more than 10%. - This is the amount of error in the sample. Error can be accounted for by the fact that certain events such as process exchange, DMx, interrupts, etc cannot be charged to any process. Also, CPU meters are kept in micro-seconds whereas the USAGE meters are in milli-seconds, so there is time lost due to rounding errors. This value may be positive or negative. The range should be about $-1\,-\,3\%$ , perhaps higher on smaller machines. ## CPU Bottleneck # SYMPTOMS: - %Idl1 is low ( < 5% ) - %CPU is less than 70% - High % for a system process (%AMLC, %Async, %DSK, etc) - Response time is very poor - Throughput is poor, especially CPU intensive jobs ## SUSPECTED PROBLEM: - Improper configuration. - Bad controller (spurious interrupts). # SOLUTIONS: - If %AMLC or %Async too high: - 1) Check baud rate of last line on last AMLC board. - 2) Check ICS INTRPT directive for ICS boards. - NOP unused and non-assigned lines. - 4) Attempted high speed input. - 5) Check all devices for garbage characters. - Check controller with high % for problems. # CPU Bottleneck - con't #### SYMPTOMS: - o %IDL1 is low ( < 5% ) - o %CPU is high ( > 90% ) - o Response time is very poor - o Throughput is poor, especially CPU intensive jobs # SUSPECTED PROBLEM: o CPU saturated # SOLUTIONS: - o On older machines, make sure interleaving and wide-word is turned on (if possible). - o Using the %CPU figure for each user, figure out which processes are using the most CPU. - If feasible, rewrite CPU intensive software to be more efficient. - If feasible, reschedule CPU intensive processes to a non-busy time. - Use CHAP or ELIGTS command to reorder process execution to favor either throughput or response time. - o CONFIG changes: - Set ICS INTRPT to '12. - Set last line on AMLC to 110 baud. - o Upgrade CPU. # <u>USAGE - Virtual Memory Meters</u> | | | 51.50 dT]<br>B5 07:33:0 | ME= 59.8<br>04 Monday | | = 47.00<br>= 6216.94 | | | |-----------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|------------------------------------------------------|-----------------------|----------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | %CPU<br>78. 50 | %Idl1<br>14.85 | %Id12 %<br>0.00 | | | vlp IO/9<br>.85 10.09 | | | | %Clock<br>1.26 | %FNT<br>0. 00 | %MPC<br>0. 00 | | | PPI %DS | | | | %AMLC<br>1.55 | %Async<br>0.00 | %Sync<br>0.00 | | | sed Page:<br>622 8192 | | Wired<br>480 | | Locate<br>15748 | %Miss<br>2.07 | %Found<br>75.19 | | hare Lo<br>0.08 263 | | | | | Disk<br>604 | Qwaits<br>O | %Gwait I<br>0.00 | | MAovr Ha<br>D. 00 | ngs %Hang<br>0 0.00 | | | | UST USETI 1 SYSTE 14 SGW 29 AMS 41 JOHAN 55 DONAL 68 BUD. K 79 LARRY 87 MARIA 93 RICH. 102 SLAVE 107 SYSTE 113 NETMA 114 RT_SE 116 FTP 117 FTPX 122 DAVE. | M 345: 600 NA. C 56 D 11- 300 . G 300 . C 40 D 11- \$ 1 M 100 M 100 M 100 N 20 RVER 40 | 2 1 2 1 2 1 2 1 2 1 2 1 1 1 1 1 1 1 1 1 | | 0. 086 4 0. 286 8 36. 885 0 1. 463 5 0. 309 6 0. 233 0. 206 8 1. 852 5 0. 317 4 0. 088 9 0. 333 7 0. 095 2 0. 937 3 1. 015 8 0. 499 6 0. 698 | 0. 144 25 0. 477 61. 611 10 2. 444 0. 517 0. 390 0. 344 3. 094 0. 530 0. 147 0. 556 0. 159 1. 565 1. 695 0. 027 0. 833 1. 167 | 55. 736 0<br>43. 664 2<br>5. 832 3<br>7. 812 0<br>6. 708 0<br>44. 984 1<br>13. 872 0<br>16. 412 2<br>6. 352 0<br>8. 384 0<br>50. 148 0<br>57. 212 0<br>7. 488 0<br>0. 824 0<br>72. 044 0<br>05. 304 0 | dI/D %I/D<br>. 420 0. 702<br>. 004 3. 347<br>. 352 5. 599<br>. 000 0. 000<br>. 148 1. 918<br>. 112 0. 187<br>. 464 4. 116<br>. 016 0. 027<br>. 084 0. 140<br>. 620 1. 036<br>. 164 0. 274<br>. 088 0. 147<br>. 036 0. 060<br>. 000 0. 000<br>. 588 0. 982<br>. 000 0. 000<br>. 156 0. 261 | | Disk<br>'26<br>O<br>1 | 261 4:<br>205 3: | Count Tim<br>3.21 5.3<br>3.94 4.3<br>9.27 0.9 | 34 4. 46<br>35 7. 27 | %Count<br>79.84 | Total Avg 7<br>%Util (ms)<br>6.42 18.9<br>0.88 18.9 | PC) | | | ′27<br>0<br>1<br>2<br>3 | 189 3<br>152 2 | 6. 79 6. 3<br>1. 29 3. 5<br>5. 17 2. 3<br>0. 17 0. 0 | 76 6.61<br>35 3.92 | | 1.50 19.6<br>0.40 22.6<br>0.00 11. | 00 | | # Virtual Memory Meters - con't o Segs, Used - VIRTUAL These two fields tell how many segments, or more specifically, Page Map Tables (PMTs) can be allocated, and how many PMTs are actually in use. Segs is NSEG + NVMFS, except that it cannot be greater than \$172. If Used approaches Segs, users will shortly be getting NO\_AVAIL\_SEG\$ raised at location ...... If this occurs, you must do at least one of the following: - increase NSEG. - have users logoff, ICE, or DELSEG. - decrease the command breadth for all users. - find out (from USAGE) who is using all the segments, and log that user off. - o Pages, Used, Wired \ PH 151CAL These three fields tell how many pages of physical memory are in your system, how many are being currently used, and how many have been wired (i.e. these pages cannot be paged out to disk). Used will often be very close to Pages. Wired should be roughly about 8 - 15% of the total. If you attempt to reduce wired memory, the wired field is a very good way to measure your success. o Mem, Wire, Segs (per user) Mem tells the number of physical pages each user owns at the end of a sample. If the system is paging fairly heavily, Mem can approximate the working set required for an application. Wire tells how many physical pages this user has wired in memory. This is fairly useless as it only records those pages in DTARs 2 & 3 (segments between 4000 and 7777). Each user will have 1 page wired in segment 6000 for their wired stack. All other pages wired in DTARs 0 & 1 are charged to SYSTEM. Segs reports the number of PMTs belonging to each user at the end of the sample. If you are running out of segments, this field can pin-point the user(s) who are using the virtual address space. CE1025 - SADS32 USAGE # Memory Bottleneck # SYMPTOMS: - %Idl1 is high ( > 15% ) - PF/S are high (6 15) - %Util on paging disks is high ( > 60% ) - %Miss is average or low - Response time is fair to poor, especially when invoking programs - Throughput is poor, especially programs which require large amounts: of memory. ## SUSPECTED PROBLEM: - Page thrashing. #### SOLUTIONS: - Reduce PRIMOS working set (adjust CONFIG, PRIMOS.COMI). - Redistribute paging (using PAGDEV, ALTDEV, and PRATIO) to non-busy controllers / drives to reduce I/O bottleneck. - Reduce MAXSCH (covered later in chapter). - Determine memory hogs and modify to reduce working set. - Convert static programs to EPFs. - Add memory. # Reducing Wired Memory - o Wired memory is main memory which cannot be paged to disk by the paging software. The more memory that is wired on the system, the less is available for the working set of the applications on your system. Thus, if your system is paging heavily, any and all pages which you can make available will help the situation. - 1 page of memory is 2048 bytes or 1024 ('2000) words (16 bits). NOTE: Typically, if a system is correctly configured, fine tuning with regard to wired memory will usually have a negligible effect. In some borderline cases however, the 10 - 20 pages you save may make the difference between thrashing or not thrashing. - o Why does memory get wired? - 1) Wired memory is required by the hardware configuration of the system. For example: - Each async line requires a wired DMG buffer. - Each ICS board requires buffers for ROIPQNM. - Each controller present requires a corresponding process (DIMs), and the code for these must be wired. - 2) A certain amount of wired memory is required by PRIMOS, and this amount varies depending on the Rev. For example: - Many PRIMOS routines (such as PAGTUR) must be wired. - The interrupt handling code (Phantom Interrupt Code) must be wired. - The Ready List must be wired. - A certain number of Disk Request Blocks must be wired (this is Rev dependent). #### Wired Memory - CONFIG Directives 3) Wired memory is required depending on how the system is configured. This applies both to the CONFIG directives, plus the different software products installed. Here is a list of all the CONFIG directives that wire memory, and what that memory is used for: # NTUSR, NRUSR, NPUSR, NSLUSR These four directives create processes. Each process will have a '100 word Process Control Block wired. ## SMLC DN, SMLC CNTRLR, SMLC (or SYNC) Each of these directives will wire down a DIM process, plus the minimum buffers needed to communicate with the devices. ## **NVMFS** NVMFS creates a table in memory called the Active Segment Table. Each entry in this table is 28 words in size. Thus, making the table 1024 entries will wire 28 pages. #### VPSD This directive wires the V mode Prime Symbolic Debugger in memory, so that it can be used. This wires about 4 pages of memory. #### NLBUF This directive allocates the number of LOCATE buffers. It will immediately wire a 22 word Buffer Control Block for each buffer. In addition, although LOCATE buffers are allocated dynamically, they tend to be virtually wired, and thus unavailable for program working sets. # Wired Memory - CONFIG Directives - con't AMLBUF, REMBUF, ASRBUF - SINCE WE ARE SUTTION AROUND A GOT ANY WAYAR MESTERNAL ON RESIDENCE These three directives wire terminal buffers. They have the largest potential for wasting wired memory. To configure these buffers correctly, you should refer to the documentation, or take one of the courses offered on system administration. #### AMLIBL, ICS INPOSZ AMLIBL configures the size of the tumble table buffers, which are used for character input from the AMLC controllers. There is one tumble table per AMLC board. ICS INPGSZ performs the same function for ICS boards. There are two tables per eight lines. # LOUTOM These directives affect wired memory in that they will force logout processes which exceed inactive or elapsed time limits. This is important since logged—in processes do require wired memory for their SDT, RO wired stack, PMTs, etc. CE1025 - SAOS32 USAGE #### <u> Wired Memory - Product Requirements</u> - 4) Wired memory required by system use. Every product which is installed, and every user which logs onto the system, will cause memory to be wired down. Here are some instances: - Every product which is installed has the potential of using wired memory. In particular, every product which is installed using the SHARE command will allocate and wire down memory for the PMTs. Therefore, do not SHARE products unless you intend on using them. #### Examples: ``` MIDASPLUS - 4 pages ROAM - 2 pages PRISAM - 1 page INFORMATION - 6 pages OAS - 3 pages EMACS - 2 pages CBL - 3 pages PRIMENET - 43 pages /* with 30 nodes configured ``` Here are some other products with wired memory requirements: #### - Networks Depending on how many nodes are configured, and whether you have full duplex, ring net, etc. you will wire approx 20 - 100 pages of memory for the data base. A smaller configuration will help keep this at a minimum. - Data Base Products Both ROAM and MIDASPLUS now have their own disk block buffering system. Although this will not cause memory to be wired directly, these buffers will be virtually wired when the products are used, and thus unavailable for application working sets. #### - PRIMIX Due to the way PRIMIX creates child processes, PRIMIX tends to have a large impact on virtual memory requirements, especially PMTs. # <u> Wired Memory - System Usage</u> - o For each user who logs onto the system, the following memory in wired: - SDTs - 1 page in segment 6000 - PMTs for each segment used PMTs represent most of the wired memory requirements. Therefore, some things to know about PMTs: - DELSEG, ICE, and LO deletes PMTs and releases all pages associated with the segment. - EPFs will release PMTs when they are removed. - EPFs share PMTs for procedure, and therefore require less system memory. - o On the average, each user who logs in will require 3 6 wired pages. CE1025 - SADS32 USAGE BACKSTOP Flowchart - Re-visited #### MAXSCH o MAXSCH is a throttle on the number of processes competing for disk resources. The reason is to prevent page thrashing (where all processes are paging out each others working set). It does this by summing the following semaphores: PAGSEM — # of processes waiting for pages in transition. LOCSEM — # of processes waiting for a BCB (LOCATE). (DSKBLK — DSKQCT) — # of processes waiting for a disk I/O. UFDLOC — # of processes accessing a UFD. UTLOC — # of processes accessing a unit table. RATLOC - # of processes accessing a DSKRAT. The sum of these semaphores is then compared to the value MAXSCH. If the sum is greater, the backstop process will not service the ELIGQ, LOPRIGS, or the IDLEQ. o Starting at Primos revision 19.0 MAXSCH is calculated as follows: $MAXSCH = (megabytes_of_memory + 3) * x + y$ where, x is 1.2 if there exists an alternate device on a different controller than the primary device, otherwise it is 1. y is 1 if CPU is a P850, otherwise it is 0. o The optimal value of MAXSCH is application dependent, hence there is no hard and fast formula to determine its value. Therefore, it is a operator command. rule of thumb: MAXSCH = Physical-Memory-Size - PRIMOS-locked-memory average-job-size CE1025 - SADS32 USAGE ### Tuning MAXSCH - Symptoms of MAXSCH being set too low: - %Idl1 is high ( > 15% ) - PF/S are avg or low for your system ( < 5 on small systems, < 10 on large systems)</li> - o By increasing MAXSCH, you should see %Idl1 decrease (you are making it easier for processes to get out of the hold queues and back on the Ready List). As long is %Idl1 decreases, you are doing some good. PF/S should increase slightly if at all. At some point, PF/S may increase dramatically, and %Idl1 will also increase. You are now thrashing, and you should back MAXSCH off this mark. - o If %Idl1 begins to <u>increase</u>, you should try decreasing MAXSCH until %Idl1 gets to it's lowest point. %Idl1 is always the indicator. - o Remember to look at long samples. The "optimal" value of MAXSCH will change constantly through the day as the application mix changes. You are trying to find the best overall value for your average application mix. # This Page for NOTES # <u>USAGE - Disk Information</u> | 05 Aug 8<br>Up since | 5 13:29<br>05 Aug | 9: <b>51</b> . 50<br>1 85 07: 1 | dTIME=<br>33:04 Mon | 59. 87<br>day | | PU=<br>ot= | | I/O=<br>I/Otot= | | | |-------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------|-----------------------------------------------------------------------------------------------------|----------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------|----------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------| | %CPU<br>78. 50 | %Idl1<br>14.85 | | | | | %O∨1p<br>23.85 | 10/5<br>10.09 | PF/S<br>3. 01 | | | | %Clock<br>1.26 | %FNT<br>0. 00 | | | | | %GPPI<br>0.00 | %DSK<br>0.15 | | | | | %AMLC<br>1 55 | %Async<br>0. 00 | • | | | g s<br>16 | Used<br>1622 | Pages<br>8192 | Used<br>8190 | Wired<br>480 | | | Locate<br>15748 | %Miss<br>2.07 | | | | re L<br>08 20 | _0c/S<br>53. 05 | LM/S<br>5. 45 | | | | | Disk<br>604 | Qwaits<br>O | | | %DMA<br>0. ( | | langs<br>O | %Hang<br>0.00 | | | | | UST USET 1 SYSTI 14 SGW 29 AMS 41 JOHAI 55 DONAI 68 BUD. I 79 LARRY 87 MARIA 93 RICH 102 SLAVI 107 SYSTI 109 SYSTI 113 NETMA 114 RT_SI 116 FTP 117 FTPX 122 DAVE. | EM 34 NNA. C LD K Y. G A. C E\$ EM 1 EM 1 EM 1 EM 1 | em Wire 55 401 62 1 08 1 58 1 14 1 30 1 35 1 40 1 14 1 11 0 00 1 00 1 00 1 24 1 48 1 41 1 25 1 53 1 | 209 | Outime<br>97.800<br>55.254<br>97.578<br>31.930<br>14.145<br>56.106<br>11.623<br>16.865<br>4.014<br>49.269<br>49.907<br>16.022<br>34.703<br>5.318<br>74.847<br>77.076 | 0. 0<br>0. 2<br>36. 8<br>1. 4<br>0. 2<br>0. 2<br>1. 8<br>0. 0 | 086 0. 286 0. 285 61. 463 2. 309 0. 233 0. 206 0. 352 3. 317 0. 088 0. 095 0. 015 1. 016 0. 098 1. | 144 2<br>477<br>611 1<br>444<br>517<br>390<br>344<br>094<br>530<br>147<br>556<br>159<br>565<br>695<br>027<br>833 1 | /Otime<br>255.736<br>43.664<br>05.832<br>7.812<br>6.708<br>44.984<br>13.872<br>16.412<br>6.352<br>8.384<br>60.148<br>59.392<br>67.212<br>7.488<br>0.824<br>72.044<br>05.304<br>2.476 | dI/D 0. 420 2. 004 3. 352 0. 000 0. 000 1. 148 0. 112 2. 464 0. 016 0. 084 0. 620 0. 164 0. 088 0. 036 0. 000 0. 588 0. 000 0. 156 | %1/0<br>0.702<br>3.347<br>5.599<br>0.000<br>0.000<br>1.918<br>0.187<br>4.116<br>0.027<br>0.140<br>1.036<br>0.274<br>0.147<br>0.060<br>0.000<br>0.982<br>0.000 | | Disk | Count : | %Count | Time %Ut | | Total<br>Count | | Avg ti<br>(msec | | | | | '26<br>0<br>1 | 205 | 33. 94 | 4. 35 7. | 27 7 | 79. 84<br>70. 17<br>9. 67 | | 18. 99<br>18. 82 | | | | | '27<br>0<br>1<br>2<br>3 | 189<br>152 | 31. 29<br>25. 17<br>0. 17 | 3. 96 6.<br>2. 35 3.<br>0. 01 0. | 61 1<br>92<br>01 | 20. 16<br>6. 29<br>3. 78<br>0. 04<br>0. 04 | 1. 50<br>0. 40<br>0. 00<br>0. 00 | 22. 00<br>11. 18 | | | | # USAGE - Disk Information con't # o I/O counters: Disk — the number of actual I/Os during the sample period Count — the number of actual I/Os charged to each controller and drive %Count - Count / Disk ID/S - Disk / dTIME ## o Error indicators: Qwaits — the number of times a process waited for a QRB DMAovr - the number of DMA overruns Hangs — the number of times a drive did not finish a seek #### o I/O time used: I/O= - the total time spent on disk I/Os during this STIME Time — the total time spent on disk I/Os for each controller and each drive I/Otime — the total time spent on disk I/Os for each user since login dI/O — the total time spent on disk I/Os for each user during the dTIME %I/O - dI/O / dTIME #### o I/O utilization: %Util (drive) - Time / dTIME %Util (controller) - Time / dTIME / # drives on controller %I/O - I/O / dTIME / total # of drives #### o Since coldstart: Total %Count - cumulative Count / cumulative total Count Total %Util — cumulative Time / cumulative dTIME Avg Time - cumulative Time / cumulative Count 10/5- LM/5= PHSICAL NO FOR PAUL PF/5= CALLS TO PAGEUR I CALL TO BACKUR NATURNS I PLUE TO LOOP IF FYING IS MENON KUPE NMO PRESSOR PREPAR IF NO MONORY IS NUMBERS. CE1025 - SA0S32 USAGE #### Tuning Disk I/O - o Wait time can be reduced in the following ways: - Supply an adequate number of QRBs. If you are seeing Qwaits and you are on a pre-Rev 19.3 system, you will get an advantage by going up Rev. - Balance disk usage. Since a controller can overlap seeks, the more balanced the disk usage is, the more concurrent I/Os a controller can handle without long waits. Here are some strategies: - For short term balancing ( < 6 hours), use %Util for the drives. Idealistically, you would want %Util to be equal on all drives. - For long term balancing ( > 6 hours), use Total %Count. This will tell you overall what drives are being the most accessed. This will include ALL I/Os since coldstart. To balance disk usage, you must move accounts or files to non-busy disks. One of the busiest disks on the system is the paging disk. Using ALDEV and PRATIO, you can balance two disks without moving data by putting more pressure on either PAGDEV or ALTDEV according to use. Buy additional disk drives / controllers. If all of your drives are being heavily utilized (%I/O > 70% and %Idl1 > 20%), your wait times can be very long per request. The only solutions are to reduce the number of I/O requests or buy additional drives so that you can balance the I/O over more drives. #### Tuning Disk I/O - con't - o <u>Seek time</u> can be reduced in the following ways: - Reduce fragmentation. Normally, a new file will have its records layed down cylinder by cylinder so that sequential access will have minimal seek time. Over time, with additions and deletions of records, a file will get fragmented around the disk. This can be identified by an increase in Avg Time for a disk. Usually, the average seek time should be about 10 - 20 ms. The solution is to backup the disk logically (using MAGSAV, BRMS, or COPY), MAKE the disk, and copy the data back. - Large logical partitions. Unfortunatly, logical partitioning is done by surface rather than by cylinder. This means a small partition has small cylinders (eg. a 2 surface partition has 18 records / cylinder whereas a 10 surface partition has 90 records / cylinder). Therefore, the larger a partition is, the lower the amount of seeking that will be necessary during sequential access. - Have one controller per drive (pre-Rev 19.3). Before Rev 19.3, a controller with more than one drive seeking would frequently wait for the wrong drive to finish. This problem can be solved by having less drives per controller, or by upgrading to Rev 19.3 where the problem has be fixed. - Keep PAGDEV and ALTDEV off your major application disks if possible. Paging tends to get hit often and randomly, and will therefore interfere with sequential file operations. #### Disk Tuning - Bottlenecked Disk # SYMPTOMS: - %Idl1 is high ( > 20%). - Throughput is poor, especially for certain applications accessing one particular disk. - %Util for some drives are much higher than on others. - %I/O may be low, average, or high, depending on how many drives you have. #### SUSPECTED PROBLEM: - Bottlenecked disk drive. - Bottlenecked disk controller (before Rev 19.3). #### SOLUTIONS: - Move heavily used directories and/or files to other drives / controllers. - Change paging load using PAGDEV, ALTDEV, and PRATIO. - If %I/O is also high, buy more disks / controllers so as to balance your I/O. - Decrease number of applications using a particular file or account. - Reprogram applications to use less I/O. - Minimize seek time on the heavily used disks. # Disk Tuning - Inefficient Seeking #### SYMPTOMS: - %Idl1 is high ( > 20% ) - %Util is much higher that %Count for a particular drive. - Average seek time high ( > 20ms ). - Throughput is poor, especially on I/O intensive applications. - Throughput on I/O intensive jobs is degrading. #### SUSPECTED PROBLEM: - Disk fragmentation. - Small partitions. - Inefficient I/O in applications. #### TOLUTIONS: - Remake disk after logical backup. - Make partitions as large as possible. - Put paging and application files on different disks. - Rewrite applications to be more I/O efficient. - If %I/O is also high, buy additional drives so as to balance I/O between more drives. - If pre Rev 19.3, buy additional controllers or upgrade Rev. CE1025 - SA0S32 USAGE # USAGE - LOCATE Information | 05 Aug 8<br>Up since | | | | | | | | | I/O=<br>I/Otot= | | 11. 67<br>72. 34 | |--------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | %CPU<br>78. 50 | %Idl1<br>14.85 | %Id12<br>0.00 | %Error<br>2.65 | | I/O<br>. 25 | %0v1p<br>23.85 | | ID/S<br>0. 09 | | | | | %Clock<br>1.26 | %FNT<br>0. 00 | %MPC<br>0.00 | %PNC<br>0. 33 | | 5LC<br>51 | %GPP 1<br>0. 00 | | %DSK<br>0.15 | | | | | %AMLC<br>1.55 | %Async<br>0.00 | %Sync<br>0.00 | %1CS<br>0 00 | | <b>egs</b><br>816 | Used<br>1622 | | ages<br>8192 | | | red<br>180 | | Locate<br>15748 | %Miss<br>2.07 | %Found<br>75.19 | %Same<br>22. 66 | | are<br>. 08 | Loc/9<br>263. 05 | | LM/S<br>5. 45 | | | | | Disk<br>604 | <b>G</b> waits<br>O | % <b>G</b> wait<br>0.00 | DMA ovr<br>O | | A0VT<br>. 00 | Hang ( | | Hang<br>0. 00 | | | | | 1 SYST 14 SGW 29 AMS 41 JOHA 55 DONA 68 BUD. 79 LARR 87 MARI 93 RICH 102 SLAV 107 SYST 113 NETM 114 RT_S 116 FTP 117 FTP | 62<br>608<br>NNA. C 58<br>LD 14<br>K 30<br>Y. G 35<br>A. C 40<br>I. D 114<br>E\$ 11<br>EM 100<br>EM 100<br>EM 100<br>EM 24<br>SERVER 48 | 401 a 1 1 1 1 1 1 1 1 1 1 1 1 1 | 209 97<br>23 55<br>43 587<br>18 31<br>18 14<br>16 56<br>14 11<br>19 16<br>22 6<br>3 4<br>11 49<br>11 116<br>4 234<br>9 5<br>12 174 | . 800<br>. 254<br>. 578<br>. 930<br>. 145<br>. 106<br>. 623<br>. 788<br>. 865<br>. 014<br>. 269<br>. 907<br>. 022<br>. 703<br>. 318<br>. 847<br>. 076 | 0. 6<br>0. 2<br>36. 8<br>1. 4<br>0. 2<br>0. 2<br>1. 8<br>0. 6<br>0. 6<br>0. 6<br>0. 6<br>0. 6<br>0. 6<br>0. 6<br>0. 6 | 086 0. 286 0. 385 61. 463 2. 309 0. 233 0. 206 0. 352 3. 317 0. 088 0. 333 0. 095 0. 937 1. 015 1. 016 0. 499 0. | 144<br>477<br>611<br>444<br>517<br>390<br>344<br>094<br>530<br>147<br>556<br>159<br>565<br>695<br>027<br>833<br>167 | 255.<br>43.<br>105.<br>7.<br>6.<br>44.<br>13.<br>16.<br>60.<br>59.<br>67.<br>7.<br>0.<br>172. | 664 832 812 708 784 1872 708 784 12 2352 784 748 748 748 748 748 748 748 748 748 | dI/D<br>. 420<br>. 004<br>. 352<br>. 000<br>. 148<br>. 112<br>. 464<br>. 016<br>. 088<br>. 036<br>. 036<br>. 036<br>. 036<br>. 000<br>. 588<br>. 000<br>. 156 | %1/0<br>0.702<br>3.347<br>5.599<br>0.000<br>0.000<br>1.918<br>0.187<br>4.116<br>0.027<br>0.140<br>1.036<br>0.274<br>0.147<br>0.060<br>0.000<br>0.982<br>0.000<br>0.261 | | Disk | Count % | Count | Time %U | til | Tota<br>%Cou | | tal A<br>til | vg ti<br>(msed | | | | | ′26<br>0<br>1 | 205 3 | 3. 94 | 4. 35 7 | . 46<br>. 27<br>. 66 | 79. (<br>70<br>9. ( | 17 6. | 42<br>88 | 18. 99<br>18. 82 | | | | | ′27<br>0<br>1<br>2<br>3 | 187 3<br>152 2<br>1 | 1. 29<br>5. 17<br>0. 17 | 3. 96 6<br>2. 35 3<br>0. 01 0 | . 64<br>. 61<br>. 92<br>. 01<br>. 03 | 20.<br>16.<br>3.<br>0.<br>0. | 29 1<br>78 0<br>04 0 | 50<br>40<br>00 | 19. 05<br>22. 00<br>11. 16<br>9. 98 | )<br>3 | | | # This Page for NOTES: CE1025 - SADS32 USAGE #### PRIMOS LOCATE Mechanism - o An LOCATE (or associative) buffer is a main memory copy of a disk record. LOCATE buffers are a means of reducing the number of disk accesses needed for logical file access. - o Multiple logical reads to one physical record may require only one disk access. Multiple logical writes to one physical record may require only one disk read and one disk write. - o Each user can own <u>one</u> LOCATE buffer. An owned LOCATE buffer is wired in memory. Previously owned LOCATE buffers remain in memory until they are again owned (wired), or deleted from memory. - o If a LOCATE buffer has been modified, it is written back to the file system disk by user 1 and/or when it is deleted from memory. User 1 copies all modified LOCATE buffers to the file system disk once a minute. - o USAGE LOCATE buffering information: - Locate the number of calls to the LOCATE mechanism. This is roughly the number of I/O requests made by applications. - %Miss the percentage of calls to LOCATE in which the requested disk record was not in memory. - %Found the percentage of calls to LOCATE in which the requested disk record was found in memory, but was unowned. - %Same the percentage of calls to LOCATE in which the requested disk record was found in memory, and the requesting process already owned it. - %Share the percentage of calls to LOCATE in which the requested disk record was found in memory, and the buffer was owned by another process. - Loc/S The average number of calls to LOCATE each second during the sample. - LM/S The average number of LOCATE misses per second during the sample period. It should be remembered that each LOCATE miss can result in 1 OR 2 actual I/Os. ## LOCATE Mechanism | | BUFFERS | | USER #1 | |------|---------|-----|---------| | | i | | • | | | | | | | DISK | | . • | | | | | • | USER #2 | | | | | | | | | | | | | · | | | | · | | | | | | • | · | • | | | | · | | ### Using NLBUF - The number of LOCATE buffers configured on the system can impact I/O performance. As of Rev 19.1, the number of buffers is configurable. - NLBUF CONFIG directive, range 8 256, default 64. - 22 word Buffer Control Block (BCB) wired at cold start for each buffer. Even though LOCATE buffers are only wired when owned, most LOCATE buffers are "virtually" wired into memory. Thus, it is a good idea to think of ALL configured buffers as wired memory. o Changing NLBUF will affect both PF/S and %Miss. Since both of these directly relate to disk I/O, the idea is to decrease one without adversely affecting the other. Therefore, there are two major symptoms which can dictate a change in NLBUF: High %Miss and low or avg PF/S ..... increase NLBUF Low %Miss and high PF/S ..... decrease NLBUF NOTE: LM/S is a very important indicator in terms of validating the percentages. %Miss does not tell you anything without LM/S. Example #1 Example #2 | %Miss | Loc/S | LM/S | %Miss | Loc/S | LM/S | |-------|---------|--------|--------|--------|-------| | 15.09 | 127. 90 | 19. 30 | 15. 09 | 22. 87 | 3. 45 | Obviously, the 15% miss rate in example #1 is affecting the system much more than the 15% miss rate in example #2. o Applications can take advantage of LOCATE by having small, sequentially accessed logical records. %Miss is most often a reflection of the application. ### LOCATE Tuning ### SYMPTOMS: - %Id11 is low ( ≤ 10% ). - %I/O is high ( > 60% ). - %Util for a drive is high ( > 80% ). - LO/S is average or high ( > 30 ). - %MISS is high ( > 20% ). - Throughput is poor, especially on I/O intensive jobs. ### SUSPECTED PROBLEM: - LOCATE buffer thrashing. - Inefficient LOCATE usage by applications. #### SOLUTIONS: - Increase NLBUF. - Reprogram applications to take advantage of LOCATE mechanism. - Reschedule I/O intensive applications to a less busy time. - Decrease paging requirements if PF/S are average or high. - Put paging on different disk from main applications. - Balance I/O between all drives. - Buy additional drives so I/O can balanced between more drives. # <u>USAGE - ROAM Buffer Information</u> | 05<br>Up | Aug E<br>since | 35 13<br>• 05 | 3: 29:<br>Aug | 51. 5<br>85 0 | 0<br>7: 3 | dTIME<br>3:04 | :=<br>Mond | 59.<br>Jay | 87 | | | PU=<br>ot= | | | 7. 00<br>6. <b>94</b> | | I/O:<br>Otot: | | 11.<br>4472. | 67<br>34 | |----------|----------------|---------------|---------------|-----------------|---------------|---------------|-------------|---------------------|-----------|--------------|------|---------------|----------|----------------|-----------------------|-----|-------------------|-----|--------------|------------------------------| | | %CPU<br>8. 50 | | Idl1<br>4.85 | | d12<br>. 00 | | ror<br>. 65 | | %I<br>3. | | | %0v<br>23. : | • | | 10/S<br>0. 09 | | PF/9 | | | | | | lock<br>1.26 | | %FNT<br>0. 00 | | MPC<br>. 00 | | PNC<br>. 33 | | %Si<br>0. | | | %GP <br>0. | | | %DSK<br>D. 15 | | | | | | | | AMLC<br>1.55 | | sync<br>0. 00 | | ync<br>. 00 | | ICS<br>. 00 | | Se<br>28 | | | Us<br>16 | | | ages<br>3192 | | Use<br>8190 | | Wired<br>480 | | | 1 | cate<br>5748 | | Miss<br>2.07 | %Fo | und<br>. 19 | | ame<br>. 66 | 7.5 | 0. ( | 7 <b>e</b> | | Loc.<br>63. ( | | | _M/S<br>5. 45 | | | | | - | | | ki/o<br>10 | | Réad<br>5 | 50. | e a d<br>. 00 | | ite<br>O | 7.6 | 0. ( | te<br>OO | A | wri' | te<br>5 | | nite<br>0.00 | I | 31 k / 9<br>4. 54 | | | | | | Disk<br>604 | | eits<br>O | | .00 | | 770 | %[ | 0. ( | 0 V T<br>0 O | i | Han | g s<br>O | | Hang<br>D. 00 | | Asyi( | o % | 0.00 | | | | User<br>SYST | | Me<br>345 | em Win<br>55 40 | re :<br>01 | Segs<br>209 | | PUt i | | | | CPU<br>086 | | %CPU | | | time<br>736 | _ | dI/O | %I/D<br>0.702 | | 14 | SGW | | | 2 | 1 | 23 | | 55. <b>2</b> | | | | 286 | | . 477 | | | 664 | | 2. 004 | 3. 347 | | | AMS | | 60 | | 1 | 43 | 58 | 37. 5 | 78 | | | | | . 611 | | | 832 | | 3. 352 | 5. 599 | | | JOHA | | | 8 | 1 | 18 | 3 | 31.5 | 30 | | | 463 | | . 444 | | | 812 | | . 000 | 0.000 | | | DONA | | | . 4 | 1 | 18 | 1 | 4. 1 | 45 | | 0. 3 | 309 | 0 | . 517 | 7 | 6. | 708 | | . 000 | 0.000 | | | BUD. | | | 30 | 1 | 16 | | 6. 1 | | | | 533 | | . 390 | | 44. | 984 | 1 | . 148 | 1. 918 | | | LARR | | | 35 | 1 | 14 | | 1. 6 | | | | 506 | | . 344 | | | 872 | | . 112 | 0.187 | | | MARI<br>RICH | | | 10 | 1 | 19 | 1 | 6. 7 | | | | 352 | | . 094 | | | 412 | | . 464 | 4. 116 | | | SLAV | | 11 | 1 | 0 | 55 | | 6. E | | | | 317 | | . 530 | | | 352 | | . 016 | 0. 027 | | | SYST | | 10 | | 1 | 3<br>11 | | 4. 0 | | | | 880 | | . 147 | | | 384 | | . 084 | 0. 140 | | | SYST | | 10 | | 1 | 11 | | 9. <b>2</b><br>9. 9 | | | | 333 | | . 556 | | | 148 | | . 620 | 1. 036 | | | SYST | | 10 | | 1 | 11 | | 6. 0 | | | | 95<br>737 | | . 159<br>. 565 | | | 392 | | 164 | 0. 274 | | | NETM | | | 24 | 1 | 4 | | 6. C<br>34. 7 | | | | 015 | | . 565<br>. 695 | | | 212<br>488 | | 088 | 0.147 | | | RT_S | | | 8 | 1 | 9 | = - | 5. 3 | | | | 016 | | . 027<br>. 027 | | | 824 | | . 000 | 0.060 | | | FTP | | | 1 | 1 | 12 | 17 | 4.8 | | | | 199 | | . <b>83</b> 3 | | | 044 | | . 588 | 0. 000<br>0. <del>9</del> 82 | | | FTPX | | | 25 | 1 | 12 | | 7.0 | | | | 578 | | . 167 | | | 304 | | . 000 | 0. 000 | | 122 | DAVE | . <b>G</b> | 5 | 3 | 1 | 8 | | 6. 6 | | | | 530 | | 884 | | | 476 | | . 156 | 0. 261 | ### ROAM Buffer Manager - o At Rev 20.0, the ROAM Buffer manager was added. The motivation for this mechanism is: - The PRWF\$\$ / LOCATE mechanism which it replaces is very generalized and not very efficient for ROAM and the data base products. - The data base products need to be able to directly manipulate the disk buffers in order to do prioritizing. - o All ROAM buffers are 2kb in size. - o ROAM buffers are only wired during an I/O operation. ### USAGE Statistics for ROAM Buffers o A new line of statistics for ROAM buffer pool access has been added to USAGE output. These statistics will give you some idea of how much the ROAM buffers are being accessed vs the LOCATE buffers. Blki/o Read %Read Write %Write Awrite %Awrite Blk/S 10 5 50.00 0 0.00 5 50.00 4.54 > . asyio %asynio O 0.00 Stats Meaning Blki/o Total number of logical block I/O operations in the sampling period Read Total number of read block I/O operations in the sampling period %Read The percentage of the total number of block I/O operations that were read operations Write Total number of synchronous write block I/O operations in the sampling period %Write The percentage of the total number of block I/O operations that were synchronous write operations Awrite Total number of asynchronous write operations in the sampling period %Awrite The percentage of the total number of block I/O operations that were asynchronous write operations Blk/s The average number of block I/Os per second during the sampling period. asyio The number of async write requests that DISKIO handled. %asyio The percentage of the total number of async write requests in the sampling period CE1025 - SADS32 USAGE CE1025 - SADS32 USAGE <u>Title</u>: Disk I/O Balancing. Objectives: Upon successful completion of this lesson, students will be able to: - Shift the layout of directories and files across disks and controllers to increase overall disk input/output throughput. - Set the PAGDEV, ALTDEV, and PRATIO configuration directives to reduce the average page fault time and increase overall disk input/output throughput. <u>Task</u>: Given a description of a system's logical disk structure answer questions on improving disk throughput. Conditions: Using any available course documentation. A system administrator at a software applications shop has been having real I/O problems. The problem for you is to configure her system to maximize I/O efficiency. - The system is a 9755, running PRIMOS revision 20.2 - There are 3MB of main memory. - There are two disk controllers. - drive O on the first controller is a BOMB disk. - drive O on the second controller is a 80MB disk. - drive 1 on the second controller is a 300MB disk. - All backup is done to tape. - There are 64 lines configured. PAGDEV is DISK10, 2nd controller, drive 1, 3 heads COMDEV is DISK00, 1st controller, drive 0, 2 heads Here is the current logical disk layout: | VOLUME<br>ID | TOTAL<br>RECS | FREE<br>RECS | %<br>FULL | COMMENTS | | | | | | |--------------|---------------|--------------|----------------|------------|-----|-------|---|------------|-------| | DISKOO | 14814 | 741 | 95. O <b>*</b> | CONTROLLER | 1 * | DRIVE | 0 | <b>*</b> 2 | heads | | DISK01 | 14814 | 741 | 95. 0 <b>*</b> | | * | | | <b>*</b> 2 | heads | | DISKO2 | 7407 | 741 | 90.0 * | | * | | | * 1 | head | | DISKO3 | 14814 | 741 | 95. O <b>*</b> | CONTROLLER | 2 * | DRIVE | 0 | * 2 | heads | | DISKO4 | 14814 | 1482 | 90.0 # | | * | | | * 2 | heads | | DISKO5 | 7407 | 741 | 90.0 * | | * | | | <b>*</b> 1 | head | | DISKO6 | 29628 | 1482 | 95.0 * | | * | DRIVE | 1 | <b>*</b> 4 | heads | | DISKO7 | 29628 | 2963 | 90.0 # | | * | | | <b>*</b> 4 | heads | | DISKOB | 29628 | 1482 | <b>95.0</b> # | | # | | | <b>*</b> 4 | heads | | DISK09 | 29628 | 26665 | 10.0 * | | # | | | * 4 | heads | Here is the approximate MFD usage given you by the System Administrator: | DI | SK | DESCRIPTION | USAGE | |----|------|-----------------------------------------------|-------------| | | SKOO | Command device | Heavy | | | SK01 | Library of old software revs | Light | | | SK02 | R&D programmer accounts | Heavy | | | SK03 | R&D software source library | Moderate | | | SK04 | R&D misl | Moderate | | | SK05 | Administrative misl | Light | | - | SK06 | Secretarial accounts using word proccessing | Heavy | | | SK07 | Payroll software - used only on Thurs and Fri | Heavy/light | | | SKOB | Accounting software | Heavy | | | SK09 | Executive accounts | Light | 1) Draw in lines dividing the physical disk pack into logical partitions. Indicate where the data from the original partitions would be copied by writing in the old partition name(s) in the new partitions you have drawn in. Make sure to indicate which disks should go on which controllers. | BO MR | 80 | MB | 300MB | | | | |-------|----|----|-------|--|--|--| | | | | | | | | | | | | • | | | | PRATIO (if decided to use) = Appendix A - Acronyms CE1025 - SAOS32 ACRONYMS ACAT Access Catagory ACL Access Control List Arithmetic Logic Unit ALU AMLC Asynchronous Multi-Line Controller AMLDIM AMLC Device Interface Manager AP Arguement Pointer ARGT Arguement Transfer Auto Speed Detect ASD AST Active Segment Table BADSPT Badspot BCB Buffer Control Block BMA Bus Memory Address BMC Bus Memory Control Bus Memory Data BMD Beginning of List Pointer BOL BPA Bus Peripheral Address Bus Peripheral Control BPC BPD Bus Peripheral Data BRA Beginning Record Address CALF Call Fault Handler CAM Contiguous Access Method CHAP Change Priority CPU Central Processing Unit CRSx Current Register Set CTI Character Timed Interrupt DAM Direct Access Method DB Directory Block DMA Direct Memory Access DMC Direct Memory Channel (or Control) DMQ Direct Memory Queve DMT Direct Memory Transfer DMx Direct Memory Transfer Disk Record Availability Table DSKRAT DTAR Descriptor Table Address Register DYNT Dunamic ECB Entry Control Block ECL Emitter Coupled Logic ELIGQ Eligibility Queue ELIGTS Eligibility Timeslice ( the minor timeslice ) EOL End of List Pointer EOR End of Range EPF Executable Program Format ERP EPF Relocatable Pointer GPP I General Purpose Peripheral Interface HIPRIG High Priority Queue HMAP Hardware Map I/O Input/Output ICS Intelligent Controller Subsystem IDLEG Idle Queue IOTLB Input/Output Table Lookaside Buffer IRB Input Ring Buffer LB Link Base LOPRIG Low Priority Queue MAXSCH Maximum Scheduled (Processes) CE1025 - SADS32 ACRONYMS MDLC Multi Line Data Link Controller MFD Master File Directory MMAP Memory Map NLBUF Number Locate Buffers ORB Output Ring Buffer Program Counter P-CTR Process Abort Handler PABORT PAGTUR Page Turner PAVCTR Page Available Counter PB Procedure Base PCB Process Control Block Procedure Call PCL PDU Power Distribution Unit PIC Phantom Interrupt Code PIO Programmed Input/Output PMA Prime Macro Assembler PMT Page Map Table PNC Prime Node Controller PPA Pointer to Process A PPB Pointer to Process B PPN Physical Page Number PRTN Procedure Return PUDCOM Per User Data Common **QAMLC** AMLC board using DMQ for character output **GB** Quota Block GRB Queue Request Block ROIPQNM Ring O Interprocess Queueing and Notification Mechanism RSx Register Set SAM Sequential Access Method SB Stack Base SDT Segment Descriptor Table SDW Segment Descriptor Word SEGDAM Segmented Direct Access Method SEGSAM Segmented Sequential Access Method SMLC Synchronous Multi Line Controller SMT Segment Mapping Table STLB Segment Table Lookaside Buffer TTL Transistor to Transistor Logic UART Universal Asynchronous Receive and Transmit Buffer UII Unimplemented Instruction UT Unit Table UTE Unit Table Entry VMFA Virtual Memory File Access VPSD Virtual Prime Symbolic Debugger WLSN Wait List Segment Number WLWN Wait List Word Number XB Extra Base