Spec set 1

| Honeywell<br>Honeywell Information systems                                             |                                            | SPEC. NO.<br>60149766 |            | SHEET | rev.<br>H |
|----------------------------------------------------------------------------------------|--------------------------------------------|-----------------------|------------|-------|-----------|
| Billerica, MA<br>U.S.A.                                                                |                                            |                       | CODE<br>C6 | 1C    |           |
| PREPARED BY DATE TITL<br>A.C. Hirtle 5/20/83<br>APPROVED BY DATE<br>See Approval Sheet | Engineering Product<br>Local Area Controll | •-                    |            | 1     |           |
|                                                                                        | •••••                                      | •                     |            |       |           |

#### REVISION RECORD

| REV. | AUTHORITY | DATE      | SIGNATURE | SHEETS AFFECTED |
|------|-----------|-----------|-----------|-----------------|
| A    | BLCDD7588 | 5/20/83   | act       | All             |
| В    |           | 8/11/83   | act       | All             |
| С    |           | 11/4/83   | and       | As marked       |
| D    |           | 1/12/84   | acia      | As marked       |
| E、   |           | 4/18/84 - | act       | As marked       |
| F    | BLCDE7775 | 10/4/84   | acA       | As marked       |
| G    | BLCDF7256 | 3/31/85   | act       | As marked       |
| Н    | BLCDG7319 | 4/30/86   | add       | As marked       |

## NOTE

This EPS-1, if not revised within one year, should be considered obsolete and therefore reference should be made to the appropriate product manual.

his document and the information contained herein are confidential to and the property of Honeywell Information Systems Inc. and are made available only to Honeywell employees for the sole purpose of conducting Honeywell's business. This document, any copy thereof and the informetion contained herein shall be maintained in strictest confidence; shall not be copied in whole or in part except as authorized by the employee's manager; and shall not be disclosed or distributed (a) to persons who are not Honeywell employees, or (b) to Honeywell employees for whom such information is not necessary in connection with their assigned responsibilities. Upon request, or when the employee in possession of this focument no longer has need for the document for the authorized Honeywell purpose, this document and any copies thereof shall be returned to the employee's manager. There shall be no exceptions to the terms and conditions set forth herein except as authorized in writing by the responsibile doneweil Vice President.





| 14.<br>1 |   |                   | ,                            | General III III III III III IIII IIII IIII I                             | -<br>- |
|----------|---|-------------------|------------------------------|--------------------------------------------------------------------------|--------|
|          |   |                   |                              | ÷                                                                        |        |
|          |   | i je<br>Grada se  | te mit <u>et</u> ti<br>Norma | ng ng<br>ng ng n                        |        |
|          | ; | n got e<br>gil er | • .                          | 198                                                                      |        |
| •        |   | <u>*</u> .•       |                              |                                                                          |        |
|          |   | * • •<br>*        |                              | an ann an Anna Anna Anna Anna Anna Anna                                  |        |
|          |   | -10               |                              | 27.28 · C 1                                                              |        |
|          |   | 4 4.              |                              | 1. E. S.                                                                 |        |
|          |   | 10 - 10           |                              | · · · · ·                                                                |        |
|          |   |                   |                              | the second states and the                                                |        |
|          |   |                   |                              | 14                                                                       | ¥<br>F |
|          |   |                   |                              | ie Traisle                                                               |        |
|          |   |                   | ~                            | ాత సంభిష్ రెడి                                                           |        |
|          |   |                   | ;                            |                                                                          |        |
|          |   |                   |                              | امر میں در دور میں میں<br>این اور اور میں اور<br>اور اور اور اور میں اور |        |
|          |   |                   |                              | ವಾರ್ಟೆಗಳ ಸಂಗ್ರಹವಾಗಿ<br>ಸಂಗ್ರಹವಾಗಿ ಇವರ<br>ಸಂಗ್ರಹವಾಗಿ ಸಂಗ್ರಹವಾಗಿ           |        |
|          |   |                   |                              | an dan sana sana sana sana sana sana san                                 |        |
|          |   |                   |                              |                                                                          |        |

•

1. Sec. 1. Sec.

| HONEYWELL                       | SPEC. NO.<br>60149766 | SHEET<br>  1.1 | REV. |
|---------------------------------|-----------------------|----------------|------|
| Author:  <br>  A. C. Hirtle     |                       | Code           |      |
| First Draft Date  <br>  5/20/83 |                       | <br>  C61C     |      |

|                                                 | HONEYWELL INFORMATION SYSTEMS<br>SYSTEMS ENGINEERING - BOSTON               |
|-------------------------------------------------|-----------------------------------------------------------------------------|
| ENGINEERING<br>PRODUCT                          | LOCAL AREA CONTROLLER<br>TITLE: <u>SUBSYSTEM (LACS)</u>                     |
| SPECIFICATION<br>( EPS - 1 )<br>SUBSYSTEM LEVEL | VERSION: <u>APPROVED</u> DATE: <u>4/30/86</u><br>PRODUCT CALENDAR REFERENCE |

#### NOTE

This EPS-1, if not revised within one year, should be considered obsolete and therefore reference should be made to the appropriate product manual.

This document and the information contained herein are confidential to and the property of Honeywell Information Systems Inc., and are made available only to Honeywell employees for the sole purpose of conducting Honeywell's business. This document, any copy thereof and the information contained herein shall be maintained in strictest confidence; shall not be copied in whole or in part except as authorized by the employee's manager; and shall not be disclosed or distributed (a) to persons who are not Honeywell employees, or (b) to Honeywell employees for whom such information is not necessary in connection with their assigned responsibilities. Upon request, or when the employee in possession of this document no longer has need for the document for the authorized Honeywell purpose, this document and any copies thereof shall be returned to the employee's manager. There shall be no exceptions to the terms and conditions set forth herein except as authorized in writing by the responsible Honeywell Vice President.

|         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                    | -                                       |                                               |
|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|-----------------------------------------|-----------------------------------------------|
| nen ↔ · | <ul> <li>We can get a set of the set of</li></ul> | 1                  | -m k '<br>4                             |                                               |
|         | , γ το το γ αφοριζός. «Νασ                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                    | 986-0-148                               |                                               |
|         | 4,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | `. <del>≱</del> u. | s i                                     | a V. C. a K. j                                |
|         | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 5 p y              | - 5                                     | араны — л<br>40 марыны — ласан<br>6 араны — л |
|         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                    |                                         | 4 ) A 4 <b>8</b> 4 ' ' '                      |
|         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                    |                                         | na transformation<br>s transformation         |
|         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | φ κ.<br>1. 2       | ал қ.<br>•<br>К.•                       |                                               |
|         | <ul> <li>F</li> <li>F</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                    |                                         |                                               |
|         | ेर हु <sup>€</sup><br>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                    |                                         | να (α <sub>μα</sub> )<br>του β (με) του σ     |
|         | 1999 -<br>2016 -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 1. e . e . e       |                                         | 1911 ·                                        |
|         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | n ne P             | an a s<br>an suis<br>an suis<br>an suis |                                               |

· · ·

.

| HONEYWELL | SPEC. NO. | 1 | SHEET | REV. | 1 |
|-----------|-----------|---|-------|------|---|
| l         | 60149766  | 1 | 2.0   | H    | 1 |

( )

# CONTENTS

|        |           | CONTENTS                                 | DACE   |
|--------|-----------|------------------------------------------|--------|
|        |           |                                          | PAGE   |
| SECTIO | N 1       | INTRODUCTION                             | 3      |
| 1.1    | Documer   | nt Definition                            | 3      |
| 1.2    |           | nce Documents                            | 3<br>3 |
| 1.3    |           | iations/Definition                       | 4      |
|        |           |                                          | _      |
| SECTIO | )N 2      | ARCHITECTURE                             | 6      |
| 2.1    | Overvi    | ew                                       | 6      |
| 2.2    | Securi    | ty                                       | 10     |
| 2.3    | Multip    | rocessor Support                         | 10     |
| 2.4    | Local     | Area Controller (LAC)                    | 11     |
| 2.5    | LAC Blo   | ock Diagram                              | 12     |
| 2.6    | Memory    | Layout                                   | 14     |
| 2.7    |           | mory Management                          | 16     |
| 2.8    | LAC So    | ftware-Firmware-Hardware Structure       | 17     |
|        | 2.8.1     | General                                  | 17     |
|        | 2.8.2     | Interprocess Communications              | 18     |
|        | 2.8.3     |                                          | 18     |
|        | 2 • U • J | Relative Flocess Florities               | TO     |
| 2.9    | Mailbo    | xes and Mailbox Message Queues           | 20     |
|        |           |                                          |        |
|        | 2.9.1     | Mailboxes Associated with IF Software    | 20     |
|        | 2.9.2     | Mailbox Message Priorities               | 21     |
| 2.10   | LAN CO    | ntrol Block                              | 21     |
| 2.11   |           | ftware Interface to the Megabus          | 21     |
| 2.12   |           | ftware Interface with Adapters           | 21     |
| 2.13   | Softwar   | re Interface Between Level 6 and LACS    | 22     |
|        |           | Transmit Data Operation Flow             | 22     |
|        |           | Receive Data Operation Flow              | 27     |
|        |           | Control Operations                       | 31     |
| 2.14   |           | tware & IF Software Functional Diagrams. | 33     |
| 2.15   |           | upts to Level 6                          | 37     |
| 2.16   |           |                                          | 38     |
| 2.17   |           | tartup                                   | 39     |
| 2.18   |           |                                          | 41     |
| 2.10   |           | ng of Software Error Conditions          | 41     |
| 2.19   | nanut I   | ng of software Error conditions          | 41     |
| SECTIO | ON 3      | FUNCTIONAL DESCRIPTION (LAC)             | 44     |
| 3.1    |           | Functions                                | 44     |
| 3.2    | I/0 Or    | ders                                     | 45     |
|        | 3.2.1     | List of I/O Orders                       | 45     |
|        | 3.2.2     | Output Order Definitions                 | 45     |
|        | 3.2.3     | Input Order Definition                   | 47     |
|        | 3.2.4     | WAIT, NAK and ACK Responses              | 47     |
|        | 3.2.5     |                                          | 48     |

| HONEYWELL<br>                             |                                  | SPEC. NO.<br>  60149766                                                                 | SHEET<br>  2.1 | REV.     |   |
|-------------------------------------------|----------------------------------|-----------------------------------------------------------------------------------------|----------------|----------|---|
| 19 20 20 20 20 20 20 20 20 20 20 20 20 20 | CONJ                             | TENTS (CONTINUED)                                                                       |                |          |   |
|                                           | ے الجا میں ا                     |                                                                                         |                | PAGE     |   |
| 3.3 Chan                                  | nel Numbers                      |                                                                                         |                | 52       |   |
| 3.4 Devi                                  | ce Identification                | Number                                                                                  |                | 52       |   |
|                                           | Transfers within                 |                                                                                         |                | 53       |   |
|                                           | ructions                         |                                                                                         |                | 53       |   |
|                                           | Firmware                         |                                                                                         |                | 53       |   |
|                                           | oftware                          |                                                                                         |                | 54       |   |
| 3.8.                                      | 1 IF Software Pro                | ocesses                                                                                 |                | 54       |   |
|                                           | 3.8.1.1 Memor                    | y DMA Request (MEI                                                                      | MDMA)          | 54       |   |
|                                           | 3.8.1.2 MAC                      |                                                                                         |                | 64       |   |
|                                           | 3813 $1/0$ 0                     | rder Dispatch (IO                                                                       | ופסזר          | 66       |   |
|                                           | 3 8 1 4 Mogabi                   | rder Dispatch (IOI<br>us Layer Managemen                                                | 5101/<br>o+    | 72       |   |
| •                                         |                                  | ayer Management                                                                         |                | 72       |   |
| ».                                        |                                  |                                                                                         |                | 12       |   |
| 3.8.                                      | 2 IF Software Int                | terrupt Routines                                                                        |                | 74       |   |
|                                           | 3.8.2.1 Inter                    | rupt Retry                                                                              |                | 74       |   |
| na kata<br>Contra an                      | 3.8.2.2 I/O D                    | ispatch                                                                                 |                | 75       |   |
| <i>I</i> *                                | 3.8.2.3 DMA Co                   | ontroller                                                                               |                | 76       |   |
| s4, €                                     | 3.8.2.4 Megab                    | us DMA Register Ex                                                                      | xhaust         | 77       |   |
| · *,                                      | 3.8.2.5 Adapt                    | er Interrupt                                                                            |                | 77       |   |
| 1. A.                                     | 3.8.2.6 RAM Pa                   | rupt Retry<br>ispatch<br>ontroller<br>us DMA Register E:<br>er Interrupt<br>arity Error |                | 77       |   |
| 3.9 Hand                                  | ling of Hardware E               |                                                                                         |                | 80       |   |
| SECTION 4                                 | INTERFACES                       |                                                                                         |                | 81       | ( |
| 4.1 Leve                                  | 1 6 Interface with               | LACS                                                                                    |                | 81       |   |
| 4.2 LAC                                   | Interface with the               | Megabus                                                                                 |                | 81       |   |
| 4.3 LAC                                   | Interface with Ada               | nters                                                                                   |                | 82       |   |
| 4.4 Test                                  | Connector Interface              | Ce                                                                                      |                | 83       |   |
| SECTION 5                                 | PERFORMANCE                      |                                                                                         |                | 84       |   |
| 5.1 LAN                                   | Data Rate                        |                                                                                         | χ.             | 84       |   |
|                                           | Throughput                       |                                                                                         |                |          |   |
| 5.3 LAC                                   | Infougnput<br>Thetamation Mining |                                                                                         |                | 84       |   |
|                                           | Instruction Timing               |                                                                                         |                | 84       |   |
|                                           | rity Position of L               |                                                                                         |                | 84       |   |
| 5.5 Prio                                  | rity Position of A               | dapters                                                                                 |                | 84       |   |
| SECTION 6                                 | PHYSICAL STRUC                   | TURE                                                                                    |                | 85       |   |
|                                           | aging                            |                                                                                         |                | 85       |   |
| 6.2 Powe                                  |                                  |                                                                                         |                | 85       |   |
|                                           | ronment                          |                                                                                         |                | 85       |   |
| 6.3 Envi                                  |                                  | •                                                                                       |                | 85       |   |
|                                           | LY                               |                                                                                         |                | 0.1      |   |
| 6.4 Safe                                  |                                  |                                                                                         |                |          |   |
| 6.4 Safe<br>6.5 Stan                      | dards<br>ability                 |                                                                                         |                | 85<br>85 |   |

# HONEYWELL CONFIDENTIAL & PROPRIETARY

٩

| HONE                 | YWELL                                              | SPEC. NO.<br>    60149766                                                                                                                                                                                     |   | REV.<br>H                                                      |
|----------------------|----------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|----------------------------------------------------------------|
|                      |                                                    | CONTENTS (CONTINUED)                                                                                                                                                                                          |   | PAGE                                                           |
| SECTI(<br>7.1<br>7.2 | General                                            | RELIABILITY AND MAINTAINABILIT<br>Requirements<br>ance Features                                                                                                                                               | Y | 86<br>86<br>86                                                 |
|                      | 7.2.3<br>7.2.4<br>7.2.5<br>7.2.6<br>7.2.7<br>7.2.8 | Error Checking and Reporting<br>Internal Loopback<br>Statistic Gathering<br>LAC RAM Load/Dump<br>FCS Checking<br>Adapter RAM Access<br>Remote Loopback<br>MAC Internal Status<br>Remote Station Inquiry (XID) |   | 86<br>86<br>87<br>87<br>87<br>87<br>87<br>87<br>87<br>87<br>87 |
| 7.3<br>7.4           |                                                    | nability<br>d Address Space Assignments                                                                                                                                                                       | : | 88<br>89                                                       |
|                      |                                                    | Overall Maps<br>Dedicated RAM Area Layouts                                                                                                                                                                    |   | 89<br>91                                                       |
| APPENI               | DIX A                                              | TOKEN BUS ADAPTER                                                                                                                                                                                             |   | 93                                                             |
| A.1                  | General                                            | Description                                                                                                                                                                                                   | • | 96                                                             |
| APPENI               | DIX B                                              | CSMA/CD (ETHERNET) ADAPTER                                                                                                                                                                                    |   | 96                                                             |
| B.1                  | General                                            | Description                                                                                                                                                                                                   |   | 98                                                             |
| APPENI               | DIX C                                              | TOKEN RING ADAPTER                                                                                                                                                                                            |   | 98                                                             |
| C.1                  | General                                            | Description                                                                                                                                                                                                   |   | 98                                                             |
|                      |                                                    |                                                                                                                                                                                                               |   |                                                                |

# HONEYWELL CONFIDENTIAL & PROPRIETARY

C

| HONEYWELL |     | SPEC. NO. | 1 | SHEET | REV. | 1 |
|-----------|-----|-----------|---|-------|------|---|
|           | i i | 60149766  | I | 2.3   | i H  | I |

# ILLUSTRATIONS

| FIGURE                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                               | PAGE                                                                       |
|-----------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------|
| 2-1<br>2-2<br>2-3<br>2-4<br>2-5<br>2-6<br>2-7<br>2-8<br>2-9<br>2-10<br>2-11                                     | LACS Applications to Local Area Networks<br>LACS Applications<br>LAC Block Diagram<br>LAC RAM Memory Map<br>LAC Operating Structure<br>LLC Transmit Flow<br>LLC Receive Flow<br>I/O Dispatch Process<br>Memory DMA Process<br>Adapter Interrupt<br>Adapter-Specific MAC Processes                                                                                                                                                             | 8<br>9<br>12<br>14<br>19<br>26<br>28<br>33<br>34<br>35<br>36               |
| <br>3-1<br>3-2<br>3-3<br>3-4<br>3-5<br>3-6<br>3-7<br>3-8<br>3-9<br>3-10<br>3-11<br>3-12<br>3-13<br>3-14<br>3-15 | LCB Format for Load/Dump<br>LCB Format for Start I/O<br>DMA Request/Confirm<br>DMA Request/Confirm<br>DMA Request/Confirm<br>DMA Request/Confirm<br>Retry Dispatch Table Request/Confirm<br>L6 Buffer List<br>Data Transmit/Fault Indicate<br>Fault Indicate Status From Data Transmit<br>Event Indicate Message Block<br>IODISP Dispatch Table Setup<br>IOLD Information Message Block<br>Data Indicate Message Block<br>LMI Request/Confirm | 50<br>51<br>58<br>59<br>60<br>61<br>62<br>63<br>66<br>71<br>76<br>78<br>79 |
| 4-1<br>4-2                                                                                                      | LAC-Adapter Bus<br>Test Connector                                                                                                                                                                                                                                                                                                                                                                                                             | 82<br>83                                                                   |
| 7-1<br>7-2<br>7-3<br>7-4<br>7-5                                                                                 | Address Space Layout During QLT<br>Address Space Layout During Normal Operation<br>I/O Order Temporary Queue<br>Configuration Information Area<br>LAC Error Status                                                                                                                                                                                                                                                                            | 89<br>90<br>91<br>92<br>92                                                 |
| A-1                                                                                                             | Token Bus Block Diagram                                                                                                                                                                                                                                                                                                                                                                                                                       | 94                                                                         |
| B-1                                                                                                             | CSMA/CD (ETHERNET) Block Diagram                                                                                                                                                                                                                                                                                                                                                                                                              | 97                                                                         |
| C-1                                                                                                             | Token Ring Block Diagram                                                                                                                                                                                                                                                                                                                                                                                                                      | 99                                                                         |
|                                                                                                                 | TABLES                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                            |
|                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                            |

| 2-1 | Software | Event | Notification | Codes |
|-----|----------|-------|--------------|-------|
|     |          |       |              |       |

# HONEYWELL CONFIDENTIAL & PROPRIETARY

43

| HONEYWELL | 1 | SPEC. NO. | SHEET | REV | 1 |
|-----------|---|-----------|-------|-----|---|
| 1         | 1 | 60149766  | 3     | Н   | 1 |
|           |   |           |       |     |   |

SECTION 1

INTRODUCTION

# 1.1 DOCUMENT DEFINITION

This document defines the functional characteristics and program-visible architecture of the Local Area Controller Subsystem (LACS).

# 1.2 <u>REFERENCE DOCUMENTS</u>

| 1.     | 60149824   | DPS6 Local Area Network Controller PFS                                                                            |
|--------|------------|-------------------------------------------------------------------------------------------------------------------|
| 2.     | 58088015   | Local Area Networks Global Functional Spec.                                                                       |
| 3.     | CC71       | Level 6 Minicomputer Handbook                                                                                     |
| 4.     | DSA-41     | Local Area Networks                                                                                               |
| 5.     | IEEE 802.1 | Local Area Network Overview, Rev. B, June<br>1983                                                                 |
| 6.     | ISO 7498   | Open System Interconnection Ref. Model                                                                            |
| 7.     | IEEE 802.2 | Local Area Network Logical Link Control,<br>Draft E, March 1984                                                   |
| 8.     | IEEE 802.3 | Local Area Network CSMA/CD Access, July 1983                                                                      |
| 9.     | IEEE 802.4 | Local Area Network Token Bus Access, Draft E,<br>July 1983                                                        |
| 10.IEE | E 802.5    | Local Area Network Token Ring Access, Draft<br>9/23/83                                                            |
| 11.    |            | Ethernet Specification, Version 2.0<br>(Digital Equipment Corp., Intel Corp.,<br>Xerox Corp.)                     |
| 12.    | B01.08     | HIS Standard, Operating Environment                                                                               |
| 13.    |            | HIS Standard, Equipment Safety                                                                                    |
| 14.    | D.002.01   |                                                                                                                   |
| 15.    |            | MRX Megabus EPS-1                                                                                                 |
| 16.    | MTG2       | PWA Test Documentation Requirements                                                                               |
| 17.    | MTG3       | PWA Test Documentation Requirements<br>PWA Microdiagnostic Creation                                               |
| 18.    | MTG5       | QLT Creation                                                                                                      |
|        |            | T&V Creation                                                                                                      |
| 20.    | 58035052   | Worldwide Maintenance Requirements                                                                                |
| 21.    |            | MC68000 User's Manual (Motorola                                                                                   |
|        | (AD2)      | Semi-conductor Products, Inc.)                                                                                    |
| 22.    | 60126298   | Level 6 Bus (Megabus) EPS-1                                                                                       |
|        | 03860507   | Purchase Specification for RF Modem                                                                               |
| 24.    |            | 82586 Reference Manual (INTEL Corp.)                                                                              |
| 25.    | 09-0016-00 | ESPL Software Technical Reference Manual,<br>Vol. 1, Kernel and Support Software (Bridge<br>Communications, Inc.) |
| 26.    | 60149817   | LAN Software EPS-1                                                                                                |
|        |            |                                                                                                                   |

HONEYWELL CONFIDENTIAL & PROPRIETARY

٩

| HON<br> | IEYWELL |            |                         | SPEC. NO.<br>60149766 |             | REV<br>  H | <br> <br>(* |
|---------|---------|------------|-------------------------|-----------------------|-------------|------------|-------------|
| 1.3     | ABBREVI | ATION      | S/DEFINITIONS           |                       |             |            | No.         |
|         | ACK     | -          | Positive Ackn<br>EPS-1) | owledgement           | (as defined | by the L6  | Bus         |
|         | СМ      | -          | Controller Ma           | nagement (So          | oftware)    |            |             |
|         | CRC     |            | Cyclic Redund           |                       |             |            |             |
|         | CPU     | -          | Central Proce           |                       |             |            |             |
|         | CS      | -          | Communication           |                       | oftware)    |            |             |
|         | CSMA/CD | -          | Carrier Sense           |                       |             | ion Detect |             |
|         | DMA     | -          | Direct Memory           | Access                | •           |            |             |
|         | DA      | -          | Destination A           |                       |             |            |             |
|         | DSAP    | -          | Destination S           |                       | ss Point    |            |             |
|         | FC      | -          | Function Code           |                       |             |            |             |
|         | FIFO    | -          | First-In-Firs           |                       | ;           |            |             |
|         | GA      | -          | Group Address           |                       |             |            |             |
|         | ICW     | -          | Interrupt Con           |                       |             |            |             |
|         | IORB    |            | Input/Output            |                       | ck          |            |             |
|         | ID      | <b>-</b> . | Identificatio           |                       |             |            |             |
|         | IF      |            | Interface (So           | ftware)               |             |            |             |
|         | I/O     | -          | Input/Output            | -                     |             |            |             |
|         | IOLD    |            | Input/Output            | Load                  |             | •          |             |
|         | LAC     | -          |                         |                       |             | • •        |             |
|         | LACS    |            | Local Area Co           | ntroller Sul          | bsystem     |            |             |
|         | LAN     | -          | Local Area Ne           | twork                 |             |            |             |
|         | LCB     |            | LAN Control B           | lock                  |             |            | (           |
|         | LCBI    | -          | LAN Control B           | lock Image            |             |            | 6           |
|         | LLC     | -          | Link Layer Co           | ntrol                 |             |            |             |
|         | LME     | -          | Layer Managem           | ent Entity            | •           |            |             |
|         | LMI     | -          | Layer Managem           | ent Interfa           | ce          |            |             |
|         | LSAP    | -          | Link Service            | Access Point          | t           |            |             |
|         | LSI     |            | Large Scale I           | ntegration            |             | •          |             |
|         | MAC     | -          | Media Access            | Controller            |             |            |             |
|         | MBZ     | -          | Must be Zero            |                       |             |            |             |
|         | MSB     | -          | Most Signific           | ant Byte              |             |            |             |
|         | MSb     | -          | Most Signific           |                       |             |            |             |
|         | MTBF    | -          | Mean Time Bet           |                       | es          |            |             |
|         | MTTR    |            | Mean Time To            |                       |             |            |             |
|         | NAK     | -          | Negative Ackn<br>EPS-1) |                       | (defined by | the L6 Bu  | 5           |
|         | ORU     |            | Optimum Repla           | ceable Unit           |             |            |             |
|         | OS      | -          | Operating Sys           | tem                   |             |            |             |
|         | OSI     |            | Open Systems            |                       | tion        |            |             |

|           |  |           |       |     | - |
|-----------|--|-----------|-------|-----|---|
| HONEYWELL |  | SPEC. NO. | SHEET | REV |   |
| 1         |  | 60149766  | 5     | Н   | I |

1.3 <u>ABBREVIATIONS/DEFINITIONS</u> (Continued)

| PC    |            | Personal Computer                         |
|-------|------------|-------------------------------------------|
| PIO   | -          | Physical Input/Output                     |
| PROM  | -          | Programmable Read-Only Memory             |
| PDU   | -          | Protocol Data Unit                        |
| QLT   | -          | Quality Logic Test                        |
| RAM   | -          | Random Access Memory                      |
| RFU   | -          | Reserved for Future Use                   |
| RHU   | -          | Reserved for Hardware Use                 |
| RSU   | -          | Reserved for Software Use                 |
| SA    | -          | Source Address/Station Address            |
| SC    | -          | Service Call                              |
| SMDSI | -          | Systems Management Data Service Interface |
| SSAP  | -          | Source Service Access Point               |
| TBD   | <b>-</b> . | To Be Defined                             |
| TC    | -          | Trunk Coupler                             |
| T&V   | -          | Test and Verification                     |
| WS    | -          | Work Station                              |



| HONEYWELL | SPEC. NO. | SHEET | REV | ł |
|-----------|-----------|-------|-----|---|
|           | 60149766  | 6     | Н   | 1 |
|           |           |       |     |   |

SECTION 2 ARCHITECTURE

#### 2.1 OVERVIEW

The Local Area Controller Subsystem (LACS) is a programmable communications subsystem that connects to the Level 6 Megabus. LACS comprises the following set of communications components:

- o Local Area Controller (LAC) Motherboard
- o Media Access Controller (MAC) & Physical Layer Adapters
- o Trunk Couplers (TCs)
- o RF Modems

This specification is concerned with the definition and description of the first two items above (i.e., the LAC and the adapters).

With suitable software loads and hardware/ adapter selection, the LACS is intended to be capable of supporting any of the IEEE 802 Local Area Network Standards.

The design of the LACS minimizes the interactions required over the Level 6/LACS interface and isolates the LACS on-board communications software from the specific hardware characteristics of the Level 6 and LAN adapter interfaces via supporting interface software.

A communications kernel based on one by Bridge Communications Inc., is used as the O.S. within the LAC. In this specification "CS Software" (Communication Service) refers to LAC-resident software which implements the OSI Link, Network, and Transport layers; "SM Software" (System Management layer instance) refers to LAC-resident software which supports IEEE802 System Management functions. CS and SM software will be written in "C" language by Honeywell Software Development and is the subject of a separate EPS-1.

"IF Software" (InterFace) refers to LAC-resident software which provides interfacing support between the CS and SM software and the LACS hardware. IF software will be written in "C" and assembly language by Honeywell Hardware Development and its functionality and interfaces are described in this specification. The Term "LAC Software" refers to all LAC-resident software (O.S. Kernel, CS SM and IF).

| HONEYWELL | SPEC. NO. | SHEET | I REV |   |  |  |
|-----------|-----------|-------|-------|---|--|--|
|           | 60149766  | 7     | H     | 1 |  |  |
|           |           |       |       |   |  |  |

Although the IEEE 802 Standard goes no higher than a standard data link control interface (Layer 3/Layer 2), the Level 6-to-LACS interface that is provided is so heavily software-defined and flexible as to be readily adaptable to support of higher (e.g. Session/Transport) layer interfaces (with suitable Level 6 and CS software).

The LACS, used for all Local Area Network (LAN) applications, is mounted in a standard Level 6 chassis and requires one slot on the Megabus; it will support the 32-bit address bus of the larger Level 6 systems. The LAN adapters provide an interface from the LAC to the LAN. The adapter (a daughterboard) includes a Media Access Controller (MAC). The LAC provides for the attachment of up to four adapter daughterboards.

The adapters are of several types (e.g., Token Bus MAC, CSMA/CD MAC, etc.).

The TCs are of several types (for example, broadband directional coupler, token ring TCU, Ethernet transceiver) and are packaged as separate units. The RF modem, used for broadband applications, is also separately packaged.

Because of its ability to support adapters of similar or dissimilar types, the LACS (with appropriate LAC software) can be used not only for 802 LAN connection with a Level 6 but also in future as a gateway between 802 LANS, or, in the case of broadband LANs, as a bridge between broadband channels. Other applications for the LACS could be as LAN traffic monitor/journalizer and network control. The CS and SM software would, of course be tailored for each application; it is expected that the IF software and O.S. Kernel will be used in all applications.

Figure 2-1 shows a Local Area Network with LACS providing connections for Level 6 systems, for workstation LAN access, and for Gateway between LANs; Figure 2-2 shows various configurations of the LACS. A maximum of two ports are shown in use.

| HONEYWELL | <br>I | SPEC. NO. | SHEET | REV |   |
|-----------|-------|-----------|-------|-----|---|
| 1         | 1     | 60149766  | 8     | I H | 1 |
|           |       |           |       |     |   |



Figure 2-1 LACS APPLICATIONS TO LOCAL AREA NETWORKS



HONEYWELL CONFIDENTIAL & PROPRIETARY

٥

| HONEYWELL |   | SPEC. NO. | SHEET | REV | 1 |
|-----------|---|-----------|-------|-----|---|
| 1         | 1 | 60149766  | 10    | H   | 1 |

# 2.2 SECURITY

No encryption/decryption functionality is defined for the LACS for the following reasons:

- 1. The IEEE 802 Standards do not specify any link layer or station encryption technique.
- 2. For a LAN, the use of the National Bureau of Standards Data Encryption Standard (DES) would be better applied at the Session or Presentation layer.
- 3. Key management on a LAN at the link layer presents many logistical problems with a DES technique. It would seem there is a good possibility that if an encryption technique is defined for LAN use, it will be based on some kind of Public Key scheme applied by the station.
- 4. Standards for Public Key systems do not exist at present.

### 2.3 MULTIPROCESSOR SUPPORT

The LAC provides for multiprocessor central systems (having up to 16 processors) in its I/O interface. Each I/O command block (LCB) issued to the LACS will contain fields which indicate the channel number of the CPU which is to be interrupted on completion of the function called for and the interrupt LEVEL to use. The LAC Software retains this information while carrying out the operation.

LAC hardware provides an interlock mechanism to handle the problem of two or more CPUs attempting to issue IOLDs (with Function Code 09/OD) simultaneously to the LAC. Further details are in subsection 3.2.2.

LAC hardware provides the specific capabilities required for connection to the multiprocessor type Megabus as well as to a monoprocessor type Megabus. Further details are in subsection 4.1.

| HONEYWELL | 1 | SPEC. NO. | SHEET | REV | 1 |
|-----------|---|-----------|-------|-----|---|
| 1         | l | 60149766  | 11    | Н   | 1 |

### 2.4 LOCAL AREA CONTROLLER (LAC)

The LAC, via hardware, software-generated parameters and CS software, provides OSI layer functions such as sequencing of outgoing frames, error control and retransmission, sequence checking of incoming frames and statistics gathering.

There are three software-visible interfaces associated with the LACS which are described in this specification: the CS/SM Software - IF Software interface in operations with the CPU and main memory; the CS/SM Software- IF Software interface in operations with the attached adapter(s) and the LACS I/O Order interface as seen by the LACS Driver in the CPU.

The operations of the three interfaces listed above and a brief description of the physical organization of the LAC are covered in the remainder of this Section. Further details of the physical organization of the LACS and its physical interfaces are covered in Section 4, 6, and 7 and in the appendices.

| HONEYWELL | 1 | SPEC. NO. | SHEET | REV | 1 |
|-----------|---|-----------|-------|-----|---|
| 1         | l | 60149766  | 112   | H   | 1 |
|           |   |           |       |     |   |

## 2.5 LAC BLOCK DIAGRAM

A block diagram of the LAC is shown in Figure 2-3.

The LAC uses a commercially popular microprocessor (MC68000) and presents that microprocessor's bus to the adapters.



Figure 2-3 LAC BLOCK DIAGRAM

HONEYWELL CONFIDENTIAL & PROPRIETARY

۵

| HONEYWELL | I | SPEC. NO. | SHEET | REV | 1 |
|-----------|---|-----------|-------|-----|---|
|           | l | 60149766  | 13    | H   | 1 |
|           |   |           |       |     |   |

The RAM is physically separated into two sections: a data buffer RAM and program RAM. The intent of the separation is to allow for simultaneous DMA of data in the data buffer RAM with the Level 6 memory or with the LAN adapters along with software execution in the program RAM. The Bus Coupler allows for simultaneous independent operation of the MC68000 busses on each side, yet permits the microprocessor to perform accesses to any location in the total RAM.

The DMA controller is a two-channel device; one channel is used by the microprocessor to perform the DMA movement of data between main memory and the data buffer RAM. The other channel is used to accept I/O order information from the Megabus and deliver it to a temporary queue in the data buffer RAM for further analysis and disposition by firmware or IF software.

The timer device provides the basic clock tick for the LAC operating system to use in providing timer functions for LAC software .

DMA functionality for the adapters is provided by hardware located on the adapters themselves. Adapter DMA is always into or out of the data buffer RAM.

Data movement between the program RAM and the data buffer RAM is performed directly by the MC68000 microprocessor; data movement between the program RAM and main memory (as in Load/Dump operations) is performed in two steps: a movement between program RAM and data buffer RAM under control of the microprocessor, and a movement between data buffer RAM and main memory performed by the DMA controller.

| HONEYWELL |   | SPEC. NO. | SHEET | REV | 1 |
|-----------|---|-----------|-------|-----|---|
| i ·       | I | 60149766  | 14    | Н   | I |

### 2.6 MEMORY LAYOUT

The Software-visible layout of the LAC RAM as it exists during normal running is shown in Figure 2-4.



Figure 2-4. LAC RAM MEMORY MAP

The first 1K words contain the MC68000 Exception and Trap vectors. The address of the top of software-useable Program memory may vary depending upon how much Program RAM is physically installed (64K or 256K words). The PROM-resident QLT routines will locate this address and save its value in RAM (see Figure 7-4).

The physical base of the Data Buffer RAM occurs at the location where the Most Significant Bit of the word address becomes a One.

| HONEYWELL |   | SPEC. NO. | SHEET | REV | 1 |
|-----------|---|-----------|-------|-----|---|
|           | i | 60149766  | 115   | Í Н | i |
| ,         |   |           |       |     |   |

The address of the top of software usable Data Buffer memory may vary depending upon how much Data Buffer RAM is physically installed (64K or 256K words). This address is ascertained by PROM-resident QLT routines and is saved in RAM (see Figure 7-4).

Software should not perform Test and Set (TAS) instructions on locations in Data Buffer RAM as this may cause a collision with a DMA operation and result in a Bus Error exception. This is a fatal error and its handling is described in Subsection 3.9.

Movement of information to or from main memory may be performed with any LAC RAM locations as an aid to troubleshooting, status/statistic gathering, or other control purposes. However, it should be noted that DMA to or from the Program RAM requires active support from the microprocessor; thus, routines must be executed by the microprocessor in performing such a DMA operation; the Load/Dump Operation and the Memory DMA process provide this function as needed.

If a microprocessor program attempts an access to non-existent program/buffer RAM, a Bus Error exception will occur. This is a Fatal error and its handling is described in Subsection 3.9. If a DMA controller channel or an adapter attempts to access non-existent data buffer RAM, the fact will be indicated in status returned by the IF software on completion of the DMA operation.

The RHU (Reserved for Hardware Use) areas of RAM should not be addressed by CS, SM or O.S. software as they may contain pointers and status required by the hardware and IF software. Thus CS, SM and O.S. software should restrict itself to use of the software-visible areas described in this subsection.

It should be noted that although hardware-specific details are included in this specification, they are not sufficiently complete to permit writing of CS/SM software which does not make use of the HIS-provided IF software support which is described in this specification.

Parity is provided in both LACS RAMS. If a DMA Controller channel or an adapter access to data buffer RAM causes a Parity Error the fact will be indicated in status returned by the IF software on completion of the DMA operation. If a RAM Parity Error Occurs on an Access by the microprocessor the condition is handled as described in Subsection 3.9.

| HONEYWELL | SPEC. NO. | SHEET | REV | 1 |
|-----------|-----------|-------|-----|---|
| Î I       | 60149766  | 116   | H   | 1 |
|           |           |       |     |   |

### 2.7 LAC MEMORY MANAGEMENT

In order to utilize the LAC RAM efficiently, memory management functionality is provided through procedure calls to the Operating System (O.S.) O.S. memory management applies only to the software-visible RAM described in subsection 2.6. O.S. memory management uses both a memory block and memory buffer allocation scheme; it maintains a list of free blocks and free buffers of various sizes from which it allocates blocks and buffers on request (ALLOCATE call or GETBUF call). When no longer needed, blocks and buffers may be returned to the free list by another call (MFREE or FREEBUF).

Ownership of buffers may be passed between LAC processes via mailbox messages. Ownership of the block containing a mailbox message is also passed when a process sends the message to another process.

To guard against exceeding the memory space availability of the LAC or of having one user or function monopolize the available space, the CS software in the LAC and the LAC Driver software in the CPU jointly implement a flow control mechanism as described in the LAN software EPS-1.

| HONEYWELL | 1 | SPEC. NO.                                | SHEET | REV | 1   |
|-----------|---|------------------------------------------|-------|-----|-----|
|           | 1 | 60149766                                 | 117   | H H |     |
|           |   | . الله الله الله الله الله الله الله الل |       |     | 🖌 🏒 |

#### 2.8 LAC SOFTWARE-FIRMWARE-HARDWARE STRUCTURE

### 2.8.1 General

Figure 2-5 represents the structural relationships of the O.S., the CS software, the SM software, the IF software and the hardware.

The Figure reflects the thrust of the functionality described throughout this specification in which CS and SM software does not directly control the LAC hardware but instead interfaces with it through IF Software processes and routines. This IF Software isolates the CS and SM software from the particular characteristics of the hardware so that future reimplementations of hardware (e.g, with larger-scale LSI parts) need not affect that software. All LAC Software is loaded into the LAC RAM.

In this specification IF software is described as consisting of processes or interrupt routines according to whether the particular piece of software is invoked by a mailbox message being sent to it or is normally invoked by the occurrence of an interrupt from the LAC hardware. From the viewpoint of the O.S., these IF "interrupt routines" are either associated with an IF mailbox-invoked process or are a process which consists essentially of only an interrupt agent.

The IF software MEMDMA and IODISP processes have associated with them a Megabus Layer Management Entity (MBLME) to which those processes report various unusual events or faults. MBLME may in turn report certain of these events to SM software; it also serves generally as the intermediary between SM and those processes.

The IF software MAC processes consist of a MAC Transmit, Receive, and Layer Management process for each physically attached adapter. The MAC layer Management process(es) perform functions analogous to those of MBLME.

CS software provides Transport, Network, and Link layer functions for the LAN connection(s). Each of these layers and layer instances has a layer management entity associated with it which performs functions analogous to MBLME.

SM software provides overall control and system status reporting for the LACS layer management entities and with System Management software in the CPU.

O.S. Kernel software provides service functions such as timers and controls the dispatching of processes and passing of mailbox messages. The handling of error responses from the Kernel for the various procedure calls sent to it by CS and IF software is given in Subsection 2.19.

The LAC also contains some PROM-resident firmware which provides for QLTs, RAM load/dump and basic I/O orders. Figure 2-5 does not show the PROM-resident firmware. HONEYWELL CONFIDENTIAL & PROPRIETARY

|           |   |           |       |     | - |
|-----------|---|-----------|-------|-----|---|
| HONEYWELL | 1 | SPEC. NO. | SHEET | REV | 1 |
|           | l | 60149766  | 18    | H H | 1 |
|           |   |           |       |     |   |

#### 2.8.2 Interprocess Communications

Mailbox messages, sent via the SENDMSG Procedure Call, are the means whereby one process may send a message or request service of another process. They are also the means whereby the occurrence of asynchronous events or the completion of asynchronous services are made visible to the software so that software processing can proceed to its next step.

The called process will retrieve messages sent to its mailboxes via the RECEIVE or BRECEIVE Procedure call.

Software processes may obtain the ID of their own mailboxes via the MYID macro; they may obtain the ID of another process' well-known registered mailbox via the RESOLVE procedure call.

#### 2.8.3 Relative Process Priorities (Normal Running)

Figure 2-5 generically names the CS and SM Software processes, and gives the names of the IF software processes. IF software also includes associated interrupt and exception-handling routines.

During normal running after start-up, processes associated with data Receive operations must have higher priority than those associated with data Transmit operations so as to minimize loss of messages and consequent retransmissions.

Among these Receive processes, the MAC Receive process(es) must be the highest priority so that as Receive buffers are used by the hardware adapter(s) they may be quickly replaced by the MAC Receive Process(es) so that other messages may be accepted. Simulations have shown that the remaining data Receive processes (Link, Network, and Transport) work well at an equal priority among themselves. The MEMDMA IF software process seems to give best performance at the same priority as these three Receive processes.

Among the data Transmit processes, simulations have shown that the MAC Transmit process(es) should be highest followed in decreasing order by LLC Transmit, Network Transmit and Transport Transmit.

In summary, the data handling process priorities in decreasing order of priority should be:

- 1. MAC Receive
- 2. LLC Receive, Network Receive, Transport Receive, MEMDMA
- 3. MAC Transmit
- 4. LLC Transmit
- 5. Network Transmit
- 6. Transport Transmit

|               | <br>                    |       |            |  |
|---------------|-------------------------|-------|------------|--|
| HONEYWELL<br> | SPEC. NO.<br>  60149766 | SHEET | REV<br>  H |  |
|               |                         |       |            |  |

For the remaining LAC processes, IODISP, the Layer Management processes, and System Management, a fairly high priority seems reasonable.

There may be a different priority relationship among the processes during the initial running of the CS and IF processes. As the processes complete their initial run, they may set themselves to their normal running priority via PROPRIORITY procedure calls.



Figure 2-5.

LAC OPERATING STRUCTURE

| HONEYWELL | SPEC. NO. | SHEET | REV | 1 |
|-----------|-----------|-------|-----|---|
|           | 60149766  | 20    | H   | 1 |
|           |           |       |     |   |

### 2.9 MAILBOXES AND MAILBOX MESSAGE QUEUES

Mailbox messages are the means of inter-process communication.

In order that RAM blocks used for mailbox messages may be reused freely, a common block size should generally be used for mailbox message blocks.

Queues of mailbox messages may be built up on any mailbox using OS facilities. The process which owns the mailbox picks up each message for processing; the act of picking up a message deletes it from the queue. Each message consists of an OS-defined header and a message body. The format and content of messages sent between CS or SM software, and IF Software is given in Section 3.

### 2.9.1 Mailboxes Associated with IF Software

During the running of the Kernel's "init" process at startup (Subsection 2.17), mailboxes are set up for IF software processes MBLME, IODISP, and MEMDMA, in the well-known mailbox list. The string name of these mailboxes is the same as the process name.

The SM and CS processes will obtain the mailbox ID of MBLME, IODISP, and MEMDMA, processes by means of RESOLVE procedure calls; they will send mailbox messages to IODISP to provide mailbox IDs for IODISP's Dispatch table.

| HONEYWELL | SPEC. NO. | SHEET | REV |  |
|-----------|-----------|-------|-----|--|
| 1         | 60149766  | 21    | H H |  |

### 2.9.2 Mailbox Message Priorities

The Bridge O.S. provides a number of priorities for mailbox messages which affect the relative position of messages in a mailbox queue. The available message priorities are URGENT, NORMAL, MUST DELIVER, and FAST.

Simulations have shown that CS processes should use an URGENT Priority for receive-related requests to the Memory DMA process whereas they should use a NORMAL priority for transmit-related Memory DMA requests.

Requests for control operations on adapters should probably use URGENT priority; data transmit requests addressed to MAC processes may all use NORMAL priority since the process will queue data messages by Service Class.

## 2.10 LAN CONTROL BLOCK

The LAN Control Block (LCB) is the prime vehicle of intercommunication between the Level 6 CPU and the LACS. One particular form of LCB is used in connection with the PROM-resident firmware-supported Load/Dump operations as shown in Figure 3-1; other forms are used for communication between software in the CPU and CS software in the LAC and these are described in the LAN Software EPS-1. LCBs are constructed in main memory by the LAC Driver software and are interpreted and executed in the LAC.

### 2.11 LAC SOFTWARE INTERFACE TO THE MEGABUS

The CS/SM software interface with the Megabus is supported through mailbox messages received from the IF software I/O Dispatch process and through mailbox messages sent to the IF Software Memory DMA process. The mailbox messages received consist essentially of pointers to LCBs (subsection 2.9) in main memory. The mailbox messages to the Memory DMA process are used to cause movement of data between main memory and the LAC Data Buffer RAM, or to read in LCBs, or to write status type information into LCBs in memory and interrupt the CPU.

# 2.12 CS SOFTWARE INTERFACE WITH ADAPTERS

The CS/SM software interface with adapters is supported through mailbox messages generated by the IF Software MAC processes (i.e. Data Indicate and Control Indicate) and through mailbox messages sent to IF Software MAC processes.

| HONEYWELL | 1 | SPEC. | NO.  | SHEET | REV | 1 |
|-----------|---|-------|------|-------|-----|---|
|           | ł | 6014  | 9766 | 22    | H   | 1 |

#### 2.13 SOFTWARE INTERFACE BETWEEN LEVEL 6 AND LACS

The software interface between Level 6 and the LACS during normal running uses IOLD orders addressed to the LACS and return status information delivered to main memory by the LAC accompanied by interrupts to the Level 6.

All of the data message and Administrative and Management operations are based on the use of LAN Control Blocks (LCBs) located in main memory and which are pointed to by information given in IOLD orders. The appropriate software process in the LAC will cause the LCB to be copied into the RAM as an LCB Image (LCBI), and after completing the requested operation, will cause final status to be delivered to the LCB. In carrying out the operation, the process will make use of various other processes.

Details of the software interface are given in the LAN software EPS-1.

As an aid to a general understanding of the intended operation of the LAC, the next two subsections describe the transmission and reception of a data message. Control functions related to setup of data transmissions and to Systems Management are then briefly mentioned. The functionality of IF Software operations and processes is described in Section 3.

2.13.1 Transmit Data Operation Flow

Figure 2-6 is a representation of the anticipated flow for a transmit data operation.

For purposes of this description, the starting point is assumed to be the IORB of the MOD 400 PIO software interface with higher level system software having effectively isolated the application from any LAN-specific characteristics.

In the following description, CS software is treated as if it consists of a single process in order to simplify the narrative.

CS software may provide support of Link, Network and Transport layer functionality. The IEEE 802 Standard includes only up to Link Layer definition; in IEEE 802 terms the operation described here is that which involves an L\_Data. request or L Data CONNECT. request primitive.

| يه جها هو |           |       |     |   |
|-----------------------------------------------|-----------|-------|-----|---|
| HONEYWELL                                     | SPEC. NO. | SHEET | REV | 1 |
| 1                                             | 60149766  | 23    | H   | 1 |
| ·                                             |           |       |     | ( |

In Step 1, the LACS Driver software in the CPU sets up the LCB in memory from information in the IORB. The LCB will contain information defining the processing and function required and parameters; it also contains physical address(es) and range(s) defining the buffer(s) in memory which contain the data to be sent. The LCB also includes space for return status from the LAC.

In Step 2, the LACS Driver issues an IOLD to the LACS. The address given with the order points to the LCB and the "Range" parameter contains two fields: the high order 8 bits are a Function Code field and the low order 8 bits define the size of the LCB. The IOLD information is taken off the Megabus and placed in a temporary queue by the LAC hardware DMA controller. This causes an interrupt which invokes the I/ODispatch process (IODISP) which inspects the order; having determined that the IOLD is valid, it uses the channel number in the order to reference a Dispatch table and determine where to route the order for further processing. In this case, the routine obtains a block of RAM (via an ALLOCATE call), places the LCB Pointer IOLD information in the block, and sends it (via a SENDMSG call) to a CS process mailbox. The format of the LCB Pointer IOLD information message block is shown in Section 3. If there are additional I/O orders in the queue, the I/O Dispatch process will handle these also. All message blocks obtained by the I/O Dispatch process must be returned to free memory by some other process (e.g. in Step 12).

In Step 3, a CS process is scheduled for execution by the O.S. (because of the mailbox message addressed to it); the process retrieves the mailbox message and, after securing a block of RAM for an LCB image (LCBI) sends a message to the mailbox of the Memory DMA Request process requesting DMA of the LCB into this LCBI. The CS process may then suspend itself if it has nothing else to do for the moment. The format of the message block sent to the Memory DMA process is shown in Section 3.

In Step 4, the Memory DMA Request process causes the DMA controller to copy the LCB into the LCBI. On completion of the operation, the controller interrupts the microprocessor and this causes the Memory DMA process to be re-invoked. This process places status information, shown in Section 3, in the message block which was sent by the CS process and then returns the block (via a SENDMSG call) to the specified return mailbox. Information originally placed in the RSU field of the block by the CS process in Step 3 allows it to identify the particular DMA operation which has been completed.

| HONEYWELL | SPEC. NO. | SHEET | REV |  |  |  |
|-----------|-----------|-------|-----|--|--|--|
| 1         | 60149766  | 24    | H   |  |  |  |
|           |           |       |     |  |  |  |

In Step 5, the CS process responds to the mailbox message of Step 4. After inspecting the LCBI and calculating the total of the L6 buffer ranges, it performs a GETBUF call to obtain a RAM buffer big enough to hold the data message; then it sends a mailbox message to the Memory DMA process to cause the movement of data from main memory to this buffer in RAM. The format of the message block is shown in Figure 3-4; the L6 buffer list is obtained from the LCBI and the LEVEL field should be zero.

In Step 6, the Memory DMA process causes the DMA controller to copy the data from main memory to the RAM buffer. The process will support a "gather" type DMA with respect to main memory, if required; with respect to the LAC RAM, DMA is always done on a logically single buffer. On completion of the DMA, the Memory DMA process is reinvoked and places status in the message block and returns it to the specified return mailbox (of the CS process).

In Step 7, the CS process responds to the mailbox message of Step 6. It sends a mailbox message to the Memory DMA process to cause it to set status complete in the LCB in memory and to interrupt the CPU. At some later time the LACS driver will post the completion into the IORB. If a message is to be sent over an IEEE 802 LAN, CS processes must create header fields and add this as prefix information to the RAM buffer. CS processes must also have left additional space at the beginning of the buffer for the MAC process to prefix its headers. A CS LLC process assembles a mailbox message and sends it to the appropriate MAC process. The format of the mailbox message block is shown in Figure 3-9. This constitutes the MA DATA.request of the IEEE 802 Standard.

In Step 8, the MAC Transmit process may queue the request if there are higher priority requests to be handled. As soon as it can, the process delivers the request to the adapter. The adapter completes prefixing of the message frame (SA and FC), and when media access rules permit, delivers a correctly formatted frame (including preamble, delimiters and FCS) to the LAN via the adapter's PHYS layer facilities. When transmission is complete, the adapter's DMA controller sends an interrupt to the microprocessor of the LAC.

In Step 9, the Adapter Interrupt routine invokes the MAC transmit Process which fetches final status from the adapter. The MAC Transmit process releases the RAM buffer (FREEBUF call). If there are other transmit requests pending the process will deliver one to the adapter.

| HONEYWELL | SPEC. NO. | SHEET | REV | 1 |
|-----------|-----------|-------|-----|---|
| 1         | 60149766  | 25    | H   | 1 |
|           |           |       |     |   |

Figure 2-6 shows the transmit flow just described. It should be noted that although the description and diagram present a single thread of flow for clarity, there are actually multiple threads being processed at various stages at any instant of time. Since each software process is written to try to complete all of its outstanding tasks, if possible, before voluntarily relinquishing the microprocessor, the number of context switches performed per message transmitted will tend to be less under typical load than when considering only a single message thread.

| HONEYWELL | I | SPEC. NO. | SHEET | REV | 1 |
|-----------|---|-----------|-------|-----|---|
| 1         | I | 60149766  | 26    | H   | 1 |
|           |   |           |       |     |   |



Figure 2-6 LACS TRANSMIT FLOW

|           |   |           |       |     | -   |
|-----------|---|-----------|-------|-----|-----|
| HONEYWELL | l | SPEC. NO. | SHEET | REV | 1   |
| 1         | 1 | 60149766  | 27    | H   | 1   |
|           |   |           |       |     | - / |

#### 2.13.2 Receive Data Operation Flow

The operation described here is that which involves an IEEE 802.2 L DATA.indication or L DATA-CONNECT.indication primitive of type 1 or type 2 operation.

For handling received messages, one of two schemes can be used depending on whether the application wishes to allocate a buffer only if and when a message is received from the LAN or whether it wishes to allocate a buffer in anticipation of a possible incoming message. In the first or Read-Notify case, two IOLDs must be issued and two interrupts must be sent to the CPU for each message and the time required in the CPU to obtain the buffer may cause performance problems. In the second case, main memory space requirements tend to be greater because of the buffers which are tied up waiting for a message.

The description of receive flow will not be given in as much detail as in the transmit case since the interactions of CS software processes, IF software processes, hardware interrupts, and interrupt firmware are similar.

For receive operation it is not necessary for CS software to request data buffers from memory management, as is the case for transmit operation. Instead, the IF Software MAC processes will automatically make available enough buffers for each adapter. After a valid message is received, the Data Indicate routine of the MAC process will pass the buffer to the proper CS process.

In the Read-Notify case, shown in Figure 2-7, CPU software issues a series of LCBs, which are called "Read-Notify" LCBs, to the LAC via Output LCB Pointer IOLD orders. These serve to provide LCBs which the CS software may use for notifying CPU software of the arrival of messages. When the arrival of a message has been indicated by this means, the CPU software will issue a Read LCB to specify where, in main memory, the message is to be placed and will also, in general, issue another Read-Notify LCB to replace the one which was used. This scheme allows the data to be input directly to the application's buffer. Read LCBs are differentiated from Read-Notify LCBs by some software-defined indication in the LCB itself.

|                                                       |   |           |       |     | - |
|-------------------------------------------------------|---|-----------|-------|-----|---|
| HONEYWELL                                             | 1 | SPEC. NO. | SHEET | REV | 1 |
| 1                                                     | 1 | 60149766  | 28    | H   | 1 |
| به هه هه چه چه هو هو هه چه سو هو هو چه هو هه هه خو خو |   |           |       |     | - |



Figure 2-7 LACS RECEIVE FLOW (READ-NOTIFY CASE)

|           |           |       | ه همه هیله دینه همه جده میزه همه همه همه هم هره ه |   |
|-----------|-----------|-------|---------------------------------------------------|---|
| HONEYWELL | SPEC. NO. | SHEET | REV                                               | 1 |
|           | 60149766  | 29    | Н                                                 | 1 |
|           |           |       | ·                                                 |   |

The sequence of operations is as follows:

In Step 1, the LACS Driver software in the CPU sets up the Read-Notify LCB in memory.

In Step 2, the LACS Driver issues an IOLD to the LACS pointing to the LCB. The DMA Controller in the LAC takes the IOLD information from the Megabus and places it in a temporary working queue and interrupts the microprocessor. In a manner similar to the transmit case, the I/O Dispatch process delivers the Read-Notify LCB Pointer IOLD information to a CS process.

In Step 3, the CS process issues a request for the Memory DMA process to copy the LCB into an LCBI in RAM, similar to the transmit case.

In Step 4, the DMA Controller copies the LCB into the LCBI and the CS process is notified of completion.

In Figure 2-7, the arrival of a message is labeled Step 5 for convenience. This should not be construed to imply that a message only arrives after the operations of Steps 1 through 4; message arrival is an independent occurrence.

In Step 5, a message arrives and is placed in the predefined buffer by DMA facilities of the adapter. On completion of this operation, the adapter interrupts the microprocessor, causing the Adapter Interrupt routine to invoke the MAC Receive process which performs an ALLOCATE call, to obtain a block of RAM for a mailbox message, places Data Indicate information in the block and sends it to the mailbox of the appropriate CS process. The ID of this mailbox has been previously made known to the MAC process. The format of the Data Indicate message block is shown in The MAC Receive process provides the adapter DMA Section 3. facility with replacement buffer(s) by performing GETBUF call(s).

| HONEYWELL | 1 | SPEC. NO. | SHEET | REV |   |
|-----------|---|-----------|-------|-----|---|
|           | 1 | 60149766  | 30    | H   | 1 |
|           |   |           |       |     |   |

In Step 6, a CS process consults its list of Read-Notify LCBs to see if there is one which pertains to the particular message just received. If there is none, the message is retained in RAM (however if some reasonable time passes without an appropriate LCB the process may be forced to discard the message). In the usual case, a CS process assembles information from the message header to be delivered to the LCB in memory, assembles a mailbox message block, and sends it to the Memory DMA process requesting DMA of this information into the Read-Notify LCB. In the message block, the CPU Chan and Intpt LEVEL fields reflect information given in the original IOLD and LCB as does the Chan No. (Also included is an identifier which the LACS Driver in the CPU can place in the Read LCB when it issues it).

In Step 7, the DMA controller delivers the information to the Read-Notify LCB and interrupts the microprocessor, causing it to re-invoke the Memory DMA process. This process now sends the requested interrupt to the CPU and when this has been accomplished returns the message block of Step 6 to the return mailbox (the CS process).

In Step 8, CPU software responds to the interrupt and, by consulting a list of outstanding IORBs or by other means, determines where in main memory the data message should be placed. The LACS Driver then sets up a Read LCB in memory. This LCB will contain the identifier of Step 6 (so that the CS process in the LAC can identify which data message is to be delivered) and specifies the main memory area(s) into which it is to be placed.

In Step 9, the LACS Driver issues an IOLD to the LACS pointing to the LCB. In the usual manner, the IF Software delivers the LCB Pointer information to the CS process.

In Step 10, the CS process issues a request for the Memory DMA process to copy the LCB into an LCBI in RAM.

In Step 11, the Memory DMA process copies the LCB into the LCBI and the CS process is notified of completion.

In Step 12, the CS process inspects the LCBI and determines that a Read operation is involved. The process calculates the total size of the L6 buffer and calculates a Range Residue value for LCB status and places final status in the LCBI; it then issues a request to the Memory DMA process to move the data message from RAM to main memory and to deliver final status from the LCBI to the LCB and to interrupt the CPU.

| HONEYWELL |   | SPEC. NO. | SHEET | REV | 1 |
|-----------|---|-----------|-------|-----|---|
|           | 1 | 60149766  | 31    | H   | - |
|           |   |           |       |     | - |

In Step 13, the DMA Controller copies the data from buffer RAM to main memory, performing a "scatter" DMA if required, under control of the DMA process. On successful completion of the data transfer the DMA process performs a Block transfer which copies the LCBI status into the LCB and interrupts the CPU. On completion of this the Memory DMA process return the mailbox message block to the return mailbox (the CS process).

In Step 14, the CS process may release the data buffer, the LCBI block and the mailbox message block.

Although the description and Figure present a single thread of flow for clarity, there are actually multiple threads being processed at various stages at any instant of time. Because each software process is written so as to try to complete all its outstanding tasks before relinquishing the microprocessor, the number of context switches performed per message received will be less under typical load than when considering only a single message thread.

In the Read LCB case, not shown in a Figure, the CPU issues IOLDS, which point to Read LCBs, each Read LCB includes pointer(s) to buffer(s) in system memory large enough to hold the largest possible message. Only one interrupt need be sent to the CPU, i.e, after the data and final status have been delivered.

2.13.3 Control Operations (during normal running)

Control operations may be divided into two general categories: functions which are involved with setting up, controlling flow, or terminating a connection to a remote user and System Management functions which are related to setting up, maintaining, and monitoring operation of the LAN itself.

| HONEYWELL | SPEC. NO. | SHEET | REV | 1 |
|-----------|-----------|-------|-----|---|
| 1         | 60149766  | 32    | H   | Ì |
|           |           |       |     |   |

The first category of functions is visible to the user or to higher-level software directly supporting the user. At the link-level interface, these functions consist of the L\_CONNECT, L\_DISCONNECT, L\_CONNECT\_FLOWCONTROL, and L\_RESET primitives. Although these functions do not involve any data transfer with higher level entities, they are handled essentially the same as in data transfer operations, using primitive codes which distinguish them from data operations. These functions generally involve link-layer messages between stations (e.g. SABM. DISC, etc.).

The second category of functions are not visible to a user or to higher-level software in support of the user. These encompass various management and administrative operations. These operations use an interface with the Level 6 which is based on the use of LCBs. The System Management functions are given in the LAN Software EPS-1). System Management performs the following operations:

- o Systems Management Data Service Interface (SMDSI) to a remote station via a LAN.
- o Layer Management Interface (LMI) to Layer Management Entities (LMEs) in the LACS.

| HONEYWELL | SPEC. NO. | SHEET | REV | 1 |
|-----------|-----------|-------|-----|---|
|           | 60149766  | 33    | Н   | E |
|           | •         | -     |     |   |

### 2.14 IF SOFTWARE FUNCTIONAL DIAGRAMS

Figures 2-8 through 2-11 are a set of flow charts whose purpose is to indicate in more detail the functional responsibilities of the various IF software processes and interrupt routines. The charts are not complete in all details and are not intended to necessarily represent how the detailed implementation of a process must be done. The flow of the CS and CM processes is given in the software EPS.



Figure 2-8 I/O DISPATCH

# I/O DISPATCH PROCESS (IF SOFTWARE)

| HONEYWELL | l | ł | SPEC. | NO.  | SHEET | REV | I |
|-----------|---|---|-------|------|-------|-----|---|
| 1         | 1 | I | 6014  | 9766 | 34    | H   | Ì |
|           |   |   |       |      |       |     |   |



\* If the LMA request includes both a Buffer Descriptor and a RAM Ptr, all the buffer xfers are done before the RAM block xfer.

Figure 2-9 MEMORY DMA PROCESS (IF SOFTWARE)

| HONEYWELL | 1 | SPEC. NO. | SHEET | REV |  |
|-----------|---|-----------|-------|-----|--|
| l         | I | 60149766  | 35    |     |  |
|           |   |           |       |     |  |



# Figure 2-10 ADAPTER INTERRUPT ROUTINE (IF SOFTWARE)

| مين هيه بينه بالله الله الله عنه الله الله الله الله الله الله الله ال |         |             |     |
|------------------------------------------------------------------------|---------|-------------|-----|
| HONEYWELL                                                              | SPEC. N | IO.   SHEET | REV |
|                                                                        | 601497  | 66 36       | H   |
|                                                                        |         |             |     |



Figure 2-11 ADAPTER-SPECIFIC MAC PROCESSES (IF SOFTWARE)

| HONEYWELL | 1 | SPEC. NO. | SHEET | REV | 1 |
|-----------|---|-----------|-------|-----|---|
|           | l | 60149766  | 37    | I H | 1 |

## 2.15 INTERRUPTS TO LEVEL 6

The Memory DMA process will send an interrupt to a CPU on successful completion of a DMA operation if the mailbox message which initiated the DMA operation so specifies. The mailbox message specifies the CPU number the interrupt level, and the LAC channel number to use; this information is obtained by CS software from the IOLD and LCB.

If the interrupt is rejected by the CPU, the Memory DMA process will put the interrupt in a Deferred Interrupt queue.

When a CPU indicates that it may be able to accept an interrupt (by a Resume Interrupt signal on the Megabus) an IF software interrupt routine, Interrupt Retry, will attempt to send the highest priority deferred interrupt of each CPU. Any interrupts that are not accepted are returned to the Queue.

Because of the way the Queue is operated, when an interrupt is accepted by a CPU, it may be an indication of completion of more than one IOLD-LCB. CPU software then must search through its list of outstanding LCBS; it can determine which have been completed by the completion status placed in them. Subsection 3.8.1.1 gives more detail on the Deferred Interrupt queue.

The CS software and the LAC Driver implement a completion sequence numbering scheme as detailed in the software EPS-1.

| HONEYWELL | 1 | SPEC. NO. | SHEET | REV | 1 |
|-----------|---|-----------|-------|-----|---|
|           | I | 60149766  | 38    | H   | 1 |
|           |   |           |       |     |   |

# 2.16 STATISTICS

The following physical connection statistics are maintained by the MAC Process on a per-physical-connection (i.e. LAN) basis and may be retrieved by System Management via its LMI interface with the MAC Layer Management Entity:

| TX-FRM  | : | Number of frames sent correctly         |
|---------|---|-----------------------------------------|
| PCEDA   | : | Number of Octets sent                   |
| RCV_FRM | : | Number of frames received correctly     |
| PCRDA   | : | Number of Octets received               |
| PCRGA   | : | Number of group-addressed PDUs received |
|         |   | correctly                               |
| PCRER   | : | (Calculated) total number of frames     |
|         |   | received incorrectly                    |
| UNR_ERR | : | Number of underruns                     |

A subset of the following physical connection statistics is maintained on a per-physical-connection (i.e. LAN) basis The particular subset is a function of the adapter type. The statistics may be retrieved by System Management via its LMI interface with the MAC Layer Management Entity.

| 0 | OVR ERR  | : | Number of overruns                      |
|---|----------|---|-----------------------------------------|
| ο | FCSERR   | : | Number of FCS errors                    |
| 0 | PCRĀB    | : | Number of received abort sequences      |
| 0 | ALN ERR  | : | Number of misaligned packets            |
| ο | BUFERR   | : | Number of packets lost due to no buffer |
| 0 | PCRLN    | : | Number of packets lost due to length    |
|   |          |   | error                                   |
| 0 | PCEBY    | : | Number of transmit deferrals            |
| 0 | PCECO    | : | Number of transmit aborts due to        |
|   |          |   | collision                               |
| 0 | PCRCL    | : | Number of collisions spoiling reception |
| 0 | PCNTR    | : | Number of token pass stations           |
| 0 | PCNTP    | : | Number of stations observed to pass     |
|   |          |   | token                                   |
| 0 | PCNPR    | : | Number of token pass repeats            |
| 0 | PCNJT    | : | Number of times use-token state entered |
| 0 | TOK_ROT  | : | Measured token rotation time            |
| 0 | ns –     | : | Next station/successor address          |
| 0 | PS       | : | Previous/predecessor address            |
| 0 | NMB_STN  | : | Number of stations in ring              |
| 0 | PCEER    | : | Number of frames aborted due to error   |
| ο | RTRY_ERR | : | Number of frames sent on second retry   |
| 0 | RTRY_RWR | : | Number of retries on                    |
|   |          |   | request-with-response frame             |

| HONEYWELL | 1 | SPEC. NO.                             | SHEET | REV | 1  |
|-----------|---|---------------------------------------|-------|-----|----|
| 1         | I | 60149766                              | 39    | Н   |    |
|           |   | · · · · · · · · · · · · · · · · · · · |       |     | († |

#### 2.17 LACS STARTUP

After the LACS has been powered up and initialized, it operates under control of firmware resident in the PROM. This firmware provides the QLTs which verify the basic operability of the LACS and supports IO and IOLD orders which permit the LACS to be identified, the LAC RAM to be loaded or dumped and LACS operation under software control to be started.

The CPU software should issue one or more Load IOLDs (Subsection 3.2.5.2) to cause the LAC to load the LAC software from main memory. On completion of the Load IOLD(s), CPU software should then issue a Start I/O (subsection 3.2.5.3) and then should not issue further IOLDs to the LAC until the Start I/O IOLD has been marked as completed (any IOLDs which are issued during this time will either be NAK'd or will have their LCBs marked with Invalid Function Status).

The Start I/O IOLD information is placed in a working area in RAM by the PROM-resident firmware. This firmware then relinquishes control of the microprocessor to LAC software in the Program RAM with software operation starting at the location specified in the Start I/O LCB.

The LAC microprocessor now commences execution of LAC software, specifically the Bridge kernel O.S. "main" routine. This leads to the creation of an O.S. initial process called "init" which creates and then registers a well-known mailbox for, each of the processes named in the init table (i.e. MEMDMA, IODISP, MBLME, SYS\_mgr). The init process then allows each of these processes to run in sequence according to their initial relative priorities.

As each process runs its initial routine it may establish mailbox interconnections with other processes and may spawn various layer instance processes as described in the LAN software EPS and LAN software component specifications. System Management sends each of the layer management processes a mailbox ID which will be retained in reserve by each process for possible need in certain trouble situations requiring an Event Notification as described in subsection 2.19. The IF Software processes, as part of their initial running, may equalize their priorities as mentioned in Subsection 2.8.3

٨

| HONEYWELL | 1 | SPEC | . NO. | SHEET | REV |   |
|-----------|---|------|-------|-------|-----|---|
| 1         | I | 601  | 49766 | 40    | Н   | 1 |

## 2.17 Continued

The IODISP process will also set up its Dispatch table from information it finds in its mailbox and then dispatches the Start I/O IOLD to the SM process via the Event Notification mailbox.

The SM process responds to the Start I/O mailbox message by requesting the MEMDMA process to copy the Start I/O LCB into RAM. When this has been done, MEMDMA so notifies SM (by returning the request mailbox message). The SM process then sends another DMA request to MEMDMA to cause completion status to be placed in the Start I/O LCB and an interrupt to be sent to the CPU. On completion of this the request mailbox message is returned to the Return mailbox.

The CPU software may now proceed to issue more IOLDs; some of these first IOLDs will undoubtably be for the purpose of setting up some current parameters for SM's use.

Note that the Start I/O applies to the LAC as a whole. Startup or shutdown of individual LAN communications is entirely a software function.

|           | ے کے ایک بڑی ہوں ہوں جن جو این این جو ایک بڑی ہیں جو جو جو جو جو جو این ہور جو جو جو جو جو جو جو |       |     |   |
|-----------|--------------------------------------------------------------------------------------------------|-------|-----|---|
| HONEYWELL | SPEC. NO.                                                                                        | SHEET | REV | 1 |
| 1 1       | 60149766                                                                                         | 41    | Н   | I |
|           |                                                                                                  |       |     |   |

A Stop I/O order is implemented in the LAC; this initializes the LAC and its adapters and returns control to the PROM-resident firmware but does not clear the LAC RAM.

Note that when the LAC is running under software control (after a Start I/O IOLD), any loading or dumping of RAM must be accomplished under CS or SM software control (i.e. not using the Load/Dump IOLD of subsection 3.2.5.2)

#### 2.18 TIMERS

Interval timers are provided via O.S. facilities. The timer tick interval is 50 miliseconds. The O.S. also provides means for performing timing functions shorter than one tick interval.

### 2.19 HANDLING OF SOFTWARE ERROR CONDITIONS

This subsection is concerned with the action to be taken by IF and CS software on the occurrence of an error response by the O.S. to a Procedure Call.

The scheme for handling those conditions is as follows:

- a. When an error response occurs, a SETALARM timer call is to be made for a period of (TBD) milliseconds if the type of error is due to a likely temporary condition (i.e. it is a recoverable error).
- b. After the time-out, if applicable, the original call should be retried.
- c. If, the error cannot be cleared by retry, it is classed as a Reportable Catastrophic error and the error is to be reported as an Event to the associated layer management entity using the mailbox Message format given in Figure 3-11 and Event Code given in Table 2-1.
- d. If the error cannot be reported it is an Unreportable Catastrophic error and, it is fatal. In this case, a trap is taken to a special routine which will set the Megabus logic to a state where it will not accept any I/O orders (except an Output LACS Control IO Order) and will mask interrupts. It is expected that the CPU will then eventually issue a Stop I/O order and dump the LAC RAM.

| ه دوره دوره هوه مده خوه هوه های خان کاه واله واله وره |   | یک سه مید مید مید مید مده مده شده مله مله می مرد مرد مرد مید مید م |       |     |   |
|-------------------------------------------------------|---|--------------------------------------------------------------------|-------|-----|---|
| HONEYWELL                                             | 1 | SPEC. NO.                                                          | SHEET | REV | 1 |
| l                                                     | l | 60149766                                                           | 42    | Н   | ł |
|                                                       |   |                                                                    |       |     |   |

e. If the Event has been successfully reported the Notifying process may possibly continue to retry.

The list of software events in Table 2-1 is exhaustive; the particular subset which may arise during a process' execution depends upon the particular subset of O.S. Procedure calls made by that process. In each case the subset is defined in the description of the process and the particular action taken by its associated layer management entity is defined in the description of that entity; this information is given in Section 3 of this specification and in the LAN software EPS and software component specifications.

| ه هاه ها، ها |           |       |     |    |
|--------------------------------------------------|-----------|-------|-----|----|
| HONEYWELL                                        | SPEC. NO. | SHEET | REV | 1  |
| 1 · · · · · · · · · · · · · · · · · · ·          | 60149766  | 43    | Н   | Í, |

| · · ·                                                                 |                                      |                                                                                                                                                                                                                                                                                                                                |
|-----------------------------------------------------------------------|--------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Procedure<br>Call                                                     | Event<br>Cod <u>e</u>                | Event Description                                                                                                                                                                                                                                                                                                              |
| PROCREATE<br>PRORUN 1<br>PRORUN 2                                     | 1000<br>11C1<br>1102                 | Procreate kernel call reported an error */<br>crorun error, process to be run does not exist */<br>prorun error, process is waitings can not run */                                                                                                                                                                            |
| PROPRIDRITY 1<br>PRCPAIDRITY 2<br>PROPRIORITY 3                       | 1201<br>1202<br>1203                 | progranity call error, invalid process control block */<br>progranity call error, shared stack rectriciion violation */<br>progranity call error, invalid priority set */                                                                                                                                                      |
| MEUXCREATE<br>MEOXDELETE 1<br>MEDXDELETE 2                            | 2000<br>2101<br>2102 :               | <pre>* mailbox create call error, no mail boxes left */ * mailbox create call error, no such mailbox exists */ *</pre>                                                                                                                                                                                                         |
| SENDASS-1<br>SENDASS-2<br>SENDASS-3<br>SENDASS-3                      | 2203                                 | <pre>* send message call error, invalid mailmon used */ * send message call error, invalid suffer descripter used */ * send message call error, invalid message priority used */ * send message call error, mailgon is full already */</pre>                                                                                   |
| HEOXON T                                                              | 2301 .                               |                                                                                                                                                                                                                                                                                                                                |
| HSOXOFF 1.<br>HBOXOFF 2                                               | 2401 /<br>2402 /                     | turn mailsox off call error, invallid mailsox used */<br>turn mailsox off call error, requestor is not owner */                                                                                                                                                                                                                |
| BRECEIVE<br>NOTIFYNFULL 1<br>NGTIFYNFULL 2<br>NOTIFYNFULL 3           | 26C0 /<br>2701 /<br>27C2 /<br>2703 / | Wait to receive bessage call erry invalid operation from shared stack process<br>notifyntull call errory invalid sailbox used #/<br>notifyntull call errory invalid buffer cescripter used #/<br>notifynfull call errory mailbox is not full #/                                                                                |
| STOPNFULL 1"<br>STOPNFULL 2                                           | 2501<br>2303                         |                                                                                                                                                                                                                                                                                                                                |
| TESTMEDE I<br>TESTMOOX_2                                              | 2901 /<br>29C2 /                     | testator call error, requestor is not owner */                                                                                                                                                                                                                                                                                 |
| REGMBOX T<br>REGMBOX 2<br>REGMBOX 3                                   | 2A01 /<br>2A02 /<br>2A03 /           | register a mail box call error, no room in resisteration table "/<br>register a mailbox call error, mailbox name is ton long */                                                                                                                                                                                                |
| RESOLVE<br>SEMACREATE<br>SEMAWAIT<br>SEMAWAIT<br>SEMAWAIT<br>SEMAWAIT | 2B01<br>3001<br>3101<br>3102<br>3103 | resolve mailbox name call error, can't find in well known up list */<br>sepacrests call error, no more seascheres avaliable */<br>sepawait call error, specifies semanners does not exist */<br>semawait call error, illejal if called by a snared stack process */<br>semawait call error, invalid semanner icensification */ |
| SEMARELESSE_1                                                         | 3201                                 | seareliase call error, specified semaphere does not exist */                                                                                                                                                                                                                                                                   |
| SEMARFI EASEL 2                                                       | C                                    | semarelease call error, invalid semanhore identification =/                                                                                                                                                                                                                                                                    |
| ALLCCATE<br>GETSUF<br>JOINBUF<br>PREPENDSUF                           | 4000 /+<br>4100 /=<br>4201 /+        | <pre>dificate memory call error, no more free memory available */ cetour memory call error, no more buffers or puffer descripters available * joincuf error call, invalid buffer descripter subjict */ cetour buffer descripter subjict */ </pre>                                                                              |
| APPENDEUF<br>Pideuf<br>Copteuf                                        | 4401 /-                              | about call error, bad parameters or no butter beschitzts available */                                                                                                                                                                                                                                                          |
| UNAPPENDEUF<br>BUFINFO<br>SETALARM_1<br>SETALARM_2                    | 4901 /                               | <pre>chappendbuf call error, bad barageters subblied, can't do it */<br/>- putinto call error, invalid timebut interval */<br/>setalars call error, invalid ouffer descripter in message */ -</pre>                                                                                                                            |
| STOPALARN                                                             | 5103 /-<br>4700                      | stopalarm call error, can't tind desires alarm dessage */                                                                                                                                                                                                                                                                      |
|                                                                       |                                      |                                                                                                                                                                                                                                                                                                                                |
| •                                                                     |                                      |                                                                                                                                                                                                                                                                                                                                |
|                                                                       | 4                                    |                                                                                                                                                                                                                                                                                                                                |

TABLE 2-1 SOFTWARE EVENT NOTIFICATION CODES

| HONEYWELL | SPEC. NO. | SHEET | REV | I |
|-----------|-----------|-------|-----|---|
|           | 60149766  | 44    | Н   | Í |
|           |           |       |     |   |

SECTION 3 FUNCTIONAL DESCRIPTION

# 3.1 BASIC FUNCTIONS

This section describes the orders, instructions, mailbox communications, IF Software, and LAC firmware functionality which support operation of the LACS.

Much of the hardware specifics of the LACS is hidden from the CS and System Management software by IF Software routines and processes. In this Section, subsections 3.2 through 3.7 address the basic built-in functionality of the LAC while subsection 3.8 addresses the functionality provided by these IF software routines and processes. Sections 4, 6, 7, and the appendices provide additional detail of the basic hardware characteristics.

The standard LAN software product in the LAC will include Link layer and System Management functions in accordance with IEEE 802.1 and 802.2 Standards.

| HONEYWELL |  | SPEC. | NO.  | SHEET | 1 | REV | 1  |
|-----------|--|-------|------|-------|---|-----|----|
|           |  | 6014  | 9766 | 45    | 1 | H   | 1  |
|           |  |       |      |       |   |     | /¥ |

## 3.2 I/O ORDERS

The following I/O Orders are provided for control of the LACS by the Level 6 CPU.

3.2.1 List of I/O Orders

#### OUTPUT ORDERS

| 1. | IO   | (FC=01)    | Output | LACS Control |
|----|------|------------|--------|--------------|
| 2. | IOLD | (FC=09/0D) | Output | LCB Pointer  |

#### INPUT ORDERS

1. IO (FC=26) Input Device ID

For details concerning the structure of the I/O order and other bus-related information, see the referenced Megabus EPS's. The conditions for the above orders to receive ACK, NAK, or WAIT response are given in Subsection 3.2.4.

3.2.2 Output Order Definitions

Only the following Output I/O Orders are defined. All other Output I/O order Function Codes (whether I/O or IOLD) are considered undefined.

Undefined I/O orders are ignored by the LAC; no response is sent to the CPU and the order is not taken by the LAC.

- Output LACS Control IO (FC=01) This order transfers a l6-bit control word to the LACS. All adapters and interfaces are affected by this order. The channel number used in the order is immaterial. The bits in the word are defined as follows:
  - o Bit O: Hard Initialize (if a one)
  - o Bits 1: Stop I/O (if a one and bit 0 is a zero)

o Bits 2-15: MBZ

Hard Initialize causes the actions described in Subsection 3.2.5.1. It requires several seconds to accomplish and is intended to be used only at startup or by T&V software.

Stop I/O performs the actions described in Subsection 3.2.5.3.

|           |   |           |       | . هذه دانه دهه دانه دینه دینه دینه دینه دینه |   |
|-----------|---|-----------|-------|----------------------------------------------|---|
| HONEYWELL | 1 | SPEC. NO. | SHEET | REV                                          | 1 |
|           | I | 60149766  | 46    | Н                                            | Ì |
|           |   |           |       |                                              |   |

2. Output LCB Pointer IOLD (FC=09/OD) - This order involves two separate bus transfers to the LAC: The first transfer is a 32-bit byte address and the second is a 16-bit "Range" word of which the high order eight bits are interpreted as described below and the low order eight bits define the LCB Size in bytes. The address and LCB Size define the location and size of an LCB in main memory. The LCB must begin on a word boundary; LCB Size must also be word-bound.

Information from the bus is placed in a temporary queue by LAC hardware and an interrupt is then sent to the LAC microprocessor. Ensuing action depends upon the value of the Protocol ID byte and whether the LAC is operating under control of its PROM-resident firmware) or running under control of LAC software after a Start I/O IOLD.

If the LAC is under firmware control the following interpretation of the high order byte of the "Range" word is observed by the PROM-resident firmware:

(FF)16=Load/Dump(Subsection 3.2.5.2)
(FE)16=Start I/O (Subsection 3.2.5.3)
(OO)16to(FD)16=Invalid

An invalid code in this byte will cause the firmware to set Invalid Function and Status complete status in the LCB (see Figure 3-1 for the general format of LCBs) and send an interrupt to the CPU in accordance with the contents of the LCB.

If the LAC is running under software control the following interpretation of the high order byte of the "Range" word is observed by the IODISP process:

| 0        | 3    | 4   | 7 |
|----------|------|-----|---|
| Function | Code | MBZ |   |
|          |      |     |   |

The Function Code is used by the IODISP Process (Subsection 3.8.1.3) in dispatching the order to the appropriate software process.

It should be noted that it is possible that in a multiprocessor CPU configuration, two (or more) CPUs might attempt to send an IOLD (i.e. Function Code 09/OD) to the LAC simultaneously; the LAC will detect this and reject (NAK) an IOLD which tries to intervene on the bus between the two bus transfers of an IOLD which has already performed its first transfer.

| HONEYWELL | 1 | SPEC. NO. | SHEET | REV | 1 |
|-----------|---|-----------|-------|-----|---|
| Ì         | Ì | 60149766  | 47    | H   |   |
|           |   |           |       |     | ( |

#### 3.2.3 Input Order Definition

Immediately following completion of execution of an Output LACS Control order (FC=01) the following Input I/O Order is provided (all other Input I/O orders are treated as undefined); this condition remains in effect until an Output LCB Pointer IOLD (FC=09/OD) is issued. Thereafter all input I/O orders are treated as undefined.

Input Device ID (FC=26) - This order causes the LAC PROM firmware to deliver a 16-bit Device ID word to the Megabus. This ID reflects both the LAC and the adapter attached to the addressed adapter channel (subsection 3.3). The ID codes are given in subsection 3.4 and in the appendices.

Undefined Input I/O orders are ignored by the LAC (i.e. no response is made to the order and no information is sent).

# 3.2.4 WAIT, NAK, and ACK Responses

Normally, the LAC responds to I/O Orders with an ACK response. It will never respond with a WAIT. It will respond with a NAK in the following cases:

- An order, other than an Output LACS Control (FC=01) is issued while the LACS is performing all of the operations commanded by an Output LACS control order (FC=01).
- 2. An IOLD order intervenes on the bus with one already underway (subsection 3.2.2).
- 3. The LAC is unable to accept another order because its temporary queue is full. This condition should not occur if the LAC Driver observes the flow control mechanism described in the LAC Software EPS-1. If the condition occurs, the order should be retried later.
- 4. A Fatal error condition exists (see subsection 3.9).
- 5. An IOLD order is issued while a Start I/O operation is still being carried out (subsection 2.17).

As noted in subsections 3.2.2 and 3.2.3, no response is made to an undefined I/O order.

|           | دین هه منه بین هو هه بین هو هه چه چه بین دی هه چه بین در ای می بین در بین دی دی دی دی دی دی دی دی دی در در در د<br> |       |     |   |
|-----------|---------------------------------------------------------------------------------------------------------------------|-------|-----|---|
| HONEYWELL | SPEC. NO.                                                                                                           | SHEET | REV | 1 |
| 1         | 60149766                                                                                                            | 48    | Н   | Ì |
|           |                                                                                                                     |       |     |   |

#### 3.2.5 Initialization, Start/Stop, and Load/Dump

### 3.2.5.1 Initialization

LACS Hard Initialize. This function is initiated by a Power-On sequence or by the Output LACS Control Order (FC=01) with bit 0 a one. It causes the following actions:

- a. The LAC and adapter RAMs are cleared
- b. Hardware registers in the LAC and adapters are cleared.
- c. The LAC runs its QLT
- d. The LAC enters a stopped condition in which its functionality consists of those functions supported by PROM-resident firmware as described in Subsection 3.2

Note that the QLT routine ascertains the configuration information shown in Figure 7-4. If the motherboard QLT does not run successfully to completion the IOLD and Input I/O orders of subsections 3.2.2 and 3.2.3 will be NAK'd. A Stop I/O order or a depression of the CP clear button on the CPU control panel may be used to put the LAC in a condition to accept a Dump order so that QLT status retrieval can be attempted.

| HONEYWELL | 1 | SPEC. NO. | SHEET | REV | 1  |
|-----------|---|-----------|-------|-----|----|
|           | l | 60149766  | 49    | Н   | 1  |
|           |   |           |       |     | (* |

#### 3.2.5.2 Load/Dump

Load/Dump operations provide means for loading of LAC Software, from main memory, for dumping various portions of the LAC RAM to main memory, and for retrieving certain configuration information from the LAC. The LAC must be running under firmware control for a Load/Dump to be performed. The operation is commanded via an Output LCB Pointer IOLD in which the high order byte of the "Range" word is (FF) 16. The detailed information needed to perform the operation is contained in the LCB as shown in Figure 3-1. The LAC channel number used for the IOLD is used in the interrupt sent on completion but is otherwise immaterial to the LAC. On completion, the Controller Status word in the LCB is updated and the Status Complete bit is set and an interrupt is sent to the CPU as specified in the LCB.

If a Megabus Parity, Memory Red or Non-existent Memory fault occurs on the retrieval of the LCB from memory, the order will not be performed and appropriate status will be set in the configuration area in RAM (Figure 7-4).

3.2.5.3 Start I/O

The Start I/O order is defined in Subsection 3.2.2 and the format of the LCB used with this order is shown in Figure 3-2. The conditions under which this order should be used are described in that Subsection and in Subsection 2.17.

The PROM-resident firmware leaves the order in the temporary queue and relinquishes control of the microprocesor to LAC software commencing execution at this Program RAM location which is defined in the LCB.

The fetching of the Start I/O LCB and the storing of final status and sending an interrupt to the CPU is a responsibility of SM software and is described in subsection 2.17. The Start I/O order should be addressed to channel 0 of the LAC; Channel 0 is the address of the System Management process which is the process which handles start-up of the LACS software system.

#### 3.2.5.4 Stop I/O

The Stop I/O order is defined in Subsection 3.2.2. A Stop I/O is also performed as a result of depressing the CP Clear button on the CPU control panel. A Stop I/O causes the following actions:

- a. Hardware registers in the LAC and adapters are cleared.
- b. The LAC commences (or continues) operation under firmware control in which its functionality consists of those functions supported by PROM-resident firmware as described in Subsection 3.2.

|           | و بروه سود هوه هوه هوه هوه هوه هوه بوه بوه بوه بوه |       |     |   |
|-----------|----------------------------------------------------|-------|-----|---|
| HONEYWELL | SPEC. NO.                                          | SHEET | REV | 1 |
| 1         | 60149766                                           | 50    | H   | 1 |
|           |                                                    |       |     |   |

Note that when a Stop I/O is performed, any software-controlled operations currently underway are abruptly terminated, outstanding LCBs are not completed and Pending interrupts are not sent. After a Stop I/O, the LACS should be reloaded and restarted as for an initial start-up (See Subsection 2.10) if further operation under software control is desired.



Notes:

 In the LCB as set up by the CPU, the Status and Completion words must be all zero. These will be updated by the LAC on completion of the operation.

2. The L6 Address, LAC RAM Address, and Extent are all byte-oriented but all must be word-bound (i.e. with LSb of zero).

3. Status Bits

RAMNE = RAM location non-existent

- RAMP = RAM parity error
- = Memory Yellow = Non-existent:L6 memory MY NEM.
- = L6 bus parity error L6E
- = Memory Red MR
- = Status Complete = Excessive Number of IOLDs issued SC
- MEM EXH INV FCT = Invalid Function/Request

4. LOAD/DUMP FUNCTION

(0000) = Store LAC RAM to memory

- (0001) = Load LAC RAM from memory
- (0002) = Read Configuration information into memory
- For the Read Configuration operation the LAC RAM address
- is ignored. The maximum range should be 96 bytes. 5.

Figure 3-1 LCB FORMAT FOR LOAD/DUMP

| HONEYWELL | SPEC. NO.<br>  60149766 | SHEET<br> 51 | REV<br>  H |   |
|-----------|-------------------------|--------------|------------|---|
|           |                         |              |            | ( |

|    | 0  |          |        |               | •     | 15           |            |      |
|----|----|----------|--------|---------------|-------|--------------|------------|------|
|    |    | RHU (5)  | CF     | U Chan<br>(4) | LEVEL | (6)          | INT CTL WD |      |
|    |    |          | RSU    |               |       |              |            |      |
| ., |    | uP Start | Addres | S             | (H)   |              | ;          |      |
| •  |    | uP Start | Addres | S             | (L)   |              | •          |      |
| 1  |    | RSU      |        |               |       | 7            | ~<br>^     |      |
|    |    | MBZ      |        |               |       |              |            |      |
|    |    | MBZ      |        | •             |       | · <b>a</b> . | <b>1</b>   |      |
|    | SC | 1182     |        |               |       |              | Completion | Word |

Notes:

- 1. In the LCB as set up by the CPU, the SC bit must be zero. The LAC will set the bit on completion of the Start operation.
  - 2. SC= Status Complete
- 3. The uP start address is a byte-oriented address but must be word-bound (i.e. with LSb of zero).

FIGURE 3-2 LCB FORMAT FOR START I/O

| HONEYWELL | SPEC. NO. | SHEET | REV | 1 |
|-----------|-----------|-------|-----|---|
| i i       | 60149766  | 52    | H   | 1 |
|           |           |       |     | _ |

#### 3.3 CHANNEL NUMBERS

The LAC is assigned a set of 64 channel numbers, using the 6 LS bits of the 10-bit channel address on the bus.

For the Input Device ID order (FC=26), the 6 LS bits of the channel address are treated by the LAC as consisting of two fields: the highest two bits specify the adapter's daughterboard position and the lowest four bits specify a subchannel associated with the adapter (to allow for future adapters which may have subchannels). The channel number coding for the Input Device ID order is shown below.



LAC = LAC Board Address (Set by DIP switch on board) ADAPT = Adapter Position (0-3) SUBCH = Subchannel on Adapter

For Load/Dump IOLDs and the Output LACS Control IO, the LS 6 bits of the channel address are immaterial to the LAC (however the given channel address will be used in any interrupt which is sent on completion).

### 3.4 DEVICE IDENTIFICATION NUMBER

The device identification number for the LACS is shown below.

| 0    | 7 | 8        | 9     | 13 | 14      | 15       |
|------|---|----------|-------|----|---------|----------|
| T    | Ι | QERR     | ADAPT | ER | SUBCHAN | <u> </u> |
| (2E) | 1 | 1        | TYPE  | 1  | TYPE    | 1        |
|      |   | <u> </u> |       |    |         | <u> </u> |

The codes for Adapter Type and Subchannel Type are given in the appropriate adapter specification (see appendices). If the adapter's QLT has not completed without error the QERR bit will be a One. If no adapter is present at this address, Adapter Type will be all zeros. If a Subchannel is not present or the adapter does not have Subchannels, Subchannel Type will be all zeros. The meaning of non-zero Subchannel Types is specific to the adapter type.

| HONEYWELL | SPEC. NO. | SHEET | REV |         |
|-----------|-----------|-------|-----|---------|
|           | 60149766  | 53    | Н   |         |
|           |           |       |     | <b></b> |

#### 3.5

### DATA TRANSFER WITHIN THE LAC

Multiple data transfers can occur in the LAC concurrently; the adapters and the Megabus interface are half-duplex but DMA transfers with the LAC data buffer RAM can be concurrently under way on all of these facilities.

All data messages are fully buffered in the LAC data buffer RAM. The adapters perform serial-parallel conversions, CRC generation/checking, framing, address recognition, and media access.

Since a message can be received by an adapter at any time and since adapters do not provide message buffering, there must be at least one receive DMA buffer set up for each adapter at all times to avoid loss of a message; it is the responsibility of the IF Software to do this.

The data traffic of the (up to) four adapters and of the Megabus interface must be time-multiplexed over the LAC's internal DMA Bus to the Data Buffer RAM; in addition the microprocessor makes accesses to this RAM via the DMA Bus. These six sources/sinks thus contend for bus access. A fixed priority scheme is used in the LAC to resolve conflicts: the adapter in the channel 0 position is highest in priority, followed by adapters 1 to 3 in order, followed by the microprocessor, followed by the Megabus. The priority is not Preemptive, i.e. it applies only when the current source/sink master releases the DMA bus. While the DMA bus can perform a word transfer in about 550 nanoseconds, the overhead for switching control of the bus from one source/sink to another is about 400 nanoseconds. To obtain maximum throughput over the bus, the time cost for switching is amortized over several effective transfer cycles, by having the sources/sinks perform their transfers in bursts wherever possible The Megabus interface and 10Mbps adapters use bursts; adapters for speeds under 5Mbps need not operate with In order to share the bus equitably, all bursts. sources/sinks except the Megabus will limit the length of their bursts to a predefined value.

### 3.6 INSTRUCTIONS

The instruction set for the MC68000 microprocessor is given in the MC68000 reference document.

### 3.7 PROM RESIDENT FIRMWARE

Resident firmware in the PROM provides the following functions via microprocessor routines:

- Support of the applicable I/O order functionality of subsection 3.2.
- o Quality Logic Test routines.
- Determination of LAC configuration information and storage of it in LAC RAM. Format and location is given in Section 7.
- Handling of Unreportable Catastrophic errors.

| ، ہو جو جو چون ہو جو میں کہ تنظیم کر جو میں جو دو جو دو دو دو دو |           |       |     |   |
|------------------------------------------------------------------|-----------|-------|-----|---|
| HONEYWELL                                                        | SPEC. NO. | SHEET | REV | 1 |
|                                                                  | 60149766  | 54    | H   | 1 |
|                                                                  |           |       |     | _ |

### 3.8 IF SOFTWARE

IF Software is provided in the form of a set of processes and interrupt routines which support the CS software processes by providing an implementation-independent interface to LACS hardware. These IF Software processes are invoked directly through calls to mailboxes. IF Software interrupt routines are invoked by the occurrence of an interrupt from LACS hardware; several of these are associated with IF software processes. The IF software is able to make various Procedure Calls to the O.S. for services and to call CS software processes; IF software is part of the standard LAN product offering with the LACS.

The IF software processes are invoked via a SENDMSG call to the O.S, specifying the mailbox of the process. Messages (i.e. requests for service) are queued in each mailbox ;the process normally retrieves each request as it is able to handle it via a RECEIVE or BRECEIVE call to the O.S. Further details on mailboxes may be found in the reference Bridge documents.

These processes require parameters each time they are invoked; this is provided in the mailbox message which invokes them. Usually these processes will return a message to the calling process when the operation is complete.

### 3.8.1 IF SOFTWARE PROCESSES

The IF Software processes are as follows:

- o Memory DMA Request (MEMDMA)
- o Megabus Layer Management (MBLME)
- o I/O Order Dispatch (IODISP)
- o MAC Transmit
- o MAC Receive
- o MAC Layer Management

### 3.8.1.1 Memory DMA Request (MEMDMA)

This process carries out DMA operations to move information between a buffer and/or block in LAC RAM and one or more buffers (scatter/gather) in Level 6 memory; it carries out the operation via the Megabus interface using the hardware DMA controller and Megabus logic registers.

The format of the mailbox messages which are used in DMA requests to call the Memory DMA process are shown in Figures 3-3 to 3-6. All addresses and ranges shown in these Figures are byte-oriented.

| HONEYWELL | 1                                             | SPEC. NO. | SHEET | REV | 1  |
|-----------|-----------------------------------------------|-----------|-------|-----|----|
|           | i i                                           | 60149766  | 55    | H   | 10 |
| •         | ،<br>سر جنه هنه هيه هيه بيه جنه هيه هيه هنه س |           |       |     | (  |

The process mailbox provides the mechanism for queuing requests to the process for DMA operations.

During the handling of DMA operations involving scatter or gather functions the process will be reinvoked via the associated Megabus DMA Register Exhaust interrupt routine as each transfer with a main memory buffer completes and will reload the Megabus hardware with information for the next buffer transfer operation. Although a RAM buffer is logically a single buffer, physically it may consist of many segments. DMA Controller interrupt routines which are part of this process take care of reloading the DMA Controller with these segments. If the mailbox request was not formatted correctly or an error occurs on the Megabus interface (L6 bus parity, Memory Red, Memory Yellow, Non-existent memory) or in accessing the RAM (RAM parity, non-existent RAM), the operation is not completed, any requested interrupt to the CPU is not sent and the fault is indicated in status in the return message sent to the Return Mailbox specified in the request.

If the operation is completed without error, an interrupt will be sent to the CPU if the request parameters so specified (non-zero LEVEL); it is expected that an interrupt will be specified only for a DMA operation which delivers status information to an LCB in memory. On final completion of the total operation (including interrupt) a return message will be sent to the requesting process.

It is possible that an interrupt to a CPU will not be accepted (NAK) because of other operations being performed in the CPU. The process maintains a queues of such Deferred Interrupts (those which have been NAK'd).

The DMA process organizes deferred interrupts into queues on a per-CPU basis. Within a queue pending interrupts are listed first in order of priority (LEVEL) with highest priority at the top; within those of the same LEVEL the ordering is FIFO. The queue members are the actual mailbox message blocks which asked for an interrupt.

| HONEYWELL                             | SPEC. NO. | SHEET | REV | 1 |
|---------------------------------------|-----------|-------|-----|---|
| l l l l l l l l l l l l l l l l l l l | 60149766  | 56    | Н   | 1 |
|                                       |           |       |     |   |

When a DMA request calls for a L6 interrupt and the associated DMA has been successfully completed, the DMA process will first inspect the pending interrupt queue for that CPU (the CPU No. field in the message block is used to select which queue i.e. the Queue No.). If there are any pending interrupts in that queue of equal or higher priority, the interrupt will not be attempted but will be added to the queue; if it is higher than any entry, it will be attempted and if accepted the message block is returned to the requesting process but if rejected it will be added to the If there is a queue member having the identical queue. interrupt specification in the queue, the interrupt (i.e. the message block) will be linked "horizontally" to the one(s) which are like it. Space is available in the DMA request mailbox message header so that the DMA process can link the blocks vertically and horizontally.

When some CPU causes a RINT (Resume Interrupt), the Interrupt Retry routine (Subsection 3.8.2.1) will retry the top entry of each queue as an interrupt; if accepted, the block is removed from the queue and returned to the process which made the request. Note that when there are a number of deferred interrupts with the same interrupt specification, only one interrupt is actually sent even though all of the message blocks will have been retained by the DMA process until that interrupt has been accepted.

In a multiprocessor environment, it may happen that a CPU for which LACS has some deferred interrupts queued will fail and that central system software will then assign some other CPU to service LACS interrupts in place of the failed CPU. Assuming that the SM in the LACS is notified of this, a mechanism is provided whereby the DMA process Interrupt Retry routine can be told (by Megabus Layer Management) to route pending interrupts originally intended for the failed CPU to The DMA process will have a table which relates the new CPU. queue number to CPU number and which is used, during interrupt retry only, to specify the CPU number to use on the interrupt (the CPU number in the queued message block is ignored on retry). This table is initially set up by the DMA process to be one-to-one but any entry in it can be accessed by sending a specific mailbox message to the DMA process. The format of this message is shown in Figure 3-7.

| HONEYWELL | 1 | SPEC. NO. | SHEET | REV | 1 |
|-----------|---|-----------|-------|-----|---|
|           | 1 | 60149766  | 57    | H H | I |
|           |   |           |       |     | ( |

The DMA process may encounter an O.S. error in performing one of the following O.S. Procedure calls:

- O SENDMSG
- **o BRECEIVE**
- O RESOLVE
- O SEMACREATE
- O SEMAWAIT
- **o SEMARELEASE**

If such an error occurs, a message in the format shown in Figure 3-11 is sent to System Management using the appropriate Event code from Table 2-1. The MEMDMA process, during initial running, obtains the mailbox ID of SM via a RESOLVE call.

The normal running flow of this process is indicated in Figure 2-9; this figure does not include the initial execution of the process during which the DMA interrupt routines (subsections 3.8.2.3 and 3.8.2.4) are registered the semaphore interlock is set up etc. Additional details may be found in the MEMDMA Component Specification.



#### Notes:

- 1. This message is used for requesting a DMA operation to move a block of data between RAM and L6 memory and for confirming completion of the operation.
- 2. A valid Return Mailbox ID must be provided in the request message and the status word must be all zeros.
- 3. In the request message the Message Type for the Header is as follows:

LCB-TO-LAC Transfer from L6 memory to RAM LCB-TO-L6 Transfer from RAM to L6 Memory

- 4. If the LEVEL field is non-zero an interrupt will normally be sent to the specified CPU on completion of the operation; however, if an error occurs during the DMA operation, the interrupt will not be sent.
- 5. In the confirm message the Message Type for the Header is the same as in the request message except that the suffix CF is added.
- 6. See Figure 3-1 for definition of Status bits.
- 7. The Buffer Descriptor in the Header is NULL.

Figure 3-3 DMA Request/Confirm Message for Block Transfer

| HONEYW       | IELL             | SPEC. NO.  SHEET   REV  <br>  60149766  59   H                                                                                                                                                                                                                                                                                                                                                                                                         |
|--------------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|              | Eleck<br>Pointer | 0<br><u>Hossace Header</u><br><u>RHU</u><br>LAC Char. (6) CPU Chan (4) LEVEL (6)<br><u>RSU</u><br><u>Return Mailbox ID (H)</u><br><u>Return Mailbox ID (L)</u><br><u>MBZ (8) FN 0 RMP MY NEW[66]</u><br><u>Total Range of L6 Buffers</u><br><u>Humber of L6 Buffers</u><br><u>L6 Buffer #1 Address (L)</u><br><u>L6 Buffer #2 Address (L)</u><br><u>L6 Buffer #2 Address (L)</u><br><u>L6 Buffer #2 Address (L)</u><br><u>L6 Buffer #2 Address (L)</u> |
| Notes:<br>1. | data between     | L6 Buffer #9 Address (E)<br>L6 Buffer #9 Address (E)<br>L6 Buffer #9 Address (E)<br>L6 Buffer #9 Range<br>RSU<br>is used for requesting a DMA operation to move<br>a logical buffer in RAM and one in L6 memory and<br>g completion of the operation.                                                                                                                                                                                                  |

- 2. A valid Return Mailbox ID must be provided in the request message and the Status word must be all zeros.
- 3. In the request message the status word should be all zero and the Message Type in the Header is as follows:

BUF-TO-LAC Transfer from L6 Memory to RAM BUF-TO-L6 Transfer from RAM to L6 Memory

- 4. If the LEVEL field is non-zero, an interrupt will normally be sent to the specified CPU on completion of the operation; however, if an error occurs during the DMA operation, the interrupt will not be sent.
- 5. In the confirm message the Message Type for the Header is the same as the request message except that the suffix CF is added.
- 6. See Figure 3-1 for Status bit definition.
- 7. The Header contains the RAM Buffer Descriptor.

Figure 3-4 DMA Request/Confirm Message for Buffer Transfer



- 1. This message is used for requesting an extended DMA operation to move data between a logical buffer in RAM and one in L6 memory and for confirming completion of the operation.
- 2. A valid Return Mailbox ID must be provided in the request message and the Status word must be all zeros.
- 3. In the request message the Message Type for the Header is as follows:

BUFX-TO-LAC - Transfer from L6 Memory to RAM BUFX-TO-L6 - Transfer from RAM to L6 Memory

- 4. The Header contains the RAM Buffer Descriptor
- 5. The format of the L6 Buffer list is shown in figure 3-8.
- 6. In the confirm message the Message Type for the Header is the same as in the request message except that the suffix CF is added.
- 7. See Figure 3-1 for Status bit Definition.
- 8. If the LEVEL field is non-zero an interrupt will normally be sent to the specified CPU on completion of the operation; however, if an error occurs during the DMA operation, the interrupt will not be sent.

Figure 3-5 DMA Request/Confirm Message for Extended Buffer Transfer

| HONEYWELL | | SPEC. NO. |SHEET | REV | | | | 60149766 |61 | H |



#### Notes:

- 1. This message is used for requesting a DMA operation to move data from a logical buffer in RAM to one in L6 memory and to move a block of data from RAM to L6 memory and is used for confirming completion of the operation.
- 2. A valid Return Mailbox ID must be provided in the request message and the Status word must be all zeros.
- 3. In the request message the Message Type for the Header is BFLCB-TO-L6. The Header contains the RAM Buffer Descriptor.
- The format of the L6 Buffer list is shown in Figure 3-8.
- 5. If an error occurs on the buffer transfer the block transfer and interrupt are not performed.
- 6. If an error occurs on the block transfer the interrupt is not performed.
- 7. In the confirm message the Message Type for the Header is the same as in the request message except that the suffix CF is added.
- 8. See Figure 3-1 for Status bit Definition.

Figure 3-6 DMA Request/Confirm Message for Combined Buffer and Block Transfer



1. The Message Type for the Header is as follows for the request:

SET-RETRY = Set "CPU#" into Retry table for specified Queue READ-RETRY = Read Retry table for specified queue

2. "CPU#" specifies the CPU to which all deferred interrupts in the specified Queue are henceforth to be sent.

3. "Queue#" refers to one of the possible 16 deferred interrupt queues maintained by the Memory DMA process which are used in accordance with interrupts requested in DMA requests.

4. The result of a "Read table" will be placed in the "CPU#" field of the return message. The Message Type for the Header for the return message is READ-RETRY.CF.

Figure 3-7 Retry Dispatch Table Request/Confirm Message

|           |   | ه مورد هوی هری هری وی وی وی وی بود بود وی |       |     |     |
|-----------|---|----------------------------------------------------------------------------|-------|-----|-----|
| HONEYWELL | 1 | SPEC. NO.                                                                  | SHEET | REV |     |
| l         | 1 | 60149766                                                                   | 63    | H   |     |
|           |   |                                                                            |       |     | (4) |

The L6 Buffer List pointer shown in Figure 3-8 specifies the starting location of a list of descriptors of main memory buffers. The list itself is in LAC RAM; each descriptor in the list consists of a four-byte address and a two-byte range. The list format is similar to that used in LCBs and is shown in Figure 3-8. All L6 buffer addresses and ranges are byte-oriented both in the LCB and in the list given to the Memory DMA process.

The Memory DMA process, without software intervention, performs, by means of its associated interrupt routines, as many loadings and reloadings as is necessary to perform the total requested DMA operation, including scatter/gather.



#### Figure 3-8 L6 BUFFER LIST FORMAT

| * 3 * * * * * * * * * * * * * * * * * * |  |           |       |     |   |  |  |
|-----------------------------------------|--|-----------|-------|-----|---|--|--|
| HONEYWELL                               |  | SPEC. NO. | SHEET | REV | 1 |  |  |
| l                                       |  | 60149766  | 64    | H   | 1 |  |  |

#### 3.8.1.2 MAC Transmit and Receive Processes

This set of processes performs all functions required to interface the hardware facilities of the adapter(s) to serve the needs of the CS and SM software processes. These functions include:

Transmission of data and control messages for LLC.
 Dispatch of messages received by the adapter(s) to the proper process.

The MAC processes used during normal running consist of a Transmit, a Receive, and a Layer Management process for each attached adapter. During its initial running the System Management process spawns a MAC Layer Management process for each physically present adapter. The Layer Management process, in turn, spawns the Transmit and Receive processes for the adapter and aids the MAC users (LLC layers) and interrupt routines in establishing the mailbox IDS needed to communicate with MAC.

The format of mailbox message used by the Link layer CS processes to call for a Transmit operation is shown in Figure 3-9.

The Transmit process does not leave requests queued in its mailbox; instead it removes them as fast as possible and requeues them internally according to type and Service Class. The process also prepends the MAC header (DA, SA, Type/Length), and adds pads if necessary, to the message in the RAM.

As each Transmit operation is completed the adapter will cause an interrupt to the LAC microprocessor; this invokes the Adapter Interrupt routine which determines that a Transmit completion has occurred and sends a Transmit Interrupt mailbox message to the Transmit process. The Transmit process delivers the topmost Transmit request in its queue to the adapter. If some fault occurred in connection iwth the just-completed Transmit, the Transmit process will send a transmit fault indication message to System Management (Figure 3-9 and 3-10).

When a message is received from the LAN the adapter causes an interrupt to the LAC microprocessor; this invokes the Adapter Interrupt routine which determines that a receive operation has occurred and sends a Receive Interrupt Mailbox message to the Receive process. The Receive process discards the message if there is an error associated with it. The process sets up the adapter with a new receive buffer; it then strips out the MAC header from the mesage in RAM and sends a Data Indicate message to the mailbox of a CS software LLC receive process (the ID of that mailbox was given during startup). Finally, it obtains a new spare buffer from the Kernel O.S. The format of the Data Indicate message is shown in Figure 3-14

| HONEYWELL | 1 | SPEC. NO. | SHEET | REV | 1  |
|-----------|---|-----------|-------|-----|----|
|           | İ | 60149766  | 65    | Н   | Í  |
|           |   |           |       |     | () |

The MAC Transmit and Receive processes may encounter an O.S. error in performing one of the following O.S. Procedure calls:

- o SENDMSG
- O BRECEIVE
- O ALLOCATE
- o GETBUF
- o PREPENDBUF
- O UNAPPENDBUF

If such an error occurs, a message in the format of Figure 3-11 is sent to the System Management process using the appropriate Event code from Table 2-1.

The normal running flow of the MAC processes is shown in Figure 2-11; this figure does not include the initial execution of MAC processes. Additional details may be found in the MAC Component Specification.

### HONEYWELL CONFIDENTIAL & PROPRIETARY

6

| HONEYWELL | 1 | SPEC. NO. | SHEET | REV | 1 |
|-----------|---|-----------|-------|-----|---|
| 1         | l | 60149766  | 66    | H   | 1 |

|                  | 0   |                              |                              |        | 15  |
|------------------|-----|------------------------------|------------------------------|--------|-----|
| Block<br>Pointer |     | Mess                         | age <u>Hea</u> der           |        |     |
|                  |     |                              | •                            | •      | ·   |
|                  | MEZ | (8)                          | Frame C                      | ontrol | (8) |
|                  |     |                              | , RSU ,                      |        |     |
|                  |     | Requestor Ma<br>Requestor Ma | Ailbox ID (H<br>Ailbox ID (L |        |     |
|                  |     | Status                       |                              | ;      |     |
|                  |     | Type/Data                    | Length                       |        |     |
| -                |     | Destinati<br>Address         | on<br>(6 bytes)              |        |     |
| J                |     | RS                           | U                            |        |     |

Notes:

| 1.       | The Message Type for the Header of the request message is MAC DATA REQ.                                        |
|----------|----------------------------------------------------------------------------------------------------------------|
| 2.       | The header must contain a RAM buffer descriptor.                                                               |
| 2.<br>3. | In the request message the Status word must be all zeros.                                                      |
| 4.       | The TYPE/Data Length field is used for IEEE 802.3 Standard CSMA/CD and Ethernet.                               |
| 5.       | The Frame Control parameter is used by IEEE 802.4 & 802.5<br>Standard adapters.                                |
| 6.       | The Destination Address field is used for all IEEE 802<br>Standard adapters.                                   |
| 7.       | For two-byte IEEE 802 Standard addressing, the first four bytes of the Destination address field must be zero. |
| 8.       | In the Fault Indicate message the Message Type is TXFLT:                                                       |
| 9.       | See Figure 3-10 for Fault Indicate status.                                                                     |

Figure 3-9. DATA TRANSMIT REQUEST/FAULT INDICATE MESSAGE BLOCK

| HONEYWELL | SPEC. NO.<br>  60149766                                                   | SHEET<br> 67 | REV<br>  H |  |
|-----------|---------------------------------------------------------------------------|--------------|------------|--|
|           | <br>الي الي الله الله على على على عنه |              |            |  |

| 0        | 7   | 8   | 9   | 10  | 11   | 12 | 13  | 14 | 15  |
|----------|-----|-----|-----|-----|------|----|-----|----|-----|
|          |     | INV |     | RAM |      |    |     |    | 1 1 |
| ACCESS C | ODE | FCN | PHY | NE  | RAMP | UR | NED | EB | UT  |
|          | 1   |     |     |     | 1    | ł  | 1   | 1  |     |

UT=Unsuccessful transmission Excess collisions (CSMA only) Excess retries Not accepted (Token Ring only) EB=Error bit ON (Token Ring only) NED=Non-exist destination (Token Ring only) UR=Unsucessful due to underrun PHY=Unsuccessful due to not In-Ring, not On-Bus, PHYS power Off. RAMNE=Non-existent RAM Memory RAMP=RAM parity error INVFCN=Invalid Function (Message Type)

Access Code:

000AAA00

AAA=Access class actually used (Token Bus only)

Figure 3-10 FAULT INDICATE STATUS FOR DATA TRANSMIT

| HONEYWELL | I | SPEC. NO. | SHEET | REV |   |  |  |
|-----------|---|-----------|-------|-----|---|--|--|
| 1         | 1 | 60149766  | 68    | Н   | 1 |  |  |
|           |   |           |       |     |   |  |  |



Note:

The Message Type for the Header is as follows:

LMINT - Control Indicate from an adapter (see appendix for Event Codes)

SM\_EVENT\_MSG - Error response received on O.S. call (see subsection 2.19 for Event Codes)

Figure 3-11 Event Indicate Message Block

| HONEYWELL | SPEC. NO. | SHEET | REV | 1         |
|-----------|-----------|-------|-----|-----------|
| 1 1       | 60149766  | 69    | H   | $\square$ |
|           |           |       |     | 12 1      |

#### 3.8.1.3 I/O Order Dispatch (IODISP)

This process performs the dispatch of incoming I/O orders to the appropriate CS or SM process by sending a mailbox message containing the I/O order to the mailbox ID corresponding to an entry in its Dispatch tables. The Dispatch tables consist of a 64-entry Mailbox Directory Table plus a number of 16-entry Mailbox ID Tables. Each entry in the Directory table is either NULL or is a pointer to the base of an ID Table. Each entry in an ID Table is either NULL or is a Mailbox ID.

The IODISP process uses the low order 6 bits of the IOLD order channel number to index into the Directory table and if a non-NULL entry is found there, uses the Function code (high order 4 bits of the IOLD "Range" word) to index into the ID table.

The CS and SM processes, in order to have particular IOLD orders dispatched directly to them by this process, must send a mailbox message to this process identifying the mailbox ID to be used. The format of the mailbox message used to set a mailbox ID into the Dispatch table is shown in Figure 3-12. This setup should be done during start-up. Table entries may also be changed or read during normal running. Any table entry which has not been specifically set up with mailbox IDs will contain a "NULL" ID and any orders addressed to its corresponding channel address and Function code will be dispatched to the Megabus Layer Management. The format used for all dispatched IOLD message blocks is shown in Figure 3-13.

The IODISP process may encounter an O.S. error in performing one of the following O.S. Procedure calls:

- O SENDMSG
- O ALLOCATE
- O BRECEIVE

If such an error occurs, a message in the format of Figure 3-11 is sent to the System Management process using the appropriate Event code from Table 2-1 if applicable.

| HONEYWELL | SPEC. NO. | SHEET | REV | 1 |
|-----------|-----------|-------|-----|---|
|           | 60149766  | 70    | H   | 1 |
|           |           |       |     |   |

The normal running flow of the IODISP process is shown in Figure 2-8 ; this figure does not include the initial execution and Table setup. Additional details may be found in the IODISP Component Specification.

The I/O Dispatch interrupt rountine (Subsection 3.8.2.2) is associated with this process.

If the IOLD is a Start I/O, IODISP will wait indefinitely for a mailbox ID to be set up for channel 0. It is assumed that the LACS Driver will provide a time-out on Start I/O orders.

| يه جه چه |           |       |     |   |
|----------------------------------------------|-----------|-------|-----|---|
| HONEYWELL                                    | SPEC. NO. | SHEET | REV | 1 |
| 1                                            | 60149766  | 71    | I H | 1 |

- -

| 0                         | <u> </u> |
|---------------------------|----------|
| HEADER                    |          |
| FUNCTION   MBZ   CHAN (6) |          |
| DISPATCH POINTER (H)      |          |
| DISPATCH POINTER (L)      |          |
| MAILBOX ID (H)            |          |
| MAILBOX ID (L)            | 1        |
| RETURN MAILBOX ID (H)     |          |
| RETURN MAILBOX ID (L)     |          |
| RSU                       |          |

#### NOTES:

1.

2.

In the request message, the Message Type for the Header is as follows: REG-MBPTR = Load Dispatch Pointer and Mailbox ID for specified Channel and Function READ-MBPTR = Read Dispatch Pointer and Mailbox ID for

READ-MBPTR = Read Dispatch Pointer and Mailbox ID for specified Channel and Function

In the confirm message the Message Type for the Header is as follows:

REG-MBPTR.CF = Confirming Pointer and Mailbox ID Entry Dispatch Request READ-MBPTR.CF = Confirming Read of Dispatch Pointer Request.

Figure 3-12 IODISP Dispatch Table Setup Request/Confirm Message Block

| HONEYWELL | SPEC. NO | .  SHEET   REV |
|-----------|----------|----------------|
| 1         | 6014976  | 6  72   H      |

#### 3.8.1.4 Megabus Layer Management

This process provides an interface between the IODISP or MEMDMA processes or their associated interrupt routines and the System Mangement process.

- o For an IOLD which cannot be dispatched due to a NULL Dispatch table entry, Megabus Layer Management will:
  - (1) Send a DMA request to MEMDMA to copy the first word of the LCB (which contains the CPU Number and LEVEL) into RAM.
  - (2) Send a DMA request to MEMDMA to write INVFCT status and Status Complete into the LCB and to interrupt the CPU.

## 3.8.1.5 MAC Layer Management

This process handles various unexpected events reported by the adapter due to happenings in the adapter or on the LAN. The process also provides an interface between these processes and the System Management process.

| · · · · · · · · · · · · · · · · · · · |   |           |       |     |    |
|---------------------------------------|---|-----------|-------|-----|----|
| HONEYWELL                             | 1 | SPEC. NO. | SHEET | REV | 1  |
|                                       | l | 60149766  | 73    | H   | IE |
|                                       |   |           |       |     | (  |

The appendices list the Events and Faults which may be reported by the different adapters. The process reports all these to System Management.

The process also performs LMI requests received from System Management.

The format of mailbox messages used to call for an LMI control function is shown in Figure 3-15. On completion of the operation a return message (confirm) will be sent to the specified Return Mailbox; this message is of the same format except that the Status field will be valid and the Return Value field will contain whatever information was requested (assuming the execution of the request was successful in obtaining it). The coding of the various identifiers and Status is given in the System Management and MAC Layer Management Component Specification.

| HONEYWELL | SPEC. NO. | SHEET   REV | 1 |
|-----------|-----------|-------------|---|
| l         | 60149766  | 74   H      | 1 |
|           |           |             |   |

## 3.8.2 IF Software Interrupt Routines

The microprocessor interrupts are assigned as follows, listed in order of increasing priority:

- 1. Interrupt Retry
- 2. DMA Controller (RAM buffer/I/O order queue)
- 3. Megabus DMA Register Exhaust
- 4. I/O Dispatch
- 5. Clock Interrupt
- 6. Adapter Interrupt
- 7. RAM parity error

Of these interrupt routines, the clock Interrupt is handled by a routine furnished by the Bridge O.S. The remainder are handled by IF Software routines and are described in this section.

### 3.8.2.1 Interrupt Retry

Subsections 2.15 and 3.8.1.1 describe the scheme of sending interrupts to the CPU and of the queuing of those which are rejected, as implemented by the Memory DMA process.

When a CPU switches from one running LEVEL to another (and thus becomes potentially able to accept an interrupt) it sends a Resume Interrupt (RINT) signal over the Megabus. The LAC hardware stores this occurrence and, after any currently underway Memory DMA request has been completed (or immediately, if none was underway), causes an Interrupt Retry interrupt request to be sent to the microprocessor.

The Interrupt Retry routine will attempt to send the interrupt at the top of the queue for each CPU. Any interrupts which are accepted are removed from the queue and their DMA request Message Blocks are returned to the requesting process mailbox in the form of a confirmation. Any interrupts which are rejected are left in the queue. The routine finds the location of the queue from a known location within the MEMDMA process which it is associated with.

The Interrupt Retry routine uses the Retry Dispatch Table to determine which CPU the interrupt from each queue should be addressed to, as described in subsection 3.8.1.1.

| HONEYWELL | SPEC. NO. | SHEET | REV | 1  |
|-----------|-----------|-------|-----|----|
|           | 60149766  | 75    | H   | 1  |
|           |           |       |     | [] |

## 3.8.2.2 I/O Dispatch

The I/O Dispatch interrupt routine does the dispatching of IOLD orders, which have been issued to the LACS, to the proper CS Software process.

An I/O Order interrupt request is sent to the microprocessor whenever the DMA controller channel which is used for incoming I/O orders takes an IOLD order from the Megabus and places it in a temporary working queue, as described in subsection 2.13.

As shown in Figure 2-8, the routine checks that the I/O order is valid; if it is, the routine obtains a RAM block of memory for a mailbox message, assembles a mailbox message containing the IOLD information (see Figure 3-13) and sends the message to the mailbox specified in its Dispatch table according to the particular Channel number and Function code of the IOLD.

If no mailbox has been specified for the Channel number and Function code used in the IOLD the mailbox message of Figure 3-13 will be sent to the mailbox of the Megabus Layer Management entity (MBLME)

If a software error occurs on an O.S. Procedure call an Event Indicate message (Figure 3-11) is sent to System Management.

This routine is associated with the I/O Dispatch process, IODISP.

| HONEYWELL<br>   |     | 3 40 40 40 40 40 40 40 40 | SI<br>  6 | PEC.        | NO.<br>9766 | SHEET<br> 76 | REV  <br>  H |
|-----------------|-----|---------------------------|-----------|-------------|-------------|--------------|--------------|
| Elock<br>Pointe | er> | 0                         | Mes       | ssage       | e He        | ader         | 15           |
|                 |     | MEZ<br>(2)                | LACS      | Char<br>(6) | NO          | (09)         |              |
|                 |     | L                         | 6 Addı    | cess        | (H          | )            |              |
|                 |     | L                         | 6 Addı    | ress        | (L          | )            |              |
|                 |     | Funct:<br>Code            | ion       | RFU         |             | LCB Size     |              |
| Note:           |     |                           |           | F           | เรบ         | :            |              |

1. The Header has a NULL Buffer Descriptor

2. The L6 Address and the LCB Size are byte-oriented but must be word-bound (i.e the LSb must be zero),

3. The Message Type for the Header is IOLD.

Figure 3-13 IOLD Information Message Block Format

3.8.2.3 DMA Controller

This routine provides reloading of the DMA controller channels. For the channel which is used for Memory DMA it does the reloading of the individual pointers associated with the single logical buffer in RAM which is being used in the DMA operation. For the channel which is used for I/O order input it reloads the channel with a new Temporary queue location for the next I/O order.

The request for this interrupt is generated by the DMA controller when either channel has a range exhaust.

This routine is associated with the Memory DMA process, MEMDMA.

| HONEYWELL   SPEC. NO.   SHEET   REV | 1   |           |
|-------------------------------------|-----|-----------|
| 60149766  77   н                    | I ( | $\square$ |

#### 3.8.2.4 Megabus DMA Register Exhaust

This routine provides reloading of the Megabus address and range registers when performing a scatter-gather Memory DMA operation. If a RAM Block transfer was requested in the Memory DMA Request (Figure 3-6) in addition to one with a logical buffer, this routine will reload the registers and the DMA controller to perform this transfer after the buffer transfer has been completed. If an interrupt was also specified, this routine will attempt the interrupt after completing all transfers. Finally, the routine will fetch the next DMA request (if any) in the Memory DMA process mailbox and set up the register and DMA controller to start this next operation.

This routine is associated with the Memory DMA MEMDMA process. Its flow and functionality are represented in Figure 2-9.

The request for this interrupt is generated by the Megabus range register when it has a range exhaust.

## 3.8.2.5 Adapter Interrupt

The routine provides handling of interrupts generated by the attached adapters due to completion of requested operations or to the occurrence of an asynchronous event. The routine is associated with the MAC processes. Its flow and functionality is represented in Figure 2-10.

When a message has arrived from the LAN the routine will send a mailbox message to the associated MAC Receive process. For a transmit completion the rountine will send a mailbox message to the associated MAC Transmit process. If an unusual event has been detected by the adapter a mailbox message as shown in Figure 3-11 is sent to the associated MAC Layer Management process.

## 3.8.2.6 RAM Parity Error

This routine is invoked when a parity error occurs on an access to RAM performed by the microprocessor to fetch an instruction or operand. The functions performed by this routine are specified in Subsection 3.9.

| HONEYWELL | SPEC. NO. | SHEET | REV |  |
|-----------|-----------|-------|-----|--|
|           | 60149766  | 78    | H   |  |

| Elock>  | <u></u>    |             |                | •         |        |    |    | 15 |
|---------|------------|-------------|----------------|-----------|--------|----|----|----|
| Pointer |            |             | Message        | Header    |        |    | •  |    |
|         | (2)<br>MBZ | (2)<br>CHAN | (4)<br>SUECHAN | Frame Co  | ntrol  |    | (8 | 3) |
|         | -          |             | MBZ            |           |        |    |    |    |
|         |            |             | MBZ            |           |        |    |    |    |
|         |            | MBZ         | (12)           |           | RAMNE  | OR | LF | ŊМ |
|         |            |             | TYPE/Dat       | ta Length |        |    |    |    |
| · • ·   |            | De          | estinatio      | on Addres | S      |    |    |    |
| ,       |            | So          | ource Ado      | lress     |        |    |    |    |
|         | A          | ctual Da    | ta Length      | n in RAM  | Buffer |    |    |    |
|         |            |             | RSU            |           |        |    |    |    |

## Notes:

| 1.<br>2. | The Header contains the buffer descriptor.<br>The Message Type for the Header is MAC_DATA_IND. |
|----------|------------------------------------------------------------------------------------------------|
| 3.       | LF= Long Frame (longer than buffer)<br>OR= Overrun<br>RAMNE= Non-existent RAM                  |
| 4.       | For two byte addresses, the high order four bytes of the address fields are zero.              |

Figure 3-14 DATA INDICATE MESSAGE BLOCK

| HONEYWELL    | l | SPEC. NO. | SHEET | REV | 1 |
|--------------|---|-----------|-------|-----|---|
|              | 1 | 60149766  | 79    | H   |   |
| ~~~~~~~~~~~~ |   |           |       |     |   |



Notes:

 For the request the Message Type for the header is SM\_REQ\_MSG.
 For the confirm the Message Type for the header is SM\_CNFRM\_MSG.
 See System Management and MAC Layer Management Component specifications for message detailed definition.

FIGURE 3-15 LMI REQUEST/CONFIRM MESSAGE BLOCK

| - |           |     |           |       |     |   |  |  |
|---|-----------|-----|-----------|-------|-----|---|--|--|
| 1 | HONEYWELL | 1   | SPEC. NO. | SHEET | REV | 1 |  |  |
| I |           | 1 1 | 60149766  | 80    | H   | I |  |  |

#### 3.9 HANDLING OF HARDWARE-DETECTED ERRORS

Hardware errors, faults and unusual happenings occuring within an adapter, at its connection with the LAN, or on the LAN itself, are reported to MAC Layer Management which may report it to the SM process via an Event Notification message. In IEEE 802 Standard terminology, these are Control Indicate messages. In general these are Reportable Catastrophic errors as far as the particular LAN port is concerned.

Megabus errors and RAM parity errors occurring during a DMA operation with the Megabus are reported to the process which requested the operation via status in the DMA Confirm Message returned by the Memory DMA process.

A RAM parity error occurring during a DMA operation being performed by an adapter is reported to the process which sent the request to the MAC process via status in the Data Confirm messge returned by the MAC process.

On a MOVE instruction being performed by the microprocessor, RAM parity is not regenerated but is simply copied along with the data. No action is taken.

The following errors are Unreportable Catastrophic errors:

A RAM parity error occurring on an instruction fetch or operand fetch by the microprocessor will cause a Trap to a routine in PROM. THE Trap routine will cause all adapters to logically disconnect from their LANs, will store an indication of the fault in the RAM (Figure 7-4). will set the Megabus logic to NAK all I/O orders except an Output LACS Control order (FC=01) and will leave the LAC under PROM-resident firmware control. It is assumed that the LAN Manager in the Level 6 will eventually issue a Stop I/O order and then DUMP the RAM.

Buss Errors illegal MC68000 OP codes, MC68000 parity errors, LAC hardware errors, and errors occurring on a Load/Store or Start I/O are treated the same as an Unreportable Catastrophic RAM Parity error. · · · . 

| HONEYWELL | SI    | PEC. NO. | SHEET | REV |
|-----------|-------|----------|-------|-----|
| 1         | 1 1 0 | 60149766 | 81    | н і |
|           |       |          |       |     |

SECTION 4 INTERFACES

#### 4.1 LEVEL 6 INTERFACE WITH LACS

The software-visible interface between Level 6 and the LACS uses LCBs as described in Section 2 and implements it via use of the I/O orders described in Section 3.

#### 4.2 LAC INTERFACE WITH THE MEGABUS

The physical interface between Level 6 and the LACS is the Megabus, implemented in accordance with the Level 6 Bus reference specification with extension for support of a 32-bit address bus.

The LAC microprocessor controls LAC operations on the Megabus by controlling hardware Megabus registers and the Megabus DMA controllers. The DMA controllers send interrupts to the microprocessor on completion of a DMA operation.

The LAC board is able to use either the high priority (BSREQH) or low priority (BSREQL) request line so as to satisfy MRX bus, Extended bus, and Standard bus requirements. It may be necessary to provide a DIP switch on the board to select which line to use.

The LAC board will have a DIP switch which must be set in accordance with wehter the board is attached to an MRX bus or a Standard/Extended bus. This switch selects proper use of connector Z01 pin 5.

The LAC will not support connection via the Megabus to older 18-bit-data memories.

A program-settable throttling arrangement will be provided on the LAC board so as to acheive equitable sharing of the Megabus DMA capability. Details are TBD.

Since the LAC is a buffered controller, LAC boards should always be located among the lowest priority bus postions in the system.

| HONEYWELL | SPEC. NO. | SHEET | REV | 1 |
|-----------|-----------|-------|-----|---|
| 1         | 60149766  | 82    | H   | 1 |
|           |           |       |     |   |

#### 4.3

## LAC INTERFACE WITH ADAPTERS

The physical interface between the LAC and the attached adapters uses an MC68000 type bus, the DMA bus of the Data Buffer RAM. Figure 4-1 shows this bus in detail.

The LAC microprocessor controls the adapters by sending them command blocks defining the operation desired. The adapters send interrupts to the microprocessor on completion of a DMA operation or on the occurrence of an asynchronous event. Details are specific to the particular adapter implementation and are covered in the MAC Component Specifications.



Connector "1

Connector #2

#### Figure 4-1 LAC-ADAPTER BUS

|           |   | ه همه همه همه بجه چهه بجه بجه بجه بجه جه جه بجه بجه بجه هه هه هه هه هه هه هه هه ه |       |     |   |
|-----------|---|-----------------------------------------------------------------------------------|-------|-----|---|
| HONEYWELL | 1 | SPEC. NO.                                                                         | SHEET | REV | 1 |
| 1         | I | 60149766                                                                          | 83    | H   | I |

# 4.4 TEST CONNECTOR INTERFACE

The LAC provides a test connector interface as shown in Figure 4-2. A separate Test Board may be plugged ito the interface.

| $\begin{array}{c} \text{df}  \text{FIN}  \text{CDO}  \text{es}  26  \text{INT}  \text{CTLI} \\ & \text{CD2}  \text{eq}  29  \text{INT}  \text{CTLZ} \\ & \text{GND}  \text{es}  38  \text{GND} \\ & \text{BUS}  \text{REO}  \text{es}  31  \text{BUS}  \text{GRT} \\ & \text{BUS}  \text{GRT}  \text{ACK}  \text{er}  32  \text{MON}  \text{BD}  \text{ENBL} \\   +12V  \text{es}  33  +12V \\ & \text{MON}  \text{INTP}  \text{eg}  934  \text{MONBD}  \text{DA}  \text{EN} \\ & \text{DATA}  \text{ACK}  18  35  \text{VALID}  \text{MEM} \\   +5V  12  37  +5V \\   +5V  13  38  +5V \\ & \text{uP}  \text{RESET}  14  59  \text{uP}  \text{HALT} \\    15  \text{es}  \text{MSTR}  \text{CLR} \\   16  \text{es}  11 \\   -12V  17  \text{es}  -12V \\ & \text{ENABLE}  16  \text{es}  \text{BUS}  \text{ERR} \\    -12V  17  \text{es}  \text{DATASTR} \\ & \text{GND}  21  \text{es}  \text{GND} \\ & \text{HI}  \text{DATA}  \text{STR}  22  \text{es}  \text{GND} \\ & \text{HI}  \text{DATA}  \text{STR}  22  \text{es}  \text{GND} \\ & \text{ADDR}  \text{STR}  24  \text{es}  \text{SYS}  \text{CLK} \\ & \text{GND}  25  56  \text{GND} \end{array}$ | GND $\$1$ $31$ GND<br>ADDR $BUSO1$ $22$ $32$ DATA $BUSO0$<br>02 $23$ $33$ 01<br>03 $24$ $34$ 02<br>04 $45$ $35$ GND<br>05 $27$ $37$ 04<br>06 $88$ $38$ 05<br>07 $89$ $39$ 06<br>08 $12$ $42$ 07<br>GND 11 $41$ GND<br>09 $12$ $42$ 08<br>10 $13$ $43$ 07<br>GND 11 $41$ GND<br>09 $12$ $42$ 08<br>10 $13$ $43$ 10<br>12 $15$ $45$ 11<br>GND 16 $46$ GND<br>13 $17$ $47$ 1<br>14 $15$ $45$ 11<br>GND 21 $51$ GND<br>17 $22$ $52$ SEL CTL STOR<br>18 $22$ $53$ GND<br>21 $27$ $57$ 22<br>22 $28$ $58$ GND |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Conn stor #1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

Connactor #2

٥

Figure 4-2 TEST CONNECTOR

HONEYWELL CONFIDENTIAL & PROPRIETARY

:

. .

•

| HONEYWELL | 1 | SPEC. NO. | SHEET | REV | 1 |
|-----------|---|-----------|-------|-----|---|
| 1         | l | 60149766  | 84    | H   | 1 |
|           |   |           |       |     |   |

#### SECTION 5 PERFORMANCE

#### 5.1 LAN DATA RATE

The LAC is capable of handling a peak data rate of 2.5 MBytes per second. This permits a 10 Mbps data stream from an adapter concurrent with a similar data rate to the Megabus or 10Mbps data streams concurrently on two adapters.

#### 5.2 DATA THROUGHPUT

The packet rate capability of the LACS is heavily dependent upon the LACS Software performance. Measured performance values are not available at this time. However, simulation using timing estimates indicate that the LACS running software up through Transport layer may be capable of about 120 packets per second (total for Receive and Transmit). The packet rate is independent of packet size.

## 5.3 LAC INSTRUCTION TIMING

Instruction times for the MC68000 are found in the MC68000 User's Manual reference document, using 10 MHz as the clock speed except that all memory references include a WAIT state.

#### 5.4 PRIORITY POSITION OF THE LAC ON THE MEGABUS

The LAC should be located as the lowest I/O device priority position on its bus (i.e. just above the CPU).

#### 5.5 PRIORITY POSITIONING OF ADAPTERS ON THE LAC

Because of the priority scheme on the Data Buffer RAM bus, in assigning positions of adapter daughterboards on the LAC. The adapters which are connected to the highest speed LANS should be assigned to the lowest numbered adapter positions.

•

| HONEYWELL |  | SPEC. NO. | SHEET | REV   |
|-----------|--|-----------|-------|-------|
| 1         |  | 60149766  | 85    | I H I |
|           |  |           |       |       |

SECTION 6 PHYSICAL STRUCTURE

#### 6.1 PACKAGING

The LAC is a single motherboard that accommodates up to 4 adapter daughterboards (quarter - sized).

;

## 6.2 POWER

The LACS is powered from the Level 6 bus and has the following requirements:

o 8.3 amperes @ + 5 Vdc
o 0.1 amperes @ + 12 Vdc

Adapter power is not included in these figures.

## 6.3 ENVIRONMENT

- o Temperature: 10° to 50°C ambient
- o Humidity: 5% to 90%

#### 6.4 SAFETY

The LACS meets Underwriter Laboratories and Canadian Standards Association requirements.

#### 6.5 STANDARDS

The LACS meets the referenced HIS standards to the extent to which they apply.

## 6.6 TESTABILITY

The LAC provides a test connector. The LAC design meets the requirements of the MTG2 and MTG3 reference documents.

# 6.7 RFI EMANATION

The LACS complies with the requirements of Part 15 of Federal Communication Commission Rules for a Class A computing device when mounted in standard Level 6 chassis. .

 $\bigcirc$ 

• •

| BONEYWELL | SPEC. NO. | SHEET | REV | 1 |
|-----------|-----------|-------|-----|---|
| 1 1       | 60149766  | 86    | H   | 1 |
|           |           |       |     |   |

SECTION 7 RELIABILITY AND MAINTAINABILITY

## 7.1 GENERAL REQUIRMENTS

o Mean Time between Failures (MTBF)

28000 hours - LAC Motherboard

o Mean Time to Repair (MTTR): 1 hour

Mean time to repair includes the time to determine and to replace the defective ORU and validate the repair.

The LAC motherboard is an ORU. Specifics on adapter-related ORUs are given in the Appendices.

# 7.2 MAINTENANCE FEATURES

7.2.1 Quality Logic Test (QLT)

The LAC provides a resident program called QLT that verifies the operability of the LACS. A QLT light is provided on the LAC motherboard and on each adapter. The QLTs run whenever a LACS Hard Initialize is performed. The QLT tests the motherboard first and then the adapters in turn. As it starts, the QLT turns on the QLT light on the motherboard and performs its test. Each adapter is then tested in turn; as each unit's test begins, its QLT light is turned on and when its test is completed successfully, that unit's QLT light is extinguished. A QLT Status word is stored in RAM on completion of each step of each QLT; this word is part of the Configuration information which is shown in subsection 7.4. An adapter's ID is affected by an unsuccessful QLT (subsection 3.4).

## 7.2.2 Error Checking and Reporting

The Megabus parity checking functions are supported. Failures are reported back to the LAC software as part of the status return for Memory DMA operations.

## 7.2.3 Internal Loopback

Loopback of the data stream within the adapter may be invoked. Loopback at the Trunk coupler may be possible on some 802 type LANs. Further detail is given in the Appendices.

| ا چه دو به دو ده دو ده دو |           |       |     |    |
|---------------------------------------------------------------|-----------|-------|-----|----|
| HONEYWELL                                                     | SPEC. NO. | SHEET | REV | 1  |
|                                                               | 60149766  | 87    | H   | 1  |
|                                                               |           | -     |     | 15 |

## 7.2.4 Statistic Gathering

The MAC adapter gathers the statistics enumerated in subsection 2.16 using its hardware and firmware. Other statistics may be assembled within the LAC under software control.

## 7.2.5 LAC RAM Dump/Load

The CPU can issue an I/O order which causes a portion of RAM in the LAC to be dumped into/loaded from main memory.

7.2.6 FCS Checking

FCS generation/checking is provided normally by the adapter. These functions may be independently disabled so that FCS fields can be manipulated by software in the LAC or made visible to CPU software. This ability is adapter implementation specific.

7.2.7 Adapter RAM Access

Software running in the LAC can have read or write access to locations in an adapter's RAM if this function can be supported by the LSI chips in the adapter. This not only allows a type loopback to test the loading of parameters into the adapter bualso provides ability to monitor MAC conditions which are not normally visible.

## 7.2.8 Remote Loopback

Through the TEST command, loopback of data through a remote station may be performed. This is a software function which is further defined in the IEEE 802 Standards.

7.2.9 MAC Internal Status

Read access to a selected set of MAC internal timers and status as defined in the IEEE 802 Standards.is provided.

7.2.10 Remote Station Inquiry (XID)

The ability to inquire into the availability of a remote station is provided. This is a software function which is further defined in the IEEE 802 Standards.

| HONEYWELL | SPEC. NO. | SHEET | REV   |
|-----------|-----------|-------|-------|
| 1         | 60149766  | 88    | I H I |
|           |           |       |       |

## 7.2.11 System Area in RAM

An area in RAM (see figure 7-5) is provided for saving useful information regarding errors and faults.

## 7.3 MAINTAINABILITY

Through the use of a complete set of maintainability tools for the LACS that include the QLT, T&V routines, and troubleshooting and repair procedures, the following fault detection and resolution goals apply to the LACS:

| ORU        | ISOLATION<br>TO ONE ORU | ISOLATION TO<br>TWO ORU'S | DETECTION |
|------------|-------------------------|---------------------------|-----------|
| CONTROLLER | 93%                     | 5%                        | 98%       |
| ADAPTER    | 93%                     | 5%                        | 988       |

In measuring the above goals, shorts on tristate signals on the controller/adapter interface should not be inserted; instead the ground rules developed during NMLC fault insertion tests should be followed.

| HONEYWELL | SPEC. NO. | SHEET | REV | 1 |
|-----------|-----------|-------|-----|---|
| 1         | 60149766  | 89    | H   | 1 |
|           |           |       |     |   |

#### 7.4 DETAILED ADDRESS SPACE ASSIGNMENTS

#### 7.4.1 Overall Maps

Figures 7-1 and 7-2 show the overall map of LAC during QLT execution when the MC68000 is executing code in the PROM and during normal running, respectively.

|                                   | Byte                  |
|-----------------------------------|-----------------------|
|                                   | Address               |
|                                   | 1 TT TT TE            |
| Adapter #3 Strobes                | ra aa aa              |
| Adapter 12 Strobes                | EF 17 12              |
|                                   | E0 00 00              |
|                                   | OF TE TE              |
| Adepter #1 Strobes                | 00 00 00              |
|                                   | CT TT TE              |
| Adepter (9 Strobes                | C0 00 00              |
| DMA Controller Strobes            | BF FF FE              |
| DHY CONCIDITOL SCIONAR            | 80 00 00              |
| Not Used                          | AT TT TE              |
| NOE JUN                           | A0 00 00<br>97 77 78  |
| FIFO Output Strobes               | 90 00 00              |
|                                   | ST TT TE              |
| Not Used                          | es 00 00              |
|                                   | 17 27 22              |
| Data Buffer RM expansion to 256K  | 82 00 00              |
|                                   | 82 00 00<br>81 FF FE  |
| Data Buffer RAM basis 64R         | 80 00 00              |
|                                   | 78 22 22              |
| Same as 30 00 00 to 3F FF FE      | 70 00 00              |
|                                   | 67 77 72              |
| Same as 20 00 to 27 FF FE         | 60 00 00              |
|                                   | ST TT TE              |
| Same as 10 00 00 to 1P FF FE      | 50 00 00              |
|                                   | AP PT TE              |
| Same as 00 00 00 to 07 FF FE      | 40 00 00<br>37 FF FE  |
| Not Used                          |                       |
|                                   | 38 00 00<br>37 FE_FE_ |
| " uP RAM expansion to 256K        |                       |
|                                   | 32 00 00<br>31 PF FE  |
| uP RAM basis 64K                  | 1                     |
|                                   | 30 00 00<br>2F FF FE  |
| Not Used                          | 20 00 00              |
|                                   | 2C FF FE              |
| Monitor Strebes                   | 20 00 00              |
|                                   | 28 27 72              |
| Not Used                          | 29 00 00              |
|                                   | 30 PF FE              |
| Control Strubes                   | 20 00 00<br>LP FF FE  |
| Not Used                          |                       |
|                                   | 10 80 00              |
|                                   | 10 7F FE              |
| PROM same as 00 00 00 to 00 7F FE |                       |
| ·                                 | OF FF TE              |
| Not Used                          | 00 80 00              |
| PROM W/Vectors                    |                       |
|                                   | 1                     |
|                                   | 00 00 00              |

Figure 7-1. ADDRESS SPACE LAYOUT DURING QLT

HONEYWELL

1

| 1 | SPEC. | NO.  | • |  | IS |
|---|-------|------|---|--|----|
| 1 | 6014  | 9766 | 5 |  | 9  |

| SHEET | 90

REV H 1

I

| Adapter #3 Strobes                  | FF FF FE                             |
|-------------------------------------|--------------------------------------|
|                                     |                                      |
| Adapter #2 Strobes                  | EF FF FE                             |
| Adepter #1 Strobes                  | DF FF FE                             |
| Adapter #0 Strobes                  | CF FF FE                             |
| DMA Controller Strobes              | SF TT TE                             |
| Not Used                            | 80 00 00<br>AF FF FE<br>A0 00 00     |
| FIFO Output Strobes                 | 90 00 00                             |
| Not Used                            | 87 77 72<br>88 00 00<br>87 77 72     |
| Data Buffer RAM expansion to 256K   | 87 FF FE<br>82 00 00<br>81 FF FE     |
| Data Buffer RAM basis 64K           | 80 00 00                             |
| Same as 30 00 00 to 3F FF FE        | 7 <b>7 77 72</b><br>70 00 00         |
| Eams as 20 00 00 to 27 FF FE        | 67 FF FE                             |
| Same as 10 00 00 to 1F FF FE        | 5 <b>p pp pb</b><br>50 00 0 <b>0</b> |
| Same as 00 00 00 to OF FF FE        | 47 77 78<br>40 00 00                 |
| Not Used                            | 37 77 78<br>38 00 <u>00</u>          |
| uP RAM same as 02 00 00"to 07 FF FE | 37 FF FE                             |
| up RAM same_se 00 00 00 to 01 FT 72 | 30 00 00                             |
| , Not Used                          | 2 <b>F FF FE</b><br>2D 00 00         |
| Monitor Strobes                     | 2C FF FB<br>2C 00 90                 |
| Not Veed                            | 28 FF FE<br>29 00 00                 |
| . Control Strobee                   | 28 FF FE<br>20.00 00                 |
| Not · Used                          | 17 FF FE                             |
| PROM                                | 10 7 <b>7 72</b><br>10 00 03         |
| Not Used                            | 0 <b>F FF FE</b><br>08 00 00         |
| . UP RAN expansion to 256K          | 07 TP 72                             |
| uP RAN basic 64R'                   | 02 00 00<br>01 FF FE                 |
|                                     |                                      |

Figure 7-2. ADDRESS SPACE LAYOUT DURING NORMAL OPERATION

٩

| HONEYWELL | SPEC. NO. | SHEET | REV |                |
|-----------|-----------|-------|-----|----------------|
| 1         | 60149766  | 91    | H   | 1              |
|           |           |       |     | ( <sup>2</sup> |

## 7.4.2 Dedicated RAM area Layouts

Figure 7-3 shows the location and layout of the RAM memory area assigned as the I/O order temporary queue.



Queues

Figure 7-3. I/O TEMPORARY QUEUE

Figure 7-4 shows the layout of the Configuration information (Device IDs, RAM memory sizes, Firmware Revision Number, QLT Status) as it will exist in main memory after performing a Read Configuration operation (section 3.2.5.2).

Figure 7-5 shows the location and layout of the RAM memory area ssigned as a System Area for Statistics and records of Event notifications (if maintained by SME software) and Fatal errors.

٩

| HONEYWELL |                           | SPEC. NO.<br>  60149766 | SHEET<br>  92     | REV<br>  H |  |
|-----------|---------------------------|-------------------------|-------------------|------------|--|
|           | Relative<br>Byte Location | 0                       | 7                 |            |  |
|           | Byte Location<br>00       | LAC Firmware Rey.       |                   |            |  |
|           |                           | LAC Hardware Rev.       | (H)<br>(L)        |            |  |
|           |                           | Adapter 0 Firmwar       |                   |            |  |
|           |                           | Adapter 0 Kardwar       | e Rev. (H)        |            |  |
|           |                           | Adapter 1 Firmwar       | (L)<br>e Rev.     |            |  |
|           |                           | Adapter 1 Hardward      | e Rev. (H)        |            |  |
|           |                           | Adapter 2 Firmwar       | (L)<br>E Rev.     |            |  |
|           |                           | Adapter 2 Hardward      | ( ** )            |            |  |
|           |                           | Adapter 3 Firmware      | B Rev.            |            |  |
|           |                           | Adapter 3 Hardward      | e Rev. (H)<br>(L) |            |  |
|           |                           |                         | (0)               |            |  |
|           |                           | Adapter Status          | (1)<br>(2)        | •          |  |
|           |                           | LAC Error Status        | (3)<br>(E)        |            |  |
|           |                           | Adapter 0 Error St      | (L)               |            |  |
|           |                           | Adapter 0 Lifor St      | tatus (H)<br>(L)  |            |  |
|           |                           | Adapter 1 Error St      | atus (H)<br>(L)   |            |  |
|           |                           | Adapter 2 Error St      | atus (H)          |            |  |
|           |                           | Adapter 3 Error St      | (L)<br>Latus (H)  |            |  |
|           | ,                         | Top of Buffer RAM       | (L)<br>(H)        |            |  |
|           |                           | Top of Program RAM      | (L)               |            |  |
|           |                           | TOP OI Program RAR      | 1 (H)<br>(L)      |            |  |
|           |                           | -<br>QLT Working Regist | ers               |            |  |
|           |                           |                         |                   |            |  |
|           |                           | MC68000 Register S      | ave Area          |            |  |
|           |                           |                         |                   |            |  |
|           | ¥<br>5E                   |                         |                   | :          |  |

1.

See Figure 7-5 for LAC Error Status

Figure 7-4 Configuration Information

| BE   | 1  | RF   ] |                                          | HE    | UPE    | (RFU    | V I NT   | EM    | L6B    |        | -        |
|------|----|--------|------------------------------------------|-------|--------|---------|----------|-------|--------|--------|----------|
|      |    | Rr .   | .00 1                                    |       |        |         | <u> </u> |       | цов    |        | -        |
| 1    |    |        | a ann an a | 1     | EVENT  | CODE    |          |       |        |        | -        |
| BE   | H  | 68000  | ) BUS                                    | ERRC  | R      |         |          |       |        |        |          |
| RE   | =  | 68000  | ) RAM                                    | PARI  | TY ER  | ROR     |          |       |        |        |          |
| IOC  | =  | ILLEC  | GAL 6                                    | 8000  | INSTR  | UCTION  |          |       |        |        |          |
| ΗE   | =  | LAC H  | IARDW                                    | ARE E | ERROR  | •       |          |       |        |        |          |
| UPE  | =  | MICRO  | <b>DPROC</b>                             | ESSOF | R PARI | TY ERR  | OR       |       |        |        |          |
| NEM  | =  | NON-1  | EXIST                                    | MEMO  | DRY ON | LOAD/   | STORE    | OR S  | TART   | I/0 I  | CB       |
| L6B  | =  | MEGAI  | BUS P                                    | ARITY | ERRO   | RONL    | OAD/S    | TORE  | OR ST  | FART I | /O LCB   |
| MR   | =  | MEMO   | RY RE                                    | D ON  | LOAD/  | STORE   | OR ST.   | ART I | /O L(  | CB     |          |
|      |    |        |                                          |       |        |         |          |       | •      |        |          |
| EVEN | тС | ODE =  | Unre                                     | porta | able C | atastr  | ophic    | erro  | or (se | ee Tab | ole 2-1) |
|      |    |        | Fig                                      | jure  | 7-5 L# | AC Erro | or Sta   | atus  |        |        |          |



| HONEYWELL | SPEC. NO. | SHEET | REV | 1 |
|-----------|-----------|-------|-----|---|
| 1         | 60149766  | 93    | Н   | 1 |
|           |           |       |     |   |

#### APPENDIX A TOKEN BUS ADAPTER

## A.1 GENERAL DESCRIPTION

The Token Bus Adapter consists of a (TBD) sized daughterboard that mounts on the LAC motherboard. It contains logic to interface with the Data Buffer bus, a Media Access controller, digital logic for the Physical layer, and an interface to the R.F. Modem (which is separately packaged) for Broadband application, and a drop cable interface for Baseband applications.

Figure A-1 is a block diagram of the adapter. The interface with the modem is described in the modem purchase specification reference in Subsection 1.2.

The power requirements for the daughterboard are as follows:

TBD amperes @ + 5VDC TBD amperes @ + 12VDC

The maximum Station Delay for this adapter is TBD.

The adapter ID is TBD

Control Indicate Event Codes are as follows:

(0081)<sub>16</sub>=Jabber Inhibit (0082)<sub>16</sub>=Faulty Transmitter (0083)<sub>16</sub>=Change of Successor (0084)<sub>16</sub>=Null Successor

|           |           |       | · · · · · |    |
|-----------|-----------|-------|-----------|----|
| HONEYWELL | SPEC. NO. | SHEET | REV       |    |
| 1         | 60149766  | 94    | H         | 1  |
|           |           |       |           | (* |

(TBD)

Figure A-1. TOKEN BUS DAUGHTERBOARD BLOCK DIAGRAM

|           |           |       |     | 3 4880 |
|-----------|-----------|-------|-----|--------|
| HONEYWELL | SPEC. NO. | SHEET | REV | 1      |
|           | 60149766  | 95    | H   | 1      |
|           |           |       |     |        |

The adapter and the referenced modem are Optimum Replaceable Units (ORUs). Reliability and maintainability figures for these units are as follows:

| UNIT     | MTBF    | MTTR    |
|----------|---------|---------|
| Adapter  | TBD hrs | TBD hrs |
| RF Modem | TBD     | TBD     |

The adapter and the referenced modem have built-in loopback paths which are chosen to utilize as much as possible of the particular unit's circuitry so as to aid in ORU resolution. The specific loopback points are TBD. ; • 

| HONEYWELL   SPEC. NO.  SHEET   REV  <br>      60149766  96   H |           |           |       |     |   |
|----------------------------------------------------------------|-----------|-----------|-------|-----|---|
|                                                                | HONEYWELL | SPEC. NO. | SHEET | REV |   |
|                                                                | 1         | 60149766  | 96    | H   | ļ |

APPENDIX B CSMA/CD (ETHERNET) ADAPTER

#### B.1 GENERAL DESCRIPTION:

The CSMA/CD Adapter is a quarter-sized daughterboard that mounts on the LLC motherboard. It contains interface logic to interface with the MC68000 bus and two LSI controller chips which provide the Media Access and physical layer functions for interface with the CSMA/CD (Ethernet) transceiver.

The adapter ID returned in Input Device ID operations is as follows:

(2E08)16=Normal Ethernet (2E88)16=QLT Error Ethernet (2E0C)16=Normal 802.3 (2E8C)16=QLT Error 802.3

Figure B-l is a block diagram of the adapter.

The interface with the transceiver is in accordance with IEEE 802 specifications. It does not include the optional Control Out interface circuit.

The Ethernet Controller AMD 7990 chip requires that buffers be at least 100 bytes in size when chanined for a packet and 64 bytes minimum when the packet exists in one buffer only. The Honeywell-supplied CS and MAC software observes these requirements.

| HONEYWELL | SPEC. NO. | SHEET | REV | 1   |
|-----------|-----------|-------|-----|-----|
| 1         | 60149766  | 97    | Н   | 1   |
|           |           |       |     | 6 7 |

Control Indicate Event Codes are as follows:

(0091)16=Heartbeat Fail (0092)16=Carrier Sense Failure (0093)16=Late Collision Detect (0094)16=Jabber Error (0095)16=Received Frame Too Long

The power requirements for the daughterboard are as follows:

1.2 amperes @ + 5VDC

The adapter is an ORU.

Maintainability figures for the adapter are as follows:

| MTBF | 494000 | hours | MTTR    | 1 | hour   |
|------|--------|-------|---------|---|--------|
|      | 333000 | HOULD | *** **/ |   | 110 01 |



Figure B-1 CSMA/CD (ETHERNET) BLOCK DIAGRAM

| HONEYWELL | SPEC. NO. | SHEET | REV | 1 |
|-----------|-----------|-------|-----|---|
| 1         | 60149766  | 98    | H   | 1 |
|           |           |       |     |   |

APPENDIX C TOKEN RING ADAPTER

#### C.1 GENERAL DESCRIPTION

The Token Ring adapter is a half-size daughterboard that mounts on the LAC motherboard. It contains logic to interface with the MC68000 bus, Media Access Controller, Physical layer circuitry and an interface to a Media Interface Connector (MIC). The MIC provides a connection to the ring Trunk coupling Unit (TCU) which is separately packaged. LSI chips provide the MAC and physical layer functions.

The adapter ID returned in Input Device ID operations is

(2E04) 16 Normal (2E84 16 QLT Error

Power requirements for the adapter are as follows:

TBD amp @ +5VDC

The adapter is an ORU. Maintainability figures for the adapter are as follows:

MTBF:TBDhoursMTTR:1hourFigure C-1 is a block diagram of the adapterControl Indicate Event Codes are as follows:

(0011) 16 = Private Event (0012) 16 = Claim Token State (0013) 16 = Transmit Beacon (0014) 16 = Receive Frame Beacon (0015) 16 = Active Monitor State (0016) 16 = Standby State (0017) 16 = Duplicate Address Detected (0018) 16 = Request Initialization (0019) 16 = Upstream Neighbor Change (0020) 16 = Notification Incomplete (0021) 16 = Error

| HONEYWELL | 1 | SPEC. NO. | SHEET | REV | 1 |  |
|-----------|---|-----------|-------|-----|---|--|
| Ì         | ĺ | 60149766  | 99    | Н   |   |  |
|           |   |           |       |     |   |  |



# FIGURE C-1 TOKEN RING BLOCK DIAGRAM

# HONEYWELL CONFIDENTIAL & PROPRIETARY

Ø

|           |     | ، چه چه که که که خوان که که کو که چه چه چه چه خوا |       |     |   |
|-----------|-----|---------------------------------------------------|-------|-----|---|
| HONEYWELL | 1 1 | SPEC. NO.                                         | SHEET | REV | 1 |
| 1         | 1   | 60149766                                          | 100   | I E | Ì |

APPROVAL SHEET ( For Revision G)

PREPARED BY:

4 1985 DATE:

A. Hirtle Systems Engineering & Standards

APPROVED BY:

J. Conway, Manager System Engineering & Standards

and Tiggs DATE:

DATE: Sc. 21, 1975

APPROVED BY:

R. Farrell, Manager Communications Hardware Development

APPROVED BY:

W. K. O'Neill, Manager Communications Software Development

DATE: Marr 4, 20,

APPROVED BY

Director D. DeVoy, MicroSystems, Communications & Terminals

DATE: March 20,1985

•

# HONEYWELL PROPRIETARY

|   | Homorayoll                    | SPEC. NO. | SHEET | REV. |
|---|-------------------------------|-----------|-------|------|
|   | Honeywell                     | 60149766  | 101   | н    |
| 4 | HONEYWELL INFORMATION SYSTEMS |           |       |      |

APPROVALS FOR REVISION H

PREPARED BY

A. Hirtle MSC&T Systems

APPROVED BY

R. Farrell, Manager

Communications Eng'g

APPROVED BY

< - 1 D. Devoy, Director MSC&T Development

DATE

March 26, 1986 April 16, 1986 DATE

DATE MPALE 17, 1904

# HONEYWELL PROPRIETARY

3 . .