Aircraft Digital Electronic and Computer Systems
A next-generation Boeing 737 aircraft with seating for up to 190 passengers and an operational range of up to 3,000 nautical miles (5,500 km). Like all of today’s aircraft, the Boeing 737-800, makes extensive use of digital electronic and computer systems.
# Contents

<table>
<thead>
<tr>
<th>Preface</th>
<th>ix</th>
</tr>
</thead>
<tbody>
<tr>
<td>Acknowledgements</td>
<td>xiii</td>
</tr>
</tbody>
</table>

## Chapter 1 Introduction
1.1 Flight instruments  
1.2 Cockpit layouts  
1.3 Multiple-choice questions  

## Chapter 2 Number systems
2.1 Decimal (denary) numbers  
2.2 Binary numbers  
2.3 Octal numbers  
2.4 Hexadecimal numbers  
2.5 American Standard Code for Information Interchange  
2.6 Multiple-choice questions  

## Chapter 3 Data conversion
3.1 Analogue and digital signals  
3.2 Digital to analogue conversion  
3.3 Analogue to digital conversion  
3.4 Multiple-choice questions  

## Chapter 4 Data buses
4.1 Introducing bus systems  
4.2 ARINC 429  
4.3 Other bus standards  
4.4 Multiple-choice questions  

## Chapter 5 Logic circuits
5.1 Introducing logic  
5.2 Logic circuits  
5.3 Boolean algebra  
5.4 Combinational logic
# CONTENTS

## Chapter 12  ESD
- 12.1 Static electricity 146
- 12.2 Static-sensitive devices 148
- 12.3 ESD warnings 149
- 12.4 Handling and transporting ESDs 150
- 12.5 Multiple-choice questions 151

## Chapter 13  Software
- 13.1 Software classification 153
- 13.2 Software certification 154
- 13.3 Software upgrading 155
- 13.4 Data verification 160
- 13.5 Multiple-choice questions 160

## Chapter 14  EMC
- 14.1 EMI generation 162
- 14.2 EMC and avionic equipment 165
- 14.3 Spectrum analysis 166
- 14.4 Effects and causes of EMI 169
- 14.5 Aircraft wiring and cabling 172
- 14.6 Grounding and bonding 172
- 14.7 Multiple-choice questions 173

## Chapter 15  Avionic systems
- 15.1 Aircraft Communication Addressing and Reporting System 175
- 15.2 EFIS 176
- 15.3 Engine indication and crew alerting system 180
- 15.4 Fly-by-wire 182
- 15.5 Flight management system 183
- 15.6 Global Positioning System 184
- 15.7 Inertial reference system 186
- 15.8 Traffic alert collision avoidance system 187
- 15.9 Automatic test equipment 189
- 15.10 Built-in test equipment 189
- 15.11 Multiple-choice questions 189

## Chapter 16  Aircraft data networks and AFDX
- 16.1 Integrated modular avionics 191
- 16.2 Local area networks 191
- 16.3 LAN topology 192
- 16.4 Ethernet 193
- 16.5 Avionics full-duplex switched networks 194
- 16.6 Determinism and quality of service 195
- 16.7 Virtual links 196
- 16.8 Bandwidth allocation 197
- 16.9 AFDX frame format 197
- 16.10 Redundancy, reliability and integrity checking 198
- 16.11 Multiple-choice questions 201
The books in this series have been designed for both independent and tutor-assisted studies. They are particularly useful to the ‘self-starter’ and to those wishing to update or upgrade their aircraft maintenance licence. The series also provides a useful source of reference for those taking ab initio training programmes in EASA Part 147 and FAR 147 approved organizations, as well as those following related programmes in further and higher education institutions.

This book is designed to cover the essential knowledge base required by certifying mechanics, technicians and engineers engaged in engineering maintenance activities on commercial aircraft. In addition, this book should appeal to members of the armed forces and others attending training and educational establishments engaged in aircraft maintenance and related aeronautical engineering programmes (including BTEC National and Higher National units as well as City and Guilds and NVQ courses).

The book provides an introduction to the principles, operation and maintenance of aircraft digital electronic and computer systems. The aim has been to make the subject material accessible and present it in a form that can be readily assimilated. The book provides full syllabus coverage of Module 5 of the EASA Part-66 syllabus, with partial coverage of avionic topics in Modules 11 and 13. The book assumes a basic understanding of aircraft flight controls as well as an appreciation of electricity and electronics (broadly equivalent to Modules 3 and 4 of the EASA Part-66 syllabus).

Chapter 1 sets the scene by providing an overview of flight instruments and cockpit layouts. It also introduces the use of electronic flight instruments (EFIS) and the displays that they produce.

Denary, binary and hexadecimal number systems are introduced in Chapter 2. This chapter provides numerous examples of the techniques used for converting from one number system to another – for example, binary to hexadecimal or octal to binary.

Data conversion is the subject of Chapter 3. This chapter introduces analogue and digital signals and the techniques used for analogue to digital and digital to analogue conversion. Representative circuits are provided for various types of converter, including successive approximation, flash and dual slope analogue to digital converters.

Chapter 4 describes the data bus systems that allow a wide variety of avionic equipment to communicate with one another and exchange data. The principles of aircraft bus systems and architecture are discussed and the operation of the ARINC 429 bus is discussed in detail. Various other bus standards (e.g. ARINC 629 and ARINC 573) are briefly discussed. Further references to aircraft bus systems (including those based on optical fibres) appear in later chapters.

Logic circuits are introduced in Chapter 5. This chapter begins by introducing the basic logic functions (AND, OR, NAND and NOR) before moving on to provide an introduction to Boolean algebra and combinational logic arrangements. An example of the use of combinational logic is given in the form of a landing gear door warning system. Chapter 5 also describes the use of tri-state logic devices as well as monostable and bistable devices. An example of the use of combinational logic is included in the form of
an auxiliary power unit (APU) starter control circuit. The chapter concludes with an explanation of the properties and characteristics of common logic families, including major transistor–transistor logic (TTL) variants and complementary metal oxide semiconductor (CMOS) logic.

Modern aircraft use increasingly sophisticated avionic systems based on computers. Chapter 6 describes the basic elements used in a computer system and explains how data is represented and stored within a computer system. Various types of semiconductor memory are explained, including random access memory (RAM) and read-only memory (ROM). The chapter also provides an introduction to computer programs and software and examples of computer instructions are given. Chapter 6 also provides an introduction to the backplane bus systems used for larger aircraft computers. The chapter is brought to a conclusion with a discussion of two examples of aircraft computers; a flight deck clock computer and an aircraft integrated data system (AIDS) data recorder.

Chapter 7 provides an introduction to the operation of microprocessor central processing units (CPU). The internal architecture of a typical CPU is presented, together with a detailed explanation of its operation and the function of its internal elements.

Examples of several common microprocessor types are given, including the Intel x86 family, Intel Pentium family and the AMD 29050, which now forms the core of a proprietary Honeywell application-specific integrated circuit (ASIC) specifically designed for critical embedded aerospace applications.

Chapter 8 describes the fabrication technology and application of a wide variety of modern integrated circuits, from those that use less than ten to those with many millions of active devices. The chapter also includes sections on the packaging and pin numbering of integrated circuit devices.

Medium-scale integrated (MSI) logic circuits are frequently used in aircraft digital systems to satisfy the need for more complex logic functions, such as those used for address decoding, code conversion and the switching of logic signals between different bus systems. Chapter 9 describes typical MSI devices and their applications (including decoding, encoding and multiplexing). Examples of several common MSITTL devices are included.

By virtue of their light weight, compact size, exceptional bandwidth and high immunity to electromagnetic interference, optical fibres are now widely used to interconnect aircraft computer systems. Chapter 10 provides an introduction to optical fibres and their increasing use in the local area networks (LANs) used in aircraft.

Chapter 11 describes typical displays used in avionic systems, including the cathode ray tube (CRT) and active matrix liquid crystal displays (AMLCD) used in electronic flight instrument systems (EFIS).

Modern microelectronic devices are particularly susceptible to damage from stray static charges and, as a consequence, they require special handling precautions. Chapter 12 deals with the techniques and correct practice for handling and transporting such devices.

Aircraft software is something that you can’t see and you can’t touch, yet it must be treated with the same care and consideration as any other aircraft part. Chapter 13 describes the different classes of software used in an aircraft and explains the need for certification and periodic upgrading or modification. The chapter provides an example of the procedures required for upgrading the software used in an electronic engine control (EEC).

One notable disadvantage of the increasing use of sophisticated electronics within an aircraft is the proliferation of sources of electromagnetic interference (EMI) and the urgent need to ensure that avionic systems are electromagnetically compatible with one another. Chapter 14 provides an introduction to electromagnetic compatibility (EMC) and provides examples of measures that can be taken to both reduce EMI and improve EMC. The chapter also discusses the need to ensure the electrical integrity of the aircraft structure and the techniques used for grounding and bonding, which serves to protect an aircraft (and its occupants) from static and lightning discharge.

Chapter 15 provides an overview of a variety of different avionic systems that are based on the use of digital electronics and computer systems. This chapter serves to bring into context the principles and theory discussed in the previous chapters.

The use of integrated modular avionics (IMA) has become commonplace in the latest generation of aircraft. Chapter 16 provides an introduction to the use of ethernet-based networks in modern aircraft. After a brief explanation of the different topologies used in LANs it provides an outline of the architecture and operation of the avionics full-duplex switched network (AFDX).
Finally, Chapter 17 will provide you with an introduction to some of the techniques used in the development, testing and verification of the very large-scale logic systems used in aircraft today. Usually fabricated on a single silicon chip, such systems often comprise many tens or hundreds of thousands of individual logic elements connected in a way that fulfils the requirements of the system. Simple examples of the use of very high-speed integrated circuit hardware description language (VHDL) are included in this chapter, sufficient to provide engineers with an understanding of how the language contributes to the development process.

The book concludes with four useful appendices, including a comprehensive list of abbreviations and acronyms used with aircraft digital electronics and computer systems.

The review questions at the end of each chapter are typical of those used in CAA and other examinations. Further examination practice can be gained from the six revision papers given in Appendix 2. Other features that will be particularly useful if you are an independent learner are the ‘key points’ and ‘test your understanding’ questions interspersed throughout the text.
This page intentionally left blank
The author would like to express sincere thanks to those who helped in producing this book. In particular, thanks go to Gavin Fidler and Emma Gadsden from Taylor & Francis who ably ‘fielded’ my many queries and who supported the book from its inception. Lloyd Dingle (who had the original idea for this series) for his vision and tireless enthusiasm. David Wyatt for proofreading the original manuscript and for acting as a valuable ‘sounding board’. Finally, a big ‘thank you’ to Yvonne for her patience, understanding and support during the many late nights and early mornings that went into producing it!

Supporting material for this book (including interactive questions and answers) is available online. To access this material please go to www.66web.co.uk and follow the instructions on screen.
Although it may not be apparent at first sight, it’s fair to say that a modern aircraft simply could not fly without the electronic systems that provide the crew with a means of controlling the aircraft. Avionic systems are used in a wide variety of different applications, ranging from flight control and instrumentation to navigation and communication. In fact, an aircraft that uses modern ‘fly-by-wire’ techniques could not even get off the ground without the electronic systems that make it work.

This chapter begins with an introduction to the basic instruments needed for indicating parameters such as heading, altitude and airspeed, and then continues by looking at their modern electronic equivalents. Finally, we show how flight information can be combined using integrated instrument systems and flight information displays, as shown in Figure 1.1.

1.1 FLIGHT INSTRUMENTS

Of paramount importance in any aircraft is the system (or systems) used for sensing and indicating the aircraft’s attitude, heading, altitude and speed. In early aircraft, these instruments were simple electro-mechanical devices. Indeed, when flying under visual flight rules (VFR) rather than instrument flight rules (IFR) the pilot’s most important source of information about what the aircraft was doing would have been the view out of the cockpit window! Nowadays, sophisticated avionic and display technology, augmented by digital logic and computer systems, has made it possible for an aircraft to be flown (with a few possible exceptions) entirely by reference to instruments. More about these important topics appears in Chapters 5 and 6.
Various instruments are used to provide the pilot with flight-related information, such as the aircraft’s current heading, airspeed and attitude.

Modern aircraft use electronic transducers and electronic displays and indicators. Cathode ray tubes (CRT) and liquid crystal displays (LCD) are increasingly used to display this information in what has become known as a ‘glass cockpit’. Modern passenger aircraft generally have a number of such displays, including those used for primary flight data and multifunction displays that can be configured to display a variety of information. We shall begin this section with a brief review of the basic flight instruments.

1.1.1 Basic flight instruments

Crucial among the flight instruments fitted to any aircraft are those that indicate the position and attitude of the aircraft. These basic flight instruments are required to display information concerning:

- heading
- altitude
- airspeed
- rate of turn
- rate of climb (or descent)
- attitude (relative to the horizon).

A summary of the instruments that provide these indications is shown in Table 1.1, with the typical instrument displays shown in Figures 1.2–1.8. Note that several of these instruments are driven from the aircraft’s pitot-static system. Because of this, they are often referred to as ‘air data instruments’ (see Figures 1.11–1.13).
### Table 1.1 Basic flight instruments

<table>
<thead>
<tr>
<th>Instrument</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Altimeter (<a href="#">Figure 1.2</a>)</td>
<td>Indicates the aircraft’s height (in feet or metres) above a reference level (usually mean sea level) by measuring the local air pressure. To provide accurate readings the instrument is adjustable for local barometric pressure. In large aircraft a second standby altimeter is often available (see Figure 1.3)</td>
</tr>
<tr>
<td>Attitude indicator or ‘artificial horizon’ (<a href="#">Figure 1.4</a>)</td>
<td>Displays the aircraft’s attitude relative to the horizon (see Figure 1.4). From this the pilot can tell whether the wings are level and if the aircraft nose is pointing above or below the horizon. This is a primary indicator for instrument flight and is also useful in conditions of poor visibility. Pilots are trained to use other instruments in combination should this instrument or its power fail</td>
</tr>
<tr>
<td>Airspeed indicator (<a href="#">Figures 1.5 and 1.6</a>)</td>
<td>Displays the speed of the aircraft (in knots) relative to the surrounding air. The instrument compares the ram-air pressure in the aircraft’s pitot-tube with the static pressure (see Figure 1.11). The indicated airspeed must be corrected for air density (which varies with altitude, temperature and humidity) and for wind conditions in order to obtain the speed over the ground</td>
</tr>
<tr>
<td>Magnetic compass (<a href="#">Figure 1.7</a>)</td>
<td>Indicates the aircraft’s heading relative to magnetic north. However, due to the inclination of the earth’s magnetic field, the instrument can be unreliable when turning, climbing, descending or accelerating. Because of this the HSI (see below) is used. For accurate navigation, it is necessary to correct the direction indicated in order to obtain the direction of true north or south (at the extreme ends of the Earth’s axis of rotation)</td>
</tr>
<tr>
<td>Horizontal situation indicator</td>
<td>The horizontal situation indicator (HSI) displays a plan view of the aircraft’s position showing its heading. Information used by the HSI is derived from the compass and radio navigation equipment (VOR), which provides accurate bearings using ground stations. In light aircraft the VOR receiver is often combined with the VHF communication radio equipment but in larger aircraft a separate VOR receiver is fitted</td>
</tr>
<tr>
<td>Turn and bank indicator or ‘turn coordinator’</td>
<td>Indicates the direction and rate of turn. An internally mounted inclinometer displays the ‘quality’ of turn, i.e. whether the turn is correctly coordinated, as opposed to an uncoordinated turn in which the aircraft would be in either a slip or skid. In modern aircraft the turn and bank indicator has been replaced by the turn coordinator which displays (a) rate and direction of roll when the aircraft is rolling, and (b) rate and direction of turn when the aircraft is not rolling</td>
</tr>
<tr>
<td>Vertical speed indicator (<a href="#">Figure 1.8</a>)</td>
<td>Indicates rate of climb or descent (in feet per minute or metres per second) by sensing changes in air pressure (see Figure 1.11)</td>
</tr>
</tbody>
</table>
1.7 Standby magnetic compass

1.8 Standby vertical speed indicator

**TEST YOUR UNDERSTANDING 1.1**

Identify the instruments shown in Figs. 1.9 and 1.10. Also state the current indication displayed by each instrument.

1.10 See Test your understanding 1.1
1.1.2 Acronyms

A number of acronyms are used to refer to flight instruments and cockpit indicating systems. Unfortunately, there is also some variation in the acronyms used by different aircraft manufacturers. The most commonly used acronyms are listed in Table 1.2. A full list can be found in Appendix 1.

<table>
<thead>
<tr>
<th>Acronym</th>
<th>Meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td>ADI</td>
<td>Attitude direction indicator</td>
</tr>
<tr>
<td>ASI</td>
<td>Airspeed indicator</td>
</tr>
<tr>
<td>CDU</td>
<td>Control and display unit</td>
</tr>
<tr>
<td>EADI</td>
<td>Electronic attitude and direction indicator</td>
</tr>
<tr>
<td>ECAM</td>
<td>Electronic centralised aircraft monitoring</td>
</tr>
<tr>
<td>EFIS</td>
<td>Electronic flight instrument system</td>
</tr>
<tr>
<td>EHSI</td>
<td>Electronic horizontal situation indicator</td>
</tr>
<tr>
<td>EICAS</td>
<td>Engine indicating and crew alerting system</td>
</tr>
<tr>
<td>FDS</td>
<td>Flight director system</td>
</tr>
<tr>
<td>FIS</td>
<td>Flight instrument system</td>
</tr>
<tr>
<td>FMC</td>
<td>Flight management computer</td>
</tr>
<tr>
<td>FMS</td>
<td>Flight management system</td>
</tr>
<tr>
<td>HSI</td>
<td>Horizontal situation indicator</td>
</tr>
<tr>
<td>IRS</td>
<td>Inertial reference system</td>
</tr>
<tr>
<td>ND</td>
<td>Navigation display</td>
</tr>
<tr>
<td>PFD</td>
<td>Primary flight display</td>
</tr>
<tr>
<td>RCDI</td>
<td>Rate of climb/descent indicator</td>
</tr>
<tr>
<td>RMI</td>
<td>Radio magnetic indicator</td>
</tr>
<tr>
<td>VOR</td>
<td>Very high frequency omni-range</td>
</tr>
<tr>
<td>VSI</td>
<td>Vertical speed indicator</td>
</tr>
</tbody>
</table>

1.1.3 Electronic flight instruments

Modern aircraft make extensive use of electronic instruments and displays. One advantage of using electronic instruments is that data can easily be exchanged between different instrument systems and used as a basis for automatic flight control. We will explore the potential of this a little later in this chapter but, for now, we will look at the two arguably most important
electronic instruments, the electronic attitude and direction indicator (EADI) and the electronic horizontal situation indicator (EHSI).

**Electronic attitude and direction indicator**

The electronic attitude direction indicator (EADI – see Figure 1.14) is designed to replace the basic ADI and normally comprises:

- an attitude indicator
- a fixed aircraft symbol
- pitch and bank command bars
- a glide slope indicator
- a localiser deviation indicator
- a slip indicator
- flight mode annunciator
- various warning flags.

The aircraft’s attitude relative to the horizon is indicated by the fixed aircraft symbol and the flight command bars. The pilot can adjust the symbol to one of three flight modes. To fly the aircraft with the command bars armed, the pilot simply inserts the aircraft symbol between the command bars.

The command bars move up for a climb or down for descent, roll left or right to provide lateral guidance. They display the computed angle of bank for standard-rate turns to enable the pilot to reach a selected heading or track. The bars also show pitch commands that allow the pilot to capture and fly an instrument landing system (ILS) glide slope, a pre-selected pitch attitude or maintain a selected barometric altitude. To comply with the directions indicated by the command bars, the pilot manoeuvres the aircraft to align the fixed symbol with the command bars. When not using the bars, the pilot can move them out of view.

The glide slope deviation pointer represents the centre of the ILS glide slope and displays vertical deviation of the aircraft from the glide slope centre. The glide slope scale centreline shows aircraft position in relation to the glide slope.

The localiser deviation pointer, a symbolic runway, represents the centre of the ILS localiser, and comes into view when the pilot has acquired the glide slope. The expanded scale movement shows lateral deviation from the localiser and is approximately twice as sensitive as the lateral deviation bar in the horizontal situation indicator. The selected flight mode is displayed in the lower left of the EADI for pitch modes, and lower right for lateral modes. The slip indicator provides an indication of slip or skid indications.

**Electronic horizontal situation indicator**

The electronic horizontal situation indicator (EHSI) assists pilots with the interpretation of information provided by a number of different navigation aids. There are various types of EHSI, but essentially they all perform the same function. An EHSI display (see Figure 1.15) can be configured to display a variety of information (combined in various different ways), including:

- heading indication
- radio magnetic indication (RMI)
- track indication
- range indication
- wind speed and direction
- VOR, DME, ILS or ADF information.

**1.1.4 Flight director systems**

The major components of a flight director system (FDS) are the EADI and EHSI, working together with a mode selector and a flight director computer.

The FDS combines the outputs of the electronic flight instruments to provide an easily interpreted
display of the aircraft’s flight path. By comparing this information with the pre-programmed flight path, the system can automatically compute the necessary flight control commands to obtain and hold the desired path.

The flight director system receives information from the:

- attitude gyro
- VOR/localiser/glide slope receiver
- radar altimeter
- compass system
- barometric sensors.

The flight director computer uses this data to provide flight control command information that enables the aircraft to:

- fly a selected heading
- fly a predetermined pitch attitude
- maintain altitude
- intercept a selected VOR track and maintain that track
- fly an ILS glide slope/localiser.

The flight director control panel comprises a mode selector switch and control panel that provides the input information used by the FDS.

The pitch command control pre-sets the desired pitch angle of the aircraft for climb or descent. The command bars on the FDS then display the computed attitude to maintain the pre-selected pitch angle. The pilot may choose from among many modes, including the HDG (heading) mode, the VOR/LOC (localiser tracking) mode, or the AUTO APP or G/S (automatic capture and tracking of ILS and glide path) mode. The auto mode has a fully automatic pitch selection computer that takes into account aircraft performance and wind conditions, and operates once the pilot has reached the ILS glide slope.

Flight director systems have become increasingly more sophisticated in recent years. More information appears in Chapter 15.

1.1.5 Electronic flight instrument systems

An electronic flight instrument system (EFIS) is a system of graphically presented displays with underlying sensors, electronic circuitry and software that effectively replaces all mechanical flight instruments and gauges with a single unit.

The EFIS fitted to larger aircraft consists of a primary flight display (PFD) or electronic attitude and direction indicator (EADI) and a navigation display (ND) or electronic horizontal situation indicator (EHSI). These instruments are duplicated for the captain and the first officer.

The PFD presents the usual attitude indicator in connection with other data, such as airspeed, altitude, vertical speed, heading or coupled landing systems (see Figure 1.16). The ND displays route information,
In addition to the two large graphical displays, a typical EFIS will have a display select panel, a display processor unit, a weather radar panel, a multi-function processor unit, and a multi-function display. We will look briefly at each of these.

**EFIS primary flight display**

The typical EFIS PFD is a multicolour CRT or LCD display unit that presents a display of aircraft attitude and flight control system commands, including VOR, localiser, TACAN (tactical air navigation), or RNAV (area navigation) deviation, together with glide slope or pre-selected altitude deviation. Various other information can be displayed, including mode annunciation, radar altitude, decision height and excessive ILS deviation.

**EFIS navigation display**

Like the EFIS PFD, a typical EFIS ND takes the form of a multicolour CRT or LCD display unit. However, in this case the display shows the aircraft’s horizontal situation information which, according to the display mode selected, can include compass heading, selected heading, selected VOR, localiser or RNAV course and deviation (including annunciation or deviation type), navigation source annunciation, digital selected course/desired track readout, excessive ILS deviation, to/from information, distance to station/waypoint, glide slope, or VNAV deviation, ground speed, time-to-go, elapsed time or wind, course information and source annunciation from a second navigation source, weather radar target alert, waypoint alert when RNAV is the navigation source, and a bearing pointer that can be driven by VOR, RNAV or ADF sources as selected on the display select panel. The display mode can also be set to approach format or en-route format with or without weather radar information included in the display.

**Display select panel**

The display select panel (DSP) provides navigation sensor selection, bearing pointer selection, format selection, navigation data selection (ground speed, time-to-go, time and wind direction/speed), and the selection of VNAV (if the aircraft has this system), weather or second navigation source on the ND. A DH SET control that allows decision height to be set on the PFD is also provided. Additionally, course, course direct to and heading are selected from the DSP.

a compass card or the weather radar picture (see Figure 1.17).
Display processor unit

The display processor unit (DPU) provides sensor input processing and switching, the necessary deflection and video signals and power for the electronic flight displays. The DPU is capable of driving two electronic flight displays with different deflection and video signals. For example, a PFD on one display and an ND on the other.

Weather radar panel

The weather radar panel (WXP) provides MODE control (OFF, STBY, TEST, NORM, WX and MAP), RANGE selection (10, 25, 50, 100, 200 and 300 nm) and system operating controls for the display of weather radar information on the MFD and the ND when RDR is selected on the MFD and/or the DSP.

Multi-function display

The multi-function display takes the form of another multicolour CRT or active-matrix LCD display unit. The display is normally mounted on the instrument panel in the space provided for the weather radar (WXR) indicator. Standard functions displayed by the unit include weather radar, pictorial navigation map and, in some systems, checklist and other operating data. Additionally, the MFD can display flight data or navigation data in case of a PFD or ND failure.

Multifunction processor unit

The multifunction processor unit (MPU) provides sensor input processing and switching and the necessary deflection and video signals for the multi-function display. The MPU can provide the deflection and video signals to the PFD and ND displays in the event of failures in either or both DPUs.

1.1.6 Electronic centralised aircraft monitor

Technical information concerning the state of an Airbus aircraft is displayed using the aircraft’s electronic centralised aircraft monitor (ECAM – see Figure 1.18). This normally takes the form of two CRT or LCD displays that are vertically arranged in the centre of the instrument panel. The upper (primary) display shows the primary engine parameters (N1/fan speed, EGT, N2/high pressure turbine speed), as well as the fuel flow, the status of lift augmentation devices (flap and slat positions), along with other information. The lower (secondary) ECAM display presents additional information, including that relating to any system malfunction and its consequences.

1.1.7 Engine indicating and crew alerting system

In Boeing aircraft the equivalent integrated electronic aircraft monitoring system is known as the engine indicating and crew alerting system (EICAS). This system provides graphical monitoring of the engines of later Boeing aircraft, replacing a large number of individual panel-mounted instruments. In common with the Airbus ECAM system, EICAS uses two vertically mounted, centrally located displays (see Figure 1.19).

1.18 A320 ECAM displays located above the centre console between the captain and first officer

TEST YOUR UNDERSTANDING 1.4

Figure 1.20 shows a flight deck display.

1. Identify the display.
2. What information is currently displayed?
1.1.8 Flight management system

The flight management system (FMS) fitted to a modern passenger aircraft brings together data and information gathered from the electronic flight instruments, aircraft monitoring and navigation systems, and provides outputs that can be used for automatic control of the aircraft from immediately after take-off to final approach and landing. The key elements of an FMS include a flight management computer (FMC), control and display unit (CDU), inertial reference system (IRS), auto flight control system (AFCS) and a system of data buses that facilitates the interchange of data with the other digital and computerised systems and instruments fitted to the aircraft.

Two FMSs are fitted, one for the captain and one for the first officer. During normal operation the two systems share the incoming data. However, each system can be made to operate independently in the event of failure. By automatically comparing (on a continuous basis) the indications and outputs provided by the two systems it is possible to detect faults within the system and avoid erroneous indications.

The inputs to the FMC are derived from several other systems, including IRS, EICAS, engine thrust management computer and the air data computer. Figures 1.21 and 1.22 shows the FMC control and display units fitted to an A320 aircraft. We shall be looking at the operation of the FMS in greater detail later in Chapter 15.
1.2 COCKPIT LAYOUTS

Major developments in display technology and the introduction of increasingly sophisticated aircraft computer systems have meant that cockpit layouts have been subject to continuous change over the past few decades. At the same time, aircraft designers have had to respond to the need to ensure that the flight crew are not overburdened with information and that relevant data is presented in an appropriate form and at the time it is needed.

Figure 1.23 shows how the modern EFIS layouts have evolved progressively from the basic ‘T’ instrument configuration found in non-EFIS aircraft. Maintaining the relative position of the instruments has been important in allowing pilots to adapt from one aircraft type to another. At the same time, the large size of modern CRT and LCD displays, coupled with the ability of these instruments to display combined data (for example, heading, airspeed and altitude) has led to a less-cluttered instrument panel (see Figures 1.24 and 1.26). Lastly, a number of standby (or secondary) instruments are made available in order to provide the flight crew with reference information which may become invaluable in the case of a malfunction in the computer system.
1.24 Captain’s flight instrument and display layout on the A320

TEST YOUR UNDERSTANDING 1.5

1. Identify each of the Boeing 767 flight instruments and displays shown in Figure 1.25.
2. Classify the flight instruments in Question 1 as either primary or standby.
1.3 MULTIPLE-CHOICE QUESTIONS

1. A multifunction display (MFD) can be:
   (a) used only for basic flight information
   (b) configured for more than one type of information
   (c) set to display information from the standby magnetic compass.

2. Which standby instruments are driven from the aircraft’s pitot-static system:
   (a) Airspeed indicator, altimeter and vertical speed indicator
   (b) Airspeed indicator, vertical speed indicator and magnetic compass
   (c) Airspeed indicator, altimeter and angle-of-attack indicator.

3. Static pressure is fed:
   (a) only to the airspeed indicator
   (b) only to the airspeed indicator and vertical speed indicator
   (c) to the airspeed indicator as well as the altimeter and vertical speed indicator.

4. The horizontal situation indicator (HSI) uses information derived from:
   (a) the VOR receiver
   (b) the pitot-static system
   (c) the airspeed indicator.

5. The term ‘glass cockpit’ refers to:
   (a) the use of LCD and CRT displays
   (b) the use of toughened glass windows
   (c) the use of a transparent partition between the flight deck and passenger cabin.

6. Basic air data instruments are:
   (a) airspeed indicator, altimeter and magnetic compass
   (b) airspeed indicator, altimeter and vertical speed indicator
   (c) airspeed indicator, vertical speed indicator and artificial horizon.

7. Three airborne parameters that can be used to assess aircraft position are:
   (a) airspeed, height and weight
   (b) heading, airspeed and height
   (c) heading, weight and airspeed.

8. The instrument shown in Figure 1.27 is the:
   (a) ADI
   (b) ASI
   (c) VSI.

9. Engine parameters such as turbine speed are displayed on:
   (a) ECAM
   (b) EHSI
   (c) EADI.
10. The aircraft slip indicator is found in the:
   (a) EADI
   (b) ECAM
   (c) CRTs in the passenger cabin.

11. Where is the ‘rising runway’:
   (a) EADI
   (b) ECAM
   (c) CRTs in the passenger cabin.

12. Under visual flight rules (VFR) the pilot’s most important source of information concerning the aircraft’s position and attitude is:
   (a) the view out of the cockpit window
   (b) the altimeter and vertical speed indicators
   (c) the airspeed indicator and the magnetic compass.

13. The EFIS fitted to a large aircraft usually consists of:
   (a) a single multi-function display
   (b) separate primary flight and navigation displays
   (c) a primary display with several standby instruments.

14. The instrument shown in Figure 1.28 is the:
   (a) EADI
   (b) EHSI
   (c) ECAM.

15. The instrument shown in Figure 1.29 is the:
   (a) EADI
   (b) EHSI
   (c) ECAM.

16. In a basic ‘T’ configuration of instruments:
   (a) the ADI appears on the left and the ASI appears on the right
   (b) the ADI appears on the left and the HSI appears on the right
   (c) the ASI appears on the left and the altimeter appears on the right.

17. The flight director system receives information:
   (a) only from the VOR/localiser
   (b) only from the attitude gyro and altimeter
   (c) from both of the above.

18. EICAS provides the following information:
   (a) engine parameters only
   (b) engine parameters and system warnings
   (c) engine parameters and navigational data.

19. The two sets of flight regulations that a pilot may fly by are:
   (a) VFR and IFR
   (b) VHF and IFR
   (c) VFR and IFU.
20. Secondary heading information is obtained from:
   (a) the gyro  
   (b) the compass  
   (c) the pitot-static system.

21. A major advantage of EFIS is a reduction in:
   (a) effects of EMI  
   (b) wiring and cabling  
   (c) moving parts present in the flight deck.

22. The term ‘artificial horizon’ is sometimes used to describe the indication produced by:
   (a) the altimeter  
   (b) the attitude indicator  
   (c) the vertical speed indicator.

23. Typical displays on an EHSI are:
   (a) engine indications  
   (b) VOR, heading, track  
   (c) VOR, altitude, rate of climb.

24. In a basic ‘T’ configuration of instruments:
   (a) the ADI appears at the top and the HSI appears at the bottom  
   (b) the HSI appears at the top and the ASI appears at the bottom  
   (c) the ASI appears at the top and the ADI appears at the bottom.

25. Operational faults in FMS can be detected by:
   (a) automatically comparing outputs on a continuous basis  
   (b) routine maintenance inspection of the aircraft  
   (c) pre-flight checks.

26. The display marked X in Figure 1.30 is the:
   (a) navigation display  
   (b) primary flight display  
   (c) FMS CDU.

27. The display marked Y in Figure 1.31 is the:
   (a) standby flight instruments  
   (b) primary flight display  
   (c) FMS CDU.

28. The upper ECAM display provides:
   (a) navigation information  
   (b) secondary flight information  
   (c) engine parameters.
The signals in digital logic and computer systems are conveyed along individual electrical conductors and also using multiple wiring arrangements where several conductors are used to convey signals from one place to another in what is known as a bus system. As we will see in Chapter 4, the number of individual bus lines depends on the particular bus standard employed; however, signals on the individual lines, no matter what they are used for or how they are organised, can exist in only two basic states: logic 0 (‘low’ or ‘off’) or logic 1 (‘high’ or ‘on’). Thus information within a digital system is represented in the form of a sequence of 1s and 0s, known as binary data.

Since binary numbers (particularly large ones) are not very convenient for human use, we often convert binary numbers to other forms of number that are easier to recognise and manipulate. These number systems include hexadecimal (base 16) and octal (base 8). This chapter is designed to introduce you to the different types of number system as well as the process of conversion from one type to another.

### 2.1 DECIMAL (DENARY) NUMBERS

The decimal numbers that we are all very familiar with use the base 10 system. In this system the weight of each digit is ten times as great as the digit immediately to its right. The rightmost digit of a decimal integer (i.e. a whole number) is the unit’s place (100); the digit to its left is the ten’s digit (10¹); the next is the hundred’s digit (10²); and so on. The valid digits in a decimal number are 0 to 9. Figures 2.1 and 2.2 show how the decimal number 179 is constructed.

#### TEST YOUR UNDERSTANDING 2.1

Write down the values of:

(a) $2 \times 102$
(b) $3 \times 104$
(c) $(1 \times 103) + (9 \times 102) + (0 \times 101) + (1 \times 100)$

#### 2.2 An example showing how the decimal number 251 is constructed
show two examples of how decimal numbers are constructed. Note that we have used the suffix '10' to indicate that the number is a decimal. So, $179_{10}$ and $251_{10}$ are both decimal (or base 10) numbers. The use of subscripts helps us to avoid confusion about what number base we are actually dealing with.

2.2 BINARY NUMBERS

In the binary system (base 2), the weight of each digit is two times as great as the digit immediately to its right. The rightmost digit of a binary integer is the one’s digit; the next digit to the left is the two’s digit; next is the four’s digit; then the eight’s digit; and so on. The valid digits in the binary system are 0 and 1. Figure 2.3 shows an example of a binary number (note the use of the suffix ‘2’ to indicate the number base).

The binary numbers that are equivalent to the decimal numbers 0 to 9 are shown in Table 2.1. Notice how the most significant digit (MSD) is shown on the left and the least significant digit (LSD) appears on the right. In the table, the MSD has a weight of $2^3$ (or 8 in decimal) while the LSD has a weight of $2^0$ (or 1 in decimal). Since the MSD and LSD are represented by binary digits (either 0 or 1) we often refer to them as the most significant bit (MSB) and least significant bit (LSB), respectively, as shown in Figure 2.4.

2.2.1 Binary to decimal conversion

In order to convert a binary number to its equivalent decimal number we can determine the value of each successive binary digit, multiply it by the column value (in terms of the power of the base) and then simply add the values up. For example, to convert the binary number 1011, we take each digit and multiply it by the binary weight of the digit position (8, 4, 2 and 1) and add the result, as shown in Figure 2.5.

<table>
<thead>
<tr>
<th>Binary</th>
<th>Decimal</th>
</tr>
</thead>
<tbody>
<tr>
<td>0000</td>
<td>0</td>
</tr>
<tr>
<td>0001</td>
<td>1</td>
</tr>
<tr>
<td>0010</td>
<td>2</td>
</tr>
<tr>
<td>0011</td>
<td>3</td>
</tr>
<tr>
<td>0100</td>
<td>4</td>
</tr>
<tr>
<td>0101</td>
<td>5</td>
</tr>
<tr>
<td>0110</td>
<td>6</td>
</tr>
<tr>
<td>0111</td>
<td>7</td>
</tr>
<tr>
<td>1000</td>
<td>8</td>
</tr>
<tr>
<td>1001</td>
<td>9</td>
</tr>
</tbody>
</table>
2.2.2 Decimal to binary conversion

There are two basic methods for converting decimal numbers to their equivalent in binary. The first method involves breaking the number down into a succession of numbers that are each powers of 2 and then placing the relevant digit (either a 0 or a 1) in the respective digit position, as shown in Figure 2.6.

\[ 23_{10} = 16 + 4 + 2 + 1 = (1 \times 2^4) + (0 \times 2^3) + (1 \times 2^2) + (1 \times 2^1) + (1 \times 2^0) \]

Another method involves successive division by two, retaining the remainder as a binary digit and then using the result as the next number to be divided, as shown in Figure 2.7. Note how the binary number is built up in reverse order, i.e. with the last remainder as the MSB and the first remainder as the LSB.

2.2.3 Binary coded decimal

The system of binary numbers that we have looked at so far is more correctly known as natural binary. Another form of binary number commonly used in digital logic circuits is known as binary coded decimal (BCD). In this simpler system, binary conversion to

TEST YOUR UNDERSTANDING 2.3

1. Convert the following binary numbers to decimal: (a) 10101; (b) 110011; (c) 1001001; (d) 10101011.

2. Convert the following decimal numbers to binary: (a) 25; (b) 43; (c) 65; (d) 100.

and from decimal numbers involves arranging binary numbers in groups of four binary digits from right to left, each of which corresponds to a single decimal digit, as shown in Figures 2.8 and 2.9.
2.2.4 One’s complement

The one’s complement of a binary number is formed by inverting the value of each digit of the original binary number (i.e. replacing 1s with 0s and 0s with 1s). So, for example, the one’s complement of the binary number 1010 is simply 0101. Similarly, the one’s complement of 01110001 is 10001110. Note that if you add the one’s complement of a number to the original number the result will be all 1s, as shown in Figure 2.10.

2.2.5 Two’s complement

Two’s complement notation is frequently used to represent negative numbers in computer mathematics (with only one possible code for zero – unlike one’s complement notation). The two’s complement of a binary number is formed by inverting the digits of the original binary number and then adding 1 to the result. So, for example, the two’s complement of the binary number 1001 is 0111. Similarly, the two’s complement of 01110001 is 10001111. When two’s complement notation is used to represent negative numbers the MSD is always a 1. Figure 2.11 shows two examples of finding the two’s complement of a binary number. In the case of Figure 2.11b it is important to note the use of a carry digit when performing the binary addition.

2.3 OCTAL NUMBERS

The octal number system is used as a more compact way of representing binary numbers. Because octal consists of eight digits (0 to 7), a single octal digit can replace three binary digits. Put another way, by arranging a binary number into groups of three binary digits (or bits) we can replace each group by a single octal digit (see Figure 2.12). Note that, in a similar manner to the numbering systems that we met

---

**TEST YOUR UNDERSTANDING 2.4**

1. Convert the following decimal numbers to BCD: (a) 97; (b) 6450.
2. Convert the following BCD numbers to decimal: (a) 10000011; (b) 01111101001.

---

**2.2.4 One’s complement**

The one’s complement of a binary number is formed by inverting the value of each digit of the original binary number (i.e. replacing 1s with 0s and 0s with 1s). So, for example, the one’s complement of the binary number 1010 is simply 0101. Similarly, the one’s complement of 01110001 is 10001110. Note that if you add the one’s complement of a number to the original number the result will be all 1s, as shown in Figure 2.10.

![Example of converting the BCD number 01110001 to decimal](image)

**2.2.5 Two’s complement**

Two’s complement notation is frequently used to represent negative numbers in computer mathematics (with only one possible code for zero – unlike one’s complement notation). The two’s complement of a binary number is formed by inverting the digits of the original binary number and then adding 1 to the result. So, for example, the two’s complement of the binary number 1001 is 0111. Similarly, the two’s complement of 01110001 is 10001111. When two’s complement notation is used to represent negative numbers the MSD is always a 1. Figure 2.11 shows two examples of finding the two’s complement of a binary number. In the case of Figure 2.11b it is important to note the use of a carry digit when performing the binary addition.

**2.3 OCTAL NUMBERS**

The octal number system is used as a more compact way of representing binary numbers. Because octal consists of eight digits (0 to 7), a single octal digit can replace three binary digits. Put another way, by arranging a binary number into groups of three binary digits (or bits) we can replace each group by a single octal digit (see Figure 2.12). Note that, in a similar manner to the numbering systems that we met
previously in this chapter, the weight of each digit in an octal number is eight times as great as the digit immediately to its right. The rightmost digit of an octal number is the unit’s place (8^0), the digit to its left is the eight’s digit (8^1), the next is the 64’s digit (8^2), and so on.

<table>
<thead>
<tr>
<th align="right">8^2</th>
<th align="right">8^1</th>
<th align="right">8^0</th>
</tr>
</thead>
<tbody>
<tr>
<td align="right"></td>
<td align="right"></td>
<td align="right">1</td>
</tr>
<tr>
<td align="right">(=64)</td>
<td align="right">(=8)</td>
<td align="right">(=1)</td>
</tr>
</tbody>
</table>

2.3.1 Octal to decimal conversion

In order to convert a binary number to a decimal number we can determine the value of each successive octal digit, multiply it by the column value (in terms of the power of the base) and simply add the values up. For example, the octal number 207 is converted by taking each digit and then multiplying it by the octal weight of the digit position and adding the result, as shown in Figure 2.13.

```
207_8 ->
```

2.3.2 Decimal to octal conversion

As with decimal to binary conversion, there are two methods for converting decimal numbers to octal. The first method involves breaking the number down into a succession of numbers that are each powers of 8 and then placing the relevant digit (having a value between 0 and 7) in the respective digit position, as shown in Figure 2.14.

```
67_10 = 64 + 3
      = (1×8^2) + (0×8^1) + (3×8^0)
```

```
<table>
<thead>
<tr>
<th align="right">8^2</th>
<th align="right">8^1</th>
<th align="right">8^0</th>
</tr>
</thead>
<tbody>
<tr>
<td align="right"></td>
<td align="right"></td>
<td align="right">1</td>
</tr>
<tr>
<td align="right">(=64)</td>
<td align="right">(=8)</td>
<td align="right">(=1)</td>
</tr>
</tbody>
</table>
```

2.14 Example of decimal to octal conversion

The other method of decimal to octal conversion involves successive division by eight, retaining the remainder as a digit (with a value between 0 and 7) before using the result as the next number to be divided, as shown in Figure 2.15. Note how the octal number is built up in reverse order, i.e. with the last remainder as the MSD and the first remainder as the LSD.

```
67/8 = 8 remainder 3
     8/8 = 1 remainder 0
      1/8 = 0 remainder 1
```

2.15 Example of decimal to octal conversion using successive division

22..1122 Example of an octal number

22..1133 Example of octal to decimal conversion

22..1144 Example of decimal to octal conversion

22..1155 Example of decimal to octal conversion using successive division

**TEST YOUR UNDERSTANDING 2.5**

1. Find the one’s complement of the binary number 100010.
2. Find the two’s complement of the binary number 101101.
2.3.3 Octal to binary conversion

In order to convert an octal number to a binary number we simply convert each digit of the octal number to its corresponding three-bit binary value, as shown in Figure 2.16.

![Figure 2.16](image)

2.3.4 Binary to octal conversion

Converting a binary number to its equivalent in octal is also extremely easy. In this case you simply need to arrange the binary number in groups of three binary digits from right to left and then convert each group to its equivalent octal number, as shown in Figure 2.17.

![Figure 2.17](image)

2.4 HEXADECIMAL NUMBERS

Although computers are quite comfortable working with binary numbers of 8, 16 or even 32 binary digits, humans find it inconvenient to work with so many digits at a time. The hexadecimal (base 16) numbering system offers a practical compromise acceptable to both humans and machines. One hexadecimal digit can represent four binary digits, thus an 8-bit binary number can be expressed using two hexadecimal digits. For example, 10000011 binary is the same as 83 when expressed in hexadecimal.

The correspondence between a hexadecimal (hex) digit and the four binary digits it represents is quite straightforward and easy to learn (see Table 2.2). Note that in hexadecimal the decimal numbers from 10 to 15 are represented by the letters A to F, respectively. Furthermore, conversion between binary

<table>
<thead>
<tr>
<th>Binary</th>
<th>Decimal</th>
<th>Hexadecimal</th>
<th>Octal</th>
</tr>
</thead>
<tbody>
<tr>
<td>0000</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>0001</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>0010</td>
<td>2</td>
<td>2</td>
<td>2</td>
</tr>
<tr>
<td>0011</td>
<td>3</td>
<td>3</td>
<td>3</td>
</tr>
<tr>
<td>0100</td>
<td>4</td>
<td>4</td>
<td>4</td>
</tr>
<tr>
<td>0101</td>
<td>5</td>
<td>5</td>
<td>5</td>
</tr>
<tr>
<td>0110</td>
<td>6</td>
<td>6</td>
<td>6</td>
</tr>
<tr>
<td>0111</td>
<td>7</td>
<td>7</td>
<td>7</td>
</tr>
<tr>
<td>1000</td>
<td>8</td>
<td>8</td>
<td>10</td>
</tr>
<tr>
<td>1001</td>
<td>9</td>
<td>9</td>
<td>11</td>
</tr>
<tr>
<td>1010</td>
<td>10</td>
<td>A</td>
<td>12</td>
</tr>
<tr>
<td>1011</td>
<td>11</td>
<td>B</td>
<td>13</td>
</tr>
<tr>
<td>1100</td>
<td>12</td>
<td>C</td>
<td>14</td>
</tr>
<tr>
<td>1101</td>
<td>13</td>
<td>D</td>
<td>15</td>
</tr>
<tr>
<td>1110</td>
<td>14</td>
<td>E</td>
<td>16</td>
</tr>
<tr>
<td>1111</td>
<td>15</td>
<td>F</td>
<td>17</td>
</tr>
</tbody>
</table>

Table 2.2 Binary, decimal, hexadecimal and octal numbers

![Table](image)
and hexadecimal is fairly straightforward by simply arranging the binary digits in groups of four bits (starting from the least significant). Hexadecimal notation is much more compact than binary notation and easier to work with than decimal notation.

### 2.4.1 Hexadecimal to decimal conversion

In order to convert a hexadecimal number to a decimal number we can determine the value of each successive hexadecimal digit, multiply it by the column value (in terms of the power of the base) and simply add the values up. For example, the hexadecimal number of A7 is converted by taking each digit and then multiplying it by the weight of the digit position, as shown in Figure 2.18.

$$10_{10} = 96 + 7 = (6 \times 16^1) + (7 \times 16^0)$$

(a)

$$254_{10} = 240 + 14 = (15 \times 16^1) + (14 \times 16^0)$$

(b)

2.18 Example of hexadecimal to decimal conversion

### 2.4.2 Decimal to hexadecimal conversion

In order to convert a decimal number to its hexadecimal equivalent you can break the number down into a succession of numbers that are each powers of 16, and then place the relevant digit (a value between 0 and F) in the respective digit position, as shown in Figure 2.19. Note how, in the case of the example shown in Figure 2.19b the letters F and E, respectively, replace the decimal numbers 15 and 14.

2.19 Example of decimal to hexadecimal conversion

### 2.4.3 Hexadecimal to binary conversion

In order to convert a hexadecimal number to a binary number we simply need to convert each digit of the hexadecimal number to its corresponding four-bit binary value, as shown in Figure 2.20. The method is similar to that which you used earlier to convert octal numbers to their binary equivalents.

2.20 Example of hexadecimal to binary conversion

### 2.4.4 Binary to hexadecimal conversion

Converting a binary number to its equivalent in hexadecimal is also extremely easy. In this case you simply need to arrange the binary number in groups of four binary digits, working from right to left, before converting each group to its hexadecimal equivalent, as shown in Figure 2.21. Once again, the
method is similar to that which you used earlier to convert binary numbers to their octal equivalents.

2.5 AMERICAN STANDARD CODE FOR INFORMATION INTERCHANGE

While not a system of numbers, the American Standard Code for Information Interchange (ASCII) is important as it provides us with a way of representing printable characters using binary, decimal or hexadecimal numbers. ASCII is the means by which computers are able to store and exchange alphanumeric data with other computers and peripheral devices such as character-based displays and printers.

Standard ASCII is based on a 7-bit binary code and caters for a total of 128 ($2^7$) alphanumeric characters (both upper and lower case), punctuation and special control characters. Extended ASCII employs an eighth (leading) bit to provide an additional 128 characters from a single 8-bit byte.

The first 32 ASCII characters (corresponding to hexadecimal codes 00 to 1F) are non-printing control characters used to facilitate data transfer and control peripherals such as character-based displays and printers.

The ASCII printable characters (corresponding to hexadecimal codes 20 to 7F) represent letters, numbers, punctuation and a few miscellaneous symbols (see Table 2.3). Note that the first of these characters (32 decimal) corresponds to the space character that doesn’t actually print!

TEST YOUR UNDERSTANDING 2.6

1. Find the decimal equivalent of the octal number 41.
2. Find the octal equivalent of the decimal number 139.
3. Find the binary equivalent of the octal number 537.
4. Find the octal equivalent of the binary number 111001100.
5. Convert the hexadecimal number 3F to: (a) decimal; (b) binary.
6. Convert the binary number 101111001 to: (a) octal; (b) hexadecimal.
7. Which of the following numbers is the largest? (a) $C_{16}$; (b) $11000001_2$; (c) $303_8$.

TEST YOUR UNDERSTANDING 2.7

1. Convert the ASCII data 00110000 00111001 01011100 to printable alphanumerical text.
2. Convert the alphanumeric text 'TCAS' to ASCII data.

KEY POINT

ASCII uses seven binary digits to represent alphanumeric characters, punctuation and control codes. The basic 7-bit ASCII character set is frequently extended by adding an additional leading digit to form an 8-bit code; each character of the extended ASCII character set is then represented by a single byte (8-bits) of data.
Table 2.3  Decimal, octal, hexadecimal, binary and ASCII values

<table>
<thead>
<tr>
<th>Decimal</th>
<th>Octal</th>
<th>Hexadecimal</th>
<th>Binary</th>
<th>ASCII</th>
<th>Meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>000</td>
<td>00</td>
<td>00000000</td>
<td>NUL</td>
<td>Null</td>
</tr>
<tr>
<td>1</td>
<td>001</td>
<td>01</td>
<td>00000001</td>
<td>SOH</td>
<td>Start of heading</td>
</tr>
<tr>
<td>2</td>
<td>002</td>
<td>02</td>
<td>00000010</td>
<td>STX</td>
<td>Start of text</td>
</tr>
<tr>
<td>3</td>
<td>003</td>
<td>03</td>
<td>00000011</td>
<td>ETX</td>
<td>End of text</td>
</tr>
<tr>
<td>4</td>
<td>004</td>
<td>04</td>
<td>00000100</td>
<td>EOT</td>
<td>End of transmission</td>
</tr>
<tr>
<td>5</td>
<td>005</td>
<td>05</td>
<td>00000101</td>
<td>ENQ</td>
<td>Enquiry</td>
</tr>
<tr>
<td>6</td>
<td>006</td>
<td>06</td>
<td>00000110</td>
<td>ACK</td>
<td>Acknowledgement</td>
</tr>
<tr>
<td>7</td>
<td>007</td>
<td>07</td>
<td>00000111</td>
<td>BEL</td>
<td>Bell</td>
</tr>
<tr>
<td>8</td>
<td>010</td>
<td>08</td>
<td>00001000</td>
<td>BS</td>
<td>Backspace</td>
</tr>
<tr>
<td>9</td>
<td>011</td>
<td>09</td>
<td>00001001</td>
<td>HT</td>
<td>Horizontal tab</td>
</tr>
<tr>
<td>10</td>
<td>012</td>
<td>0A</td>
<td>00001010</td>
<td>LF</td>
<td>Line feed</td>
</tr>
<tr>
<td>11</td>
<td>013</td>
<td>0B</td>
<td>00001011</td>
<td>VT</td>
<td>Vertical tab</td>
</tr>
<tr>
<td>12</td>
<td>014</td>
<td>0C</td>
<td>00001100</td>
<td>FF</td>
<td>Form feed</td>
</tr>
<tr>
<td>13</td>
<td>015</td>
<td>0D</td>
<td>00001101</td>
<td>CR</td>
<td>Carriage return</td>
</tr>
<tr>
<td>14</td>
<td>016</td>
<td>0E</td>
<td>00001110</td>
<td>SO</td>
<td>Shift out</td>
</tr>
<tr>
<td>15</td>
<td>017</td>
<td>0F</td>
<td>00001111</td>
<td>SI</td>
<td>Shift in</td>
</tr>
<tr>
<td>16</td>
<td>020</td>
<td>10</td>
<td>00010000</td>
<td>DLE</td>
<td>Data line escape</td>
</tr>
<tr>
<td>17</td>
<td>021</td>
<td>11</td>
<td>00010001</td>
<td>DC1</td>
<td>Device control 1</td>
</tr>
<tr>
<td>18</td>
<td>022</td>
<td>12</td>
<td>00010010</td>
<td>DC2</td>
<td>Device control 2</td>
</tr>
<tr>
<td>19</td>
<td>023</td>
<td>13</td>
<td>00010011</td>
<td>DC3</td>
<td>Device control 3</td>
</tr>
<tr>
<td>20</td>
<td>024</td>
<td>14</td>
<td>00010100</td>
<td>DC4</td>
<td>Device control 4</td>
</tr>
<tr>
<td>21</td>
<td>025</td>
<td>15</td>
<td>00010101</td>
<td>NAK</td>
<td>Negative acknowledgement</td>
</tr>
<tr>
<td>22</td>
<td>026</td>
<td>16</td>
<td>00010110</td>
<td>SYN</td>
<td>Synchronous idle</td>
</tr>
<tr>
<td>23</td>
<td>027</td>
<td>17</td>
<td>00010111</td>
<td>ETB</td>
<td>End of transmit block</td>
</tr>
<tr>
<td>24</td>
<td>030</td>
<td>18</td>
<td>00011000</td>
<td>CAN</td>
<td>Cancel</td>
</tr>
<tr>
<td>25</td>
<td>031</td>
<td>19</td>
<td>00011001</td>
<td>EM</td>
<td>End of medium</td>
</tr>
<tr>
<td>26</td>
<td>032</td>
<td>1A</td>
<td>00011010</td>
<td>SUB</td>
<td>Substitute</td>
</tr>
<tr>
<td>27</td>
<td>033</td>
<td>1B</td>
<td>00011011</td>
<td>ESC</td>
<td>Escape</td>
</tr>
<tr>
<td>Decimal</td>
<td>Octal</td>
<td>Hexadecimal</td>
<td>Binary</td>
<td>ASCII</td>
<td>Meaning</td>
</tr>
<tr>
<td>---------</td>
<td>-------</td>
<td>-------------</td>
<td>------------</td>
<td>-------</td>
<td>------------------</td>
</tr>
<tr>
<td>28</td>
<td>034</td>
<td>1C</td>
<td>00011100</td>
<td>FS</td>
<td>File separator</td>
</tr>
<tr>
<td>29</td>
<td>035</td>
<td>1D</td>
<td>00011101</td>
<td>GS</td>
<td>Group separator</td>
</tr>
<tr>
<td>30</td>
<td>036</td>
<td>1E</td>
<td>00011110</td>
<td>RS</td>
<td>Record separator</td>
</tr>
<tr>
<td>31</td>
<td>037</td>
<td>1F</td>
<td>00011111</td>
<td>US</td>
<td>Unit separator</td>
</tr>
<tr>
<td>32</td>
<td>040</td>
<td>20</td>
<td>00100000</td>
<td></td>
<td>Space</td>
</tr>
<tr>
<td>33</td>
<td>041</td>
<td>21</td>
<td>00100001</td>
<td>!</td>
<td>Exclamation mark</td>
</tr>
<tr>
<td>34</td>
<td>042</td>
<td>22</td>
<td>00100010</td>
<td>&quot;</td>
<td>Double quotes</td>
</tr>
<tr>
<td>35</td>
<td>043</td>
<td>23</td>
<td>00100011</td>
<td>#</td>
<td>Number</td>
</tr>
<tr>
<td>36</td>
<td>044</td>
<td>24</td>
<td>00100100</td>
<td>$</td>
<td>Dollar</td>
</tr>
<tr>
<td>37</td>
<td>045</td>
<td>25</td>
<td>00100101</td>
<td>%</td>
<td>Percent</td>
</tr>
<tr>
<td>38</td>
<td>046</td>
<td>26</td>
<td>00100110</td>
<td>&amp;</td>
<td>Ampersand</td>
</tr>
<tr>
<td>39</td>
<td>047</td>
<td>27</td>
<td>00100111</td>
<td>'</td>
<td>Single quote</td>
</tr>
<tr>
<td>40</td>
<td>050</td>
<td>28</td>
<td>00101000</td>
<td>(</td>
<td>Open parenthesis</td>
</tr>
<tr>
<td>41</td>
<td>051</td>
<td>29</td>
<td>00101001</td>
<td>)</td>
<td>Close parenthesis</td>
</tr>
<tr>
<td>42</td>
<td>052</td>
<td>2A</td>
<td>00101010</td>
<td>*</td>
<td>Asterisk</td>
</tr>
<tr>
<td>43</td>
<td>053</td>
<td>2B</td>
<td>00101011</td>
<td>+</td>
<td>Plus</td>
</tr>
<tr>
<td>44</td>
<td>054</td>
<td>2C</td>
<td>00101100</td>
<td>.</td>
<td>Comma</td>
</tr>
<tr>
<td>45</td>
<td>055</td>
<td>2D</td>
<td>00101101</td>
<td>-</td>
<td>Hyphen</td>
</tr>
<tr>
<td>46</td>
<td>056</td>
<td>2E</td>
<td>00101110</td>
<td>.</td>
<td>Full stop</td>
</tr>
<tr>
<td>47</td>
<td>057</td>
<td>2F</td>
<td>00101111</td>
<td>/</td>
<td>Divide</td>
</tr>
<tr>
<td>48</td>
<td>060</td>
<td>30</td>
<td>00110000</td>
<td>0</td>
<td>Zero</td>
</tr>
<tr>
<td>49</td>
<td>061</td>
<td>31</td>
<td>00110001</td>
<td>1</td>
<td>One</td>
</tr>
<tr>
<td>50</td>
<td>062</td>
<td>32</td>
<td>00110010</td>
<td>2</td>
<td>Two</td>
</tr>
<tr>
<td>51</td>
<td>063</td>
<td>33</td>
<td>00110011</td>
<td>3</td>
<td>Three</td>
</tr>
<tr>
<td>52</td>
<td>064</td>
<td>34</td>
<td>00110100</td>
<td>4</td>
<td>Four</td>
</tr>
<tr>
<td>53</td>
<td>065</td>
<td>35</td>
<td>00110101</td>
<td>5</td>
<td>Five</td>
</tr>
<tr>
<td>54</td>
<td>066</td>
<td>36</td>
<td>00110110</td>
<td>6</td>
<td>Six</td>
</tr>
<tr>
<td>55</td>
<td>067</td>
<td>37</td>
<td>00110111</td>
<td>7</td>
<td>Seven</td>
</tr>
<tr>
<td>56</td>
<td>070</td>
<td>38</td>
<td>00111000</td>
<td>8</td>
<td>Eight</td>
</tr>
</tbody>
</table>
### Table 2.3 continued

<table>
<thead>
<tr>
<th>Decimal</th>
<th>Octal</th>
<th>Hexadecimal</th>
<th>Binary</th>
<th>ASCII</th>
<th>Meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td>57</td>
<td>071</td>
<td>39</td>
<td>00111001</td>
<td>9</td>
<td>Nine</td>
</tr>
<tr>
<td>58</td>
<td>072</td>
<td>3A</td>
<td>00111010</td>
<td>:</td>
<td>Colon</td>
</tr>
<tr>
<td>59</td>
<td>073</td>
<td>3B</td>
<td>00111011</td>
<td>;</td>
<td>Semicolon</td>
</tr>
<tr>
<td>60</td>
<td>074</td>
<td>3C</td>
<td>00111100</td>
<td>&lt;</td>
<td>Less than</td>
</tr>
<tr>
<td>61</td>
<td>075</td>
<td>3D</td>
<td>00111101</td>
<td>&gt;</td>
<td>Equals</td>
</tr>
<tr>
<td>62</td>
<td>076</td>
<td>3E</td>
<td>00111110</td>
<td>:</td>
<td>Greater than</td>
</tr>
<tr>
<td>63</td>
<td>077</td>
<td>3F</td>
<td>00111111</td>
<td>;</td>
<td>Question mark</td>
</tr>
<tr>
<td>64</td>
<td>100</td>
<td>40</td>
<td>01000000</td>
<td>@</td>
<td>At symbol</td>
</tr>
<tr>
<td>65</td>
<td>101</td>
<td>41</td>
<td>01000001</td>
<td>A</td>
<td>Uppercase A</td>
</tr>
<tr>
<td>66</td>
<td>102</td>
<td>42</td>
<td>01000010</td>
<td>B</td>
<td>Uppercase B</td>
</tr>
<tr>
<td>67</td>
<td>103</td>
<td>43</td>
<td>01000011</td>
<td>C</td>
<td>Uppercase C</td>
</tr>
<tr>
<td>68</td>
<td>104</td>
<td>44</td>
<td>01000100</td>
<td>D</td>
<td>Uppercase D</td>
</tr>
<tr>
<td>69</td>
<td>105</td>
<td>45</td>
<td>01000101</td>
<td>E</td>
<td>Uppercase E</td>
</tr>
<tr>
<td>70</td>
<td>106</td>
<td>46</td>
<td>01000110</td>
<td>F</td>
<td>Uppercase F</td>
</tr>
<tr>
<td>71</td>
<td>107</td>
<td>47</td>
<td>01000111</td>
<td>G</td>
<td>Uppercase G</td>
</tr>
<tr>
<td>72</td>
<td>110</td>
<td>48</td>
<td>01001000</td>
<td>H</td>
<td>Uppercase H</td>
</tr>
<tr>
<td>73</td>
<td>111</td>
<td>49</td>
<td>01001001</td>
<td>I</td>
<td>Uppercase I</td>
</tr>
<tr>
<td>74</td>
<td>112</td>
<td>4A</td>
<td>01001010</td>
<td>J</td>
<td>Uppercase J</td>
</tr>
<tr>
<td>75</td>
<td>113</td>
<td>4B</td>
<td>01001011</td>
<td>K</td>
<td>Uppercase K</td>
</tr>
<tr>
<td>76</td>
<td>114</td>
<td>4C</td>
<td>01001100</td>
<td>L</td>
<td>Uppercase L</td>
</tr>
<tr>
<td>77</td>
<td>115</td>
<td>4D</td>
<td>01001101</td>
<td>M</td>
<td>Uppercase M</td>
</tr>
<tr>
<td>78</td>
<td>116</td>
<td>4E</td>
<td>01001110</td>
<td>N</td>
<td>Uppercase N</td>
</tr>
<tr>
<td>79</td>
<td>117</td>
<td>4F</td>
<td>01001111</td>
<td>O</td>
<td>Uppercase O</td>
</tr>
<tr>
<td>80</td>
<td>120</td>
<td>50</td>
<td>01010000</td>
<td>P</td>
<td>Uppercase P</td>
</tr>
<tr>
<td>81</td>
<td>121</td>
<td>51</td>
<td>01010001</td>
<td>Q</td>
<td>Uppercase Q</td>
</tr>
<tr>
<td>82</td>
<td>122</td>
<td>52</td>
<td>01010010</td>
<td>R</td>
<td>Uppercase R</td>
</tr>
<tr>
<td>83</td>
<td>123</td>
<td>53</td>
<td>01010011</td>
<td>S</td>
<td>Uppercase S</td>
</tr>
<tr>
<td>84</td>
<td>124</td>
<td>54</td>
<td>01010100</td>
<td>T</td>
<td>Uppercase T</td>
</tr>
<tr>
<td>Decimal</td>
<td>Octal</td>
<td>Hexadecimal</td>
<td>Binary</td>
<td>ASCII</td>
<td>Meaning</td>
</tr>
<tr>
<td>---------</td>
<td>-------</td>
<td>-------------</td>
<td>-----------</td>
<td>-------</td>
<td>------------------</td>
</tr>
<tr>
<td>85</td>
<td>125</td>
<td>55</td>
<td>01010101</td>
<td>U</td>
<td>Uppercase U</td>
</tr>
<tr>
<td>86</td>
<td>126</td>
<td>56</td>
<td>01010110</td>
<td>V</td>
<td>Uppercase V</td>
</tr>
<tr>
<td>87</td>
<td>127</td>
<td>57</td>
<td>01010111</td>
<td>W</td>
<td>Uppercase W</td>
</tr>
<tr>
<td>88</td>
<td>130</td>
<td>58</td>
<td>01011000</td>
<td>X</td>
<td>Uppercase X</td>
</tr>
<tr>
<td>89</td>
<td>131</td>
<td>59</td>
<td>01011001</td>
<td>Y</td>
<td>Uppercase Y</td>
</tr>
<tr>
<td>90</td>
<td>132</td>
<td>5A</td>
<td>01011010</td>
<td>Z</td>
<td>Uppercase Z</td>
</tr>
<tr>
<td>91</td>
<td>133</td>
<td>5B</td>
<td>01011011</td>
<td>[</td>
<td>Opening bracket</td>
</tr>
<tr>
<td>92</td>
<td>134</td>
<td>5C</td>
<td>01011100</td>
<td>\</td>
<td>Backslash</td>
</tr>
<tr>
<td>93</td>
<td>135</td>
<td>5D</td>
<td>01011101</td>
<td>]</td>
<td>Closing bracket</td>
</tr>
<tr>
<td>94</td>
<td>136</td>
<td>5E</td>
<td>01011110</td>
<td>^</td>
<td>Caret</td>
</tr>
<tr>
<td>95</td>
<td>137</td>
<td>5F</td>
<td>01011111</td>
<td>_</td>
<td>Underscore</td>
</tr>
<tr>
<td>96</td>
<td>140</td>
<td>60</td>
<td>01100000</td>
<td>`</td>
<td>Grave accent</td>
</tr>
<tr>
<td>97</td>
<td>141</td>
<td>61</td>
<td>01100001</td>
<td>a</td>
<td>Lowercase a</td>
</tr>
<tr>
<td>98</td>
<td>142</td>
<td>62</td>
<td>01100010</td>
<td>b</td>
<td>Lowercase b</td>
</tr>
<tr>
<td>99</td>
<td>143</td>
<td>63</td>
<td>01100011</td>
<td>c</td>
<td>Lowercase c</td>
</tr>
<tr>
<td>100</td>
<td>144</td>
<td>64</td>
<td>01100100</td>
<td>d</td>
<td>Lowercase d</td>
</tr>
<tr>
<td>101</td>
<td>145</td>
<td>65</td>
<td>01100101</td>
<td>e</td>
<td>Lowercase e</td>
</tr>
<tr>
<td>102</td>
<td>146</td>
<td>66</td>
<td>01100110</td>
<td>f</td>
<td>Lowercase f</td>
</tr>
<tr>
<td>103</td>
<td>147</td>
<td>67</td>
<td>01100111</td>
<td>g</td>
<td>Lowercase g</td>
</tr>
<tr>
<td>104</td>
<td>150</td>
<td>68</td>
<td>01101000</td>
<td>h</td>
<td>Lowercase h</td>
</tr>
<tr>
<td>105</td>
<td>151</td>
<td>69</td>
<td>01101001</td>
<td>i</td>
<td>Lowercase i</td>
</tr>
<tr>
<td>106</td>
<td>152</td>
<td>6A</td>
<td>01101010</td>
<td>j</td>
<td>Lowercase j</td>
</tr>
<tr>
<td>107</td>
<td>153</td>
<td>6B</td>
<td>01101011</td>
<td>k</td>
<td>Lowercase k</td>
</tr>
<tr>
<td>108</td>
<td>154</td>
<td>6C</td>
<td>01101100</td>
<td>l</td>
<td>Lowercase l</td>
</tr>
<tr>
<td>109</td>
<td>155</td>
<td>6D</td>
<td>01101101</td>
<td>m</td>
<td>Lowercase m</td>
</tr>
<tr>
<td>110</td>
<td>156</td>
<td>6E</td>
<td>01101110</td>
<td>n</td>
<td>Lowercase n</td>
</tr>
<tr>
<td>111</td>
<td>157</td>
<td>6F</td>
<td>01101111</td>
<td>o</td>
<td>Lowercase o</td>
</tr>
<tr>
<td>112</td>
<td>160</td>
<td>70</td>
<td>01110000</td>
<td>p</td>
<td>Lowercase p</td>
</tr>
<tr>
<td>113</td>
<td>161</td>
<td>71</td>
<td>01110001</td>
<td>q</td>
<td>Lowercase q</td>
</tr>
</tbody>
</table>
2.6 MULTIPLE-CHOICE QUESTIONS

1. The binary number 10101 is equivalent to the decimal number:

(a) 19
(b) 21
(c) 35.

2. The decimal number 29 is equivalent to the binary number:

(a) 10111
(b) 11011
(c) 11101.

3. Which one of the following gives the two’s complement of the binary number 10110:

(a) 01010
(b) 01001
(c) 10001.

4. The binary coded decimal (BCD) number 10110010 is equivalent to the decimal number:

(a) 19
(b) 91
(c) 145.

5. The decimal number 37 is equivalent to the binary coded decimal (BCD) number:

(a) 00110111
(b) 00100101
(c) 00101111.

6. Which one of the following numbers could not be an octal number:

(a) 11011
(b) 771
(c) 139.
7. The octal number 73 is equivalent to the decimal number:
   (a) 47  
   (b) 59  
   (c) 111.

8. The binary number 100010001 is equivalent to the octal number:
   (a) 111  
   (b) 273  
   (c) 421.

9. The hexadecimal number 111 is equivalent to the octal number:
   (a) 73  
   (b) 273  
   (c) 421.

10. The hexadecimal number C9 is equivalent to the decimal number:
    (a) 21  
    (b) 129  
    (c) 201.

11. The binary number 10110011 is equivalent to the hexadecimal number:
    (a) 93  
    (b) B3  
    (c) 113.

12. The hexadecimal number AD is equivalent to the binary number:
    (a) 10101101  
    (b) 11011010  
    (c) 10001101.

13. The number 706_8 is equivalent to:
    (a) 1C6_16  
    (b) 111001110_2  
    (c) 484_10.
Because signals in the real world exist in both digital (on/off) and analogue (continuously variable) forms, digital and computer systems need to be able to accept and generate both types of signal as inputs and outputs, respectively. Because of this, there is a need for devices that can convert signals in analogue form to their equivalent in digital form, and vice versa. This chapter introduces digital to analogue and analogue to digital conversion. Later we will show how data conversion devices are used in some practical aircraft systems. We shall begin by looking at the essential characteristics of analogue and digital signals and the principle of quantisation.

### 3.1 ANALOGUE AND DIGITAL SIGNALS

Examples of analogue and digital signals are shown in Figure 3.1. The analogue signal shown in Figure 3.1a consists of a continuously changing voltage level, whereas the digital signal shown in Figure 3.1b consists of a series of discrete voltage levels that alternate between logic 0 (‘low’ or ‘off’) and logic 1 (‘high’ or ‘on’). The actual voltages used to represent the logic levels are determined by the type of logic circuitry employed; however, logic 1 is often represented by a voltage of approximately +5 V and logic 0 by a voltage of 0 V (we will discuss the actual range of voltages used to represent logic levels later in Chapter 5).

In order to represent an analogue signal using digital codes it is necessary to approximate (or quantise) the signal into a set of discrete voltage levels as shown in Figure 3.2.

![Figure 3.1 Example of (a) analogue and (b) digital signals](image)

3 Data conversion

The 16 quantisation levels for a simple analogue to digital converter using a four-bit binary code are shown in Figure 3.3. Note that in order to accommodate analogue signals that have both positive and negative polarity we have used the two’s complement representation to indicate negative voltage levels. Thus, any voltage represented by a digital code in which the MSB is logic 1 will be negative. Figure 3.4 shows how a typical analogue signal would be quantised into voltage levels by sampling at regular intervals ($t_1$, $t_2$, $t_3$, etc.).
3.2 DIGITAL TO ANALOGUE CONVERSION

The basic digital to analogue converter (DAC) has a number of digital inputs (often 8, 10, 12 or 16) and a single analogue output, as shown in Figure 3.5.

The simplest form of digital to analogue converter shown in Figure 3.6a uses a set of binary weighted resistors to define the voltage gain of an operational summing amplifier and a four-bit binary latch to store the binary input while it is being converted. Note that since the amplifier is connected in inverting mode, the analogue output voltage will be negative rather than

3.3 Quantisation levels for a simple analogue to digital converter using a four-bit binary code (note the use of the two’s complement to indicate negative voltage levels)

3.4 A bipolar analogue signal quantised into voltage levels by sampling at regular intervals (t₁, t₂, t₃, etc.)

3.2 The process of quantising an analogue signal into its digital equivalent
positive. However, a further inverting amplifier stage can be added at the output in order to change the polarity if required.

The voltage gain of the inputs to the operational amplifier (determined by the ratio of feedback to input resistance and taking into account the inverting configuration) is shown in Table 3.1. If we assume that the logic levels produced by the four-bit data latch are ‘ideal’ such that logic 1 corresponds to +5 V and logic 0 corresponds to 0 V, we can determine the output voltage corresponding to the eight possible input states by summing the voltages that will result from each of the four inputs taken independently. For example, when the output of the latch takes the binary value 1010 the output voltage can be calculated from the relationship:

\[
V_{\text{out}} = (-1 \times 5) + (-0.5 \times 0) + (-0.25 \times 5) + (-0.125 \times 0) = -6.25 \text{ V}
\]

Similarly, when the output of the latch takes the binary value 1111 (the maximum possible) the output voltage can be determined from:

\[
V_{\text{out}} = (-1 \times 5) + (-0.5 \times 5) + (-0.25 \times 5) + (-0.125 \times 5) = -9.375 \text{ V}
\]

The complete set of voltages corresponding to all eight possible binary codes are given in Table 3.2.

An improved binary-weighted DAC is shown in Figure 3.6b. This circuit operates on a similar principle to that shown in Figure 3.6a, but uses four analogue switches instead of a four-bit data latch. The analogue switches are controlled by the logic inputs so that the respective output is connected to the reference voltage \(V_{\text{ref}}\) when the respective logic input is at logic 1, and to 0 V when the corresponding logic input is at

### Table 3.1 Voltage gain for the simple DAC shown in Figure 3.6a

<table>
<thead>
<tr>
<th>Bit</th>
<th>Voltage gain</th>
</tr>
</thead>
<tbody>
<tr>
<td>3 (MSB)</td>
<td>(-\frac{R}{R} = -1)</td>
</tr>
<tr>
<td>2</td>
<td>(-\frac{R}{2R} = -0.5)</td>
</tr>
<tr>
<td>1</td>
<td>(-\frac{R}{4R} = -0.25)</td>
</tr>
<tr>
<td>0 (LSB)</td>
<td>(-\frac{R}{8R} = -0.125)</td>
</tr>
</tbody>
</table>
logic. When compared with the previous arrangement, this circuit offers the advantage that the reference voltage is considerably more accurate and stable than using the logic level to define the analogue output voltage. A further advantage arises from the fact that the reference voltage can be made negative, in which case the analogue output voltage will become positive. Typical reference voltages are \(-5\) V, \(-10\) V, \(+5\) V and \(+10\) V.

Unfortunately, by virtue of the range of resistance values required, the binary-weighted DAC becomes increasingly impractical for higher-resolution applications. Taking a 10-bit circuit as an example, and assuming that the basic value of \(R\) is \(1\) k\(\Omega\), the binary weighted values would become:

<table>
<thead>
<tr>
<th>Bit 3</th>
<th>Bit 2</th>
<th>Bit 1</th>
<th>Bit 0</th>
<th>Output voltage</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0 V</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>(-0.625) V</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>(-1.250) V</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>(-1.875) V</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>(-2.500) V</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>(-3.125) V</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>(-3.750) V</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>(-4.375) V</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>(-5.000) V</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>(-5.625) V</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>(-6.250) V</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>(-6.875) V</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>(-7.500) V</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>(-8.125) V</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>(-8.750) V</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>(-9.375) V</td>
</tr>
</tbody>
</table>

Table 3.2 Output voltages produced by the simple DAC shown in Figure 3.6a

The accuracy of a DAC depends not only on the values of the resistance used, but also on the reference voltage used to define the voltage levels. Special band-gap references (similar to precision zener diodes) are normally used to provide reference voltages that are closely maintained over a wide range of temperature and supply voltages. Typical accuracies of between 1 per cent and 2 per cent can be achieved using most modern low-cost DAC devices.

The resolution of a DAC is an indication of the number of increments in output voltage that it can produce, and it is directly related to the number of binary digits used in the conversion. The two simple four-bit DACs that we met earlier can each provide 16 different output voltages, but in practice we would probably require many more (and correspondingly smaller) increments in output.
voltage. This can be achieved by adding further binary inputs.

For example, a DAC with eight inputs (i.e. an 8-bit DAC) would be capable of producing 256 (i.e. $2^8$) different output voltage levels. A 10-bit device, on the other hand, will produce 1,024 (i.e. $2^{10}$) different voltage levels. The resolution of a DAC is generally stated in terms of the number of binary digits (i.e. bits) used in the conversion.

### 3.2.2 Filters

As we have seen, the output of a DAC consists of a series of quantised voltage levels. The presence of these levels on the output signal can be undesirable for some applications and hence they are removed in order to ‘smooth’ the output voltage. This can be easily accomplished by passing the output signal through a low-pass filter, as shown in Figure 3.7. The filter is designed so that the residual sampling frequency components (i.e. those that cause the ‘steps’ in the analogue signal) are well beyond the cut-off frequency of the filter and are therefore subject to an appreciable amount of attenuation.

### 3.3 ANALOGUE TO DIGITAL CONVERSION

The basic analogue to digital converter (ADC) has a single analogue input and a number of digital outputs (often 8, 10, 12 or 16 lines), as shown in Figure 3.8. Various forms of analogue to digital converter are available for use in different applications, including multi-channel ADCs with up to 16 analogue inputs. The simplest form of ADC is the flash converter shown in Figure 3.9a. In this type of ADC the incoming analogue voltage is compared with a series of fixed reference voltages using a number of operational amplifiers (IC1 to IC7 in Figure 3.9). When the
analogue input voltage exceeds the reference voltage present at the inverting input of a particular operational amplifier stage the output of that stage will go to logic 1. So, assuming that the analogue input voltage is 2 V, the outputs of IC1 and IC2 will go to logic 1 while the remaining outputs will be at logic 0. The priority encoder is a logic device that produces a binary output code that indicates the value of the most significant logic 1 received on one of its inputs. In this case, the output of IC2 will be the most significant logic 1 and hence the binary output code generated will be 010, as shown in Figure 3.9b. Flash ADC are extremely fast in operation (hence the name), but they become rather impractical as the resolution increases. For example, an 8-bit flash ADC would require 256 operational amplifier comparators and a 10-bit device would need a staggering 1,024 comparator stages! Typical conversion times for a flash ADC lie in the range 50 ns to 1 µs, so this type of ADC is ideal for “fast” or rapidly changing analogue signals. Due to their complexity, flash ADC are relatively expensive.

A successive approximation ADC is shown in Figure 3.10. This shows an 8-bit converter that uses a DAC (usually based on an $R_\text{–}2R$ ladder) together with a single operational amplifier comparator (IC1) and a successive approximation register (SAR). The 8-bit output from the SAR is applied to the DAC and to an 8-bit output latch. A separate end-of-conversion (EOC) signal (not shown in Figure 3.10) is generated to indicate that the conversion process is complete and the data is ready for use.

When a start conversion (SC) signal is received, successive bits within the SAR are set and reset...
according to the output from the comparator. At the point at which the output from the comparator reaches zero, the analogue input voltage will be the same as the analogue output from the DAC and, at this point, the conversion is complete. The EOC signal is then generated and the 8-bit code from the SAR is read as a digital output code.

Successive approximation ADC are significantly slower than flash types and typical conversion times (i.e. the time between the SC and EOC signals) are in the range 10 µs to 100 µs. Despite this, conversion times are fast enough for most non-critical applications and this type of ADC is relatively simple and available at low cost.

A ramp-type ADC is shown in Figure 3.11. This type of ADC uses a ramp generator and a single operational amplifier comparator, IC1. The output of the comparator is either a 1 or a 0, depending on whether the input voltage is greater or less than the instantaneous value of the ramp voltage. The output of the comparator is used to control a logic gate (IC2), which passes a clock signal (a square wave of accurate frequency) to the input of a pulse counter whenever the input voltage is greater than the output from the
ramp generator. The pulses are counted until the voltage from the ramp generator exceeds that of the input signal, at which point the output of the comparator goes low and no further pulses are passed into the counter. The number of clock pulses counted will depend on the input voltage and the final binary count can thus provide a digital representation of the analogue input. Typical waveforms for the ramp-type waveform are shown in Figure 3.12.

Finally, the dual-slope ADC (Figure 3.13) is a refinement of the ramp-type ADC which involves a similar comparator arrangement but uses an internal voltage reference and an accurate, fixed-slope negative ramp which starts when the positive-going ramp reaches the analogue input voltage. The important thing to note about this type of ADC is that, while the slope of the positive ramp depends on the input voltage, the negative ramp falls at a fixed rate. Hence this type of ADC can provide a very high degree of accuracy and can also be made so that it rejects noise and random variations present on the input signal. The main disadvantage, however, is that the process of ramping up and down requires some considerable time and hence this type of ADC is only suitable for ‘slow’ signals (i.e. those that are not rapidly changing). Typical conversion times lie in the range 500 µs to 20 ms.

### TEST YOUR UNDERSTANDING 3.1

The binary codes produced by a four-bit bipolar analogue to digital converter (see Figures 3.3 and 3.4), sampled at intervals of 1 ms, have the following values:

<table>
<thead>
<tr>
<th>Time (ms)</th>
<th>Binary code</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0101</td>
</tr>
<tr>
<td>1</td>
<td>0100</td>
</tr>
<tr>
<td>2</td>
<td>0011</td>
</tr>
<tr>
<td>3</td>
<td>0010</td>
</tr>
<tr>
<td>4</td>
<td>0001</td>
</tr>
<tr>
<td>5</td>
<td>0000</td>
</tr>
<tr>
<td>6</td>
<td>1111</td>
</tr>
<tr>
<td>7</td>
<td>1110</td>
</tr>
</tbody>
</table>

Sketch the waveform of the analogue voltage and name its shape.
3.4 MULTIPLE-CHOICE QUESTIONS

1. A DAC can produce 256 different output voltages. This DAC has a resolution of:
   (a) 8 bits
   (b) 128 bits
   (c) 256 bits.

2. In a bipolar ADC a logic 1 in the MSB position indicates:
   (a) zero input voltage
   (b) negative input voltage
   (c) positive input voltage.

3. Which one of the following types of ADC is the fastest:
   (a) ramp type
   (b) flash type
   (c) successive approximation type.

4. Which one of the following ADC types uses a large number of comparators:
   (a) ramp type
   (b) flash type
   (c) successive approximation type.

5. The advantage of an $R-2R$ ladder DAC is that:
   (a) it uses fewer resistors overall
   (b) it uses a smaller number of analogue switches
   (c) it avoids having a large number of different value resistors.

6. A 10-bit DAC is capable of producing:
   (a) 10 different output levels
   (b) 100 different output levels
   (c) 1,024 different output levels.

7. The process of sampling approximating an analogue signal to a series of discrete levels is referred to as:
   (a) interfacing
   (b) quantising
   (c) data conversion.

8. In a binary-weighted DAC the voltage gain for each digital input is determined by:
   (a) a variable slope ramp
   (b) a variable reference voltage
   (c) resistors having different values.

9. The resolution of a DAC is stated in terms of:
   (a) the accuracy of the voltage reference
   (b) the open-loop gain of the comparator
   (c) the number of bits used in the conversion.

10. The conversion time of a flash ADC is typically in the range:
    (a) 50 ns to 1 µs
    (b) 50 µs to 1 ms
    (c) 50 ms to 1 s.

11. The DAC used in a successive approximation ADC is usually:
    (a) ramp type
    (b) binary-weighted type
    (c) successive approximation type.

TEST YOUR UNDERSTANDING 3.2

What type of ADC would be most suitable for each of the following applications? Give reasons for your answers.

1. Sensing and recording the strain in a beam to an accuracy of better than 1 per cent and with a resolution of 1 part in $10^3$.
2. Converting a high-quality audio signal into a digital datastream for recording on a CD-ROM.
3. Measuring DC voltages (that may be accompanied by supply-borne hum and noise) in a digital voltmeter.

5. The advantage of an $R-2R$ ladder DAC is that:
   (a) it uses fewer resistors overall
   (b) it uses a smaller number of analogue switches
   (c) it avoids having a large number of different value resistors.

6. A 10-bit DAC is capable of producing:
   (a) 10 different output levels
   (b) 100 different output levels
   (c) 1,024 different output levels.

7. The process of sampling approximating an analogue signal to a series of discrete levels is referred to as:
   (a) interfacing
   (b) quantising
   (c) data conversion.

8. In a binary-weighted DAC the voltage gain for each digital input is determined by:
   (a) a variable slope ramp
   (b) a variable reference voltage
   (c) resistors having different values.

9. The resolution of a DAC is stated in terms of:
   (a) the accuracy of the voltage reference
   (b) the open-loop gain of the comparator
   (c) the number of bits used in the conversion.

10. The conversion time of a flash ADC is typically in the range:
    (a) 50 ns to 1 µs
    (b) 50 µs to 1 ms
    (c) 50 ms to 1 s.

11. The DAC used in a successive approximation ADC is usually:
    (a) ramp type
    (b) binary-weighted type
    (c) successive approximation type.
12. In a successive approximation ADC, the time interval between the SC and EOC signals is:
   (a) the clock time
   (b) the cycle time
   (c) the conversion time.

13. An advantage of a dual-ramp ADC is:
   (a) a fast conversion time
   (b) an inherent ability to reject noise
   (c) the ability to operate without the need for a clock.
Aircraft data bus systems allow a wide variety of avionics equipment to communicate with one another and exchange data. In this section we shall take a brief look at the principles of aircraft data bus systems before introducing some of the systems that are commonly used in modern aircraft.

4.1 INTRODUCING BUS SYSTEMS

The word ‘bus’ is a contraction of the Greek word ‘omnibus’ and the word simply means ‘to all’. Thus, in the context of computers and digital systems, ‘bus’ refers to a system that permits interconnection and data exchange between the devices in a complex system. Note, however, that ‘interconnection’ involves more than just physical wiring; among other things it defines the voltage levels and rules (or protocols) that govern the transfer of data.

With such a large number of avionic systems, a modern aircraft requires a considerable amount of cabling. Furthermore, some of the cabling runs in a large aircraft can be quite lengthy, as shown in Figure 4.1. Aircraft cabling amounts to a significant proportion of the unladen weight of an aircraft and so minimising the amount of cabling and wiring present is an important consideration in the design of modern aircraft, both civil and military.

4.1.1 Bus terminology

Bus systems can be either unidirectional (one way) or bidirectional (two way), as shown in Figure 4.2. They can also be serial (one bit of data transmitted at a time) or parallel (where often 8, 16 or 32 bits of data appear as a group on a number of data lines at the same time). Because of the constraints imposed by conductor length and weight, all practical aircraft bus systems are based on serial (rather than parallel) data transfer.

Bus systems provide an efficient means of exchanging data between the diverse avionic systems found in a modern aircraft (see Figure 4.3).
Individual line replaceable units (LRUs), such as the engine data interface or flap/slat electronics units shown in Figure 4.3, are each connected to the bus by means of a dedicated bus coupler and serial interface module (not shown in Figure 4.3). Within the LRU, the dedicated digital logic and microprocessor systems that process data locally each make use of their own local bus system. These local bus systems invariably use parallel data transfer, which is ideal for moving large amounts of data very quickly, but only over short distances.

4.2 Unidirectional and bidirectional serial and parallel data

4.1.2 Bus protocols

The notion of a protocol needs a little explaining. Imagine for a moment that you are faced with the problem of organising a discussion between a large number of people sitting around a table, all of whom are blindfolded and therefore cannot see one another. In order to ensure that they don’t all speak at once, you need to establish some ground rules, including how the delegates will go about indicating that they had something to say and also establishing some priorities as to who should be allowed to speak in the event that several delegates indicate that they wish to speak at the same time. These (and other) considerations would form an agreed protocol between the delegates for conducting the discussion. The debate should proceed without too many problems provided everybody in the room understands and is willing to accept the protocol you have established. In computers and digital systems communications protocols are established to enable the efficient exchange of data between multiple devices connected to the same bus. A number of different standards are commonly used.

4.1.3 Bus architecture

Bus architecture is a general term that refers to the overall structure of a computer or other digital system that relies on a bus for its operation. The architecture is often described in the form of a block schematic diagram showing how the various system elements are interconnected and also how the data flow is organised between the elements. The architecture of a system based on the use of a unidirectional serial bus system is shown in Figure 4.4a, while a comparable bidirectional bus system is shown in Figure 4.4b. Note how the bidirectional system simplifies the interconnection...
of the LRUs and allows all of the devices to transmit and receive on the same bus.

**KEY POINT**

Communication protocols enable the efficient exchange of data between a number of devices connected to the same bus. Protocols consist of a set of rules and specifications governing, among other things, data format and physical connections.

### 4.1.4 Serial bus principles

A simple system for serial data transfer between two LRUs, each of which comprises an avionic system in its own right, is shown in Figure 4.5. Within the LRU, data are transferred using an internal parallel data bus (either 8, 16, 32 or 64 bits wide). The link between the two LRUs is made using a simple serial cable (often with only two, four or six conductors). The required parallel-to-serial and serial-to-parallel data conversion is carried out by a bus interface (often this is a single card or module within the LRU). The data
to be transferred can be synchronous (using clock signals generated locally within each LRU) or it may be asynchronous (i.e. self-clocking).

The system shown in Figure 4.5 has the obvious limitation that data can only be exchanged between two devices. In practice we need to share the data between many LRUs/avionic units. This can be achieved by the bus system illustrated in Figure 4.6. In this system, data is transferred using a shielded twisted pair (STP) bus cable with a number of coupler panels that are located at appropriate points in the aircraft (e.g. the flight deck, avionics bay, etc.). Each coupler panel allows a number of avionic units to be connected to the bus using a stub cable. In order to optimise the speed of data transfer and minimise problems associated with reflection and mismatch, the bus cable must be terminated at each end using a matched bus terminator.

Bus couplers are produced as either voltage mode or current mode units, depending on whether they use voltage- or current-sensing devices. Within each LRU/avionics unit, an interface is provided that performs the required serial-to-parallel or parallel-to-serial data conversion, as shown in Figure 4.7.

As well as providing an electrical interface (with appropriate voltage- and current-level shifting) the interface unit also converts the data formats (e.g. from serial analogue doublets present in the stub cable to Manchester-encoded serial data required by the terminal controller), as shown in Figure 4.8.

In order to transmit data using the serial data bus, information must be presented in a standard format. A typical format for serial data would use a word length of 32 bits. This word comprises several discrete fields, including:

- up to 20 bits for data (which may be further divided);
• an 8-bit label field which is used to identify the data type and any parameters that may be associated with it;
• a source/destination identifier (SDI);
• a number of status bits used to provide information about the mode, hardware condition or validity of data;
• an added parity bit which provides a means of validating the data (i.e. determining whether or not it is free from error).

4.2 ARINC 429

The ARINC 429 data bus has proved to be one of the most popular bus standards used in commercial aircraft. The ARINC 429 specification defines the electrical and data characteristics and protocols that are used.

ARINC 429 employs a unidirectional data bus standard known as Mark 33 Digital Information Transfer System (DITS). Messages are transmitted in packets of 32 bits at a bit-rate of either 12.5 or 100 kilobits per second (referred to as low and high bit-rate, respectively). Because the bus is unidirectional, separate ports, couplers and cables will be required when an LRU wishes to be able to both transmit and receive data.
receive data. Note that a large number of bus connections may be required on an aircraft that uses sophisticated avionic systems.

ARINC 429 has been installed on a wide variety of commercial transport aircraft, including: Airbus A310/A320 and A330/A340; Boeing 737, 747, 757 and 767; and McDonnell Douglas MD-11. More modern aircraft (e.g. Boeing 777 and Airbus A380) use significantly enhanced bus specifications (see page 49) in order to reduce the weight and size of cabling and to facilitate higher data rates than are possible with ARINC 429. Despite these moves to faster, bidirectional bus standards, the ARINC 429 standard has proved to be highly reliable and so is likely to remain in service for many years to come.

4.2.1 Electrical characteristics

ARINC 429 is a two-wire differential bus that can connect a single transmitter or source to one or more receivers or sinks. Two speeds are available, 12.5 kbps (bits per second) and 100 kbps. The data bus uses two signal wires to transmit 32-bit words. Transmission of sequential words is separated by at least four bit times of NULL (zero voltage). This eliminates the need for a separate clock signal and it makes the system self-clocking.

The ARINC 429 electrical characteristics are summarised below:

<table>
<thead>
<tr>
<th>Voltage levels</th>
<th>+5 V, 0 V, –5 V (each conductor with respect to ground); +10 V, 0 V, –10 V (conductor A with respect to conductor B)</th>
</tr>
</thead>
<tbody>
<tr>
<td>Data encoding</td>
<td>Bipolar return to zero</td>
</tr>
<tr>
<td>Word size</td>
<td>32 bits</td>
</tr>
<tr>
<td>Bit-rate (high)</td>
<td>100 kbps</td>
</tr>
<tr>
<td>Bit-rate (low)</td>
<td>12.5 kbps</td>
</tr>
<tr>
<td>Slew rate (high)</td>
<td>1.5 ms (±0.5 ms)</td>
</tr>
<tr>
<td>Slew rate (low)</td>
<td>10 ms (±5 ms)</td>
</tr>
</tbody>
</table>

The nominal transmission voltage is 10 V ± 1 V between wires (differential), with either a positive or negative polarity. Therefore, each signal leg ranges between +5 V and –5 V. If one conductor is at +5 V, the other conductor is at –5 V, and vice versa. One wire is called the ‘A’ (or ‘+’ or ‘HI’) conductor and the other is called the ‘B’ (or ‘−’ or ‘LO’) wire. The modulation employed is bipolar return to zero (BPRZ) modulation (see Figure 4.9). The composite signal state may be at one of the following three levels (measured between the conductors):

- HI, which should be within the range +7.25 V to 11 V (A to B);
- NULL, which should be within the range +0.5 V to –0.5 V (A to B);
- LO, which should be within the range –7.25 V to –11 V (A to B).

The received voltage on a serial bus depends on line length and the number of receivers connected to the bus. With ARINC 429, no more than 20 receivers should be connected to a single bus. Since each bus is unidirectional, a system needs to have its own transmit bus if it is required to respond to or send messages. Hence, to achieve bidirectional data transfer it is necessary to have two separate bus connections.

4.2.2 Protocol

Since there can be only one transmitter on a twisted wire pair, ARINC 429 uses a very simple, point-to-point protocol. The transmitter is continuously sending...
32-bit data words or is placed in the NULL state. Note that although there may only be one receiver on a particular bus cable, the ARINC specification supports up to 20.

### 4.2.3 Bit timing and slew rate

The slew rate refers to the rise and fall time of the ARINC waveform. Specifically, it refers to the amount of time it takes the ARINC signal to rise from the 10 per cent to the 90 per cent voltage amplitude points on the leading and trailing edges of a pulse. The data shown in Table 4.1 applies to the high- and low-speed ARINC 429 systems.

#### Table 4.1 ARINC 429 parameters

<table>
<thead>
<tr>
<th>Parameter</th>
<th>High speed</th>
<th>Low speed</th>
</tr>
</thead>
<tbody>
<tr>
<td>Bit rate</td>
<td>100 kbps</td>
<td>12.5–14.5 kbps</td>
</tr>
<tr>
<td>Bit time (y)</td>
<td>10 µs ± 5 per cent</td>
<td>1/bit rate µs ± 5 per cent</td>
</tr>
<tr>
<td>High time (x)</td>
<td>5 µs ± 5 per cent</td>
<td>y/2 µs ± 5 per cent (see Figure 4.10)</td>
</tr>
<tr>
<td>Rise time</td>
<td>1.5 µs ± 0.5 µs</td>
<td>10 µs ± 5 µs</td>
</tr>
<tr>
<td>Fall time</td>
<td>1.5 µs ± 0.5 µs</td>
<td>10 µs ± 5 µs</td>
</tr>
</tbody>
</table>

1. Explain the difference between serial and parallel methods of data transfer.
2. Explain why serial data transfer is used for aircraft bus systems.
3. Explain the function of each of the following bus system components:
   (a) bus cable
   (b) stub cable
   (c) bus terminator
   (d) coupler panel.
4. State the voltage levels present on the twisted pair conductors in an ARINC 429 data bus.
4.2.4 ARINC 429 data word format

In most cases, an ARINC message consists of a single 32-bit data word (see Figure 4.11). The 8-bit label field defines the type of data that is contained in the rest of the word. ARINC data words are always 32 bits and typically include five primary fields, namely parity, SSM, data, SDI and label. ARINC convention numbers the bits from 1 (LSB) to 32 (MSB). A number of different data formats is possible.

The data field contains the actual data to be sent. The principal data formats defined in the specification are binary coded decimal (BCD), which uses groups of four bits to contain a single decimal digit and BNR (see below) which is binary coding. For both of these data types, the specification defines the units, resolution, range, number of bits used and how frequently the label should be sent.

The SSM field is used for information that assists the interpretation of the numeric value in the data field. Examples of SSM values might be North, East, South, West, Plus, Minus, Above or Below.

The P field is the parity bit. ARINC 429 uses odd parity. The parity bit is the last bit transmitted within the data word.

Some examples of data sent over an ARINC 429 bus are shown in Figures 4.12 and 4.13. In Figure 4.12 a BCD word (see page 18) is being transmitted; while in Figure 4.13 the data is encoded in binary format. The ARINC 429 binary specification calls for the use of two’s complement notation to indicate negative numbers (see page 19). This binary format is known as BNR.

In Figure 4.13 the label (103) corresponds to selected airspeed and the indicated value is 268 knots (256 + 8 + 4). The zero in the bit-29 position indicates a positive value and the data (presented in natural binary format) uses bit-28 (for the MSB) to bit-20 (for the LSB). The remaining bits are padded with zeros. In Figure 4.12 the BNR data conveys a value (this time expressed in BCD format) of 25,786.

Tables 4.2 and 4.3 provide some examples of labels and equipment ID (SDI).

---

**Figure 4.11** Basic ARINC 429 data word format (note the total length is 32 bits)

<table>
<thead>
<tr>
<th>32</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>1</th>
</tr>
</thead>
<tbody>
<tr>
<td>P</td>
<td>SSM</td>
<td>MSB</td>
<td>DATA</td>
<td>LSB</td>
<td>SDI</td>
<td>LABEL</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Bits are transmitted starting with bit 1 of the label, and the final bit transmitted is the parity bit. The standard specifies the use of odd parity (the parity bit is set to 1 or reset to 0 in order to ensure that there is an odd number of 1s in each transmitted word). It is worth noting that the label is transmitted with the MSB first, while the data is transmitted with the LSB first.

The label field is an octal value that indicates the type of data (e.g. airspeed, altitude, etc.) that is being transmitted.

The SDI field is used when a transmitter is connected to multiple receivers, but not all data is intended for use by all the receivers. In this case each receiver will be assigned an SDI value and will look only at labels which match its SDI value. While the specification calls for SDI 00 to be universally accepted, this may not actually be the case.

**Figure 4.12** ARINC 429 BCD data word format

(a) BCD word format

<table>
<thead>
<tr>
<th>32</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>1</th>
</tr>
</thead>
<tbody>
<tr>
<td>P</td>
<td>SSM</td>
<td>CHAR 1</td>
<td>CHAR 2</td>
<td>CHAR 3</td>
<td>CHAR 4</td>
<td>CHAR 5</td>
<td>SDI</td>
<td>LABEL</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

(b) BCD word example
4.13 Basic ARINC 429 BNR word format (note the total length is 32 bits)

Table 4.2 Examples of ARINC 429 label codes

<table>
<thead>
<tr>
<th>Label (octal)</th>
<th>Transmitted code (binary)</th>
<th>Equip. ID (hex)</th>
<th>Parameter transmitted</th>
<th>Data format</th>
</tr>
</thead>
<tbody>
<tr>
<td>140</td>
<td>01 100 000</td>
<td>001</td>
<td>Flight director – roll</td>
<td>BNR</td>
</tr>
<tr>
<td></td>
<td></td>
<td>025</td>
<td>Flight director – roll</td>
<td>BNR</td>
</tr>
<tr>
<td></td>
<td></td>
<td>029</td>
<td>Pre-cooler output temperature</td>
<td>BNR</td>
</tr>
<tr>
<td></td>
<td></td>
<td>05A</td>
<td>Actual fuel quantity display</td>
<td>BCD</td>
</tr>
<tr>
<td>141</td>
<td>01 100 001</td>
<td>001</td>
<td>Flight director – pitch</td>
<td>BNR</td>
</tr>
<tr>
<td></td>
<td></td>
<td>025</td>
<td>Flight director – pitch</td>
<td>BNR</td>
</tr>
<tr>
<td></td>
<td></td>
<td>029</td>
<td>Pre-cooler input temperature</td>
<td>BNR</td>
</tr>
<tr>
<td></td>
<td></td>
<td>05A</td>
<td>Pre-selected fuel quantity display</td>
<td>BCD</td>
</tr>
<tr>
<td>142</td>
<td>01 100 010</td>
<td>002</td>
<td>Flight director – fast/slow</td>
<td>BNR</td>
</tr>
<tr>
<td></td>
<td></td>
<td>003</td>
<td>Flight director – fast/slow</td>
<td>BNR</td>
</tr>
<tr>
<td></td>
<td></td>
<td>025</td>
<td>Flight director – fast/slow</td>
<td>BNR</td>
</tr>
<tr>
<td></td>
<td></td>
<td>05A</td>
<td>Left wing fuel quantity display</td>
<td>BCD</td>
</tr>
</tbody>
</table>

Test Your Understanding 4.2

1. Explain the difference between BNR and BCD encoding.
2. Using BNR encoding, which bit in an ARINC 429 data word indicates whether the data are positive or negative?
3. What is the largest positive value that can be transmitted using a single ARINC 429 data word using:
   (a) BNR encoding
   (b) BCD encoding.
4.3 OTHER BUS STANDARDS

The following is a brief summary of some of the other aircraft data bus systems that have appeared over the last 40 years. It is important to note that these often describe enhancements to existing standards. However, in all cases, the main aim is that of ensuring that equipment manufacturers and operators are working to a common specification which ensures that hardware and software is both interoperable and upgradeable.

4.3.1 ARINC 419

The ARINC 419 standard describes several digital transmission standards that predate ARINC 429. Some of these used 32-bit words similar to ARINC 429. Some standards were based on the use of a six-wire system, while others used a shielded two-wire twisted pair (like ARINC 429) or a coaxial cable. Line voltage levels were either two-state (HI/LO) or three-state (HI/NULL/LO), with voltages ranging from 10 V to 18.5 V for the high state and from less than 1 V to less than 5 V for the NULL state.

Table 4.3 Examples of equipment IDs

<table>
<thead>
<tr>
<th>Equipment ID (hex)</th>
<th>Equipment type</th>
</tr>
</thead>
<tbody>
<tr>
<td>001</td>
<td>Flight control computer</td>
</tr>
<tr>
<td>002</td>
<td>Flight management computer</td>
</tr>
<tr>
<td>003</td>
<td>Thrust control computer</td>
</tr>
<tr>
<td>004</td>
<td>Inertial reference system</td>
</tr>
<tr>
<td>005</td>
<td>Attitude and heading system</td>
</tr>
<tr>
<td>006</td>
<td>Air data system</td>
</tr>
<tr>
<td>007</td>
<td>Radio altimeter</td>
</tr>
<tr>
<td>025</td>
<td>Electronic flight instruments</td>
</tr>
<tr>
<td>026</td>
<td>Flight warning computer</td>
</tr>
<tr>
<td>027</td>
<td>Microwave landing system</td>
</tr>
<tr>
<td>029</td>
<td>ADDCS and EICAS</td>
</tr>
<tr>
<td>02A</td>
<td>Thrust management computer</td>
</tr>
</tbody>
</table>

4. In relation to an ARINC 429 data word, explain the function of:
(a) the SDI field
(b) the SSM field.

4.14 Using a bus analyser (Bus Tools from Condor Engineering) to examine the data present on an ARINC 429 data bus and display the rate at which fuel is being used.
4.3.2 ARINC 561

ARINC 561 was based on a six-wire system involving three pairs that were used for DATA, SYNC and CLOCK. Non-return to zero (NRZ) encoding was employed with logic 1 represented by 12 V. Like ARINC 429, the word length was 32 bits with bits 32 and 31 comprising the sign/status matrix (SSM) and no parity available. The remaining fields include an 8-bit label and six BCD fields, five of four bits and one of two bits. This system was widely used in aircraft manufactured prior to about 1970. ARINC 568 uses the same electrical interface specification as used in ARINC 561.

4.3.3 ARINC 573

ARINC 573 is the standard adopted for use with flight data recorders (FDR) which use a continuous data-stream of Harvard Bi-Phase encoded 12-bit words. These words are encoded into frames which contain a snapshot of the data from each of the avionics subsystems on the aircraft. Each frame comprises four sub-frames. A unique synchronising word appears at the start of each sub-frame. ARINC 717 supersedes ARINC 573 and caters for a number of different bit-rates and frame sizes.

4.3.4 ARINC 575

Similar to ARINC 429, this standard is a low-speed bus system that is based on a single twisted pair of wires. Due to the low data rate supported, this bus standard is now considered obsolete. Electrically, ARINC 575 is generally compatible with low-speed ARINC 429. However, some variants of ARINC 575 use a bit-rate that is significantly slower than ARINC 429 and they may not be compatible in terms of the electrical specification and data formats.

4.3.5 ARINC 615

ARINC 615 is a software protocol that can be layered on top of ARINC 429-compatible systems. ARINC 615 supports high-speed data transfer to and from onboard digital systems permitting, for example, reading and writing of 3.5-inch disks.

4.3.6 ARINC 629

ARINC 629 was introduced in the mid-1990s and it supports a data rate of 2 Mbps (20 times faster than ARINC 429). The bus supports 120 connected devices and is currently used on the Boeing 777, Airbus A330 and A340 aircraft. A notable enhancement of the earlier ARINC 429 standard is that ARINC 629 is a bidirectional bus system (in other words, connected devices can transmit, receive or do both). Another advantage of ARINC 629 is that it achieves bidirectional bus communication without the need for a bus controller (which could be a potential source of single-point failure). The physical bus medium is shielded twisted pair (STP).

4.3.7 ARINC 708

ARINC 708 is used to transfer data from the airborne weather radar receiver to the aircraft’s radar display. The bus is unidirectional and uses Manchester-encoded data at a data rate of 1 Mbps. Data words are 1,600 bits long and are composed of one 64-bit status word and 512 3-bit data words.

4.3.8 MIL-STD-1553B/1773B

Military standard 1533B is a bidirectional centrally controlled data bus designed for use in military aircraft. The standard uses a bus controller that can support up to 31 devices, which are referred to as remote terminals. The standard supports a bit-rate of 1 Mbps. MIL-STD-1773B is a fibre-optic implementation of MIL-STD-1553B that provides significantly greater immunity to exposure to high-intensity radiated electromagnetic fields (HIRFs).

4.3.9 CSDB and ASCB

The CSDB and ASCB standards are proprietary protocols from Collins and Honeywell, respectively. These systems are often used in small business and private general aviation aircraft. CSDB is a unidirectional bus that permits the connection of up to ten receivers and one transmitter. The standard supports data rates of 12.5 kbps and 50 kbps. ASCB is a centrally controlled bidirectional bus. A basic configuration...
comprises a single bus controller and two isolated buses, each of which can support up to 48 devices.

4.3.10 FDDI

The fibre distributed data interface (FDDI) was originally developed by Boeing for use on the Boeing 777 aircraft. FDDI is a local area network (LAN) based on a dual token-ring topology. Data in each ring flows in opposite directions. The data rate is 100 Mbps and data is encoded into frames. CDDI (copper distributed data interface) and SDDI (shielded twisted pair distributed data interface) are similar network bus standards based on copper and shielded twisted pair as the physical media. The data format is NRZI (a data format similar to NRZ, but in which a change in the line voltage level indicates a logic 1 and no change indicates a logic 0). For reasons of cost and in order to reduce the number and complexity of network standards used in its aircraft, Boeing now plans to replace the system on the 777 with a less expensive 10 Mbps copper ethernet.

4.4 MULTIPLE-CHOICE QUESTIONS

1. A bus that supports the transfer of data in both directions is referred to as:
   (a) universal
   (b) bidirectional
   (c) asynchronous.

2. The main advantage of using a serial bus in an aircraft is:
   (a) there is no need for data conversion
   (b) it supports the highest possible data rates
   (c) reduction in the size and weight of cabling.

3. Which one of the following is used to minimise reflections present in a bus cable:
   (a) coupler panels
   (b) bus terminators
   (c) shielded twisted pair cables.

4. The data format in an ARINC 429 stub cable consists of:
   (a) serial analogue doublets
   (b) parallel data from the local bus
   (c) Manchester-encoded serial data.

5. In order to represent negative data values, BNR data uses:
   (a) two’s complement binary
   (b) BCD data and a binary sign bit
   (c) an extra parity bit to indicate the sign.

6. The physical bus media specified in ARINC 629 is:
   (a) fibre-optic
   (b) coaxial cable
   (c) shielded twisted pair.

7. The validity of an ARINC 429 data word is checked by using:
   (a) a parity bit
   (b) a checksum
   (c) multiple redundancy.

TEST YOUR UNDERSTANDING 4.3

Which of the listed bus standards would be most suitable for each of the following applications? Give reasons for your answers.

1. A low-cost bus system for the simple avionics fitted to a small business aircraft.
2. Connecting a weather radar receiver to a radar display.
3. A bus system for linking the various avionics systems of a modern passenger aircraft to its flight data recorder.
4. A bus system for the avionics of a military aircraft fitted with multiple radars and electronic counter measures (ECMs).
8. The label field in an ARINC 429 data word consists of:
   (a) five bits
   (b) three bits
   (c) eight bits.

9. The voltages present on an ARINC 429 data bus cable are:
   (a) ±5 V
   (b) ±15 V
   (c) +5 V and +10 V.

10. The maximum bit rate supported by ARINC 429 is:
    (a) 12.5 kbps
    (b) 100 kbps
    (c) 1 Mbps.

11. An ARINC 429 NULL state is represented by:
    (a) a voltage of –5 V
    (b) a voltage of 0 V
    (c) a voltage of +5 V.

12. The maximum data rate supported by MIL-STD-1553 is:
    (a) 12.5 kbps
    (b) 100 kbps
    (c) 1 Mbps.

13. A bus that is self-clocking is referred to as:
    (a) universal
    (b) bidirectional
    (c) asynchronous.

14. The physical bus media specified in MIL-STD-1773B is:
    (a) fibre-optic
    (b) coaxial cable
    (c) shielded twisted pair.

15. The length of an ARINC 429 word is:
    (a) 16 bits
    (b) 20 bits
    (c) 32 bits.

16. ARINC 573 is designed for use with:
    (a) INS
    (b) FDR
    (c) weather radar.

17. The maximum data rate supported by the FDDI bus is:
    (a) 1 Mbps
    (b) 10 Mbps
    (c) 100 Mbps.
5 Logic circuits

An ability to make decisions based on a variety of different factors is crucial to the safe operation of a modern aircraft. It is therefore not surprising that logic systems are widely used in aircraft today. In this chapter we introduce the basic building blocks of digital logic circuits (AND, OR, NAND, NOR, etc.) together with the symbols and truth tables that describe the operation of the most common logic gates. We then show how these gates can be used in simple combinational logic circuits before moving on to introduce bistable devices, counters and shift registers. The chapter concludes with a brief introduction to the two principal technologies used in modern digital logic circuits, TTL and CMOS.

5.1 INTRODUCING LOGIC

We all make decisions based on logic in our everyday lives. The sort of decisions that we make are invariably conditional (i.e. they depend on a particular set of circumstances) and they often take the form:

If {condition} then {action}

For example:

If cold then put on the heating

or

If thirsty then go to the bar

We also make compound decisions that are based on more than one set of circumstances and can take the form:

If {condition 1} or {condition 2} then {action}

or

If {condition 1} and {condition 2} then {action}

For example:

If hungry or thirsty then go to the cafe

or

If cold and dark then go to bed

Another possibility is that we might want to make a decision based on the absence of a condition rather than its presence. For example:

If {condition 1} or {condition 2} and not {condition 3} then {action}

An example of this might be:

If hungry or thirsty and not raining then walk to the pub

The important words in the above conditional statements are ‘and’, ‘or’ and ‘not’. These words describe logical conditions; next we look at ways in which electronic circuits can emulate these logic functions.
5.2 LOGIC CIRCUITS

Aircraft logic systems follow the same conventions and standards as those used in other electronic applications. In particular, the MIL/ANSI standard logic symbols are invariably used and the logic elements they represent operate in exactly the same way as those used in non-aircraft applications.

MIL/ANSI standard symbols for the most common logic gates are shown together with their truth tables in Figure 5.1.

5.2.1 Buffers

Buffers do not affect the logical state of a digital signal (i.e. a logic 1 input results in a logic 1 output, whereas a logic 0 input results in a logic 0 output). Buffers are normally used to provide extra current drive at the output but can also be used to regularise the logic levels present at an interface.

5.2.2 Inverters

Inverters are used to complement the logical state (i.e. a logic 1 input results in a logic 0 output and vice versa). Inverters also provide extra current drive and, like buffers, are used in interfacing applications where they provide a means of regularising logic levels present at the input or output of a digital system.

5.2.3 AND gates

AND gates will only produce a logic 1 output when all inputs are simultaneously at logic 1. Any other input combination results in a logic 0 output.

5.2.4 OR gates

OR gates will produce a logic 1 output whenever any one, or more, inputs are at logic 1. Putting this another way, an OR gate will only produce a logic 0 output whenever all of its inputs are simultaneously at logic 0.

5.2.5 NAND gates

NAND (i.e. NOT-AND) gates will only produce a logic 0 output when all inputs are simultaneously at logic 1. Any other input combination will produce a logic 1 output. A NAND gate therefore is nothing more than an AND gate with its output inverted. The circle shown at the output of the gate denotes this inversion.

5.2.6 NOR gates

NOR (i.e. NOT-OR) gates will only produce a logic 1 output when all inputs are simultaneously at logic 0. Any other input combination will produce a logic 0 output. A NOR gate, therefore, is simply an OR gate with its output inverted. A circle is again used to indicate inversion.

5.2.7 Exclusive-OR gates

Exclusive-OR gates will produce a logic 1 output whenever either one of the two inputs is at logic 1 and...
the other is at logic 0. Exclusive-OR gates produce a logic 0 output whenever both inputs have the same logical state (i.e. when both are at logic 0 or both are at logic 1).

5.2.8 Exclusive-NOR gates

Exclusive-NOR gates will produce a logic 0 output whenever either one of the two inputs is at logic 1 and the other is at logic 0. Exclusive-OR gates produce a logic 1 output whenever both inputs have the same logical state (i.e. when both are at logic 0 or both are at logic 1).

5.2.9 Inverted outputs and inputs

The NAND and NOR gates that we have just met are said to have inverted outputs. In other words, they are respectively equivalent to AND and OR gates with their outputs passed through an inverter (or NOT gate), as shown in Figure 5.2a–b.

5.3 BOOLEAN ALGEBRA

Boolean algebra is frequently used to describe logical operations used in avionic systems. The basic Boolean logic expressions are:

<table>
<thead>
<tr>
<th>Expression</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>( Y = A \cdot B )</td>
<td>(the AND function)</td>
</tr>
<tr>
<td>( Y = A + B )</td>
<td>(the OR function)</td>
</tr>
<tr>
<td>( Y = A \cdot \overline{B} )</td>
<td>(the NAND function)</td>
</tr>
<tr>
<td>( Y = A + \overline{B} )</td>
<td>(the NOR function)</td>
</tr>
<tr>
<td>( Y = \overline{A} )</td>
<td>(the NOT function)</td>
</tr>
</tbody>
</table>
The rules (or laws) of Boolean algebra are as follows.

**The Commutative Law**

\[ A + B = B + A \]
\[ A \cdot B = B \cdot A \]
\[ A + (B + C) = (A + B) + C \]
\[ A \cdot (B \cdot C) = (A \cdot B) \cdot C \]

**The Distributive Law**

\[ A \cdot (B + C) = (A \cdot B) + (A \cdot C) \]

**The AND rules**

\[ A \cdot 0 = 0 \]
\[ A \cdot 1 = A \]
\[ A \cdot A = A \]
\[ A \cdot \overline{A} = 0 \]

**The OR rules**

\[ A + 0 = A \]
\[ A + 1 = 1 \]
\[ A + A = 1 \]
\[ A + \overline{A} = A \]

**The NOT rules**

\[ 0 = 1 \]
\[ 1 = 0 \]
\[ \overline{\overline{A}} = A \] (double inversion)

Note that it is important to avoid confusing the symbols and laws of Boolean algebra with those that apply to conventional algebra! For example, in conventional algebra, \( x + x = 2x \), whereas in Boolean algebra \( x + x = x! \)

It may help to remember the rule as ‘split (or join) the bar and change the sign’.

In an avionic system the Boolean variables (A, B, C, etc.) are usually replaced by the abbreviated names of signals, such as NOSE GEAR DOWN, IRS GND SPD >100 KTS, AUTOTRIM VALID, GROUND TEST REQUEST, etc. With a little practice, the use of Boolean algebra should become second nature!

---

**KEY POINT**

Logic circuits involve signals that can only exist in one of two mutually exclusive states. These two states are usually denoted by 1 and 0, ‘on’ or ‘off’, ‘high’ or ‘low’, ‘closed’ or ‘open’, etc.

---

**5.4 COMBINATIONAL LOGIC**

By using a standard range of logic levels (i.e. voltage levels used to represent the logic 1 and logic 0 states) logic circuits can be combined together in order to solve more complex logic functions. As an example, assume that a logic circuit is to be constructed that will produce a logic 1 output whenever two, or more, of its three inputs are at logic 1. This circuit is referred to as a majority vote circuit and its truth table is shown in Figure 5.4. Figure 5.5 shows the logic circuitry required and the Boolean expressions for the logic at each node in the circuit.

---

**5.5.1 De Morgan’s Theorem**

We have already shown how, when the two inputs to an AND gate are inverted the resulting logic is the same as that of a NOR gate. This follows from De Morgan’s Theorem and can be shown using Boolean algebra as:

\[ \overline{A \cdot B} = A + B \]

Similarly, when the two inputs to an OR gate are inverted the resulting logic is the same as that of a NAND gate. Using Boolean algebra this is shown as:

\[ \overline{A + B} = A \cdot B \]

---

**5.4 The majority vote truth table**
Now let’s look at a more practical example of the use of logic in the typical aircraft system shown in Figure 5.6. The inputs to this logic system consist of five switches that detect whether or not the respective landing gear door is open. The output from the logic system is used to drive six warning indicators. Four of these are located on the overhead display panel and show which door (or doors) are left open, while an indicator located on the pilot’s instrument panel provides a master landing gear door warning. A switch is also provided in order to enable or disable the five door warning indicators.

The landing gear warning logic primary module consists of the following integrated circuit devices:

A1  Regulated power supply for A5
A2  Regulated power supply for A7 and A11
A5  Ten inverting (NOT) gates
A7  Five-input NAND gates
A11 Six inverting (NOT) gates

Note that the power supply for A1 and A2 is derived from the essential services DC bus. This is a 28 V DC bus which is maintained in the event of an aircraft generator failure. Note also that the indicators are active-low devices (in other words, in Figure 5.6 they require a logic 0 input in order to become illuminated).

In order to understand how the landing gear warning logic works it is simply a matter of tracing logic 0 and logic 1 states through the logic diagram. Figure 5.7 shows how this is done when all of the landing gear doors are closed (this is the normal in-flight condition). Note how the primary door warning indicator shows the pilot that the system is active. When all of the landing gear doors are closed all inputs to A5 are taken to logic 0, all outputs from A5 are at logic 0, as is the output from A7. This, in turn, results in logic 1 inputs to the indicators, which remain in the off (non-illuminated) state.

In Figure 5.8 the nose landing gear door is open. In this condition the output of A7 goes to logic 1 and the master warning becomes illuminated on the pilot’s panel. At the same time, the nose-door-open warning becomes illuminated. In Figure 5.9
both the left wing and the nose landing gear doors are open. In this condition the output of A7 goes to logic 1 and the master warning becomes illuminated as before. This time, however, both the nose-door-open and left-wing-door-open warnings become illuminated.

Note that in a real passenger aircraft a secondary landing gear door warning logic system is fitted. This system is identical to the primary system shown and provides a back-up in case the primary system fails. Primary or secondary system operation can be selected by the pilot.
**LOGIC CIRCUITS**

5.9 Landing gear door warning logic with nose and left wing door open

---

**KEY POINT**

The logical function of a combinational logic circuit (i.e. an arrangement of logic gates) can be described by a truth table or by using Boolean algebra.

---

**TEST YOUR UNDERSTANDING 5.1**

1. Show how a four-input AND gate can be made using three two-input AND gates.
2. Show how a four-input OR gate can be made using three two-input OR gates.
3. Show how an exclusive-OR gate can be made by combining AND, OR and NOT gates.

---

**TEST YOUR UNDERSTANDING 5.2**

1. Draw the truth table and state the Boolean expression for the logic gate arrangement shown in Figure 5.10.

   ![Figure 5.10](image)

   **5.10** See Question 1 of Test your understanding 5.2

2. State the Boolean logic expression for the logic gate arrangement shown in Figure 5.11.

   ![Figure 5.11](image)

   **5.11** See Question 2 of Test your understanding 5.2
5.5 TRI-STATE LOGIC

Tri-state logic devices operate in a similar manner to conventional logic gates but have a third, high-impedance output state. This high-impedance state permits the output of several tri-state devices to be connected directly together. Such arrangements are commonly used when a bus system has to be driven by several logic gates. The output state (whether a logic level or high impedance) is controlled by means of an enable (EN) input. This EN input may be either active-high or active-low, as shown in Figure 5.13.

Figures 5.13a–b show the truth tables for a buffer with active-high and active-low enable inputs, respectively. Note that the state of the EN input determines whether the output takes the same logical state as the input or whether the output is taken to its high-impedance state (shown as X in the truth table).

Figures 5.13c–d show the truth table for an inverter with active-high and active-low enable inputs, respectively. In this case, the state of the EN input determines whether the output takes the opposite logical state to the input or whether the output is taken to its high-impedance state (again shown as X in the truth table).

5.6 MONOSTABLES

Monostable (or one-shot) devices provide us with a means of generating precise time delays. Such delays become important in many sequential logic applications where logic states are not constant but subject to change with time.

The action of a monostable is quite simple – its output is initially logic 0 until a change of state occurs at its trigger input. The level change can be from 0 to 1 (positive edge trigger) or 1 to 0 (negative edge trigger).
 Immediately the trigger pulse arrives, the output of the monostable changes state to logic 1. It then remains at logic 1 for a pre-determined period before reverting back to logic 0. Monostable circuits can be used as pulse stretchers (a means of elongating a short pulse) as well as producing accurate time delays.

An example of the use of a monostable is shown in the auxiliary power unit (APU) starter logic shown in Figure 5.14. This arrangement has three inputs (APU START, APU SHUTDOWN and APU RUNNING) and one output (APU STARTER MOTOR). The inputs are all active-high (in other words, a logic 1 is generated when the pilot operates the APU START switch, and so on). The output of the APU starter motor control logic goes to logic 1 in order to apply power to the starter motor via a large relay.

There are a few things to note about the logic arrangement shown in Figure 5.14:

1. When the APU runs on its own we need to disengage the starter motor. In this condition the APU MOTOR signal needs to become inactive (i.e. it needs to revert to logic 0).
2. We need to avoid the situation that might occur if the APU does not start but the starter motor runs continuously (as this will drain the aircraft batteries). Instead, we should run the starter motor for a reasonable time (say, 60 seconds) before disengaging the starter motor. The 60 seconds timing is provided by means of a positive edge triggered monostable device. This device is triggered from the APU START signal.
3. Since the pilot is only required to momentarily press the APU START switch, we need to hold the condition until such time as the engine starts or times out (i.e. at the end of the 60-second period). We can achieve this by OR-ing the momentary APU START signal with the APU STARTER MOTOR signal.
4. We need to provide a signal that the pilot can use to shutdown the APU (for example, when the aircraft’s main engines are running or perhaps in the event of a fault condition).
In order to understand the operation of the APU starter motor logic system we can once again trace through the logic system using 1s and 0s to represent the logical condition at each point (just as we did for the landing gear door warning logic).

In Figure 5.15a the APU is in normal flight and the APU is not running. In this condition the main engines are providing the aircraft’s electrical power. In Figure 5.15b the pilot is operating the APU START switch. The monostable is triggered and output of the OR and AND gates both go to logic 1 in order to assert the APU STARTER MOTOR signal.

In Figure 5.15c the APU START signal is removed but the output of the AND gate is held at logic 1 by feeding back its logical state via the OR gate. The monostable remains triggered and continues to produce a logic 1 output for its 60-second period.

In Figure 5.15d the APU is now running and the APU RUNNING signal has gone to logic 1 in order to signal this condition. This results in the output of the AND gate going to logic 0 and the APU STARTER MOTOR signal is no longer made active. The starter motor is therefore disengaged.

In Figure 5.15e the APU has failed to run during the 60-second monostable period. In this timed-out condition the output of the AND gate goes to logic 0 and the APU STARTER MOTOR signal becomes inactive. The system then waits for the pilot to operate the APU START button for a further attempt at starting!

5.7 BISTABLES

The output of a bistable circuit has two stable states (logic 0 or logic 1). Once set in one or other of these states, the output of a bistable will remain at a particular logic level for an indefinite period until reset. A bistable thus forms a simple form of memory as it remains in its latched state (either set or reset) until a signal is applied to it in order to change its state (or until the supply is disconnected).

The simplest form of bistable is the R-S bistable. This device has two inputs, SET and RESET, and complementary outputs, Q and \( \bar{Q} \). A logic 1 applied to the SET input will cause the Q output to become (or remain at) logic 1, while a logic 1 applied to the RESET input will cause the Q output to become (or remain at) logic 0. In either case, the bistable will remain in its SET or RESET state until an input is applied in such a sense as to change the state. Two simple forms of R-S bistable based on cross-coupled logic gates are shown in Figure 5.16.

Unfortunately, the simple cross-coupled logic gate bistable has a number of serious shortcomings (consider what would happen if a logic 1 was simultaneously present on both the SET and RESET inputs!) and practical forms of bistable make use of much-improved purpose-designed logic circuits such as D-type and J-K bistables.

The D-type bistable has two inputs: D (standing variously for ‘data’ or ‘delay’) and CLOCK (CLK). The data input (logic 0 or logic 1) is clocked into the bistable such that the output state only changes when the clock changes state. Operation is thus said to be synchronous.

Additional subsidiary inputs (which are invariably active-low) are provided which can be used to directly set or reset the bistable. These are usually called PRESET (PR) and CLEAR (CLR). D-type bistables are used both as latches (a simple form of memory) and as binary dividers. The simple circuit arrangement in Figure 5.17 together with the timing diagram shown in Figure 5.18 illustrate the operation of D-type bistables.

J-K bistables (see Figure 5.19) have two clocked inputs (J and K), two direct inputs (PRESET and CLEAR), and transitions on both inputs can change the output state synchronously. The inputs are held active-low (active-high) and each input changes the output state when the clock changes state. Figure 5.19 shows both inputs applied simultaneously to change the output state.
CLEAR), a CLOCK (CLK) input, and outputs (Q and \(Q\)). As with R-S bistables, the two outputs are complementary (i.e. when one is 0 the other is 1, and vice versa). Similarly, the PRESET and CLEAR inputs are invariably both active-low (i.e. a 0 on the PRESET input will set the Q output to 1 whereas a 0 on the CLEAR input will set the Q output to 0). Figure 5.20 summarises the input and corresponding output states of a J-K bistable for various input states. J-K bistables are the most sophisticated and flexible of the bistable types and they can be configured in various ways for use in binary dividers, shift registers and latches.

(a) PRESET and CLEAR inputs

<table>
<thead>
<tr>
<th>Inputs</th>
<th>Output</th>
<th>Comment</th>
</tr>
</thead>
<tbody>
<tr>
<td>PRESET</td>
<td>CLEAR</td>
<td>Q</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>?</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>-</td>
</tr>
</tbody>
</table>

Note that the PRESET and CLEAR inputs are unaffected by the state of the clock

(b) Clocked operation using the J and K inputs

<table>
<thead>
<tr>
<th>Inputs</th>
<th>Output (Q_{n+1})</th>
<th>Comment</th>
</tr>
</thead>
<tbody>
<tr>
<td>J</td>
<td>K</td>
<td>(Q_n)</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>(Q_n)</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>(Q_n)</td>
</tr>
</tbody>
</table>

Note that \(Q_n\) means 'Q in whatever state it was before' whilst \(Q_{n+1}\) means 'Q after the next clock transition'

5.20 Truth tables for the J-K bistable
5.7.1 Binary counters

Figure 5.21 shows the arrangement of a four-stage binary counter based on J-K bistables. The timing diagram for this circuit is shown in Figure 5.22. Each stage successively divides the clock input signal by a factor of two. Note that a logic 1 input is transferred to the respective Q-output on the falling edge of the clock pulse and all J and K inputs must be taken to logic 1 to enable binary counting.

5.7.2 Shift registers

Figure 5.23 shows the arrangement of a four-stage shift register based on J-K bistables. The timing diagram for this circuit is shown in Figure 5.24. Note that each stage successively feeds data (via the Q-output) to the next stage and that all data transfer occurs on the falling edge of the clock pulse.
5.8 LOGIC FAMILIES

The task of realising a complex logic circuit is made simple with the aid of digital integrated circuits, which are classified according to the semiconductor technology used in their fabrication (the logic family to which a device belongs is largely instrumental in determining its operational characteristics, such as power consumption, speed and immunity to noise – see Table 5.1). The two basic logic families are complementary metal oxide semiconductor (CMOS) and

---

5.23 Four-stage shift register using J-K bistables

5.24 Timing diagram for the four-stage shift register

5.25 Representative internal circuitry for a two-input NAND gate in (a) standard TTL and (b) standard CMOS technology
transistor–transistor logic (TTL). Each of these families is then further sub-divided into classes that are based on refinements of the parent technology, such as ‘high-current’ (or buffered output), low-noise, etc. Representative circuits for a basic two-input NAND gate using TTL and CMOS technology are shown in Figures 5.25a–b, respectively.

### 5.8.1 TTL logic

The most common family of TTL logic devices is the 74-series. Devices from this family are coded with the prefix number 74 (e.g. 7400). Sub-families (based on the use of variations in the technology) are distinguished by letters which follow the initial prefix, for example:

- **74F00**: A logic device that uses fast TTL technology and operates at higher speed than the 7400 with which it is logic and pin-compatible.
- **74LS08**: A logic device that is logic and pin-compatible with the 7408, but which uses low-power Schottky technology.
- **74HCT74**: A high-speed CMOS version of the 7474 logic device which has CMOS-compatible inputs.
- **74ALS132**: A logic device that is logic and pin-compatible with the 7414, but which uses advanced low-power Schottky technology.

### 5.8.2 CMOS logic

The most common family of CMOS devices is the 4000-series. Variants within the family are identified by the suffix letters, for example:

- **4001A**: A standard (un-buffered) CMOS logic device that is logic and pin-compatible with the 4001.
- **4011B**: A logic device that is logic and pin-compatible with the 4001 but which has buffered outputs.
- **4069 UBE**: A logic device that is logic and pin-compatible with the 4069 but which has un-buffered outputs.

### 5.8.3 Logic levels and noise margin

Logic levels are simply the range of voltages used to represent the logic states 0 and 1. The logic levels for CMOS differ markedly from those associated with TTL. In particular, CMOS logic levels are relative to the supply voltage used while the logic levels associated with TTL devices tend to be absolute (see Figure 5.26).

The noise margin of a logic device is a measure of its ability to reject noise and spurious signals; the larger the noise margin the better its ability to...
perform in an environment in which noise is present. Noise margin is defined as the difference between the minimum values of high state output and high state input voltage and the maximum values of low state output and low state input voltage. Hence:

\[
\text{Noise margin} = V_{\text{OH(MIN)}} - V_{\text{IH(MIN)}}
\]

and also

\[
\text{Noise margin} = V_{\text{OL(MAX)}} - V_{\text{IL(MAX)}}
\]

where \(V_{\text{OH(MIN)}}\) is the minimum value of high state (logic 1) output voltage, \(V_{\text{IH(MIN)}}\) is the minimum value of high state (logic 1) input voltage, \(V_{\text{OL(MAX)}}\) is the maximum value of low state (logic 0) output voltage, and \(V_{\text{IL(MAX)}}\) is the minimum value of low state (logic 0) input voltage.

The noise margin for standard 7400 series TTL is typically 400 mV, while that for CMOS is \((1/3)V_{\text{DD}}\), as shown in Figure 5.26.

**KEY POINT**

The two major logic families are CMOS and TTL. These two families have quite different characteristics, supply requirements and logic levels. CMOS logic devices operate from a wide range
of voltage levels and consume very little power (and are therefore often preferred for portable low-power applications). TTL logic devices, on the other hand, tend to be faster but have a much lower noise margin and are therefore more susceptible to noise and interference. The two main logic families are further divided into a number of different sub-families based on variations in the parent technology.

**TEST YOUR UNDERSTANDING 5.3**

Figure 5.29 shows the pin connections for some common CMOS and TTL logic devices.

1. Which of the devices shown is a two-input OR gate?
2. What voltage would you expect to measure on pin 14 of a 7408 device?
3. Sketch a circuit (including pin numbers) showing how a 4001 device could be used as a dual R-S bistable.
4. Sketch circuits (including pin numbers) showing how a 7400 could be used as: (a) a two-input AND gate; and (b) a two-input OR gate.
5.9 MULTIPLE-CHOICE QUESTIONS

1. The logic device shown in Figure 5.30 is:
   (a) an OR gate
   (b) a NOR gate
   (c) an exclusive-OR gate.

![Logic Gate](image)

5.30 See Question 1

2. The normal supply voltage for a TTL logic device is:
   (a) 2.5 V ± 5 per cent
   (b) 5 V ± 5 per cent
   (c) 12 V ± 5 per cent.

3. A two-input NAND gate will produce a logic 0 output when:
   (a) both of the inputs are at logic 0
   (b) either one of the inputs is at logic 0
   (c) both of the inputs are at logic 1.

4. In a binary counter, the clock input of each bistable stage is fed from:
   (a) the same clock line
   (b) the Q output of the previous stage
   (c) the CLEAR line.

5. The device shown in Figure 5.31 is:
   (a) a low-power Schottky TTL device
   (b) a high-density standard TTL device
   (c) a buffered CMOS device.

![Logic Gate](image)

5.31 See Question 5

6. The most appropriate logic family for use in a portable item of test equipment is:
   (a) CMOS
   (b) TTL
   (c) low-power Schottky TTL.

7. The logic gate arrangement shown in Figure 5.32 performs the same function as:
   (a) a NOR gate
   (b) a NAND gate
   (c) an exclusive-OR gate.

![Logic Gate](image)

5.32 See Question 7

8. The noise margin for standard TTL devices is:
   (a) 400 mV
   (b) 800 mV
   (c) 2 V.

9. A CMOS logic gate is operated from a 12 V supply. If a voltage of 3 V is measured at the input to the gate, this would be considered equivalent to:
   (a) logic 0
   (b) indeterminate
   (c) logic 1.

10. The truth table shown in Figure 5.33 is for:
    (a) a two-input OR gate
    (b) a two input NOR gate.

<table>
<thead>
<tr>
<th>A</th>
<th>B</th>
<th>Y</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>0</td>
</tr>
</tbody>
</table>

5.33 See Question 10
Modern aircraft use increasingly sophisticated avionic systems which involve the use of microprocessor-based computer systems. These systems combine hardware and software and are capable of processing large amounts of data in a very short time. This chapter provides an overview of aircraft computer systems.

### 6.1 COMPUTER SYSTEMS

The basic components of a computer system are shown in Figure 6.1. The main components are:

1. a central processing unit (CPU);
2. a memory, comprising both ‘read/write’ and ‘read only’ devices (commonly called RAM and ROM, respectively);
3. a means of providing input and output (I/O) (for example, a keypad for input and a display for output).

In a microprocessor system the functions of the CPU are provided by a single very large-scale integrated (VLSI) microprocessor chip (see Chapter 7). This chip is equivalent to many thousands of individual transistors.

Semiconductor devices are also used to provide the read/write and read-only memory. Strictly speaking, both types of memory permit ‘random access’ since any item of data can be retrieved with equal ease regardless of its actual location within the memory. Despite this, the term ‘RAM’ has become synonymous with semiconductor read/write memory.

The basic components of the system (CPU, RAM, ROM and I/O) are linked together using a multiple-wire connecting system known as a bus (see Figure 6.1). Three different buses are present; these are:

1. the address bus used to specify memory locations;
2. the data bus on which data is transferred between devices; and
3. the control bus which provides timing and control signals throughout the system.

The number of individual lines present within the address bus and data bus depends upon the particular microprocessor employed. Signals on all lines, no matter whether they are used for address, data or control, can exist in only two basic states: logic 0 (low) or logic 1 (high). Data and addresses are represented by binary numbers (a sequence of 1s and 0s) that appear respectively on the data and address bus.

Some basic microprocessors designed for control and instrumentation applications have an 8-bit data bus and a 16-bit address bus. More sophisticated processors can operate with as many as 64 or 128 bits at a time.

The largest binary number that can appear on an 8-bit data bus corresponds to the condition when all eight lines are at logic 1. Therefore the largest value of data that can be present on the bus at any instant of time is equivalent to the binary number 11111111 (or 255). Similarly, the highest address that can appear on a 16-bit address bus is 1111111111111111 (or 65,535). The full range of data values and addresses for a simple microprocessor of this type is thus:

<table>
<thead>
<tr>
<th>Data</th>
<th>from</th>
<th>to</th>
</tr>
</thead>
<tbody>
<tr>
<td>00000000</td>
<td>11111111</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Addresses</th>
<th>from</th>
<th>to</th>
</tr>
</thead>
<tbody>
<tr>
<td>0000000000000000</td>
<td>1111111111111111</td>
<td></td>
</tr>
</tbody>
</table>

Finally, a locally generated clock signal provides a time reference for synchronising the transfer of data within the system. The clock usually consists of a high-frequency square wave pulse train derived from a quartz crystal (see Chapter 8).

### 6.2 DATA REPRESENTATION

As we have learned from Chapter 2, binary numbers – particularly large ones – are not very convenient. To make numbers easier to handle we introduced the hexadecimal (base 16) numbering system. This format is easier for mere humans to comprehend and also offers the significant advantage over base 10 numbers in that numbers can be converted to and from binary with ease.

A group of eight bits, operated on as a unit, is referred to as a byte. Since hexadecimal characters can be represented by a group of four bits, a byte of data can be expressed using two hexadecimal characters. Note that groups of four bits are sometimes referred to as nibbles and that a byte can take a hexadecimal value ranging from 00 to FF. The basic unit of data that can be manipulated as an entity is often referred to as a word. Words can be any convenient length, but 16-, 32- and 64-bit words are common (see Table 6.1).

A single byte of data can be stored at each address within the total memory space of a computer system. Hence, one byte can be stored at each of the 65,536 memory locations within a microprocessor system having a 16-bit address bus. Individual bits within a byte are numbered from 0 (least significant bit, or LSB) to 7 (most significant bit, MSB). In the case of 16-bit words (which are stored in consecutive memory locations) the bits are numbered from 0 (LSB) to 15 (MSB).

#### Table 6.1 Some common data types

<table>
<thead>
<tr>
<th>Data type</th>
<th>Bits</th>
<th>Range of values</th>
</tr>
</thead>
<tbody>
<tr>
<td>Unsigned byte</td>
<td>8</td>
<td>0 to 255</td>
</tr>
<tr>
<td>Signed byte</td>
<td>8</td>
<td>−128 to +127</td>
</tr>
<tr>
<td>Unsigned word</td>
<td>16</td>
<td>0 to 65,535</td>
</tr>
<tr>
<td>Signed word</td>
<td>16</td>
<td>−32,768 to +32,767</td>
</tr>
<tr>
<td>Unsigned double word</td>
<td>32</td>
<td>0 to 4,294,967,296</td>
</tr>
</tbody>
</table>
Negative numbers (or signed numbers) are usually represented using two’s complement (see page 19) notation where the leading (most significant) bit indicates the sign of the number (1 = negative, 0 = positive). For example, the signed 8-bit number 10000001 represents the decimal number –1.

**TEST YOUR UNDERSTANDING 6.1**

1. What is the highest data value (expressed in decimal) that can appear on a 12-bit address bus?
2. What is the decimal equivalent of the signed 8-bit binary number 11111110?

**KEY POINT**

A computer system consists of a central processing unit (CPU), a read-only memory (ROM), a read/write (random access) memory (RAM) and one or more input/output (I/O) devices. These elements are linked together using a local bus system that comprises an address bus, a data bus and a control bus.

### 6.3 DATA STORAGE

The semiconductor ROM within a microprocessor system provides storage for the program code, as well as any permanent data that requires storage. All of this data is referred to as non-volatile because it remains intact when the power supply is disconnected.

The semiconductor RAM within a microprocessor system provides storage for the transient data and variables that are used by programs. Part of the RAM is also used by the microprocessor as a temporary store for data while carrying out its normal processing tasks.

It is important to note that any program or data stored in RAM will be lost when the power supply is switched off or disconnected. The only exception to this is low-power CMOS RAM, which is kept alive by means of a small battery. This battery-backed memory is used to retain important data, such as the time and date.

When expressing the amount of storage provided by a memory device we usually use Kilobytes (Kbyte). It is important to note that a Kilobyte of memory is actually 1,024 bytes (not 1,000 bytes). The reason for choosing the Kbyte rather than the kbyte (1,000 bytes) is that 1,024 happens to be the nearest power of 2 (note that 2^10 = 1,024).

The capacity of a semiconductor ROM is usually specified in terms of an address range and the number of bits stored at each address. For example, 2K × 8 bits (capacity 2 Kbytes), 4K × 8 bits (capacity 4 Kbytes), and so on. Note that it is not always necessary (or desirable) for the entire memory space of a computer to be populated by memory devices.

#### 6.3.1 Random access memory

A large proportion (typically 80 per cent or more) of the total addressable memory space of a computer system is devoted to read/write memory. This area of memory is used for a variety of purposes, the most obvious of which is program and data storage. The term ‘random access’ simply refers to a memory device in which data may be retrieved from all locations with equal ease (i.e. access time is independent of actual memory address). This is important since our programs often involve moving sizeable blocks of data into and out of memory.

The basic element of a semiconductor memory is known as a cell. Cells can be fabricated in one of two semiconductor technologies: MOS (metal oxide semiconductor) and bipolar. Bipolar memories are now rarely used even though they offer much faster access times. Their disadvantage is associated with power supply requirements (they need several voltage rails, both positive and negative, and use significantly more power than their MOS counterparts).

RAMs can be further divided into static and dynamic types. The important difference between the two types is that dynamic memories require periodic refreshing if they are not to lose their contents. While, in the normal course of events, this would be carried out whenever data was read and rewritten, this technique cannot be relied upon to refresh all of the dynamic memory space, and steps must be taken to ensure that all dynamic memory cells are refreshed.
periodically. This function has to be integrated with the normal operation of the computer system, or performed by a dedicated dynamic memory controller. Static memories do not need refreshing and can be relied upon to retain their memory until such time as new data is written or the power supply is interrupted (in which case all data is lost).

The circuit of a typical bipolar static memory cell is shown in Figure 6.3. The transistors form an R-S bistable (see page 62) that can be SET or RESET by means of a pulse applied to the appropriate emitter. The CELL SELECT line is used to identify the particular cell concerned. This type of cell uses emitter-coupled logic (ECL) and requires both negative and positive supply rails.

The circuit of a typical MOS static memory cell is shown in Figure 6.4. This is also clearly recognisable as a bistable element. The CELL SELECT line is used to gate signals into and out of the memory cell. Note that, as for the bipolar cell, the SET and RESET lines are common to a number of cells.

The circuit of a typical MOS dynamic memory cell is shown in Figure 6.5. In contrast to the previous types of cell this clearly does not use a bistable arrangement. Instead, a capacitor, C, is used as the storage element. The capacitor is in fact the input capacitance of an MOS transistor. This is charged or discharged according to the state of the INPUT, OUTPUT and CELL SELECT lines. The characteristics of a number of common RAMs are shown in Table 6.2. Both static (SRAM) and dynamic (DRAM) examples have been included. Note that there is some variation in the way these memories are organised.

From Table 6.2 it should be readily apparent that individual RAMs must contain some form of internal decoding in order to make each cell individually addressable. This is achieved by arranging the cells in the form of a matrix.

Figure 6.6 shows one possible arrangement where 16,384 individual memory cells form a matrix consisting of 128 rows by 128 columns. Each cell within the array has a unique address and is selected by placing appropriate logic signals on the row and column address lines. All that is necessary to interface the memory matrix to the system is some additional logic, but first we must consider the mechanism which allows the address bus to be connected to the memory cell.

The row and column decoders of Figure 6.6 have 128 output lines and seven input lines. Each possible combination of the seven input lines results in the selection of a unique output line. If we assume that the row decoder handles the most significant part of the address while the column decoder operates on the least significant portion, the cell at the top
left-hand corner of the matrix will correspond to memory location 0 (memory address 0000h), whereas the corresponding position in the next row will be 128 (memory address 0080h). Finally, the cell at the bottom right-hand corner will be 16,383 (memory address 3FFFh).

While it would be possible to have 14 separate address lines fed into the chip, this is somewhat inelegant since, with the aid of some additional gating and latches, it is possible to reduce the number of address lines to seven. This is achieved by multiplexing part of the address bus and then de-multiplexing it within the memory device. A typical arrangement is shown in Figure 6.7.

Separate row and column address select (RAS and CAS) control signals are required in order to enable the appropriate latches when the multiplexed address information is valid. The multiplexing arrangement for the address bus is shown in Figure 6.8.
Note that, in practice, additional control signals will be required when several 16K blocks of RAM are present within the system. Such a precaution is essential in order to prevent data conflicts in which more than one memory cell (in different RAM blocks) is addressed simultaneously.

Table 6.3 shows the truth table for the address lines and decoding logic of the memory device. This table assumes that the most significant part of the address (high order) appears first and is decoded to the appropriate row while the least significant (low order) part appears second and is decoded to the appropriate
The table shows the logic states for three address locations: 0000h, 00FFh and 3FFFh.

The memory matrix described earlier is capable of storing a single bit at any of 16,384 locations (16K \times 1 
bit). For a complete byte (eight bits) we would obviously require eight such devices. These would share the same address, RAS and CAS lines, but each chip would be responsible for different bits of the data bus. Various methods are employed for data transfer into and out of the matrix, sensing the state of either the rows or the columns of the matrix and gating with the write enable (WE) line so that data transfers only occur at the correct time. Data output is generally tri-state (see page 60) by virtue of the shared data bus.

### 6.3.2 Read only memory

As its name implies, read only memory (ROM) is memory which, once programmed, can only be read from, not written to. It may thus be described as ‘non-volatile’ since its contents are not lost when the supply is disconnected. This facility is, of course, necessary for the long-term semi-permanent storage of operating systems and high-level language interpreters. To change the control program or constant data it is necessary to replace the ROM. This is a simple matter because ROMs are usually plug-in devices or can be programmed electrically. The following types are in common use.

**Mask-programmed ROM.** This relatively expensive process is suitable for very high volume production (several thousand units or more) and involves the use of a mask that programs links within the ROM chip. These links establish a permanent pattern of bits in the row/column matrix of the memory. The customer (computer manufacturer) must supply the ROM manufacturer with the programming information from which the mask is generated.

**One-time programmable electrically programmable ROM (OTP EPROM).** This is a somewhat less expensive process than mask programming and is suitable for small/medium-scale production. The memory cells consist of nichrome or polysilicon fuse links between rows and columns. These links can, by application of a suitable current pulse, be open-circuited or ‘blown’. OTP EPROMs are ideal for prototype use and programming can be carried out by the computer manufacturer (or the component supplier) using relatively inexpensive equipment. When an OTP EPROM has been thoroughly tested (and provided that high-volume production can be envisaged) it is possible for the device to be replaced by a conventional mask-programmed ROM.
Erasable PROM (UV EPROM). Unlike the two previous types of ROM, the EPROM can be reprogrammed. EPROMs are manufactured with a window that allows light to fall upon the semiconductor memory cell matrix. The EPROM may be erased by exposure to a strong ultraviolet light source over a period of several minutes, or tens of minutes. Once erasure has taken place any previously applied bit pattern is completely removed, the EPROM is ‘blank’ and ready for programming. The programming process is carried out by the manufacturer from master software using a dedicated programming device which supplies pulses to establish the state of individual memory cells. This process usually takes several minutes (though some EPROM programmers can program several devices at once) and, since EPROMs tend to be relatively expensive, this process is clearly unsuitable for anything other than very small-scale production. Furthermore, it should be noted that EPROMs tend to have rather different characteristics from PROMs and ROMs and thus subsequent volume production replacement may cause problems.

Electrically erasable PROM (EEPROM) (also known as flash memory). This type of ROM can both be read to and written from. However, unlike RAM, Flash ROM is unsuitable for use in the read/write memory section of a computer since the writing process takes a considerable amount of time (typically 1,000 times longer than the reading time). EEPROMs are relatively recent and relatively expensive devices. It’s also worth noting that, until recently, a reasonable compromise for semi-permanent data and program storage could take the form of low-power consumption RAM fitted with back-up batteries (in certain circumstances such a system can be relied upon to retain stored information for a year or more).

The internal matrix structure of ROMs is somewhat similar to that employed for RAMs, i.e. individual cells within the matrix are uniquely referenced by means of row and column address lines. ROMs vary in capacity and 64K, 128K and 256K devices are commonplace. The characteristics of some common ROMs are shown in Table 6.4.

Finally, it is important to note that ROM and EPROM devices do not lose their data when the supply is disconnected. They are thus said to be non-volatile memories (NVM). Most RAM devices, unless battery-backed (see page 72), are volatile memories and the stored data will be lost when the supply is disconnected.

<table>
<thead>
<tr>
<th>Type</th>
<th>Size (bits)</th>
<th>Organisation</th>
<th>Package</th>
<th>Technology</th>
<th>Supply</th>
</tr>
</thead>
<tbody>
<tr>
<td>2764</td>
<td>64K</td>
<td>64K words × 8 bit</td>
<td>28-pin DIL</td>
<td>UV EPROM</td>
<td>+5 V at 50 mA</td>
</tr>
<tr>
<td>27C64</td>
<td>64K</td>
<td>64K words × 8 bit</td>
<td>28-pin DIL</td>
<td>CMOS UV EPROM</td>
<td>+5 V at 30 mA</td>
</tr>
<tr>
<td>613256</td>
<td>256K</td>
<td>32K words × 8 bit</td>
<td>28-pin DIL</td>
<td>Mask ROM</td>
<td>+5 V at 50 mA</td>
</tr>
<tr>
<td>AT28C256</td>
<td>256K</td>
<td>32K words × 8 bit</td>
<td>28-pin DIL</td>
<td>CMOS EEPROM</td>
<td>+5 V at 50 mA</td>
</tr>
<tr>
<td>AM29F010</td>
<td>1M</td>
<td>128K words × 8 bit</td>
<td>32-pin PLCC</td>
<td>Flash EPROM</td>
<td>+5 V at 30 mA</td>
</tr>
<tr>
<td>AT27010</td>
<td>1M</td>
<td>128K words × 8 bit</td>
<td>32-pin PLCC</td>
<td>OTP EPROM</td>
<td>+5 V at 25 mA</td>
</tr>
</tbody>
</table>

**KEY POINT**

RAM and ROM devices provide storage for data and programs within a computer system. Various semiconductor technologies are used to produce RAM and ROM devices and this
6.4 PROGRAMS AND SOFTWARE

A program is simply a sequence of instructions that tells the computer to perform a particular operation. As far as the microprocessor is concerned, each instruction comprises a unique pattern of binary digits. It should, however, be noted that the computer may also require data and/or addresses of memory locations in order to fulfil a particular function. This information must also be presented to the microprocessor in the form of binary bit patterns. Clearly it is necessary for the processor to distinguish between the instruction itself and any data or memory address which may accompany it. Furthermore, instructions must be carried out in strict sequence. It is not possible for the microprocessor to execute more than one instruction at a time!

A computer program may exist in one of several forms, although ultimately the only form usable by the processor is that which is presented in binary. This is unfortunate since most humans are not very adept at working in binary. The following program fragment presented in binary is for an Intel x86 family or Pentium processor:

```
10111000
00000001
00000000
10111011
00000010
00000001
11011000
10001001
11000001
11110100
```

CPU registers. Clearly a more meaningful program representation is required!

An obvious improvement in making a program more understandable (at least for humans) is to write the program in a number base with which we are familiar. For this purpose we could choose octal (base 8), decimal (base 10) or hexadecimal (base 16). The decimal equivalent of the above program code would, for example, be:

```
184, 1, 0, 187, 2, 0, 1, 216, 137, 193, 244
```

There is clearly not much improvement, although it is somewhat easier to recognise errors. We would, of course, still require some means of converting the decimal version of the program into binary so the program makes sense to the processor. A better method, and one which we introduced you to in Chapter 2, uses hexadecimal. Hopefully you will recall that we can easily convert eight bits of binary code into its equivalent hexadecimal by arranging the binary values into groups of four bits and then converting each four-bit group at a time. For example, taking the first byte of the program that we met earlier:

```
1011 = B and 1000 = 8
```

therefore 10111000 = B8 when written in hex.

Similarly:

```
0000 = 0 and 0001 = 1
```

therefore 00000001 = 01 when written in hex. The simple addition program that we met earlier in its binary form takes on the following appearance when written in hex:

```
B8, 01, 00, BB, 02, 00, 01, D8, 89, C1, F4
```

While it still does not make much sense (unless you just happen to be familiar with x86 machine language programming!) a pattern can be easily recognised with the program written in this form. Furthermore, the conversion to and from binary has been a relatively simple matter.
6.4.1 Instruction sets

An instruction set is the name given to the complete range of instructions that can be used with any particular microprocessor. It should be noted that although there are many similarities, instruction sets are unique to the particular microprocessor concerned. In some cases manufacturers have attempted to ensure that their own product range of microprocessors share a common sub-set of instructions. This permits the use of common software, simplifies development and helps make improvements in microprocessors more acceptable to equipment designers and manufacturers. The Intel Pentium processor, for example, was originally designed as an enhancement of the 8086, 80286, 80386 and 80486 processors. These processors share a common sub-set of instructions and thus a program written for the (now obsolete) 8086 processor will run on a Pentium-based system.

Sophisticated microprocessors offer a large number of instructions; so much so, in fact, that the sheer number and variety of instructions can often be bewildering. It is also rather too easy to confuse the power of a microprocessor with the number of instructions that are available from its instruction set; these two things are not always directly related.

Instructions are presented to the microprocessor in words that occupy one or more complete bytes (often one, two, three or four bytes depending upon the processor and whether it is an 8-bit or 16-, 32- or 64-bit type). These instruction words are sent to a register within the processor that is known appropriately as the Instruction Register.

6.4.2 Mnemonics

Most people find instructions written in hex rather difficult to remember, even though one does get to know some of the more common hex codes after working with a particular processor over a period of time. What is needed, therefore, is a simple method of remembering instructions in a form that is meaningful to the programmer. To this end, microprocessor manufacturers provide us with mnemonics for their instruction codes. They are given in a shorthand form that has some minor variations from one manufacturer to the next. One of the most common instructions is associated with loading or moving data into a register. For an Intel processor, the instruction or operation code mnemonic for this operation is written as MOV.

For the load instruction to be meaningful we need to tell the processor which register is to be loaded and with what. This information, which is known as an operand, must also be contained in the instruction. Thus, if we wished to load the 16-bit accumulator register (known as the AX register) of an Intel processor with a 16-bit data value equivalent to 01 hexadecimal, we would use the instruction:

\[ \text{MOV AX, 01h} \]

This simply means ‘place a data value of 01 hex in the AX register’. The ‘h’ simply indicates that we have specified the address in hexadecimal. If, alternatively, we simply wished to copy the contents of the AX register into the CX register we would write:

\[ \text{MOV CX, AX} \]

Notice how the destination register appears before the source register. Each of these two instructions has its own hexadecimal representation, the first being:

\[ \text{B8, 01, 00} \]

and the second:

\[ \text{89, C1} \]

Notice how the first instruction consists of three hex bytes while the second comprises only two bytes.

A program written in instruction code mnemonics is known as an assembly language program. The process of converting the mnemonics to their hexadecimal equivalents is known as assembly and, while it is possible to translate assembly language programs to hexadecimal by referring to instruction code tables (i.e. hand assembly) this is, to say the least, a somewhat tedious and repetitious task and one which is very much prone to error. Instead, we use a computer program to perform this task. This assembler program accepts source code written in assembly language and converts this to object code that the CPU can execute.

The simple addition program that we met on page 000 takes the following form when written in x86 assembly language:
MOV AX, 0001       Load AX with 16-bit data
MOV BX, 0002       load BX with 16-bit data
ADD AX, BX         add the two values together
MOV CX, AX         place the result in CX
HLT                 and stop

Note that we have also added some comments (on the right) in order to clarify the operation of the source code. Comments can be useful for maintenance or subsequent debugging.

6.4.3 Instructions

The available instructions within a specific computer instruction set (see page 79) can be grouped into a number of categories according to their function. Table 6.5 shows a subset of the x86 instruction set organised by their class or group. Most of the basic instructions can be used in several different ways according to the way in which they reference the source and/or destination data. Note also that the individual registers (see Chapter 7) may be either general purpose or may have some specific purpose (such as acting as an accumulator or as a counter).

The following x86 data movement instructions give some idea of the range of options available:

<table>
<thead>
<tr>
<th>Instruction</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>MOV AL, data</td>
<td>Moves 8-bit immediate data into the least-significant byte of the accumulator, AL</td>
</tr>
<tr>
<td>MOV AH, data</td>
<td>Moves 8-bit immediate data into the most-significant byte of the accumulator, AH</td>
</tr>
<tr>
<td>MOV AX, reg</td>
<td>Copies the contents of the specified 16-bit register to the 16-bit extended accumulator (AX)</td>
</tr>
<tr>
<td>MOV AH, reg</td>
<td>Copies the byte present in the specified 8-bit register to the 8-bit register, AH</td>
</tr>
<tr>
<td>MOV AX, [addr]</td>
<td>Copies the 16-bit word at the specified address into the general-purpose base register, AX</td>
</tr>
</tbody>
</table>

Table 6.5 A subset of Intel processor instructions

<table>
<thead>
<tr>
<th>Data transfer instructions</th>
</tr>
</thead>
<tbody>
<tr>
<td>MOV</td>
</tr>
<tr>
<td>IN</td>
</tr>
<tr>
<td>OUT</td>
</tr>
<tr>
<td>PUSH</td>
</tr>
<tr>
<td>POP</td>
</tr>
<tr>
<td>XCHG</td>
</tr>
<tr>
<td>XLAT</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Logical instructions</th>
</tr>
</thead>
<tbody>
<tr>
<td>NOT</td>
</tr>
<tr>
<td>AND</td>
</tr>
<tr>
<td>OR</td>
</tr>
<tr>
<td>XOR</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Shift and rotate instructions</th>
</tr>
</thead>
<tbody>
<tr>
<td>SHL</td>
</tr>
<tr>
<td>SHR</td>
</tr>
<tr>
<td>ROL</td>
</tr>
<tr>
<td>ROR</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Arithmetic instructions</th>
</tr>
</thead>
<tbody>
<tr>
<td>ADD</td>
</tr>
<tr>
<td>SUB</td>
</tr>
<tr>
<td>INC</td>
</tr>
<tr>
<td>DEC</td>
</tr>
<tr>
<td>NEG</td>
</tr>
<tr>
<td>CMP</td>
</tr>
<tr>
<td>MUL</td>
</tr>
<tr>
<td>DIV</td>
</tr>
</tbody>
</table>
Finally, as a further example of the use of assembly language mnemonics, the following short code fragment reads an input port and transfers 16K bytes of data from the port to a series of memory locations, starting at address 7000 hex:

<table>
<thead>
<tr>
<th>Instruction</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>MOV DX, 0300h</td>
<td>port used for input</td>
</tr>
<tr>
<td>MOV AX, 7000h</td>
<td>address to start data</td>
</tr>
<tr>
<td>MOV DS, AX</td>
<td>set up data segment</td>
</tr>
<tr>
<td>MOV DI, 0</td>
<td>first location</td>
</tr>
<tr>
<td>MOV CX, 04FFh</td>
<td>set data size to 16K</td>
</tr>
<tr>
<td>IN AL, DX</td>
<td>get a byte of data and save it</td>
</tr>
<tr>
<td>MOV [DI], AL</td>
<td>move to next location</td>
</tr>
<tr>
<td>INC DI</td>
<td>wait a short time</td>
</tr>
<tr>
<td>CALL delay</td>
<td>and go around again</td>
</tr>
<tr>
<td>LOOP getdata</td>
<td>return to main program.</td>
</tr>
<tr>
<td>RET</td>
<td></td>
</tr>
</tbody>
</table>

### 6.5 BACKPLANE BUS SYSTEMS

The computer systems used on modern aircraft are becoming increasingly sophisticated, frequently requiring powerful 32- and 64-bit processors capable of manipulating large amounts of data in a small time. In addition, many avionic systems may need several processors operating concurrently, large memories and complex I/O sub-systems.

In order to meet these needs, today’s avionic computer systems use a *backplane bus* which generally comprises a number of identical-sized cards mounted in a frame and linked together at the rear of the card frame by tracks on a printed circuit board mounted at right angles to the cards. This form of bus provides a means of linking together the sub-system components of a larger computer system. Each sub-system component consists of a PCB card and a number of VLSI devices. Such a system may incorporate several microprocessors (each of which has its own support devices and local bus system) or may involve just a single microprocessor (again with support devices and its own local bus) operating in conjunction with a number of less intelligent supporting cards.

Backplane bus systems are inherently flexible and the modular nature of the bus provides a means of easily changing and upgrading a system to meet new and changing demands. A high degree of modularity also allows cards to be exchanged when faults develop, or interchanged between systems for testing. The user is thus able to minimise down-time and need not be concerned with board-level servicing as cards can be returned to manufacturers or their appointed (and suitably equipped) service agents.

At the conceptual level, the functional elements of a bus system can be divided into *bus masters* (intelligent controlling devices that can generate bus commands), *bus slaves* (devices that generally exhibit less intelligence and cannot themselves generate bus commands and exercise control over the bus) and *intelligent slaves* (these are slaves that have their own intelligent controlling device but which do not themselves have the ability to place commands on the bus).

The ability to support more than one bus master is clearly a highly desirable facility and one which allows us to exploit the full potential of a bus system. Systems that can do this are referred to as *multiprocessing systems*. Note that while several bus masters can be connected to a bus, only one of them can command the bus at any time. The resources

### Table 6.5 continued

<table>
<thead>
<tr>
<th>Instruction</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>JMP</td>
<td>Unconditional jump</td>
</tr>
<tr>
<td>JE</td>
<td>Jump if equal</td>
</tr>
<tr>
<td>JZ</td>
<td>Jump if zero</td>
</tr>
<tr>
<td>LOOP</td>
<td>Loop unconditional</td>
</tr>
<tr>
<td>LOOPE</td>
<td>Loop if equal</td>
</tr>
<tr>
<td>LOOPZ</td>
<td>Loop if zero</td>
</tr>
<tr>
<td>CALL, RET</td>
<td>Call, return from procedure</td>
</tr>
<tr>
<td>PUSHF</td>
<td>Push flags onto stack</td>
</tr>
<tr>
<td>POPF</td>
<td>Pop flags off stack</td>
</tr>
<tr>
<td>ESC</td>
<td>Escape to external processor interface</td>
</tr>
<tr>
<td>LOCK</td>
<td>Lock bus during next instruction</td>
</tr>
<tr>
<td>NOP</td>
<td>No operation (do nothing)</td>
</tr>
<tr>
<td>WAIT</td>
<td>Wait for signal on TEST input</td>
</tr>
<tr>
<td>HLT</td>
<td>Halt processor</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Instruction</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>JMP</td>
<td>Unconditional jump</td>
</tr>
<tr>
<td>JE</td>
<td>Jump if equal</td>
</tr>
<tr>
<td>JZ</td>
<td>Jump if zero</td>
</tr>
<tr>
<td>LOOP</td>
<td>Loop unconditional</td>
</tr>
<tr>
<td>LOOPE</td>
<td>Loop if equal</td>
</tr>
<tr>
<td>LOOPZ</td>
<td>Loop if zero</td>
</tr>
<tr>
<td>CALL, RET</td>
<td>Call, return from procedure</td>
</tr>
<tr>
<td>PUSHF</td>
<td>Push flags onto stack</td>
</tr>
<tr>
<td>POPF</td>
<td>Pop flags off stack</td>
</tr>
<tr>
<td>ESC</td>
<td>Escape to external processor interface</td>
</tr>
<tr>
<td>LOCK</td>
<td>Lock bus during next instruction</td>
</tr>
<tr>
<td>NOP</td>
<td>No operation (do nothing)</td>
</tr>
<tr>
<td>WAIT</td>
<td>Wait for signal on TEST input</td>
</tr>
<tr>
<td>HLT</td>
<td>Halt processor</td>
</tr>
</tbody>
</table>
offered by the slaves can be shared between the bus masters.

In systems that support more than one potential bus master, a system of bus arbitration must be employed to eliminate possible contentions for control of the bus. Several techniques are used to establish bus priority and these generally fall into two classes, serial and parallel.

In a serially arbitrated system, bus access is granted according to a priority that is based on the physical slot location. Each master present on the bus notifies the next lower-priority master when it needs to gain access to the bus. It also monitors the bus request status of the next higher-priority master. The masters thus pass bus requests on from one to the next in a daisy-chain fashion.

In a parallel arbitrated system, external hardware is used to determine the priority of each bus master. Both systems have their advantages and disadvantages and some bus standards permit the use of both techniques.

6.5.1 The VME bus

One of the popular local computer bus systems used in aircraft today is the VersaModule Eurocard (VME) bus. The standard resulted from a joint effort between semiconductor manufacturers Mostek, Motorola and Signetics to establish a framework for 8-, 16- and 32-bit parallel-bus computer architectures capable of supporting both single and multiple processors. The bus provides fast data transfer rates and uses two DIN 41612 indirect connectors fitted to each bus card in order to provide access to the full 32-bit bus. The basic VME standard defines four main buses present within a system:

1. The data transfer bus, which provides a means of transferring data between bus cards.
2. The priority interrupt bus, which provides a means of alerting processors to external events in real-time and prioritises them so the most important is dealt with first.
3. The arbitration bus, which provides a means of determining which processor or bus master has control of the bus at any particular time.
4. The utility bus, which provides a means of distributing power and also synchronising power-up and power-down operations.

6.6 SOME EXAMPLES OF AIRCRAFT COMPUTER SYSTEMS

To help put this chapter into context, we shall conclude with a brief overview of two simple computer systems found in large transport aircraft. The information provided here is designed to show the different approaches to computer architecture and the interconnections made with other aircraft avionic systems.
6.6.1 Clock computer

The captain and first officer’s clocks are required to provide various functions, not just indicating the current time. This makes them ideal candidates for the use of a microprocessor in a simple yet essential computer system.

Figure 6.11 shows the simplified block schematic of the clock computer. The unit is powered from the aircraft’s 28V DC hot-battery bus and the functions it provides are:

- continuous display of Greenwich Mean Time (GMT);
- secondary display of elapsed time or chronograph time (as selected by the captain or first officer);
- GMT output to the flight management computer (FMC) via the ARINC 429 bus.

Inputs to the clock system consist of a number of switches that can be used for setting the clock parameters, changing the clock mode and freezing the clock display. The master timing signal for the clock is derived from an accurate crystal oscillator.

6.6.2 Aircraft integrated data system

The aircraft integrated data system (AIDS) collects and records operational data to permit detailed analysis of aircraft performance and maintenance requirements. The data is acquired by the digital flight data acquisition unit (DFDAU) and preserved for future reference by a quick access recorder (QAR). This latter device comprises a cartridge drive that records the data parameters on magnetic tape. The tape cartridge has a capacity of 14 hours of data.
storage. The QAR is able to search for and replay data from a specified GMT reference before subsequently returning to the current recording position.

A data management entry panel (DMEP) provides keyboard input of hexadecimal data and a limited set of commands (such as ENTER, CLEAR, PRINT, etc.). Data and status information is displayed on an LCD display located on the control display unit (CDU). The data recording system within the AIDS system is shown in Figure 6.12. Interconnection and data exchange with other aircraft systems is via the ARINC 629 and ARINC 717 buses.

### 6.12 AIDS data recorder sub-system

6.7 MULTIPLE-CHOICE QUESTIONS

1. The feature marked Q in Figure 6.13 is:
   - (a) RAM
   - (b) ROM
   - (c) I/O.

2. In Figure 6.13, the address is the feature marked:
   - (a) T
   - (b) U
   - (c) V.

### KEY POINT

Modern transport aircraft make extensive use of distributed computer systems. Some of these systems are based on the use of a single microprocessor device together with its support devices connected in a local bus arrangement. More complex systems use backplane bus systems in which multiple processors have shared access to the system’s resources. Interconnection and data exchange between the various avionic computer systems is based on the use of serial bus standards such as ARINC 429, ARINC 629 and ARINC 717.
3. In Figure 6.13, which feature is responsible for providing read/write memory:
   (a) Q
   (b) R
   (c) S.

4. Which computer bus is used to specify memory locations:
   (a) address bus
   (b) control bus
   (c) data bus.

5. What is the largest hexadecimal address that can appear on a 24-bit address bus:
   (a) FFFF
   (b) FFFFFF
   (c) FFFFFFFF.

6. Bus arbitration is required in order to:
   (a) prevent memory loss
   (b) avoid bus contention
   (c) reduce errors caused by noise and EMI.

7. A memory device in which any item of data can be retrieved with equal ease is known as:
   (a) parallel access
   (b) random access
   (c) sequential access.

8. Which one of the following memory devices can be erased and reprogrammed:
   (a) Mask-programmed ROM
   (b) OTP EPROM
   (c) EPROM.

9. The processor instruction HLT is classed as:
   (a) a control instruction
   (b) a data transfer instruction
   (c) a logical instruction.

10. The VME bus standard uses:
    (a) a single 32-way DIN 41612 connector
    (b) two 32-way DIN 41612 connectors
    (c) a 100-way PCB edge connector.

11. What type of memory uses the principle of charge storage:
    (a) bipolar static RAM
    (b) MOS static memory
    (c) MOS dynamic memory.

12. The memory cell shown in Figure 6.14 is:
    (a) an MOS static cell
    (b) a MOS dynamic cell
    (c) a bipolar static cell.
13. How many $16K \times 4$-bit DRAM devices will be required to provide 32K bytes of storage:

(a) 2  
(b) 4  
(c) 8.

14. A memory device has a pin marked CAS. The function of this pin is:

(a) chip active select  
(b) control address signal  
(c) column address select.

15. A semiconductor memory consists of 256 rows and 256 columns. The capacity of this memory will be:

(a) 256 bits  
(b) 512 bits  
(c) 64K bits.

16. In the assembly language instruction, MOV AX,07FEh the operation code is:

(a) MOV  
(b) AX  
(c) 07FE.

17. A bus arbitration system based on the physical location of cards is referred to as:

(a) serial arbitration  
(b) parallel arbitration  
(c) sequential arbitration.
The microprocessor central processing unit (CPU) forms the heart of any microprocessor or micro-computer system computer and, consequently, its operation is crucial to the entire system. The primary function of the microprocessor is that of fetching, decoding and executing instructions resident in memory. As such, it must be able to transfer data from external memory into its own internal registers and vice versa. Furthermore, it must operate predictably, distinguishing, for example, between an operation contained within an instruction and any accompanying addresses of read/write memory locations. In addition, various system housekeeping tasks need to be performed, including being able to suspend normal processing in order to respond to an external device that needs attention.

7.1 INTERNAL ARCHITECTURE

The main parts of a microprocessor CPU are:

1. registers for temporary storage of addresses and data;
2. an arithmetic logic unit (ALU) that is capable of performing arithmetic and logical operations;
3. a unit that receives and decodes instructions;
4. a means of controlling and timing operations within the system.

Figure 7.1 shows the principal internal features of a typical 8-bit microprocessor as well as the data paths that link them together. Because this diagram is a little complex, we will briefly explain each of these features and what they do.

7.1.1 Accumulator

The accumulator functions both as a source and as a destination register for many of the basic microprocessor operations. As a source register it contains the data that will be used in a particular operation, while as a destination register it will be used to hold the result of a particular operation. The accumulator (or A register) features in a very large number of microprocessor operations, consequently more reference is made to this register than any other.

7.1.2 Instruction register

The instruction register provides a temporary storage location in which the current microprocessor instruction is held while it is being decoded. Program instructions are passed into the microprocessor, one at a time, through the data bus.

On the first part of each machine cycle, the instruction is fetched and decoded. The instruction is executed on the second (and subsequent) machine cycles. Each machine cycle takes a finite time (usually less than a microsecond) depending upon the frequency of the microprocessor’s clock.
7.1.3 Data bus (D0 to D7)

The external data bus provides a highway for data that links all of the system components (such as RAM, ROM and I/O devices) together. In an 8-bit system, the data bus has eight data lines, labelled D0 (the least significant bit) to D7 (the most significant bit) and data are moved around in groups of eight bits, or bytes. With a 16-bit data bus the data lines are labelled D0 to D15, and so on.

7.1.4 Data bus buffer

The data bus buffer is a temporary register through which bytes of data pass on their way into and out of the microprocessor. The buffer is thus referred to as bidirectional, with data passing out of the microprocessor on a write operation and into the processor during a read operation. The direction of data transfer is determined by the control unit as it responds to each individual program instruction.

7.1.5 Internal data bus

The internal data bus is a high-speed data highway that links all of the microprocessor’s internal elements together. Data is constantly flowing backwards and forwards along the internal data bus lines.

7.1.6 General purpose registers

Many microprocessor operations (for example, adding two 8-bit numbers together) require the use of more than one register. There is also a requirement for temporarily storing the partial result of an operation while other operations take place. Both of these needs can be met by providing a number of general purpose registers. The use to which these registers are put is left mainly up to the programmer.
7.1.7 Stack pointer

When the time comes to suspend a particular task in order to briefly attend to something else, most microprocessors make use of a region of external random access memory (RAM) known as a stack. When the main program is interrupted, the microprocessor temporarily places in the stack the contents of its internal registers together with the address of the next instruction in the main program. When the interrupt has been attended to, the microprocessor recovers the data that has been stored temporarily in the stack, together with the address of the next instruction within the main program. It is thus able to return to the main program exactly where it left off and with all the data preserved in its registers. The stack pointer is simply a register containing the address of the last used stack location.

7.1.8 Instruction pointer

As mentioned in Chapter 6, computer programs consist of a sequence of instructions that are executed by the microprocessor. These instructions are stored in external RAM or ROM.

Instructions must be fetched and executed by the microprocessor in a strict sequence. By storing the address of the next instruction to be executed, the instruction pointer (or program counter) allows the microprocessor to keep track of where it is within the program. The program counter is automatically incremented when each instruction is executed.

7.1.9 Address bus buffer

The address bus buffer is a temporary register through which addresses (in this case comprising 16-bits) pass on their way out of the microprocessor. In a simple microprocessor, the address buffer is unidirectional with addresses placed on the address bus during both read and write operations. The address bus lines are labelled A0 to A15, where A0 is the least significant address bus line and A15 is the most significant address bus line. Note that a 16-bit address bus can be used to communicate with 65,536 individual memory locations. At each location a single byte of data is stored.

7.1.10 Control bus

The control bus is a collection of signal lines that are both used to control the transfer of data around the system and also to interact with external devices. The control signals used by microprocessors tend to differ with different types; however, the following are commonly found:

<table>
<thead>
<tr>
<th>Signal</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>READ</td>
<td>An output signal from the CPU that indicates that the current operation is a read operation.</td>
</tr>
<tr>
<td>WRITE</td>
<td>An output signal from the CPU that indicates that the current operation is a write operation.</td>
</tr>
<tr>
<td>RESET</td>
<td>A signal that resets the internal registers and initialises the instruction pointer program counter so that the program can be restarted from the beginning.</td>
</tr>
<tr>
<td>IRQ</td>
<td>An interrupt request from an external device attempting to gain the attention of the CPU (the request may either be obeyed or ignored according to the state of the microprocessor at the time that the interrupt request is received).</td>
</tr>
<tr>
<td>NMI</td>
<td>Non-maskable interrupt (i.e. an interrupt signal that cannot be ignored by the microprocessor).</td>
</tr>
</tbody>
</table>

7.1.11 Address bus (A0 to A15)

The address bus provides a highway for addresses that links with all of the system components (such as RAM, ROM and I/O devices). In a system with a 16-bit address bus, there are 16 address lines, labelled A0 (the least significant bit) to A15 (the most significant bit). In a system with a 32-bit address bus there are 32 address lines, labelled A0 to A31, and so on.

7.1.12 Instruction decoder

The instruction decoder is nothing more than an arrangement of logic gates that acts on the bits stored in the instruction register and determines which instruction is currently being referenced. The
instruction decoder provides output signals for the microprocessor’s control unit.

### 7.1.13 Control unit

The control unit is responsible for organising the orderly flow of data within the microprocessor as well as generating, and responding to, signals on the control bus. The control unit is also responsible for the timing of all data transfers. This process is synchronised using an internal or external clock signal (not shown in Figure 7.1).

### 7.1.14 Arithmetic logic unit (ALU)

As its name suggests, the ALU performs arithmetic and logic operations. The ALU has two inputs (in this case these are both 8 bits wide). One of these inputs is derived from the accumulator while the other is taken from the internal data bus via a temporary register (not shown in Figure 7.1). The operations provided by the ALU usually include addition, subtraction, logical AND, logical OR, logical exclusive-OR, shift left, shift right, etc. The result of most ALU operations appears in the accumulator.

### 7.1.15 Status register

The result of an ALU operation is sometimes important in determining what subsequent action takes place. The status register (flag register or condition code register) contains a number of individual bits that are set or reset according to the outcome of an ALU operation. These bits are referred to as flags. The following flags are some typical examples of those provided by most microprocessors:

<table>
<thead>
<tr>
<th>Flag</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>ZERO</td>
<td>The zero flag is set when the result of an ALU operation is zero.</td>
</tr>
<tr>
<td>CARRY</td>
<td>The carry flag is set whenever the result of an ALU operation (such as addition) generates a carry bit (in other words, when the result cannot be contained within an 8-bit register).</td>
</tr>
<tr>
<td>INTERRUPT</td>
<td>The interrupt flag indicates whether external interrupts are currently enabled or disabled.</td>
</tr>
</tbody>
</table>

### 7.1.16 Clocks

The clock used in a computer system is simply an accurate and stable square wave generator. In most cases the frequency of the square wave generator is determined by a quartz crystal. A simple 4 MHz square wave clock oscillator (together with the clock waveform that it produces) is shown in Figure 7.2. Note that one complete clock cycle is sometimes referred to as a T-state.

Microprocessor central processing units sometimes have an internal clock circuit, in which case the quartz crystal (or other resonant device) is connected directly to pins on the microprocessor chip. In Figure 7.3a an external clock is shown connected to a microprocessor, while in Figure 7.3b an internal clock oscillator is used.

![A typical microprocessor clock circuit](image)

**7.2** (a) A typical microprocessor clock circuit; (b) waveform produced by the clock circuit

---

**TEST YOUR UNDERSTANDING 7.1**

Figure 7.4 shows the simplified internal architecture of an 8-bit microprocessor CPU. Use this diagram to complete the missing information in Table 7.1.
7.3 (a) An external CPU clock; (b) an internal CPU clock

### Table 7.1 Function of the principal features in Figure 7.4

<table>
<thead>
<tr>
<th>Name</th>
<th>Function</th>
<th>Feature in Figure 7.4</th>
</tr>
</thead>
<tbody>
<tr>
<td>Accumulator</td>
<td>Internal register that holds the result of an operation</td>
<td>A</td>
</tr>
<tr>
<td></td>
<td>Device for performing arithmetic and logical operations</td>
<td>B</td>
</tr>
<tr>
<td>Control unit</td>
<td></td>
<td>F</td>
</tr>
<tr>
<td>Flag register</td>
<td>Internal register used to indicate the internal status of the processor</td>
<td></td>
</tr>
<tr>
<td>General-purpose registers</td>
<td>Internal registers used for the temporary storage of data during processing</td>
<td></td>
</tr>
<tr>
<td>Instruction decoder</td>
<td>Logic circuit arrangement that decodes the current instruction code</td>
<td></td>
</tr>
<tr>
<td></td>
<td>Register that indicates the address of the next instruction</td>
<td>H</td>
</tr>
<tr>
<td>Instruction register</td>
<td>Internal register that stores the current instruction code</td>
<td></td>
</tr>
</tbody>
</table>
7.2 MICROPROCESSOR OPERATION

The majority of operations performed by a microprocessor involve the movement of data. Indeed, the program code (a set of instructions stored in ROM or RAM) must itself be fetched from memory prior to execution. The microprocessor thus performs a
continuous sequence of instruction fetch and execute cycles. The act of fetching an instruction code (or operand or data value) from memory involves a read operation, while the act of moving data from the microprocessor to a memory location involves a write operation (see Figure 7.6).

Each cycle of CPU operation is known as a machine cycle. Program instructions may require several machine cycles (typically between two and five). The first machine cycle in any cycle consists of an instruction fetch (the instruction code is read from the memory) and is known as the M1 cycle. Subsequent cycles M2, M3 and so on, depend on the type of instruction that is being executed. This fetch–execute sequence is shown in Figure 7.7.

Microprocessors determine the source of data (when it is being read) and the destination of data (when it is being written) by placing a unique address on the address bus. The address at which the data is to be placed (during a write operation) or from which it is to be fetched (during a read operation) can either constitute part of the memory of the system (in which case it may be within ROM or RAM) or it can be considered to be associated with input/output.

Since the data bus is connected to a number of VLSI devices, an essential requirement of such chips (e.g. ROM or RAM) is that their data outputs should be capable of being isolated from the bus whenever necessary. These chips are fitted with select or enable inputs that are driven by address-decoding logic that ensures that external devices (ROM, RAM and I/O) never simultaneously attempt to place data on the bus.

The inputs of the address-decoding logic are derived from one or more of the address bus lines. The address decoder effectively divides the available memory into blocks corresponding to a particular function (ROM, RAM, I/O, etc.). Hence, where the processor is reading and writing to RAM, for example, the address-decoding logic will ensure that only the RAM is selected while the ROM and I/O remain isolated from the data bus.

Within the CPU, data is stored in several registers. Registers themselves can be thought of as a simple pigeon-hole arrangement that can store as many bits as there are holes available. Generally, these devices can store groups of 16 or 32 bits. Additionally, some registers may be configured as either one register of 32 bits or two registers of 16 bits.

Some microprocessor registers are accessible to the programmer, whereas others are used by the microprocessor itself. Registers may be classified as either general purpose or dedicated. In the latter case a particular function is associated with the register, such as holding the result of an operation or signalling the result of a comparison.

A basic 8-bit microprocessor (the Z80) and its register model is shown in Figure 7.8. Note that this microprocessor has six general-purpose registers and that these are 8 bits in length. The registers can also be used ‘end-on’ so that, for example, the BC register pair can be used to hold 16-bit data. Note also that the Z80’s instruction pointer is referred to as the program counter and the status register is called the flag register. Note that different manufacturers use different names for these registers but their function remains the same.

### 7.2.1 ALU operation

The ALU can perform arithmetic operations (addition and subtraction) and logic (complementation, logical AND, logical OR, etc.). The ALU operates on two inputs (8, 16, 32 or 64 bits in length, depending upon...
The ALU status is preserved in the flag register so that, for example, an overflow, zero or negative result can be detected and the necessary action can then be taken to deal with this eventuality. A typical example might be that of a program that needs to repeat an operation a set number of times until a zero result is obtained.

The control unit is responsible for the movement of data within the CPU and the management of control signals, both internal and external. The control unit asserts the requisite signals to read or write data as appropriate to the current instruction.

### TEST YOUR UNDERSTANDING 7.5

The execution of a microprocessor instruction involves an M1 cycle comprising four T-states and an M2 cycle requiring five T-states. If the CPU clock is running at 20 MHz, how long will it take for the microprocessor to execute the complete instruction?

### TEST YOUR UNDERSTANDING 7.6

With the aid of a timing diagram, explain the meaning of the term ‘fetch–execute cycle’.

### 7.3 INTEL X86 FAMILY

The original member of the x86 family was Intel’s first true 16-bit processor, which had 20 address lines that could directly address up to 1 MB of RAM. The chip was available in 5, 6, 8 and 10 MHz versions. The 8086 was designed with modular internal architecture. This approach to microprocessor design has allowed Intel to produce a similar microprocessor with identical internal architecture but employing an 8-bit external bus. This device, the 8088, shares the same 16-bit internal architecture as its 16-bit bus counterpart. Both devices were packaged in 40-pin DIL encapsulations. The CPU signal lines are described in Table 7.2.

The 8086/8088 can be divided internally into two functional blocks comprising an execution unit (EU) and a bus interface unit (BIU), as shown in Figure 7.9. The EU is responsible for decoding and executing instructions, while the BIU pre-fetches instructions from memory and places them in an instruction queue where they await decoding and execution by the EU.

The EU comprises a general- and special-purpose register block, temporary registers, arithmetic logic unit (ALU), a flag (status) register and control logic. It is important to note that the principal elements of the 8086 EU remain common to each of the subsequent members of the x86 family, but with additional registers with the more modern processors.
The BIU architecture varies according to the size of the external bus. The BIU comprises four segment registers and an instruction pointer, temporary storage for instructions held in the instruction queue, and bus control logic.

The register model and principal signals for the 8086 and x86 processors are shown in Figure 7.10.

Note that the main registers can be used as either 8-bit or 16-bit registers. The 16-bit accumulator (register AX), for example, can be used as two 8-bit registers (AH and AL). In this case, Intel use the ‘X’ as an abbreviation for ‘extended’, ‘H’ for ‘high’ (i.e. the high byte) and ‘L’ for ‘low’ (i.e. the low byte). Note also the use of segment registers for addressing.

These registers allow the x86 processors to address memory outside a 16-bit address space (without these registers the processor could only address a total of 64 Kbytes of memory and I/O). We will explain how this works in the next section.

### 7.3.1 Addressing

The 8086 has 20 address lines (see Table 7.2) and so provides for a physical 1 MB memory address range (memory address locations 00000 to FFFFFFF hex). The I/O address range is 64 Kb (I/O addresses 0000 to FFFF hex).

<table>
<thead>
<tr>
<th>Signal</th>
<th>Function</th>
<th>Notes</th>
</tr>
</thead>
<tbody>
<tr>
<td>AD0-AD7 (8088)</td>
<td>Address/data bus</td>
<td>Multiplexed 8-bit address/data lines</td>
</tr>
<tr>
<td>A8-A19 (8088)</td>
<td>Address bus</td>
<td>Non-multiplexed address lines</td>
</tr>
<tr>
<td>AD0-AD15 (8086)</td>
<td>Address/data bus</td>
<td>Multiplexed 16-bit address/data bus</td>
</tr>
<tr>
<td>A16-A19 (8086)</td>
<td>Address bus</td>
<td>Non-multiplexed address lines</td>
</tr>
<tr>
<td>S0–S7</td>
<td>Status lines</td>
<td>S0–S2 are only available in Maximum Mode and are connected to the 8288 bus controller. Note that status lines S3–S7 all share pins with other signals</td>
</tr>
<tr>
<td>INTR</td>
<td>Interrupt line</td>
<td>Level-triggered, active-high interrupt request input</td>
</tr>
<tr>
<td>NMI</td>
<td>Non-maskable interrupt line</td>
<td>Positive edge-triggered non-maskable interrupt input</td>
</tr>
<tr>
<td>RESET</td>
<td>Reset line</td>
<td>Active-high reset input</td>
</tr>
<tr>
<td>READY</td>
<td>Ready line</td>
<td>Active-high ready input</td>
</tr>
<tr>
<td>TEST</td>
<td>Test</td>
<td>Input used to provide synchronisation with external processors. When a WAIT instruction is encountered in the instruction stream, the CPU examines the state of the TEST line. If this line is found to be high, the processor waits in an ‘idle’ state until the signal goes low</td>
</tr>
<tr>
<td>QS0, QS1</td>
<td>Queue status lines</td>
<td>Outputs from the processor which may be used to keep track of the internal instruction queue</td>
</tr>
<tr>
<td>LOCK</td>
<td>Bus lock</td>
<td>Output from the processor which is taken low to indicate that the bus is not currently available to other potential bus masters</td>
</tr>
<tr>
<td>RQ/GT0-RQ/GT1</td>
<td>Request/Grant</td>
<td>Used for signalling bus requests and grants placed in the Cl register</td>
</tr>
</tbody>
</table>
The actual 20-bit physical memory address is formed by shifting the segment address four zero bits to the left (adding four LSBs), which effectively multiplies the segment register contents by 16. The contents of the instruction pointer (IP), stack pointer (SP) or other 16-bit memory reference is then added to the result. This process is illustrated in Figure 7.11.

As an example of the process of forming a physical address reference, Table 7.3 shows the state of the 8086 registers after the RESET signal is applied. The instruction referenced (i.e. the first instruction to be executed after the RESET signal is applied) will be found by combining the instruction pointer (offset address) with the code segment register (paragraph address). The location of the instruction referenced is FFFF0 (i.e. F0000 + FFF0). Note that the PC’s ROM physically occupies addresses F0000 to FFFFF and that, following a power-on or hardware reset, execution commences from address FFFF0 with a jump to the initial program loader.

### Table 7.3 Contents of the 8086 registers after a reset

<table>
<thead>
<tr>
<th>Register</th>
<th>Contents (hex)</th>
</tr>
</thead>
<tbody>
<tr>
<td>Flag</td>
<td>0002</td>
</tr>
<tr>
<td>Instruction pointer</td>
<td>FFF0</td>
</tr>
<tr>
<td>Code segment</td>
<td>F000</td>
</tr>
<tr>
<td>Data segment</td>
<td>0000</td>
</tr>
<tr>
<td>Extra segment</td>
<td>0000</td>
</tr>
<tr>
<td>Stack segment</td>
<td>0000</td>
</tr>
</tbody>
</table>

#### 7.3.2 80286, 80386 and 80486

The 80286 offers a total physical addressing of 16 MB, but the chip also incorporates memory management capabilities that can map up to a gigabyte of virtual...
The bit functions within the MSW are summarised in Table 7.4. The MSW is initialised with a value of FFF0H upon reset, the remainder of the 80286 registers being initialised as shown in Table 7.3. The 80286 is packaged in a 68-pin JEDEC type-A plastic leadless chip carrier (PLCC).

The 80386 (or '386) was designed as a full 32-bit device capable of manipulating data 32 bits at a time and communicating with the outside world through a 32-bit address bus. The 80386 offers a 'virtual 8086' mode of operation in which memory can be divided into 1 MB chunks with a different program allocated to each partition.

The 80386 was available in two basic versions. The 80386SX operates internally as a 32-bit device but presents itself to the outside world through only 16 data lines. This has made the CPU extremely popular for use in low-cost systems which could still boast the processing power of a 80386 (despite the obvious limitation imposed by the reduced number of data lines, the 'SX' version of the 80386 runs at approximately 80 per cent of the speed of its fully fledged counterpart). The 80386 comprises a bus interface unit (BIU), a code prefetch unit, an instruction decode unit (INU), and an external processor interface (EPI).

Table 7.4 Bit functions of the 80286 machine status word

<table>
<thead>
<tr>
<th>Bit</th>
<th>Name</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Protected mode (PM)</td>
<td>Enables protected mode and can only be cleared by asserting the RESET signal</td>
</tr>
<tr>
<td>1</td>
<td>Monitor processor (MP)</td>
<td>Allows WAIT instructions to cause a 'processor extension not present' exception (Exception 7)</td>
</tr>
<tr>
<td>2</td>
<td>Emulate processor (EP)</td>
<td>Causes a 'processor extension not present' exception (Exception 7) on ESC instructions to allow emulation of a processor extension</td>
</tr>
<tr>
<td>3</td>
<td>Task switched (TS)</td>
<td>Indicates that the next instruction using a processor extension will cause Exception 7 (allowing software to test whether the current processor extension context belongs to the current task)</td>
</tr>
</tbody>
</table>

7.10 The x86 CPU (showing some of its more important control signals and its register model)
unit, an execution unit (EU), a segmentation unit and a paging unit. The code prefetch unit performs the program 'lookahead' function. When the BIU is not performing bus cycles in the execution of an instruction, the code prefetch unit uses the BIU to fetch sequentially the instruction stream. The prefetched instructions are stored in a 16-byte 'code queue' where they await processing by the instruction decode unit. The prefetch queue is fed to the instruction decode unit which translates the instructions into microcode. These microcoded instructions are then stored in a three-deep instruction queue on a first-in first-out (FIFO) basis. This queue of instructions awaits acceptance by the EU. Immediate data and opcode offsets are also taken from the prefetch queue.

The 80486 processor was not merely an upgraded 80386 processor; its redesigned architecture offers significantly faster processing speeds when running at the same clock speed as its predecessor. Enhancements include a built-in maths coprocessor, internal cache memory and cache memory control. The internal cache is responsible for a significant increase in processing speed. As a result, a '486 operating at 25 MHz can achieve a faster processing speed than a '386 operating at 33 MHz.

The '486 uses a large number of additional signals associated with parity checking (PCHK) and cache operation (AHOLD, FLUSH, etc.). The cache comprises a set of four 2 Kb blocks (128 × 16 bytes) of high-speed internal memory. Each 16-byte line of memory has a matching 21-bit 'tag'. This tag comprises a 17-bit linear address together with four protection bits. The cache control block contains 128 sets of seven bits. Three of the bits are used to implement the 'least recently used' (LRU) system for replacement and the remaining four bits are used to indicate valid data.

### 7.3.3 Interrupt handling

Interrupt service routines are sub-programs stored away from the main body of code that are available for execution whenever the relevant interrupt occurs. However, since interrupts may occur at virtually any point in the execution of a main program, the response must be automatic; the processor must suspend its current task and save the return address so that the program can be resumed at the point at which it was left. Note that the programmer must assume responsibility for preserving the state of any registers which may have their contents altered during execution of the interrupt service routine and restoring them after the interrupt has been serviced.

The Intel processor family uses a table of 256 four-byte pointers stored in the bottom 1 Kb of memory (addresses 0000H to 03FFH). Each of the locations in the interrupt pointer table can be loaded with a pointer to a different interrupt service routine. Each pointer contains two bytes for loading into the
instruction pointer (IP). This allows the programmer to place his or her interrupt service routines in any appropriate place within the 1 MB physical address space.

### 7.4 THE INTEL PENTIUM FAMILY

Initially running at 60 MHz, the Pentium could achieve 100 million instructions per second. The original Pentium had (see Figure 7.12) an architecture based on 3.2 million transistors and a 32-bit address bus like the '486, but a 64-bit external data bus. The chip was capable of operation at twice the speed of its predecessor, the '486. The Pentium was eventually to become available in 60, 66, 75, 90, 100, 120, 133, 150, 166 and 200 MHz versions. The first ones fitted Socket 4 boards while the rest fitted Socket 7 boards. The Pentium was *super-scalar* and could execute two instructions per clock cycle. With two separate 8 Kb memory caches it was much faster than a '486 with the same clock speed.

The Pentium Pro incorporated a number of changes over the Pentium, which made the chip run faster for the same clock speeds. Three instead of two instructions can be decoded in each clock cycle and instruction decoding and execution are decoupled, meaning that instructions can still be executed if one pipeline stops. Instructions could also be executed out of strict order. The Pentium Pro had an 8 Kb level 1 cache for data and a separate cache for instructions. The chip was available with up to 1 MB of onboard L2 cache.
cache, which further increased data throughput. The architecture of the Pentium Pro was optimised for 32-bit code, but the chip would only run 16-bit code at the same speed as its predecessor.

Optimised for 32-bit applications, the Pentium II had 32 Kb of L1 cache (16 Kb each for data and instructions) and had a 512 Kb L2 cache on package. To discourage competitors from making direct replacement chips, this was the first Intel chip to make use of its patented ‘Slot 1’.

The Intel Celeron was a cut-down version of Pentium II, aimed primarily at the laptop computer market. The chip was slower as the L2 cache had been removed. Later versions were supplied with 128 Kb of L2 cache.

The Pentium III was released in February 1999 and first made available in a 450 MHz version supporting 100 MHz bus. The latest Pentium IV architecture is based on its new ‘NetBurst’ architecture that combines four technologies: Hyper Pipelined Technology; Rapid Execution Engine; Execution Trace Cache; and a 400 MHz system bus.

The Pentium IV processor is available at speeds ranging from 1.70 GHz to 2.80 GHz, with system bus speeds of 400 MHz and 533 MHz (the latter delivering a staggering 4.2 GB of data-per-second into and out of the processor). This performance is accomplished through a physical signalling scheme of quad-pumping the data transfers over a 133 MHz clocked system bus and a buffering scheme allowing for sustained 533 MHz data transfers.

7.5 AMD 29050

The AMD 29050 (and other 29K family members) have been extremely popular with avionics manufacturers over the past decade and many of these processors have been employed in critical applications. Despite its popularity in the aerospace sector, AMD discontinued the 29K series completely in 1995 due mainly to the development of the AMD K5 and K6 processors for mass-market applications. Further development of the high-end 29050 processor passed to Honeywell, who used the 29050 core as the basis of an application-specific integrated circuit (ASIC), which is currently used in its versatile integrated avionics (VIA) package. VIA provides a variety of integrated avionics functions, including data logging, data display and control of critical sub-systems.

Each section of VIA takes the form of a core processing module (CPM). Each CPM is based on a pair of processors (either AMD 29050 or HI-29KII in the later Honeywell ASIC version). The CPUs are set-up in a system known as voting. All outputs (address, data and control) are passed to a comparator; if each CPU sends out the same signals then the system continues. If the signals do not match then a fault condition is present and the system enters an error mode in which it discontinues processing, logs the error and then attempts to recover. The 29050 (and its Honeywell derivative) is currently found on the Boeing 717, 737-600/700/800, 777 and the Federal Express MD-80.

The instruction set of the 29K family was designed to closely match the internal representation of operations generated by optimising compilers. Instruction execution times are not burdened by redundant instruction formats and options found on other micro-processors.

The 29K family have a number of useful features that add to their attractiveness for powerful embedded applications such as those found in an aircraft. The 29K family is based on reduced instruction set computer (RISC) architecture. Essentially this means that relatively few instructions are used and that these instructions are kept extremely simple. These small, simple instructions are usually executed much faster than longer, more complex ones. Furthermore, since most computer programs involve executing simple instructions over and over again, by making these instructions very efficient it is possible to make significant improvements to the overall speed of execution. Note that RISC is not just to do with the number of instructions that are available, but rather it is to do with ensuring that the instructions that are used are very straightforward and execute in the quickest possible time.

Another important feature of the 29K family is the use of instruction pipelining. Each 29K processor has a four-stage pipeline consisting of first a fetch stage, followed by an instruction decode, then the execute and write-back stages. Instructions (with a few exceptions) execute in a single cycle. Processors in the 29K family also make use of other techniques usually associated with RISC, such as delayed branching to keep the processor fed with a continuous stream of instructions and to prevent the pipeline stalling.

The high-end members of the 29K family (including the 29050 used in critical avionic applications) use
a three-bus Harvard architecture (see Figure 7.13) rather than the simpler two-bus (plus control) structure used with simpler processors. The key feature of the three-bus architecture is the separation of instructions from the address bus. Instructions are fed to the processor by means of a separate instruction bus from either the instruction read/write memory or the instruction ROM. An additional bus bridge is usually incorporated in order to provide a means of supplying instruction information from the data bus (as shown in Figure 7.13).

**KEY POINT**

Modern integrated avionic systems demand processors that are both powerful and highly reliable. The core processor modules (CPM) of the Boeing 777 integrated avionics system (see Figure 7.14) use pairs of processors operating in a self-checking ‘Lockstep’ configuration. The Boeing 777 incorporates Honeywell’s airplane information management system (AIMS) which is based on CPMs fitted with pairs of AMD 29050 (AIMS-1) or HI-29KII (AIMS-2) processors. These systems work by continuously comparing all processor inputs and outputs (address, data, instructions). If a difference is detected, an error is flagged, all processing is halted (so that erroneous data is not propagated to other avionic systems) and the error is logged before a recovery is attempted.

**TEST YOUR UNDERSTANDING 7.7**

Briefly explain the meaning of the following terms: (a) segmented addressing; (b) instruction pipeline.

**TEST YOUR UNDERSTANDING 7.8**

Explain how the Boeing 777 AIMS uses two identical microprocessors to implement a critical avionics system.
TEST YOUR UNDERSTANDING 7.9

With the aid of a diagram, explain how a three-bus architecture can be used to improve processor performance.

7.6 MULTIPLE-CHOICE QUESTIONS

1. In the diagram of a CPU shown in Figure 7.15, the accumulator is the feature marked:

(a) A
(b) B
(c) C.
2. In the diagram of a CPU shown in Figure 7.15, which feature indicates the current status of the processor:
   (a) A  
   (b) B  
   (c) C.

3. In the diagram of a CPU shown in Figure 7.15, which feature performs logical operations:
   (a) A  
   (b) B  
   (c) C.

4. The stack is used for:
   (a) permanent storage of data  
   (b) temporary storage of data  
   (c) temporary storage of programs.

5. The stack is a structure located:
   (a) in the ALU  
   (b) in the general-purpose registers  
   (c) in external read/write memory.

6. A byte of data is to be inverted. This task is performed by:
   (a) the ALU  
   (b) the instruction register  
   (c) the instruction decoder.

7. Data can be transferred from one bus to another by means of:
   (a) a bus cycle  
   (b) a bus buffer  
   (c) a bus bridge.

8. The output of the instruction pointer appears on:
   (a) the address bus  
   (b) the data bus  
   (c) the control bus.

9. The output of the circuit shown in Figure 7.16 will be:
   (a) a square wave  
   (b) a sine wave  
   (c) a series of narrow pulses.

10. Which component in Figure 7.16 determines the frequency of the output:
    (a) A  
    (b) B  
    (c) C.

11. A typical application for the circuit shown in Figure 7.16 is:
    (a) a bus interface  
    (b) a clock generator  
    (c) a read/write memory.

12. The CPU data bus buffer is:
    (a) unidirectional  
    (b) bidirectional  
    (c) omnidirectional.

13. Another way to describe the CPU register that acts as an instruction pointer is:
    (a) the program counter  
    (b) the stack pointer  
    (c) the instruction register.

14. In which cycle is an instruction fetched and decoded:
    (a) M0  
    (b) M1  
    (c) M2.
15. If a microprocessor clock runs at 50 MHz, an instruction requiring 11 T-states will execute in a time of:

(a) 220 ns
(b) 440 ns
(c) 2.2 ms.

16. An external device can gain the attention of the CPU by generating a signal on the:

(a) R/W line
(b) RESET line
(c) IRQ line.

17. When executing the assembly language instruction MOV AX,07FEh, the operation code will be transferred to:

(a) the accumulator
(b) the instruction register
(c) the instruction pointer.

18. After executing the assembly language instruction MOV AX,07FEh, the binary data in the AL register will be:

(a) 11101111
(b) 00000111
(c) 11111110.

19. The advantage of pipelining is:

(a) easier programming
(b) faster execution times
(c) more reliable operation.

20. Figure 7.17 shows the architecture of a three-bus microprocessor system. The instruction ROM is the feature marked:

(a) A
(b) B
(c) C.

21. Figure 7.17 shows the architecture of a three-bus microprocessor system. The bus bridge is the feature marked:

(a) A
(b) B
(c) C.

22. Segmentation is used with x86 processors in order to:

(a) increase the speed of processing
(b) set up an instruction pipeline
(c) extend the addressing range.
Considerable cost savings can be made by manufacturing all of the components required for a particular circuit function on one small slice of semiconductor material (usually silicon). The resulting integrated circuit may contain as few as ten or more than 100,000 active devices (transistors and diodes). With the exception of a few specialised applications (such as amplification at high power levels), integrated circuits have largely rendered conventional circuits (i.e. those based on discrete components such as individually packaged resistors, diodes and transistors) obsolete.

Integrated circuits can be divided into two general classes, linear (analogue) and digital. Typical examples of linear integrated circuits are operational amplifiers, whereas typical examples of digital integrated circuits are the logic gates and microprocessors that you met in the earlier chapters.

It’s worth noting that a number of integrated circuit devices bridge the gap between the analogue and digital world. Such devices include analogue to digital converters (ADC), digital to analogue converters (DAC) and timers. Table 8.1 outlines the main types of integrated circuit.

<table>
<thead>
<tr>
<th>Table 8.1 Types of integrated circuits</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>Digital</strong></td>
</tr>
<tr>
<td>Logic gates</td>
</tr>
<tr>
<td>Microprocessors</td>
</tr>
<tr>
<td>Memory devices</td>
</tr>
<tr>
<td><strong>Analogue</strong></td>
</tr>
<tr>
<td>Operational amplifiers</td>
</tr>
<tr>
<td>Low-noise amplifiers</td>
</tr>
</tbody>
</table>
8.1 SCALE OF INTEGRATION

The relative size of a digital integrated circuit (in terms of the number of logic gates or equivalent devices it contains) is often referred to as its scale of integration. The terminology shown in Table 8.2 is commonly used to describe the scale of these circuits.

<table>
<thead>
<tr>
<th>Voltage regulators</th>
<th>Linear integrated circuits that are designed to maintain a constant output voltage in circumstances when the input voltage or the load current changes over a wide range</th>
</tr>
</thead>
<tbody>
<tr>
<td>Hybrid (combined digital and analogue)</td>
<td></td>
</tr>
<tr>
<td>Timers</td>
<td>Integrated circuits that are designed primarily for generating signals that have an accurately defined time interval such as that which could be used to provide a delay or determine the time between pulses. Timers generally comprise several operational amplifiers together with one or more bistable devices</td>
</tr>
<tr>
<td>Analogue to digital converters (ADC)</td>
<td>Integrated circuits that are used to convert a signal in analogue form to one in digital form. A typical application would be where temperature is sensed using a thermistor to generate an analogue signal. This signal is then converted to an equivalent digital signal using an ADC and then sent to a microprocessor for processing</td>
</tr>
<tr>
<td>Digital to analogue converters (DAC)</td>
<td>Integrated circuits that are used to convert a signal in digital form to one in analogue form. A typical application would be where the speed of a DC motor is to be controlled from the output of a microprocessor. The digital signal from the microprocessor is converted to an analogue signal by means of a DAC. The output of the DAC is then further amplified before applying it to the field winding of a DC motor</td>
</tr>
</tbody>
</table>

### 8.1 Key Point

VLSI integrated circuits contain many thousands of components fabricated on a small piece of silicon. Each of these ‘chips’ can replace very large numbers of conventional components. Typical examples of VLSI devices are microprocessors and memory devices.

### 8.2 FABRICATION TECHNOLOGY

Integrated circuits are fabricated on wafers of very pure silicon. The layers of semiconductor material are fabricated by means of a photographic process using ultraviolet light and a series of masks corresponding to the doping required for each semiconductor layer. The resolution of the photographic process ultimately determines the number of devices that can be integrated into a single chip (currently the processes used by leading manufacturers allow for a manufacturing resolution of 90 nm or less). Using this process, multiple integrated circuit devices are formed on a single wafer of up to 30 cm diameter (see Figure 8.1).
When the doping process is complete, the wafer is tested before being cut into small rectangular areas called dice. Non-functional die are marked and rejected while those that are functional move on to the next stage of the process, which involves mounting the die into a package using aluminium (or gold) wires which are welded to pads formed around the edge of the die. These tiny wires form the connection from the die to the connecting or soldering pins on the package in which the die is finally mounted and hermetically sealed. Testing accounts for a significant proportion of the production cost, and low yield on the more complex devices (VLSI and ULSI packages) can be problematic and, as a result, costs can be high.

### 8.3 Packaging and Pin Numbering

The earliest integrated circuits, in the 1960s, were packaged in ceramic flat packs. These were used in military and critical aerospace applications for several decades due to their small size and high reliability. Packaging of integrated circuits for domestic, consumer and industrial applications moved quickly to the popular dual in-line package (DIL or DIP). The first generation of DIL integrated circuits were supplied in ceramic packages, but lower-cost plastic packages quickly became popular for non-critical applications, such as the first generation of personal computers.

With the advent of powerful 16- and 32-bit microprocessors in the 1980s, pin counts of VLSI circuits exceeded the practical limit for DIP packaging (around 68 pins) and so the pin grid array (PGA) and leadless chip carrier (LCC) or plastic leadless chip carrier (PLCC) packages were introduced.

Surface-mounted packaging first appeared in the early 1980s and became widespread a decade or so later. Surface-mounted integrated circuits used connections that were more closely spaced, with their connections formed as either gull-wing or J-lead, as exemplified by the small-outline integrated circuit (SOIC).

PGA packages are still in common use but, in the late 1990s, PQFP and TSOP packages were introduced as a more space-efficient solution for integrated circuits.
8.3 An 8-bit CMOS microprocessor supplied in an 80-pin plastic quad flat package (PQFP)

8.4 An 81-pin integrated circuit mounted in a pin grid array (PGA) package

8.5 Pin connections and numbering for various integrated circuit packages (top view)

Table 8.3 Integrated circuit packages and pin numbering

<table>
<thead>
<tr>
<th>Abbreviation</th>
<th>Meaning</th>
<th>Figure</th>
</tr>
</thead>
<tbody>
<tr>
<td>BGA</td>
<td>Ball grid array</td>
<td>(e)</td>
</tr>
<tr>
<td>DIL</td>
<td>Dual in-line</td>
<td>(b)</td>
</tr>
<tr>
<td>DIP</td>
<td>Dual in-line package</td>
<td>(b)</td>
</tr>
<tr>
<td>PGA</td>
<td>Pin grid array</td>
<td>(e)</td>
</tr>
<tr>
<td>PLCC</td>
<td>Plastic leadless chip carrier</td>
<td>(d, f)</td>
</tr>
<tr>
<td>PQFP</td>
<td>Plastic quad flat package</td>
<td>(d, f)</td>
</tr>
<tr>
<td>QFP</td>
<td>Quad flat package</td>
<td>(d, f)</td>
</tr>
<tr>
<td>SDIP</td>
<td>Shrink dual in-line package</td>
<td>(b)</td>
</tr>
<tr>
<td>SIL</td>
<td>Single in-line</td>
<td>(a)</td>
</tr>
<tr>
<td>SIP</td>
<td>Single in-line package</td>
<td>(a)</td>
</tr>
<tr>
<td>SO</td>
<td>Small outline</td>
<td>(b)</td>
</tr>
<tr>
<td>SOIC</td>
<td>Small outline integrated circuit</td>
<td>(b)</td>
</tr>
<tr>
<td>SOJ</td>
<td>Small outline J-lead</td>
<td>(b)</td>
</tr>
<tr>
<td>SOP</td>
<td>Small outline package</td>
<td>(b)</td>
</tr>
<tr>
<td>SSOP</td>
<td>Shrink small outline package</td>
<td>(b)</td>
</tr>
<tr>
<td>TSOP</td>
<td>Thin small outline package</td>
<td>(b)</td>
</tr>
<tr>
<td>ZIP</td>
<td>Zig-zag in-line package</td>
<td>(c)</td>
</tr>
</tbody>
</table>
circuits with a high pin count (several hundred pins, or more).

Table 8.3 summarises the various types of integrated circuit package; Figure 8.5 shows the corresponding pin numbering schemes. These are shown looking from the top of the device.

It is important to note that manufacturers often provide differently packaged versions of the same integrated circuit device. The different variants are usually distinguished by additional letters and/or numbers in the device coding. Figure 8.6 shows an example of two different styles of packaging used for a small MSI device.

### TEST YOUR UNDERSTANDING 8.1

What do each of the following abbreviations stand for?

1. SSI  
2. DIL  
3. QFP  
4. SOIC.

### TEST YOUR UNDERSTANDING 8.2

Explain what is meant by a hybrid integrated circuit and give two examples of such devices.

### 8.4 MULTIPLE-CHOICE QUESTIONS

1. A standard logic gate manufactured in 1981 is likely to be supplied in a:
   
   (a) DIL package  
   (b) PGA package  
   (c) QFP package.

2. A standard logic gate is a typical example of:
   
   (a) an SSI device  
   (b) an LSI device  
   (c) a VLSI device.

3. Which one of the following scales of integration is the largest:
   
   (a) SSI  
   (b) LSI  
   (c) MSI.

4. A microprocessor is an example of:
   
   (a) SSI technology  
   (b) MSI technology  
   (c) VLSI technology.

5. When compared with DIP packaging, PLCC offers:
   
   (a) more pins  
   (b) larger size  
   (c) greater reliability.

6. Which one of the following integrated circuit packaging technologies requires that the chip should always be soldered in place:
   
   (a) DIL  
   (b) SOIC  
   (c) PGA.

7. Which of the following integrated circuit packaging technologies was the earliest to be used:
   
   (a) ceramic DIP  
   (b) ceramic QFP  
   (c) PLCC.
8. The connections from the pads on an integrated circuit die are:
   (a) soldered to the internal wire links
   (b) crimped to the internal wire links
   (c) welded to the internal wire links.

9. An integrated circuit bus transceiver contains 64 logic gates and buffers. This chip is an example of:
   (a) SSI
   (b) MSI
   (c) LSI.

10. The integrated circuit packages shown in Figure 8.7 are:
    (a) DIL
    (b) PGA
    (c) PLCC.

11. The integrated circuit package shown in Figure 8.8 is:
    (a) DIL
    (b) QFP
    (c) PLCC.

12. The number of the integrated circuit pin circled in Figure 8.9 is:
    (a) 1
    (b) 7
    (c) 8.

13. Production tests are performed on an integrated circuit wafer:
    (a) before cutting it into individual chips
    (b) after cutting it into individual chips
    (c) only when the chips are finally mounted.
14. The programmed logic device shown in Figure 8.10 is an example of:

(a) SSI technology
(b) MSI technology
(c) LSI technology.

15. Each individual integrated circuit produced from a wafer is known as a:

(a) blank
(b) die
(c) gate.

8.10 See Question 14
Medium-scale integration (MSI) logic circuits are frequently used in avionic systems to satisfy the need for more complex logic functions such as those required for address decoding, code conversion, keyboard encoding/decoding and the switching of logic signals between different bus connections. Some typical MSI applications include:

- address decoders
- priority encoders
- multiplexers and data selectors
- BCD to binary code converters
- BCD to seven-segment code converters.

We shall begin this section by introducing two important concepts relating to the interconnection of large numbers of logic gates.

### 9.1 FAN-IN AND FAN-OUT

When large numbers of logic gates are connected together, the output of one logic gate may be connected to inputs on several other gates. In a practical logic circuit, the loading effect of these inputs needs to be taken into account.

Fan-out is defined as the maximum number of standard logic inputs (of the same logic family) that a logic gate can supply without risk of the logic levels falling out of specification. Most standard TTL logic gates have a fan-out of 10. This means they can drive up to ten standard TTL inputs. Any more than this may result in unreliable operation because the gate is unable to source sufficient current when the output is in the ‘high’ state and sink sufficient current when the output is in the ‘low’ state. Either of these conditions is likely to compromise the logic levels required for successful operation.

Fan-in is a measure of the loading effect (expressed as the number of equivalent logic inputs of the same logic family) imposed by each of a gate’s inputs. Thus, a standard logic gate input has a fan-in of 1.

Figure 9.1 shows an example of how the fan-in of a simple logic circuit is determined. Assuming that all of the logic gates in the circuit are standard devices (i.e. each of their inputs represents unity fan-in), then external input A has a fan-in of 1 (it only drives one input, G1) while external input B has a fan-in of 2 (it drives two standard inputs, one on G3 and one on G4). Figure 9.2 shows an example of how fan-out is determined in a simple logic circuit. Assuming that all of the logic gates in the system are standard logic devices, G1 must have a minimum fan-out of 6 because it needs to drive inputs on six gates: G2, G3, G4, G5, G6 and G7.

9.1 An example of determining the fan-in for a simple logic system. If all gates are standard logic devices then input A has a fan-in of 1 and input B has a fan in of 2.
9.2 CODING SYSTEMS

As we saw in Chapter 1, a variety of different coding schemes are used to represent numerical data in avionic systems. They include binary (or, more correctly, natural binary), binary coded decimal (BCD), Gray code, octal (base 8) and hexadecimal (base 16), as shown in Figure 9.3.

BCD uses four digits to represent each numerical character. Thus, decimal 11 is represented by 0001 0001 (or just 10001, omitting the three leading zeros). Gray code is an important code because only one digit changes at a time. This property assists with error correction. Notice also how the least significant three bits of each Gray-coded number become reflected after a decimal count of seven. Because of this, Gray code is often referred to as a reflected code.

![Diagram of logic system]

9.2 An example of determining the fan-out in a simple logic system. If all gates are standard logic devices, G1 must have a minimum fan-out of six because it drives inputs on G2, G3, G4, G5, G6 and G7.

9.2 CODING SYSTEMS

As we saw in Chapter 1, a variety of different coding schemes are used to represent numerical data in

<table>
<thead>
<tr>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0000</td>
<td>0000 0000</td>
<td>0000</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>0001</td>
<td>0000 0001</td>
<td>0001</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>2</td>
<td>0010</td>
<td>0000 0010</td>
<td>0011</td>
<td>2</td>
<td>2</td>
</tr>
<tr>
<td>3</td>
<td>0011</td>
<td>0000 0011</td>
<td>0010</td>
<td>3</td>
<td>3</td>
</tr>
<tr>
<td>4</td>
<td>0100</td>
<td>0000 0100</td>
<td>0110</td>
<td>4</td>
<td>4</td>
</tr>
<tr>
<td>5</td>
<td>0101</td>
<td>0000 0101</td>
<td>0111</td>
<td>5</td>
<td>5</td>
</tr>
<tr>
<td>6</td>
<td>0110</td>
<td>0000 0110</td>
<td>0101</td>
<td>6</td>
<td>6</td>
</tr>
<tr>
<td>7</td>
<td>0111</td>
<td>0000 0111</td>
<td>0100</td>
<td>7</td>
<td>7</td>
</tr>
<tr>
<td>8</td>
<td>1000</td>
<td>0000 1000</td>
<td>1100</td>
<td>10</td>
<td>8</td>
</tr>
<tr>
<td>9</td>
<td>1001</td>
<td>0000 1001</td>
<td>1101</td>
<td>11</td>
<td>9</td>
</tr>
<tr>
<td>10</td>
<td>1010</td>
<td>0001 0000</td>
<td>1111</td>
<td>12</td>
<td>A</td>
</tr>
<tr>
<td>11</td>
<td>1011</td>
<td>0001 0001</td>
<td>1110</td>
<td>13</td>
<td>B</td>
</tr>
<tr>
<td>12</td>
<td>1100</td>
<td>0001 0010</td>
<td>1010</td>
<td>14</td>
<td>C</td>
</tr>
<tr>
<td>13</td>
<td>1101</td>
<td>0001 0011</td>
<td>1011</td>
<td>15</td>
<td>D</td>
</tr>
<tr>
<td>14</td>
<td>1110</td>
<td>0001 0100</td>
<td>1001</td>
<td>16</td>
<td>E</td>
</tr>
<tr>
<td>15</td>
<td>1111</td>
<td>0001 0101</td>
<td>1000</td>
<td>17</td>
<td>F</td>
</tr>
</tbody>
</table>

9.3 Summary of several common coding schemes for numerical data

TEST YOUR UNDERSTANDING 9.1

Figure 9.4 shows simple logic arrangements that will perform natural binary to Gray code conversion and vice versa. Construct a truth table for each arrangement and use them to verify the operation of each circuit.
9.4 Natural binary to Gray code conversion

### Data line

<table>
<thead>
<tr>
<th>Altitude (feet)</th>
<th>D4</th>
<th>A1</th>
<th>A2</th>
<th>A4</th>
<th>B1</th>
<th>B2</th>
<th>B4</th>
<th>C1</th>
<th>C2</th>
<th>C4</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>100</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>200</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>300</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>400</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>500</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>600</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>700</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>800</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>900</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>1000</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>1100</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>30500</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>30600</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>30700</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>30800</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>30900</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>31000</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>31100</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
</tr>
</tbody>
</table>

9.5 Gillham code
9.2.1 Gillham code

Early altitude encoders were mechanical devices integrated into the barometric altimeter. The electrical output was a 10-bit parallel bus, although more modern implementations use an expanded 11-bit bus. To ensure that only one bit of the bus changes on each transition (so that no transient false values are generated as the output changes between successive values) the altitude is represented in a form of Gray code, not a natural binary code. The interface required to perform this operation is commonly referred to as a Gillham interface and, as a result, the altitude code that it produces (which operates in increments of 100 feet) is often referred to as Gillham code (see Figure 9.5).

KEY POINT

Unfortunately, there has been at least one case when the failure of a single data line in a Gillham interface has generated erroneous altitude data which has caused an aircraft’s traffic alert collision avoidance system (TCAS) to guide an aircraft into a near-miss situation. Hence there is now a requirement to test and verify the operation of Gillham-based systems and, as a result, the use of Gillham code interfaces has actively been discouraged in favour of more modern digital systems.

9.3 DECODERS

Decoders are used to convert information from one number system to another, such as binary to octal or binary to decimal. A simple two to four line decoder is shown in Figure 9.6. In this arrangement there are two inputs, A and B, and four outputs, Y₀, Y₁, Y₂, and Y₃.

The binary code appearing on A and B is decoded into one of the four possible states and corresponding output appears on the four output lines, with Y₀ being the most significant. Because two to four and three to eight line decoders are frequently used as address decoders in computer systems (where memory and I/O devices are enabled by a low rather than a high state), the outputs are active-low, as indicated by the circles on the logic diagrams.

A basic two to four line decoder is shown in Figure 9.7. This arrangement uses two inverters and three two-input NAND gates. All four outputs are active-low; Y₀ will go low when A and B are both at logic 0, Y₁ will go low when A is at logic 0 and B is at logic 1, Y₂ will go low when A is at logic 1 and B is at logic 0, and Y₃ will go low when both A and B are at logic 1.

An improved version of the basic two to four line decoder is shown in Figure 9.8. The extra inverting

9.6 Two to four line decoders and their corresponding truth tables. The arrangement shown in (b) has a separate active-low enable input (when this input is high all of the outputs remain in the high state regardless of the A and B inputs)
gates are added at the inputs in order to reduce the fan-in to unity. On more complex arrangements (such as three to eight and four to sixteen decoders) these extra gates also help to avoid the situation where the inputs may present wildly differing loads.

A typical dual two to four line MSI decoder chip, the 74LS139, is shown in Figure 9.9. The chip is implemented using low-power Schottky TTL technology. The device is supplied in a 16-pin DIP package (as shown in Figure 9.11), but is also available in ceramic and SOIC packaged versions (see page 107). The decoder is frequently used in logic circuits and address decoders.

A three to eight line decoder is shown in Figure 9.10. Note that, as with the two to four line decoder shown in Figure 9.6b, this arrangement has a separate active-low enable (EN) input. When this input is taken high, all eight of the decoder’s outputs will go high. Only when the enable input is taken low will one (and only one) of the decoder’s outputs go low. A typical example of a three to eight line decoder is the 74LS138. Like the 74LS139, this is a low-power Schottky device commonly used for address decoding.

<table>
<thead>
<tr>
<th>C</th>
<th>B</th>
<th>A</th>
<th>EN</th>
<th>Y7</th>
<th>Y6</th>
<th>Y5</th>
<th>Y4</th>
<th>Y3</th>
<th>Y2</th>
<th>Y1</th>
<th>Y0</th>
</tr>
</thead>
<tbody>
<tr>
<td>X</td>
<td>X</td>
<td>X</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
</tbody>
</table>

X = don't care
ENCODERS

Encoders provide the reverse function to that of a decoder. In other words, they accept a number of inputs and then generate a binary code corresponding to the state of those inputs. Typical applications for encoders include generating a binary code corresponding to the state of a keyboard/keypad or generating BCD from a decade (ten-position) rotary switch.

A particularly useful form of encoder is one that can determine the priority of its inputs. This device is known as a priority encoder and its inputs are arranged in priority order, from lowest to highest priority. If more than one input becomes active, the input with the highest priority will be encoded and its binary coded value will appear on the outputs. The state of the other (lower priority) inputs will be ignored.

Figure 9.12 shows an eight to three line priority encoder together with its corresponding truth table. Note that this device has active-low inputs as well as active-low outputs. A practical realisation of this type of device, the 74LS148, is shown in Figure 9.13. Additional inputs and outputs (enable input (EI) and enable output (EO)) are provided in order to permit cascading of several devices of the same type. For example, a simple decimal keypad would require two such devices, with the EO of the first device connected to the EI of the second device.
9.13 Pin connections for the 74LS148 eight to three line encoder (note that there is no need for a 0 input)

9.14 An octal to binary encoder

**TEST YOUR UNDERSTANDING 9.2**

*Figure 9.14* shows the circuit of an octal to binary encoder. Verify the operation of this circuit by constructing its truth table.

**TEST YOUR UNDERSTANDING 9.3**

Redesign the octal to binary encoder shown in *Figure 9.14* by adding inverters so that each of the input lines presents a fan-in of 1.

9.15 Switch equivalent circuits for some common types of multiplexer or data selector
9.5 MULTIPLEXERS

Like encoders, multiplexers have several inputs. However, unlike encoders, they have only one output. Multiplexers provide a means of selecting data from one of several sources. Because of this, they are often referred to as data selectors.

Switch-equivalent circuits of some common types of multiplexer are shown in Figure 9.15. The single two-way multiplexer in Figure 9.15a is equivalent to a simple SPDT (changeover) switch. The dual two-way multiplexer shown in Figure 9.15b performs the same function, but two independent circuits are controlled from the same select signal. A single four-way multiplexer is shown in Figure 9.15c. Note that two digital select inputs are required, A and B, in order to place the switch in its four different states.

Block schematic symbols, truth tables and simplified logic circuits for two to one and four to one multiplexers are shown in Figures 9.16 to 9.19.

9.16 A basic two to one multiplexer arrangement with its corresponding truth table

9.17 Logic circuit arrangement for the basic two to one multiplexer

9.18 A four to one multiplexer. The logic state of the A and B inputs determines which of the four logic inputs (X₀ to X₃) appears at the output

9.19 Logic gate arrangement for the four to one multiplexer

TEST YOUR UNDERSTANDING 9.4

Verify the operation of the two to one multiplexer circuit shown in Figure 9.17 by constructing its truth table.
The practical realisation of eight to one and sixteen to one multiplexers, the 74LS151 and 74LS150, respectively, are shown in Figures 9.20 and 9.22. These MSI devices are both implemented using low-power Schottky TTL technology and are supplied in either plastic DIP, ceramic or SOIC packages (see page 108).

**TEST YOUR UNDERSTANDING 9.5**
Verify the operation of the four to one multiplexer circuit shown in Figure 9.19 by constructing its truth table.

**TEST YOUR UNDERSTANDING 9.6**
Design a logic circuit arrangement that will function as an eight to one multiplexer. Confirm the operation of the circuit by constructing its truth table.

**TEST YOUR UNDERSTANDING 9.7**
Modify your answer to Test your understanding 9.6 so that each input has a fan-in of unity.

9.20 Pin connections for the 74LS151 eight-input multiplexer (data selector)

9.21 Four-channel altimeter data selector based on a dual four channel multiplexer
A typical example of the use of multiplexers and decoders is shown in the simplified block schematic of the altimeter data selector shown in Figure 9.21. This arrangement uses a dual four-channel multiplexer to select corresponding clock and data streams from the four ARINC 429 bus receivers.

9.6 MULTIPLE-CHOICE QUESTIONS

1. A standard TTL logic gate has a fan-out of:
   (a) 1
   (b) 5
   (c) 10.

2. The equivalent number of standard input loads (of the same logic family) imposed by the input of a logic circuit is known as:
   (a) fan-in
   (b) fan-out
   (c) fan-load.

3. A simple logic circuit is shown in Figure 9.23. What is the minimum fan-out for G6:
   (a) 1
   (b) 5
   (c) 6.

4. Another name for a multiplexer is:
   (a) a data selector
   (b) a bus transceiver
   (c) a shift register.

5. A four to one multiplexer has:
   (a) one select input
   (b) two select inputs
   (c) four select inputs.

6. Which is the select input in the two-way multiplexer shown in Figure 9.24:
   (a) A
   (b) B
   (c) C.
7. The integrated circuit device shown in Figure 9.25 is:
   (a) a dual two to four line decoder
   (b) a dual four to two line multiplexer
   (c) a dual four way data selector.

8. Additional enable inputs and outputs are provided in some encoders in order to permit:
   (a) inverting
   (b) cascading
   (c) error detection.
Optical fibres have been widely used as a transmission medium for ground-based long-haul data communications and in local area networks (LANs) for many years; they are now being introduced into the latest passenger aircraft to satisfy the need for wideband networked avionic and cabin entertainment systems.

By virtue of their light weight, compact size and exceptionally wide bandwidth, optical fibres are ideally suited for use as a replacement for conventional copper network cabling. The technology is, however, relatively new in the civil aircraft industry and brings with it a whole new set of problems and challenges for those involved with aircraft operation and maintenance.

10.1 ADVANTAGES AND DISADVANTAGES

Optical fibres offer some very significant advantages over conventional copper cables. These include:

- optical fibres are lightweight and of small physical size;
- exceptionally wide bandwidth and very high data rates can be supported;
- relative freedom from electromagnetic interference;
- significantly reduced noise and cross-talk compared with conventional copper cables;
- relatively low values of attenuation within the medium;
- high reliability coupled with long operational life;
- electrical isolation and freedom from earth/ground loops.

The reduction in weight that results from the use of fibre optical cabling can yield significant fuel savings. Copper cabling is typically five times heavier than polymer optical fibre cabling and 15 times heavier than silica optical fibre. On a large, latest-generation aircraft with sophisticated avionics, the total saving in weight can be as much as 1,300 kg.

There are very few disadvantages of optical fibres. They include:

- industry resistance to the introduction of new technology;
- need for a high degree of precision when fitting cables and connectors;
- concerns about the mechanical strength of fibres and the need to ensure that cable bends have a sufficiently large radius to minimise losses and the possibility of damage to fibres.

10.2 PROPAGATION IN OPTICAL FIBRES

Essentially, an optical fibre consists of a cylindrical silica glass core surrounded by further glass cladding. The fibre acts as a channel (or waveguide) along which an electromagnetic wave can pass with very little loss.

Fibre-optics are governed by the fundamental laws of reflection and refraction. For example, when a light wave passes from a medium of higher refractive index to one of lower refractive index, the wave is
bent towards the normal, as shown in Figure 10.1a. Conversely, when travelling from a medium of lower refractive index to one of higher refractive index, the wave will be bent away from the normal, as shown in Figure 10.1b. In this latter case, some of the incident light will be reflected at the boundary of the two media and, as the angle of incidence is increased, the angle of refraction will also be increased until, at a critical value, the light wave will be totally reflected (i.e. the refracted ray will no longer exist, as shown in Figure 10.2). The angle of incidence at which this occurs is known as the critical angle, \( \theta_c \). The value of \( \theta_c \) depends on the absolute refractive indices of the media and is given by:

\[
\theta_c = \sqrt{\frac{2(n_1 - n_2)}{n_1}}
\]

where \( n_1 \) and \( n_2 \) are the refractive indices of the more dense and less dense media, respectively.

Optical fibres are manufactured by drawing silica glass from the molten state and they are thus of cylindrical construction. The more dense medium (the core) is surrounded by the less dense medium (the cladding). Provided the angle of incidence of the input wave is larger than the critical angle, the light wave will propagate inside the core by means of a series of total internal reflections. Any other light waves that are incident on the upper boundary at an angle \( \theta > \theta_c \) will also propagate along the inner medium. Conversely, any light wave that is incident upon the upper boundary with \( \theta < \theta_c \) will pass into the outer medium and there be lost by scattering and/or absorption.
10.2.1 Launching

Having briefly considered propagation within the fibre, we shall turn our attention to the mechanism by which waves are launched into the fibre. The cone of acceptance (see Figure 10.3) is the complete set of angles which will be subject to total internal reflection. Rays entering from the edges will take a longer path through the fibre but will travel faster because of the lower refractive index of the outer layer. The numerical aperture determines the bandwidth of the fibre and is given by:

\[ A = \sin \theta_a \]

Clearly, when a number of light waves enter the system with differing angles of incidence, a number of waves (or modes) are able to propagate. This multimode propagation is relatively simple to achieve but has the attendant disadvantage that, since the light waves will take different times to pass through the fibre, the variation of transit time will result in dispersion, which imposes an obvious restriction on the maximum bit-rate the system will support.

There are two methods for reducing multimode propagation. One uses a fibre of graded refractive index, while the other uses a special single mode (or monomode) fibre. The inner core of this type of fibre is reduced in diameter so it has the same order of magnitude as the wavelength of the incident wave. This ensures that only one mode will successfully propagate.

10.2.2 Attenuation

The loss within an optical fibre arises from a number of causes, including: absorption, scattering in the core (due to non-homogeneity of the refractive index), scattering at the core/cladding boundary, and losses due to radiation at bends in the fibre. Note that the attenuation coefficient of an optical fibre (see Figure 10.4) refers only to losses in the fibre itself and neglects coupling and bending losses (which can be significant). In general, the attenuation of a good-quality fibre can be expected to be less than 2 dB per kilometre at a wavelength of 1.3 µm (infrared). Hence a 50 m length of fibre can be expected to exhibit a loss of around 0.1 dB.

Whereas the attenuation coefficient of an optical fibre is largely dependent upon the quality and consistency of the glass used for the core and cladding, the attenuation of all optical fibres varies widely with wavelength. The typical attenuation/wavelength characteristic for a monomode fibre is shown in Figure 10.4. It should be noted that the sharp peak at about 1.39 µm arises from excess absorption within the monomode fibre.

Monomode fibres are now a common feature of ground-based high-speed data communication systems and manufacturing techniques have been developed that ensure consistent and reliable products with low attenuation and wide operational bandwidths. However, since monomode fibres are significantly smaller in diameter than their multimode predecessors (see Figure 10.5), a consistent and reliable means of cutting, surface preparation, alignment and interconnection is essential, and for this reason slower multimode fibres are still prevalent in current aircraft designs.
A simple one-way (simplex) fibre-optic data link is shown in Figure 10.6. The optical transmitter consists of an infrared light emitting diode (LED) or low-power semiconductor laser diode coupled directly to the optical fibre. The diode is supplied with pulses of current from a bus interface. These pulses of current produce equivalent pulses of light that travel along the fibre until they reach the optical receiver unit. The optical receiver unit consists of a photodiode or phototransistor that passes a relatively large current when illuminated and negligible current when not. The pulses of current at the transmitting end are thus replicated at the receiving end.

The maximum data rate (and consequently the bandwidth) of the optical data link depends on the ability of the system shown in Figure 10.6 to faithfully reproduce a train of narrow digital pulses. Unfortunately, in a multimode fibre different modes...
travel at different velocities, as shown earlier in Figure 10.2d. This phenomenon is known as dispersion and it has the effect of stretching the output pulse, as shown in Figure 10.7b.

When digital data is supplied to the optical transmitter, the stretching of pulses imposes an upper limit on the rate at which the pulses can be transmitted. In other words, the data rate is determined by the amount of dispersion simply because a longer bit interval means fewer bits can be transmitted in the same unit of time (see Figure 10.8).

10.4 PRACTICAL OPTICAL NETWORKS

The Boeing 777 was the first commercial aircraft to enter production with an optical fibre-based LAN for onboard data communications. The system was originally developed in the 1980s and it comprised an avionics local area network (AVLAN) fitted in the flight deck and electrical equipment bay, together with a cabin local area network (CABLAN) fitted in the roof of the passenger cabin. These two fibre-optic networks conform to the ARINC 636 standard, which was adapted for avionics from the fibre distributed interface (FDDI) in order to provide a network capable of supporting data rates of up to 100 Mbps.

10.4.1 Fibre-optic cable construction

The construction of a typical fibre-optic cable is shown in Figure 10.9. This comprises:

- five optical fibres and two filler strands;
- separator tape;
- aramid yarn strength member;
- an outer jacket.

10.9 A typical fibre-optic cable
The cable has an overall diameter of about 0.2 inches and the individual optical fibre strands have a diameter of 140 µm (approximately 0.0055 inches). A protective buffer covers each fibre and protects it during manufacture, and increases mechanical strength and diameter in order to make handling and assembly easier. The buffers are coded in order to identify the fibres using colours (blue, red, green, yellow and white). The filler strands are made from polyester and are approximately 0.035 inches in diameter. A polyester separator tape covers the group of five fibres and two filler strands. This tape is manufactured from low-friction polyester and it serves to make the cable more flexible.

A layer of woven aramid (or Kevlar) yarn provides added mechanical strength and protection for the cable assembly. The outer thermoplastic jacket (usually purple in colour) is fitted to prevent moisture ingress and also to provide insulation.

10.4.2 Fibre-optic connectors

The essential requirements for connectors used with optical fibres are that they should be:

- reliable
- robust
- precise and repeatable (even after numerous mating operations)
- suitable for installation without specialist tooling
- low loss
- low cost.

While the loss exhibited by a connector may be quoted in absolute terms, it is often specified in terms of an equivalent length of optical fibre. If, for example, six connectors are used on a cable run and each connector has a loss of 0.5 dB, the total connector loss will be 3 dB. This is equivalent to several kilometres of low-loss fibre!

A typical fibre-optic cable connector arrangement is shown in Figure 10.10. This comprises:

- alignment keys and grooves
- guide pins and cavities
- coloured alignment bands
- three start threads.

Each connector has alignment keys on the plug and matching alignment grooves on the receptacle. These are used to accurately align the connector optical components; the guide pins in the plug fit into cavities in the receptacle when the plug and receptacle connect. In order to ensure that the connector is not over-tightened (which may cause damage to the fibres) the pins of the plug are designed to provide a buffer stop against the bottom of the cavities in the receptacle.

The plug and receptacle have ceramic contacts that are designed to make physical contact when properly connected (the light signal passes through the holes in the end of the ceramic contacts when they are in direct physical contact with each other).

The coupling nut on the plug barrel has a yellow band, while the receptacle barrel has a red and a yellow band. A correct connection is made when the red band on the receptacle is at least 50 per cent covered by the coupling nut. This position indicates an effective connection in which the optical fibres in the plug are aligned end-to-end with the fibre in the receptacle.

Three start threads on the plug and receptacle ensure a straight start when they join. The recessed
receptacle components prevent damage from the plug if it strikes the receptacle at an angle. The plug and receptacle are automatically sealed in order to prevent the ingress of moisture and dust.

**KEY POINT**

Care must be taken when assembling optical fibre connectors, both in terms of the correct alignment of the plugs and receptacles and cleanliness of the contact area (this is essential to ensure low loss and efficient coupling). Before attempting to examine the face or ceramic contacts of a connector arrangement it is essential to disconnect the cable from the equipment at both ends. The light from the optical fibre is invisible and can be intense enough to cause permanent damage to the eyes.

### 10.5 OPTICAL NETWORK COMPONENTS

Several other components are found in optical fibre networks. These include couplers (with three or four ports), switches (using mirrors to deflect beams into different fibre strands) and routers. These last named devices are designed to control the routing of signals through the LAN and they comprise switches, processors, controllers and one or more bus interfaces.

The router processor sends control signals to the bypass switch unit (BSU). Typical BSU control signals are:

- PRI HI
- PRI RTN
- SEC HI
- SEC RTN.

A logic high on PRI HI or SEC HI connects the BSU to the fibre-optic ring. A logic low on PRI HI or SEC HI disconnects the BSU from the fibre optic ring. The PRI RTN and SEC RTN control signals are grounds (active-low inputs) to the BSU switch relays. The fibre-optic interface changes BSU fibre-optic signals to electronic signals and electronic signals to BSU fibre-optic signals.

### TEST YOUR UNDERSTANDING 10.3

Explain, with the aid of a sketch, how a beam of light propagates in an optical fibre.

### TEST YOUR UNDERSTANDING 10.4

Explain the difference between multimode and monomode fibres.

### TEST YOUR UNDERSTANDING 10.5

Explain the relationship between dispersion and bandwidth in an optical fibre.

### TEST YOUR UNDERSTANDING 10.6

List three advantages of optical fibre data cables when compared with conventional copper cables.

### TEST YOUR UNDERSTANDING 10.7

In relation to a multi-way optical fibre connector, explain the function and operation of:

1. the keys and guides
2. the guide pins
3. the coloured bands.
10.6 MULTIPLE-CHOICE QUESTIONS

1. In an optical fibre, the refractive index of the core is:
   (a) the same as the cladding
   (b) larger than the cladding
   (c) smaller than the cladding.

2. A suitable optical transmitter for use with an optical fibre is:
   (a) a photodiode
   (b) a phototransistor
   (c) a low-power laser diode.

3. The typical core diameter for a monomode fibre is:
   (a) 5 µm
   (b) 50 µm
   (c) 125 µm.

4. In a multicore fibre-optic cable:
   (a) the cores are colour coded
   (b) the cladding is colour coded
   (c) the buffers are colour coded.

5. The typical wavelength of light in a fibre is:
   (a) 1.3 µm
   (b) 13 µm
   (c) 130 µm.

6. What aircraft standard applies to fibre-optic networks:
   (a) ARINC 429
   (b) ARINC 573
   (c) ARINC 636.

7. If a launcher has an acceptance angle of 45º, the corresponding numerical aperture will be:
   (a) 0.5
   (b) 0.707
   (c) 1.

8. The typical cladding diameter for a monomode fibre is:
   (a) 5 µm
   (b) 50 µm
   (c) 125 µm.

9. If the numerical aperture of a fibre has a value of 1, this indicates that:
   (a) all of the light from the source is captured by the fibre
   (b) none of the light from the source is captured by the fibre
   (c) 50 per cent of the light from the source is captured by the fibre.

10. When replacing a length of multi-way fibre-optic cable, it is essential to ensure that:
    (a) the connectors are correctly aligned prior to mating the plug and the receptacle
    (b) none of the red band is covered when the coupling nut is tightened
    (c) all of the red band is covered when the coupling nut is tightened.

11. In order to support a high data rate, a fibre optic cable should have:
    (a) zero bandwidth
    (b) limited bandwidth
    (c) wide bandwidth.

12. A significant advantage of fibre-optic networks in large passenger aircraft is:
    (a) lower installation costs
    (b) reduced weight
    (c) ease of maintenance.

13. A beam of light is directed towards a boundary between two optical media having different refractive indices. If the beam is incident at the critical angle the ray emerging from the boundary will travel:
    (a) away from the boundary
    (b) along the boundary
    (c) back towards the light source.
14. The bandwidth of an optical fibre is limited by:
   (a) attenuation and cross-talk in the cable
   (b) modal dispersion occurring in the cable
   (c) the number and severity of bends in the cable.

15. Light propagates in a fibre optic by means of:
   (a) modal dispersion
   (b) continuous refraction
   (c) total internal reflection.

16. The attenuation of an optical fibre is typically:
   (a) less than 2 dB per kilometre
   (b) between 2 dB and 20 dB per kilometre
   (c) more than 20 dB per kilometre.

17. The main advantage of monomode fibres is:
   (a) lower cost
   (b) smaller data cables
   (c) faster data rates.

18. A pulse of infrared light travelling down a multi-mode fibre-optic becomes stretched. This is due to:
   (a) reflection
   (b) refraction
   (c) dispersion.

19. Attenuation in an optical fibre is due to:
   (a) absorption, dispersion and radiation
   (b) absorption, scattering and radiation
   (c) absorption, cross-talk and noise.

20. Light waves in fibre-optic cables are:
   (a) in the infrared spectrum
   (b) in the ultraviolet spectrum
   (c) in the visible spectrum.
Modern passenger aircraft employ a variety of different display technologies on the flight deck, including those based on conventional cathode ray tubes (CRTs), light emitting diodes (LEDs) and liquid crystal displays (LCDs). This chapter introduces these three main types of display and describes typical applications for each.

The trend is towards a uniform set of flight deck instruments using flat-panel displays, but displaying information in formats that have evolved from earlier instruments and displays. While there is a need to group instrument displays together in related functional areas (such as primary flight, navigation and engine instruments), a high level of integration is now possible by combining data from different avionic systems and displaying it in different ways.

Flat-panel displays, such as active matrix liquid crystal displays (AMLCD), offer considerable savings in volume compared with CRT displays. Combined with developments in the miniaturisation of electronic components, the use of modern surface-mounted devices (SMDs) and VLSI integrated circuits, this makes it possible to produce a complex multi-function instrument, complete with display, in a single enclosure. The single-box concept also helps to reduce the amount of cabling required and this, in turn, can simplify maintenance.

The latest AMLCD displays have performance parameter capabilities that exceed those of traditional CRT displays (see Figures 11.1–11.2). The main advantages are in weight, power, volume (size) and reliability. However, AMLCDs provide improved performance in several other areas, including:

- a high degree of uniformity of luminance, resolution and focus over the full display area;
- ability to maintain display performance over a wide range of viewing angles;
- immunity to ambient illumination washout and colour desaturation;
- ability to support a wide range of adjustable brightness levels;
- ability to maximise the usable display area for a given panel size;
- a high degree of fault tolerance;
- resistance to vibration and mechanical shock;

![An example of information displayed on a flight deck CRT](image)
11.1 CRT DISPLAYS

Apart from mechanical indicators, filament lamps and moving coil meters, the CRT is the oldest display technology in current aircraft use. Despite its age, the CRT offers a number of significant advantages, including the ability to provide an extremely bright colour display which can be viewed over a wide range of angles. For these two reasons, CRT displays are still found in modern aircraft despite the increasing trend to replace them with AMLCDs.

11.1.1 The CRT

The internal arrangement of a typical cathode ray tube is shown in Figure 11.3. The cathode, heater, grid and anode assembly forms an electron gun which produces a beam of electrons that is focused on the rear phosphor coating of the screen.

The heater raises the temperature of the cathode, which is coated with thoriated tungsten (a material that readily emits electrons when heated). The negatively charged electrons form a cloud above the cathode (the electrons are literally ‘boiled off’ the cathode surface) and become attracted by the high positive potential that appears on the various anodes.

The flow of electrons is controlled by the grid. This structure consists of a fine wire mesh through which the electrons must pass. The grid is made negative with respect to the cathode and this negative potential has the effect of repelling the electrons. By controlling the grid potential it is possible to vary the amount of electrons passing through the grid, thus controlling the intensity (or brightness) of the display on the screen.

The focus anodes consist of two or three tubular structures through which the electron beam passes. By varying the relative potential on these anodes, it is possible to bend and focus the beam in much the same way as a light beam can be bent and focused using a biconvex lens. The final anode consists of a graphite coating inside the CRT. This anode is given a very high positive potential (typically several kilovolts) which has the effect of accelerating the beam of electrons as they travel towards it. The result is an electron beam of high energy impacting itself against the phosphor coating on the inside rear of the screen area. The energy liberated by the collision of the electrons with the phosphors is converted into light (the colour of the light depending on the particular colour of the phosphor at the point of impact).

11.1.2 Deflection

In order to move the beam of electrons to different parts of the screen (in other words, to be able to ‘draw’ on the screen) it is necessary to bend (or deflect) the beam. Two methods of deflection are possible, depending on the size and application for the CRT. The method shown in Figure 11.4 uses electrostatic deflection (commonly used for small CRT
displays). In this method two sets of plates are introduced into the neck of the CRT between the focus anodes and the final anode. One pair of plates is aligned with the vertical plane (these X-plates provide deflection of the electron beam in the horizontal direction) while the other pair of plates is aligned in the horizontal plane (these Y-plates provide deflection of the electron beam in the vertical plane). By placing an electric charge (voltage) on the plates it is possible to bend the beam towards or away from a particular plate, as shown in Figure 11.4.

11.1.3 Scanning

In order to scan the full area of the CRT it is necessary to repeatedly scan the beam of electrons from top to bottom and left to right, as shown in Figure 11.4d. The voltage waveforms required on the X and Y plates to produce the scanned raster must be ramp-shaped (sawtooth) with different frequencies. For example, to produce the extremely crude four-line display shown in Figure 11.4d the ramp waveform applied to the X-plates would be 50 Hz and that applied to the Y-plates would be 200 Hz. A complete raster would then be scanned in a time interval of 20 ms (one fiftieth of a second).

A high-resolution display will clearly require many more than just four lines, but the principle remains the same. Suppose we need to have 400 lines displayed and we are using a 100 Hz ramp for the Y-plates. The X-plates would then need to be supplied with a 40 kHz ramp waveform.

Having produced a raster, we can illuminate individual picture cells (pixels) by modulating the brightness of the beam (we can do this by applying a ‘video’ signal voltage to the cathode of the CRT). Essentially, we are then modulating the beam of electrons with the information we need to display. In effect, the electron beam is being rapidly switched on and off in order to illuminate the individual pixels. Text can easily be displayed by this method by arranging characters into a character cell matrix. Typical arrangements of character cells are shown in Figure 11.5.

The alternative to electrostatic deflection is that of using an externally applied magnetic field to deflect the electron beam. This method is known as
electromagnetic deflection and it is based on two sets of coils placed (externally) around the neck of the CRT. Comparable circuits of a CRT using electrostatic and electromagnetic deflection are shown in Figures 11.6 and 11.7, respectively.

**TEST YOUR UNDERSTANDING 11.1**

State two advantages and two disadvantages of CRT displays when compared with AMLCD displays.

**TEST YOUR UNDERSTANDING 11.2**

Refer to the circuit shown in Figure 11.6.

1. To which electrode of the CRT is the video (intensity modulation) signal applied?
2. What approximate voltage appears on the first anode of the CRT?
3. What is the CRT heater voltage?
4. What is the approximate range of voltages applied to the third anode?
5. What is the function of TR21 and TR22?
11.6 CRT circuitry using electrostatic deflection (SG = spark gap)
11.1.4 Colour displays

By introducing a pattern of phosphors of different colours and by using a more complicated CRT with three different cathodes (see Figure 11.8) it is possible to produce a CRT that can display colour information. By combining three different colours (red, green and blue phosphors) in different amounts it is possible to generate a range of colours. For example, yellow can be produced by illuminating adjacent red and green phosphors while white can be produced by illuminating adjacent red, green and blue phosphors (see Figure 11.9).

**KEY POINT**

CRT displays use an electron gun assembly to produce an accurately focused beam of electrons which then impacts against a phosphor-coated screen. By controlling the amount of electrons (i.e. modulating the current in the beam) it is possible to control the intensity of the light produced.

**KEY POINT**

In order to cover the full screen area of a CRT display it is necessary to scan the beam (up and down and left to right) in order to create a raster. The raster is generated by applying ramp waveforms of appropriate frequency to the X- and Y-deflection system.
The arrangement of a colour CRT display is shown in Figure 11.10. Three separate video signals (corresponding to the colours red, green and blue) are fed to the three cathodes of the CRT. These signals are derived from the video-processing circuitry that generates the required waveforms used for varying the intensity of the three electron beams. Note that each beam is brought to focus on pixels of the respective colour (for example, the beam generated by the red cathode only coincides with the red phosphors). A synchronising system generates the scanning ramp waveforms and ensures that the time relationship between them is correct.

11.1.5 CRT control

A dedicated CRT controller integrated circuit acting in conjunction with a video/synchronising interface provides the necessary control signals for the CRT (including signals that are used to synchronise the X- and Y-scanning ramp waveforms). In turn, the CRT controller acts under the control of a dedicated CPU which accepts data from the bus and buffers the data ready for display. Direct memory access (DMA) is used to minimise the burden on the CPU (which would otherwise need to process data on an individual byte or word basis).
The patterns required to generate the displayed characters (see Figure 11.5) are stored in a dedicated character generator ROM (see Figure 11.11). Data for each scan line is read out from this ROM and assembled into a serial stream of bits which are fed to the appropriate video signal channels.

### 11.2 LIGHT EMITTING DIODES

LEDs can be used as general-purpose indicators. When compared with conventional filament lamps they operate from significantly smaller voltages and currents. LEDs are also very much more reliable than filament lamps. Most LEDs will provide a reasonable level of light output when a forward current of between 5 mA and 20 mA is applied. LEDs are available in various formats, with the round types being most popular. Round LEDs are commonly available in the 3 mm and 5 mm (0.2 inch) diameter plastic packages and also in a 5 mm × 2 mm rectangular format. The viewing angle for round LEDs tends to be in the region of 20–40º, whereas for rectangular types this is increased to around 100º. Table 11.1 shows the characteristics of some common types of LED.

#### 11.2.1 Spectral response

Light of different colours can be produced by using different semiconductor materials in the construction of an LED. However, there is a wide variation in both the efficiency and light output of LEDs of different colours. For this reason, red displays tend to be most common (with a peak output at around 650 nm). Note that this is towards one end of the visible spectrum, as shown in Figure 11.12.

#### Table 11.1 Characteristics of various types of LED

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Type of LED</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Miniature</td>
</tr>
<tr>
<td>Diameter (mm)</td>
<td>3</td>
</tr>
<tr>
<td>Max. forward current (mA)</td>
<td>40</td>
</tr>
<tr>
<td>Typical forward current (mA)</td>
<td>12</td>
</tr>
<tr>
<td>Typical forward voltage drop (V)</td>
<td>2.1</td>
</tr>
<tr>
<td>Max. reverse voltage (V)</td>
<td>5</td>
</tr>
<tr>
<td>Max. power dissipation (mW)</td>
<td>150</td>
</tr>
<tr>
<td>Peak wavelength (nm)</td>
<td>690</td>
</tr>
</tbody>
</table>
11.2.3 Seven-segment displays

LED displays are frequently used to display numerical data. The basis of such displays is the seven-segment indicator (see Figure 11.13), which is often used in groups of between three and five digits to form a complete display. The arrangement of the individual segments of a seven-segment indicator is shown in Figure 11.14. The segments are distinguished by the letters a–g. Since each segment comprises an individual LED it is necessary to use logic to decode binary (or binary coded decimal) data in order to illuminate the correct combination of segments to display a particular digit. For example, the number ‘1’ can be displayed by simultaneously illuminating segments b and c, while the number ‘2’ requires that segments a, b, g, e and d should be illuminated. The circuit of a seven-segment display is shown in Figure 11.15, while a typical decoder and decoder truth table are shown in Figures 11.16 and 11.17, respectively.

TEST YOUR UNDERSTANDING 11.3

State two advantages of LED indicators when compared with conventional filament lamp indicators.
11.3 LIQUID CRYSTAL DISPLAYS

Liquid crystals have properties that can be considered to be somewhere between those of a solid and those of a liquid. Solids have a rigid molecular structure while the molecules in liquids change their orientation and are able to move. A particular property of liquid crystals that makes them attractive for use as the basis of electronic displays is that the orientation of molecules (and consequently the passage of light through the crystal) can be controlled by the application of an electric field.

11.3.1 Types of LCD

LCD displays can be either reflective or backlit according to whether the display uses incident light or contains its own light source. Figure 11.19 shows the construction of both types of display. Note that, unlike LEDs, LCDs emit no light of their own and, as a consequence, they need a light source in order to operate.

Larger displays can be easily made that combine several digits into a single display. This makes it possible to have integrated displays where several sets of information are shown on a common display panel. Figure 11.20 shows the comparison of typical LCD and LED aircraft displays that show the same information. Note that each LCD display replaces several seven-segment LED displays.

Figure 11.21 shows an example of the use of three-digit seven-segment displays for battery bus voltage indication; Figure 11.22 shows the method of interfacing a three-digit LCD to a microcontroller.

Figure 11.23 shows a larger alphanumeric LCD organised on the basis of 40 characters arranged in two lines. Displays of this type are ideal for showing short text messages.

11.3.2 Passive matrix displays

In order to display more detail (for example, text and graphics characters) LCD displays can be built using a matrix of rows and columns in order to produce a display that consists of a rectangular matrix of cells. The electrodes used in this type of display consist of rows and columns of horizontal and vertical conductors, respectively. The rows and columns can be
11.18 A colour LCD display in a retrofit instrument system from Garmin

11.19 An enlarged section of an LCD showing a single character segment

11.20 Alternative standby engine indicators based on (a) LCD and (b) LED displays
separately addressed (in a similar manner to that used for a memory cell matrix – see page 74) and individual display cells can thus be illuminated. Passive matrix displays have a number of disadvantages, notably that they have a relatively slow response time and the fact that the display is not as sharp (in terms of resolution) as that which can be obtained from an active matrix display. A typical passive matrix display is shown in Figure 11.23.

11.3.3 Active matrix displays

AMLCDs use thin-film transistors (TFTs) fabricated on a glass substrate so that they are an integral part of a display. Each transistor acts as a switch that transfers charge to an individual display element. The transistors are addressed on a row/column basis as with the passive matrix display. By controlling the switching, it is possible to transfer precise amounts of charge into the display and thus exert a wide range of control over the light transmitted through it.

Colour AMLCDs comprise a matrix of pixels that correspond to three colours: red, green and blue. By precise application of charges to the appropriate pixels it is possible to produce displays that have 256 shades of red, green and blue (making a total of more than 16 million colours). High-resolution colour AMLCD make it possible to have aircraft displays with a full graphics capability.
11.4 MULTIPLE-CHOICE QUESTIONS

1. The peak wavelength of light emitted from a red LED is typically:
   (a) 475 nm
   (b) 525 nm
   (c) 635 nm.

2. The spectral response of the human eye peaks at around:
   (a) 450 nm
   (b) 550 nm
   (c) 650 nm.

3. Adjacent phosphors of blue and green are illuminated on the screen of a CRT. The resultant colour produced will be:
   (a) cyan
   (b) white
   (c) magenta.

4. The human eye is most sensitive to:
   (a) red light
   (b) blue light
   (c) green light.

5. A seven-segment LED display has segments a, b, c, d and g illuminated. The character displayed will be:
   (a) 2
   (b) 3
   (c) 5.

6. The BCD input to a seven-segment display decoder is 1001. The digit displayed will be:
   (a) 7
   (b) 8
   (c) 9.

7. The potential at the grid of a CRT is:
   (a) the same as the cathode
   (b) negative with respect to the cathode
   (c) positive with respect to the cathode.

8. The function of the final anode of a CRT is:
   (a) accelerating the electron beam
   (b) deflecting the electron beam
   (c) controlling the brightness of the display.

9. Electromagnetic deflection of a CRT uses:
   (a) coils inside the CRT
   (b) X- and Y-plates inside the CRT
   (c) coils around the neck of the CRT.

10. The three beams in a colour CRT are associated with the colours:
    (a) red, yellow and blue
    (b) red, green and blue
    (c) green, blue and yellow.

11. When compared with CRT displays, AMLCD displays have:
    (a) larger volume and lower reliability
    (b) larger volume and greater reliability
    (c) smaller volume and greater reliability.

12. The final anode of a CRT display requires:
    (a) a low-voltage AC supply
    (b) a high-voltage AC supply
    (c) a high-voltage DC supply.

13. The deflecting waveform supplied to the plates of an electrostatic CRT will be:
    (a) a sine wave
    (b) a ramp wave
    (c) a square wave.

TEST YOUR UNDERSTANDING 11.5

Explain the difference between active and passive matrix LCD. State two advantages of AMLCDs.
14. The typical value of maximum forward current for an LED indicator is:
   (a) 0.03 A
   (b) 0.3 A
   (c) 3 A.

15. The patterns required to display alphanumeric characters in a CRT controller are stored in:
   (a) static RAM
   (b) dynamic RAM
   (c) character generator ROM.

16. When compared with passive matrix LCDs, AMLCDs are:
   (a) faster and sharper
   (b) faster and less sharp
   (c) slower and less sharp.
Earlier we said that advancements in technology were bringing new challenges for those involved with the operation and maintenance of modern passenger aircraft. One of those challenges is associated with the handling of semiconductor devices that are susceptible to damage from stray electric charges. This is a problem that can potentially affect a wide range of electronic equipment fitted in an aircraft (see Figure 12.1) and can have wide-ranging effects, including total failure of the line replaceable unit (LRU) but without any visible signs of damage!

Electrostatic sensitive devices (ESDs) are electronic components and other parts that are prone to damage from stray electric charge. This problem is particularly prevalent with modern LSI and VLSI devices, but it also affects other components such as metal oxide semiconductor (MOS) transistors, microwave diodes, displays and many other modern electronic devices.

Extensive (and permanent) damage to static-sensitive devices can result from mishandling and inappropriate methods of storage and transportation. This chapter provides background information and specific guidance on the correct handling of ESDs.

### 12.1 STATIC ELECTRICITY

Static electricity is something we should all be familiar with in its most awesome manifestation — lightning (see Figure 12.2). Another example of static electricity that you might have encountered is the electric shock received when stepping out of a car. The
synthetic materials used for clothing as well as the vehicle’s interior are capable of producing large amounts of static charge, which is only released when the hapless driver or passenger sets foot on the ground!

When two dissimilar, initially uncharged non-conducting materials are rubbed together, the friction is instrumental in transferring charge from one material to the other and consequently raising the electric potential that exists between them.

12.1.1 The triboelectric series

The triboelectric series classifies different materials according to how well they create static electricity when rubbed with another material. The series is arranged on a scale of increasingly positive and increasingly negative materials.

The following materials give up electrons and become positive when charged (and so appear as positive on the triboelectric scale) when rubbed against other materials:

- air (most positive)
- dry human skin
- leather
- rabbit fur
- glass
- human hair
- nylon
- wool
- lead
- cat fur

- silk
- aluminium
- paper (least positive).

The following are examples of materials that do not tend to readily attract or give up electrons when brought into contact with or rubbed against other materials (they are thus said to be neutral on the triboelectric scale):

- cotton
- steel.

The following materials tend to attract electrons when rubbed against other materials and become negative when charged (and so appear as negative on the triboelectric scale):

- wood (least negative)
- amber
- hard rubber
- nickel, copper, brass and silver
- gold and platinum
- polyester
- polystyrene
- saran
- polyurethane
- polyethylene
- polypropylene
- polyvinylchloride (PVC)
- silicon
- Teflon (most negative).

The largest amounts of induced charge will result from materials being rubbed together that are at the extreme ends of the triboelectric scale. For example, PVC rubbed against glass or polyester rubbed against dry human skin. Note that a common complaint from people working in a dry atmosphere is that they produce sparks when touching metal objects. This is because they have dry skin, which can become highly positive in charge, especially when the clothes they wear are made of man-made material such as polyester, which can easily acquire a negative charge. The effect is much less pronounced in a humid atmosphere where the stray charge can leak away harmlessly into the atmosphere. People that build up static charges due to dry skin are advised to wear all-cotton clothes (recall that cotton is neutral on the triboelectric scale). Also, moist skin tends to dissipate charge more readily.
Human hair becomes positive in charge when combed. A plastic comb will collect negative charges on its surface. Since similar charges repel, the hair strands will push away from each other, especially if the hair is very dry. The comb (which is negatively charged) will attract objects with a positive charge (like hair). It will also attract material with no charge, such as small pieces of paper. You will probably recall demonstrations of this effect when you were studying science at school.

Electric charge can also be produced when materials with the same triboelectric polarity are rubbed together. For example, rubbing a glass rod with a silk cloth will charge the glass with positive charges. The silk does not retain any charges for long. When both of the materials are from the positive side of the triboelectric scale (as in this example) the material with the greatest ability to generate charge will become positive in charge. Similarly, when two materials that are both from the negative end of the triboelectric scale are rubbed together, the one with the greatest tendency to attract charge will become negative in charge.

Representative values of electrostatic voltages generated in some typical working situations are shown in Table 12.1. Note the significant difference in voltage generated at different values of relative humidity.

**KEY POINT**

Very large electrostatic potentials can be easily generated when different materials are rubbed together. The effect is much more pronounced when the air is dry.

**TEST YOUR UNDERSTANDING 12.1**

Explain, in relation to electric charge, what happens when a glass rod is rubbed with a polyester cloth.

**TEST YOUR UNDERSTANDING 12.2**

Explain the importance of the triboelectric series. Give one example of a material from the positive end of the triboelectric scale and one example of a material from the negative end of the triboelectric scale.

### 12.2 STATIC-SENSITIVE DEVICES

All modern microelectronic components are prone to damage from stray electric charges, but some devices are more prone to damage than others. Devices that are most prone to damage tend to be those that are based on the use of field effect technology rather than bipolar junction technology. They include CMOS logic devices (such as logic gates and MSI logic), MOSFET devices (such as transistors), NMOS and PMOS VLSI circuits (used for dynamic memory devices, microprocessors, etc.). Microwave transistors and diodes (by virtue of their very small size and junction area) are also particularly static sensitive.

---

### Table 12.1 Representative values of electrostatic voltages generated in typical work situations

<table>
<thead>
<tr>
<th>Situation</th>
<th>Typical electrostatic voltage generated</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>20 per cent relative humidity</td>
</tr>
<tr>
<td>Walking over a wool/nylon carpet</td>
<td>35 kV</td>
</tr>
<tr>
<td>Sliding a plastic box across a carpet</td>
<td>18 kV</td>
</tr>
<tr>
<td>Removing parts from a polystyrene bag</td>
<td>15 kV</td>
</tr>
<tr>
<td>Walking over vinyl flooring</td>
<td>11 kV</td>
</tr>
<tr>
<td>Removing shrink-wrap packaging</td>
<td>10 kV</td>
</tr>
<tr>
<td>Working at a bench wearing overalls</td>
<td>8 kV</td>
</tr>
</tbody>
</table>
as are some optoelectronic and display devices. If in doubt, the moral here is to treat any semiconductor device with great care and to always avoid situations in which stray static charges may come into contact with a device.

Printed circuit board assemblies can also be prone to damage from electrostatic discharge. In general, printed circuit board mounted components are at less risk than individual semiconductors. The reason for this is that the conductive paths that exist in a printed circuit can often help to dissipate excessive static charges that might otherwise damage unmounted semiconductor devices (there are no static dissipative paths when a transistor, diode or integrated circuit is handled on its own).

Table 12.2 provides a guide as to the relative susceptibility of various types of semiconductor device to damage from static voltages.

### Table 12.2 Representative values of static voltage susceptibility for different types of semiconductor

<table>
<thead>
<tr>
<th>Type of device</th>
<th>Typical static voltage susceptibility</th>
</tr>
</thead>
<tbody>
<tr>
<td>CMOS logic</td>
<td>250 V to 1 kV</td>
</tr>
<tr>
<td>TTL logic</td>
<td>550 V to 2.5 kV</td>
</tr>
<tr>
<td>Bipolar junction transistors</td>
<td>150 V to 5 kV</td>
</tr>
<tr>
<td>Dynamic memories</td>
<td>20 V to 100 V</td>
</tr>
<tr>
<td>VLSI microprocessor</td>
<td>20 V to 100 V</td>
</tr>
<tr>
<td>MOSFET transistors</td>
<td>50 V to 350 V</td>
</tr>
<tr>
<td>Thin-film resistors</td>
<td>300 V to 3 kV</td>
</tr>
<tr>
<td>Silicon-controlled rectifiers</td>
<td>4 kV to 15 kV</td>
</tr>
</tbody>
</table>

12.3 ESD WARNINGS

Static-sensitive components (including printed circuit board cards, circuit modules and plug-in devices) are invariably marked with warning notices. These are usually printed with black text on yellow backgrounds, as shown in Figures 12.3–12.7.
12.4 HANDLING AND TRANSPORTING ESDs

Special precautions must be taken when handling, transporting, fitting and removing ESDs. These include the following:

1. Use of wrist straps which must be worn when handling ESDs. These are conductive bands that are connected to an effective ground point by means of a short wire lead. The lead is usually fitted with an integral 1 MΩ resistor which helps to minimise any potential shock hazard to the wearer (the series resistor serves to limit the current passing through the wearer in the event that he/she may come into contact with a live conductor). Wrist straps are usually stored at strategic points on the aircraft (see Figure 12.5) or may be carried by maintenance technicians. Figure 12.6 shows a typical wrist strap being used for a bench operation while Figures 12.7 and 12.8 show ESD warning notices associated with the wearing of wrist straps.

2. Use of heel straps which work in a similar manner to wrist straps.

3. Use of static dissipative floor and bench mats.

4. Avoidance of very dry environments (or at least the need to take additional precautions when the relative humidity is low).

5. Availability of ground jacks (see Figure 12.6).

6. Use of grounded test equipment.

7. Use of low-voltage soldering equipment and anti-static soldering stations (low-voltage soldering irons with grounded bits).

8. Use of anti-static insertion and removal tools for integrated circuits.

9. Avoidance of nearby high-voltage sources (such as fluorescent light units).

10. Use of anti-static packaging (static-sensitive components and printed circuit boards should be stored in their anti-static packaging until such time as they are required for use).

Note that there are three main classes of materials used for protecting static-sensitive devices. These are conductive materials (such as metal foils and carbon-impregnated synthetic materials), static dissipative materials (a cheaper form of conductive material) and so-called anti-static materials (these are materials...
that are neutral on the triboelectric scale, such as cardboard, cotton and wood). Of these, conductive materials offer the greatest protection while anti-static materials offer the least protection.

**TEST YOUR UNDERSTANDING 12.3**

Which one of the following semiconductor devices is likely to be most susceptible to damage from stray static charges:

1. A dynamic memory.
2. A silicon controlled rectifier.
3. A bipolar junction transistor.

**TEST YOUR UNDERSTANDING 12.4**

Which one of the following situations is likely to produce the greatest amount of stray static charge:

1. Removing a PVC shrink wrap on a dry day.
2. Walking on a vinyl floor on a wet day.
3. Sitting at a bench wearing a wrist strap.

**TEST YOUR UNDERSTANDING 12.5**

Explain the difference between conductive and static dissipative materials for ESD protection.

**12.5 MULTIPLE-CHOICE QUESTIONS**

1. A particular problem with the build-up of static charge is that:
   (a) it is worse when wet
   (b) it is invariably lethal
   (c) it cannot easily be detected.

2. The typical resistance of a wrist strap lead is:
   (a) 1 Ω
   (b) 1 kΩ
   (c) 1 MΩ.

3. Which one of the following devices is most susceptible to damage from stray static charges:
   (a) a power rectifier
   (b) a TTL logic gate
   (c) a MOSFET transistor.

4. The static voltage generated when a person walks across a carpet can be:
   (a) no more than about 10 kV
   (b) between 10 kV and 20 kV
   (c) more than 20 kV.
5. Which of the materials listed is negative on the triboelectric scale:
   (a) glass
   (b) silk
   (c) polyester.

6. When transporting ESDs it is important to:
   (a) keep them in a conductive package
   (b) remove them and place them in metal foil
   (c) place them in an insulated plastic package.

7. To reduce the risk of damaging an ESD during soldering it is important to:
   (a) use only a low-voltage soldering iron
   (b) use only a mains-operated soldering iron
   (c) use only a low-temperature soldering iron.

8. Which one of the following items of clothing is most likely to cause static problems:
   (a) nylon overalls
   (b) a cotton T-shirt
   (c) polyester–cotton trousers.
13 Software

Aircraft software is something that you can’t see and you can’t touch, yet it must be treated with the same care and consideration as any other aircraft part. This chapter deals with aspects of the maintenance of the safety-critical software found in modern aircraft.

At the outset it is important to realise that software encompasses both the executable code (i.e. the programs) run on aircraft computers as well as the data that these programs use. The term also covers the operating systems (i.e. system software) embedded in aircraft computer systems. All of these software parts require periodic upgrading as well as modification to rectify problems and faults that may arise as a result of operational experience (see Figure 13.1 for an example emphasising the importance of this).

The consequences of software failure can range from insignificant (no effect on aircraft performance) to catastrophic (e.g. major avionic system failure, engine faults, etc.). Because of this it is important that you should have an understanding of the importance of following correct procedures for software modification and upgrading. Once again, this is an area of rapidly evolving technology which brings with it many new challenges.

13.1 SOFTWARE CLASSIFICATION

Aircraft software can be divided into five levels according to the likely consequences of its failure, as shown in Table 13.1. The highest level of criticality (Level A) is that which would have catastrophic consequences; the lowest level of criticality is that which would have no significant impact on the operation of the aircraft. Between these levels the degree of criticality is expressed in terms of the additional workload imposed on the flight crew and, in particular, the ability of the flight crew to manage the

ATA 73 – FUEL AND CONTROL EEC SOFTWARE – MODIFICATION

There have been six events of in-service loss of engine parameters displayed in the aircraft cockpit, combined with freezing of engine power setting for the affected engine. Subsequent investigation has established the cause to be a fault in engine software. A safety assessment has identified that this could result in hazardous asymmetric thrust, if the event were to occur during a take-off roll and in response the crew attempted to abort the take-off. This Airworthiness Directive requires the introduction of revised engine software.

13.1 An extract from a recent Airworthiness Directive identifying the need for software modification
aircraft without having access to the automatic control or flight information that would have otherwise been provided by the failed software. Table 13.2 provides examples of software applications and levels of software criticality associated with each.

### 13.2 SOFTWARE CERTIFICATION

The initial certification of an aircraft requires that the design organisation (DO) shall provide evidence that the software has been designed, tested and integrated with the associated hardware in a manner that satisfies standard DO-178B/ED-12B (or an agreed equivalent standard). In order to provide an effective means of software identification and change control, a software configuration management plan (CMP) (e.g. as defined in Part 7 of DO-178B/ED-12B) is required to be effective throughout the life of the equipment (the CMP must be devised and maintained by the relevant DO).

Post-certificate modification of equipment in the catastrophic, hazardous or major categories (Levels A, B and C, see Tables 13.1 and 13.2) must not be made unless first approved by the DO. Hence all software upgrades and modifications are subject to the same approval procedures as are applied to hardware modifications. This is an important point that recognises the importance of software as an 'aircraft part'. Any

---

**Table 13.1 Levels of failure**

<table>
<thead>
<tr>
<th>Level</th>
<th>Type of failure</th>
<th>Failure description</th>
<th>Probability</th>
<th>Likelihood of failure (per flight hour)</th>
</tr>
</thead>
<tbody>
<tr>
<td>A</td>
<td>Catastrophic failure</td>
<td>Aircraft loss and/or fatalities</td>
<td>Extremely improbable</td>
<td>Less than $10^{-9}$</td>
</tr>
<tr>
<td>B</td>
<td>Hazardous/severe major failure</td>
<td>Flight crew cannot perform their tasks; serious or fatal injuries to some occupants</td>
<td>Extremely remote</td>
<td>Between $10^{-7}$ and $10^{-9}$</td>
</tr>
<tr>
<td>C</td>
<td>Major failure</td>
<td>Workload impairs flight crew efficiency; occupant discomfort including injuries</td>
<td>Remote</td>
<td>Between $10^{-5}$ and $10^{-7}$</td>
</tr>
<tr>
<td>D</td>
<td>Minor failure</td>
<td>Workload within flight crew capabilities; some inconvenience to occupants</td>
<td>Probable</td>
<td>Greater than $10^{-5}$</td>
</tr>
<tr>
<td>E</td>
<td>No effect</td>
<td>No effect</td>
<td>Not applicable</td>
<td>Not applicable</td>
</tr>
</tbody>
</table>

**Table 13.2 Examples of software levels**

<table>
<thead>
<tr>
<th>Level</th>
<th>Typical aircraft applications (see Appendix 1 for acronyms)</th>
</tr>
</thead>
<tbody>
<tr>
<td>A</td>
<td>AHRS, GPS/ILS/MLS/FLS, SATNAV, VOR ADF</td>
</tr>
<tr>
<td>B</td>
<td>TCAS, ADSB Transponder, Flight Displays</td>
</tr>
<tr>
<td>C</td>
<td>DME, VHF voice communications</td>
</tr>
<tr>
<td>D</td>
<td>AHRS Automatic Levelling, CMC/CFDIU, Data Loader, Weather Radar</td>
</tr>
<tr>
<td>E</td>
<td>In-flight entertainment</td>
</tr>
</tbody>
</table>
modifications made to software must be identified and controlled in accordance with the CMP. Guidance material is provided DO-178B/ED-12B and DO-178C/ED-12C (2011).

The relationship between the development of aircraft hardware and software is shown in Figure 13.2. Note that the two life cycles (hardware and software) are closely interrelated simply because a change in hardware configuration inevitably requires a corresponding change to the software configuration. The safety assessment process (SAP) is a parallel activity to that of the system development process. It is important to be aware that changes to the system design and configuration will always necessitate a re-appraisal of safety factors.

Testing takes place throughout the development process. Independent tests are usually carried out in order to ensure that the results of tests are valid. Testing generally also involves simulation of out-of-range inputs and abnormal situations such as recovery from power failure (ensuring that a system restart is accomplished without generating dangerous or out-of-range outputs).

Traceability of software is a key component of the DO-178B criteria. Planning documents and evidence of traceability help to ensure that not only are certification requirements met, but also that the final code contains all of the required modules and that each module is the most recently updated version. Care is also needed to ensure that none of the final code will be detrimental to the overall operation of the system (for example, seeking data from sensors and transducers that may not be fitted in some configurations of a particular aircraft).

13.3 SOFTWARE UPGRADING

When considering software modifications and upgrades it is important to distinguish between executable code (i.e. computer programs) and the data that is used by programs but is not, in itself, executable code. Both of these are commonly referred to as ‘software’ and both are likely to need modification and upgrading during the life of an aircraft.

13.3.1 Field loadable software

Field loadable software (FLS) is executable code (i.e. computer programs) that can be loaded into a computer system while the system is in place within the aircraft. FLS can be loaded onto an aircraft system by a maintenance mechanic/technician in accordance with defined maintenance manual procedures. There are three main types of FLS: loadable software aircraft parts (LSAP); user modifiable software (UMS); and option selectable software (OSS).
Loadable software aircraft parts

LSAP is software that is required to meet a specific airworthiness or operational requirement or regulation. LSAP is not considered to be part of the aircraft approved design and therefore it is an aircraft part requiring formal (controlled) release documentation. Typical examples of target hardware for LSAP (FLS) include:

- electronic engine controls (EEC)
- digital flight data acquisition units (DFDAU)
- auxiliary power unit’s electronic control units (ECU)
- flight guidance computers (FGC).

User modifiable software

UMS is declared by the aircraft Type Certificate holder’s design organisation (or Supplementary Type Certificate holder’s design organisation) as being intended for modification within the constraints established during certification. UMS can usually be upgraded by the aircraft operator, design organisation or equipment manufacturer without further review by the licensing authority. Typical examples of target hardware for UMS include:

- aircraft condition monitoring systems (ACMSs)
- in-flight entertainment systems (IFEs).

Option selectable software

OSS is software that contains approved and validated components and combinations of components that may be activated or modified by the aircraft operator within boundaries defined by the Type Certificate or Supplementary Type Certificate holder. Typical examples of target hardware for OSS can be found in integrated modular avionics (IMA) units.
13.3.2 Database field loadable data

Database field loadable data (DFLD) is data that is field loadable into target hardware databases. Note that it is important to be aware that the database itself is an embedded item that resides within the target hardware and is not, itself, field loadable, and that the process of ‘loading a database’ is merely one of writing new data or overwriting old data from a supplied data file.

DFLD is usually modified or updated by overwriting it using data from a data file which is field loaded. The data file can contain data in various formats, including natural binary, binary coded decimal or hexadecimal formats. Of these, natural binary code produces the most compact and efficient data files, but the data are not readable by humans and, for this reason, binary coded decimal or hexadecimal formats are sometimes preferred.

It is important to note that the updating of an aircraft database will usually have an impact on aspects of the aircraft’s performance. However, if the data used by a program are invalid or have become corrupt, this may result in erratic or out of range conditions. Because of this, it is necessary to treat DFLD in much the same manner as the executable code or LSAP that makes use of it. Hence a DFLD must be given its own unique part number and release documentation. Typical examples of the target hardware with databases that can be field loaded with DFLD (and that need to be tracked in the same manner as other aircraft parts) include:

- flight management computers (FMC)
- terrain awareness warning system (TAWS) computers
- integrated modular avionics (IMA) units.

13.3.3 Distribution methods

FLS and DFLD can be distributed by various methods, including combinations of the following:

- Media distribution: a process whereby FLS or DFLD are moved from the producer or supplier to a remote site using storage media such as floppy disk, a PCMCIA (Personal Computer Memory Card International Association) card, a CD-ROM or an onboard replaceable module (OBRM).
- Electronic transfer: a process where a laptop, hand-held computer or portable data loader is used to transfer data using a serial data link or temporary bus connection.
- Electronic distribution: a process whereby FLS or DFLD are moved from the producer or supplier to a remote site without the use of intermediate storage media, such as floppy disk or CD-ROM.

Note that the method of release is dependant upon whether the FLS or DFLD is required to meet a specific airworthiness or operational requirement, or certification specification. For FLS or DFLD that does not need to meet a specific airworthiness, operational or certification requirement, a Certificate of Conformity is normally sufficient. In other cases an EASA Form 1 or FAA 8130-3 should accompany any FLS (executable code) that is required to meet a specific airworthiness, operational or certification requirement, or certification specification, i.e. LSAP. Examples of LSAP that would require such release would include electronic engine controls (EEC), DFDAU, auxiliary power unit’s ECUs, flight guidance computers (FGC) and IMA units.

An EASA Form 1 or FAA 8130-3 should accompany any DFLD that is required to meet a specific airworthiness or operational requirement or regulation, or certification specification. Examples of DFLD that require such release include FMCs, TAWS computers and IMA units. A ‘Letter of Acceptance’ or equivalent should accompany the release of any navigational database’s DFLD because an EASA Form 1 or FAA 8130-3 cannot be provided.

**KEY POINT**

If there is any doubt about the status of an FLS or DFLD upgrade (for example, if there is a reason to suspect that the data may be corrupt or may not be the correct version for the particular aircraft configuration), no attempt should be made to transfer the data. Instead, it should be quarantined and held pending data integrity and/or version checks specified by the supplier.

By virtue of the speed of distribution and the removal of the need for any physical transport media (which
can be prone to data corruption), electronic distribution is increasingly being used to transfer FLS or DFLD from the supplier to an operator. Operators should maintain a register that provides the following information:

- the current version of the FLS and DFLD installed;
- which aircraft the FLS and DFLD are installed on;
- the aircraft, systems and equipment that they are applicable to;
- the functions that the recorded FLS or DFLD performs;
- where (including on- or off-aircraft location) and in what format it is stored (i.e. storage media type), the name of the person who is responsible for it and the names of those who may have access to it;
- who can decide whether an upgrade is needed and then authorise that upgrade;
- a record of all replicated FLS/DFLD, traceable to the original source.

When transferring FLS or a DFLD, it is essential to ensure that:

- the FLS or DFLD has come from an appropriate source;
- effective configuration control processes are in place to ensure that only the correct data and/or executable code will be supplied;
- the FLS or DFLD is accompanied by suitable release documentation and records are kept;
- suitable controls are in place to prevent use of FLS and DFLD that have become corrupted during existence in any ‘open’ environment, such as on the internet or due to mishandling in transit;
- effective data validation and verification procedures are in place;
- the FLS and DFLD, as well as the mechanisms for transferring them (file transfer and file compaction utilities), are checked for unauthorised modification (for example, that caused by malicious software such as viruses and ‘spyware’).

Special precautions are needed when the FLS or DFLD are transferred or downloaded using the public internet. These precautions include the use of an efficient firewall to prevent unauthorised access to local servers and storage media, as well as accredited virus protection software. Further precautions are necessary when making backup copies of transferred or downloaded data. In particular, backup copies should be clearly labelled with version and date information and they must always be stored in a secure place.

**KEY POINT**

When an FLS or DFLD is transferred over an ‘open environment’ (such as the internet) extra care will be needed to ensure that the software has not become corrupt or contaminated by viruses. The supplier will usually be able to provide guidance on approved methods of checking software and data integrity.

**TEST YOUR UNDERSTANDING 13.2**

1. Explain what is meant by a loadable software aircraft part (LSAP).
2. Give two examples of LSAPs.

**TEST YOUR UNDERSTANDING 13.3**

State four precautions that must be taken when transferring field loadable software.

**TEST YOUR UNDERSTANDING 13.4**

Explain why database field loadable data should be treated with the same care and consideration as field loadable software.

A typical software loading procedure for the electronic engine control (EEC) of a modern passenger aircraft (see Figure 13.3) is as follows:
1. Make sure the electrical power to the EEC is off.
2. Connect one end of the portable data loader (PDL) cable to the connector of the loader (see Figure 13.4).
3. Disconnect the electrical connector from the EEC.
4. Connect the other end of the PDL cable to the connector of the EEC.
5. Connect the 28 V DC power source to the brown (+), black (–) and shield (chassis ground) terminals of the loader cable.
6. Load the software using the following steps:
   (a) Check you have the correct disk needed to load channels A and B with the non-volatile memory (NVM) and the operating program software.
   (b) Turn on the 28 V DC supply to the loader.
   (c) Turn on the 115 V AC (400 Hz) supply to the EEC.
   (d) Turn on the loader without the disk inserted. The PDL display will show DISK NOT INSERTED after the PDL is initiated.
   (e) Make sure you use the correct EEC software version disk and also ensure that the same software version is used for both the left and right engines.
   (f) Check that the software disk is not write-protected before you load the new software (the disk is write protected as shown in Figure 13.5).
   (g) Insert the appropriate disk into the PDL drive within five minutes after you turned on the power.
   (h) The PDL will automatically load the NVM and the operating program software to the two channels of the EEC. If it is successful, the PDL will display LOAD COMPLETE. It will take approximately 12–16 minutes to load the EEC. If the software loading has failed, it may take a few minutes before the transfer fail lamp illuminates. If the transfer fail lamp illuminates, make sure the cable connections are correct. Remove the power and repeat the software loading steps above. Note that no more than three attempts can be made if the failure recurs.
   (i) If LOAD COMPLETE is displayed on the loader, turn off the loader and then turn off the 115 V AC or 28 V DC.
   (j) Remove the disk from the loader.
7. Remove all electrical power from the EEC and the loader.
8. Remove the loader and reconnect the EEC cables.
9. Use the appropriate memory verification program (included in the software reprogramming disks) to make sure the EEC has been reprogrammed correctly. If the verify program displays PASS for the EEC part number as well as the checksums, the EEC has been programmed correctly. If FAIL is displayed because the comparison of the FADEC/EEC hardware part number did not agree with the software part number, make sure the FADEC/EEC hardware part number is correct on the nameplate. Use the PRINTSCREEN feature of the PC, and make a paper copy of the final results.
10. Use a ball-point pen to write the number of the appropriate software version, Service Bulletin number and date on the Service Bulletin plate (a metallic sticker) on the EEC (see Figure 13.3).
13.4 DATA VERIFICATION

Various techniques are used to check data files and executable code in order to detect errors. Common methods involve the use of checksums and cyclic redundancy checks (CRC). Both of these methods will provide an indication that a file has become corrupt, but neither is completely fool-proof.

Checksums involve adding the values of consecutive bytes or words in the file and then appending the generated result to the file. At some later time (for example, when the file is prepared for loading) the checksum can be re-calculated and compared with the stored result. If any difference is detected the file should not be used.

Cyclic redundancy checks involve dividing consecutive blocks of binary data in the file by a specified number. The remainder of the division is then appended to the file as a series of check digits (in much the same way as a checksum). If there is no remainder when the file is later checked by dividing by the same number, the file can be assumed to be free from errors.

TEST YOUR UNDERSTANDING 13.5

Classify each of the following applications in terms of level of software criticality:

1. Weather radar.
2. VOR.
3. In-flight entertainment.

TEST YOUR UNDERSTANDING 13.6

An FLS upgrade may have been corrupted during transfer. What action should be taken?

TEST YOUR UNDERSTANDING 13.7

Distinguish between user modifiable software and option selectable software. Give a typical example of each.

TEST YOUR UNDERSTANDING 13.8

1. Describe two methods of checking that a data file contains no errors.
2. Describe the precautions that should be taken when making backups of field loadable software.

13.5 MULTIPLE-CHOICE QUESTIONS

1. A Level C software classification is one in which a failure could result in:
   
   (a) aircraft loss
   (b) fatal injuries to passengers or crew
   (c) minor injuries to passengers or crew.
2. A Level B software classification is one in which the probability of failure is:
   (a) extremely improbable
   (b) extremely remote
   (c) remote.

3. A software configuration management plan must be created and maintained by:
   (a) the CAA or FAA
   (b) the aircraft operator
   (c) the relevant DO.

4. Weather radar is an example of:
   (a) Class B software
   (b) Class C software
   (c) Class D software.

5. Electronic engine control software is an example of:
   (a) DFLD
   (b) LSAP
   (c) OSS.

6. OSS and UMS are specific classes of:
   (a) FLS
   (b) LSAP
   (c) DFLD.

7. The final stage of loading EEC software is:
   (a) disconnecting the PDL
   (b) verifying the loaded software
   (c) switching on and testing the system.
It is an unfortunate fact of life that the operation of virtually all items of electrical and electronic equipment can potentially disturb the operation of other nearby items of electronic equipment. In recent years increasing incidence of interference has prompted the introduction of legislation that sets strict standards for the design of electrical and electronic equipment. The name given to this type of disturbance is electromagnetic interference (EMI) and the property of an electrical or electronic product (in terms of its immunity to the effects of EMI generated by other equipment and its susceptibility to the generation and radiation of its own EMI) is known as electromagnetic compatibility (EMC).

EMI (and the need for strict EMC control) can be quickly demonstrated by placing a portable radio receiver close to a computer and tuning over the AM and FM wavebands. Wideband noise and stray EMI radiation should be easily detected.

14.1 EMI GENERATION

As an example of how EMI can be produced from even the most basic of electronic circuits, consider the simple DC power supply consisting of nothing more than a transformer, bridge rectifier, reservoir capacitor and load resistor (see Figure 14.1). At first sight a simple circuit of this type may look somewhat benign, but just take a look at the waveforms shown in Figure 14.2.

The primary and secondary voltage waveforms are both sinusoidal and, as you might expect, the load voltage comprises a DC level (just less than the peak...
secondary voltage) onto which is superimposed a ripple component at 800 Hz. What’s more significant (in terms of EMC and EMI) is the waveform of the current that flows in both the secondary and primary circuits. Rather than being sinusoidal (as you might have thought) this current comprises a series of fast rise-time rectangular pulses as each pair of diodes conducts alternately in order to replace the lost charge in the reservoir capacitor. Unfortunately, these rectangular pulses contain numerous harmonics.

### 14.1.1 Harmonics

An integer multiple of a fundamental frequency is known as a harmonic. In addition, we often specify the order of the harmonic (second, third, and so on). Thus the second harmonic has twice the frequency of the fundamental, the third harmonic has three times the frequency of the fundamental, and so on.

Consider, for example, a fundamental signal at 1 kHz. The second harmonic would have a frequency of 2 kHz, the third harmonic a frequency of 3 kHz and the fourth harmonic a frequency of 4 kHz. Note that, in musical terms, the relationship between notes that are one octave apart is simply that the two frequencies have a ratio of 2:1 (in other words, the higher frequency is double the lower frequency).

All complex waveforms (of which rectangular pulses and square waves are examples) comprise a fundamental component together with a number of harmonic components, each having a specific amplitude and with a specific phase relative to the fundamental. The mathematical study of complex waves is known as ‘Fourier analysis’ and this allows us to describe a complex wave using an equation of the form:

\[
v = V_1 \sin(\omega t) + V_2 \sin(2\omega t \pm \theta_2) + V_3 \sin(3\omega t \pm \theta_3) + \ldots
\]
where \( r \) is the instantaneous voltage of the complex waveform at time, \( t \). \( V_1 \) is the amplitude of the fundamental, \( V_2 \) is the amplitude of the second harmonic, \( V_3 \) is the amplitude of the third harmonic, and so on. Similarly, \( \phi_2 \) is the phase angle of the second harmonic (relative to the fundamental), \( \phi_3 \) is the phase angle of the third harmonic (relative to the fundamental), and so on. The important thing to note from this is that all of the individual components that go to make up a complex waveform have a sine wave shape. Putting this another way, a complex wave is made up from a number of sine waves.

### 14.1.2 Frequency spectrum of a pulse

A rectangular pulse comprises a fundamental component together with an infinite series of harmonics. Taking a square wave as an extreme example of a rectangular pulse, the composite waveform can be analysed into the following components:

- a fundamental component at a frequency, \( f \), and amplitude, \( V \);
- a third harmonic component at a frequency, \( 3f \), and amplitude \( V/3 \);
- a fifth harmonic component at a frequency, \( 5f \), and amplitude, \( V/5 \);
- a seventh harmonic component at a frequency, \( 7f \), and amplitude, \( V/7 \);

and so on, ad-infinitum!

This process (up to the seventh harmonic) is shown in Figure 14.3. The corresponding frequency spectrum (showing amplitude plotted against frequency) appears in Figure 14.4. Note that, to produce a perfect square wave, the amplitude of the harmonics should decay in accordance with their harmonic order and they must all be in phase with the fundamental.

Using Fourier analysis, the equation for a square wave voltage is:

\[
r = V \sin(\omega t) + \frac{V}{3} \sin(3\omega t) + \frac{V}{5} \sin (5\omega t) + \ldots
\]

where \( V \) is the amplitude of the fundamental and \( \omega \) is the angular frequency of the fundamental (note that \( \omega = 2\pi f \), where \( f \) is the frequency of the fundamental).
14.2 EMC and avionic equipment

In recent years, EMC and EMI have become a very important consideration for avionic equipment designers. To ensure compliance with increasingly demanding standards, it has become essential for designers to consider the effects of unwanted signals generated by avionic equipment, as well as the susceptibility of the equipment to interference from outside. To illustrate this important point we will again use the example of the simple low-voltage DC power supply that we met in Figure 14.1. For this unit to meet stringent EMC requirements it needs to be modified as shown in Figure 14.5. The additional components have the following functions:

1. C5, C6, C7 and C8 provide additional decoupling (effective at high frequencies) in order to prevent instability in IC1 and IC2. Without these components, and depending upon circuit layout (stray reactances) the regulator circuits may oscillate at a high frequency.
2. C9 and C10 provide additional high-frequency decoupling to remove noise present on the output voltage rails.
3. C11, L1, L2, C12 and C13 provide a low-pass supply filter to remove noise and spurious signals resulting from the harmonics of the switching action of the diode rectifiers. This filter also reduces supply-borne noise that would otherwise enter the equipment from the supply.
4. A low-resistance ground connection is introduced to ensure that there is an effective connection between aircraft ground and the equipment chassis (note that there is also an earth connection to the laminations and internal screening on the mains transformer).

**TEST YOUR UNDERSTANDING 14.1**

A square wave voltage has an amplitude of 50 V and a frequency of 2 kHz. Determine:

1. the amplitude of the fifth harmonic component
2. the frequency of the fifth harmonic component.

**TEST YOUR UNDERSTANDING 14.2**

Sketch the circuit of a low-pass filter suitable for incorporation in a 400 Hz AC supply connection.

**KEY POINT**

Complex waveforms (such as square waves) comprise a fundamental together with a large number of harmonic components.
14.3 SPECTRUM ANALYSIS

Accurate EMC measurements involve the use of a specialised instrument known as a spectrum analyser. Such instruments display signal level (amplitude) against frequency. The complete block diagram of a modern spectrum analyser is shown in Figure 14.6. The radio frequency (RF) input signal is fed to a relay switched preamp/attenuator section that provides a maximum of 50 dB attenuation or up to 10 dB of gain. The signal then passes through a low-pass filter into a wideband mixer, where it is mixed with the 1.5–2.5 GHz local oscillator signal to give an intermediate frequency (IF) output at 1.5 GHz.

The tuning/sweep voltage is fed through a linearising amplifier which compensates for the oscillator’s non-linear tuning characteristic. The tuning input is 0 V at zero input frequency, up to +5 V at 1,000 MHz input frequency. This represents a tuning characteristic equivalent to 200 MHz/V.

The signal from the first mixer is then amplified by the first IF amplifier and then filtered by a four-stage band pass 1,500 MHz cavity filter. The output of the filter is then coupled into the second mixer, where it is mixed with the output of the second local oscillator to give the second IF output at 10.7 MHz. The second local oscillator is tuned to 10.7 MHz below the first IF (i.e. approximately 1,490 MHz).

Next, the 10.7 MHz IF signal is fed to a wideband amplifier. In ‘wideband mode’ the IF signal is passed to a logarithmic amplifier. The output of the wideband

---

**KEY POINT**

Avionic equipment incorporates low-pass filters in order to reject noise and spurious harmonic signals that might otherwise be conveyed and/or radiated from supply voltage connections.

**KEY POINT**

Noise is defined as any unwanted signal component. Noise can arise from various sources and, in particular, switching circuits.
amplifier also feeds the 120 kHz filter/amplifier stages. The combined effect of a total of three ceramic filters provides the required filter shape. The output of the 120 kHz filter stage also feeds the 9 kHz filter stages.

The logarithmic amplifier consists of an initial stage followed by two 30 dB gain-limiting amplifiers. Audio signal monitoring is provided by means of a conventional audio amplifier. The input of this stage can be taken from the FM detector or from the logarithmic amplifier when AM demodulation is required.

An 8-bit Z80 microprocessor carries out the main digital signal processing and also generates the digital video signals that are fed to the display circuitry. The digital system’s master clock operates at 8 MHz, which is then divided by two to provide the Z80’s clock input. Further division of the master clock provides the display system’s line frequency (31.25 kHz) as well as the frame signal (60 Hz) and a further 30 Hz control signal.

The Z80 CPU operates in conjunction with an 8K EPROM containing the control software and a 2K RAM that stores the video and calibration data. In order to retain the calibration data when the unit is switched off, the RAM is backed up by a long-life lithium battery.

The video display system uses a vertical raster with 448 lines displayed, each having a vertical resolution of 192 pixels (bits). The line scan is from bottom to top, the frame scan from left to right. The picture is made up of the spectrum display together with separately enabled amplitude and frequency cursors.

An internal 50 MHz crystal calibrator (using a third overtone crystal) is used to provide calibration at harmonics up to 1 GHz. The fundamental output of this stage is set accurately to a level of –20 dBm.

A typical display produced by the analyser is shown in Figure 14.7. The vertical scale shows amplitude in dBm (decibels relative to 1 mW) over the range –100 dBm to +10 dBm, while the horizontal scale shows frequency (in MHz) over the range 0.1 MHz to 1,000 MHz. The signal under investigation appears as a series of lines (i.e. a line spectrum). In order to provide a means of accurately measuring the amplitude and frequency of individual signal components, the spectrum analyser display has two cursors; one for amplitude and one for frequency. The measured signal component in Figure 14.7 has an amplitude of –26 dBm and a frequency of 121 MHz (note that modern instruments invariably provide separate digital displays of the cursor settings).

The measurement range provided by the spectrum analyser amounts to a total of 110 dB, but the ultimate sensitivity of the instrument is determined by the noise produced in the instrument itself. This is usually referred to as the instrument’s noise floor (see Figure 14.8). In this case the noise floor (with no signal
connected) is at a level of about –95 dB (less than 1 picowatt).

Note that modern instruments typically have noise floors of between –95 dB and –110 dB. Figure 14.9 shows how the spectrum analyser displays a fairly simple complex waveform comprising a fundamental component at 250 MHz with a level of –20 dBm, a second harmonic at 500 MHz with a level of –60 dBm, and a third harmonic at 750 MHz with a level of –90 dBm.

Note that any other harmonic components that may be present have a level that is below the instrument’s noise floor (i.e. they must have signal levels of less than –95 dBm).

The display of a more complex signal is shown in Figure 14.10. Here, there are two signals — one modulated by the other — together with a number of side frequency components and harmonics. The waveform has the following components:

- a fundamental component at 50 MHz with a level of –5 dBm;
- a higher frequency fundamental at 450 MHz with a level of –20 dB modulated by the 50 MHz signal;
- a first pair of side frequency components at 400 MHz and 500 MHz with levels of –40 dBm and –45 dBm, respectively;
- a second pair of side frequency components at 350 MHz and 550 MHz, with levels of –60 dBm and –75 dBm, respectively;
- a third pair of side frequency components at 300 MHz and 600 MHz with levels of –85 dBm and –93 dBm, respectively;
- a second harmonic of the 50 MHz fundamental at 100 MHz with a level of –70 dBm.

A signal with noise sidebands is shown in Figure 14.11. Since noise is essentially a randomly distrib-
uted waveform (in terms of frequency) it appears as a blurred area (like the noise floor itself) rather than as a line spectrum. This diagram shows how the noise spreads out either side of the fundamental at 450 MHz. The second harmonic of the fundamental (at 900 MHz) is also just discernible above the noise.

Figures 14.12 and 14.13, respectively, show the appearance of low- and high-frequency noise. In the first case, the noise reaches a broad peak at about 10 MHz, and in the latter it reaches a peak at about 900 MHz.

14.3.1 Frequency bands

For convenience the complete frequency spectrum is divided into a number of bands. These bands are often referred to when describing the effects of particular types of EMI, and they are shown in Table 14.1.

TEST YOUR UNDERSTANDING 14.3

Explain what is meant by the ‘noise floor’ of a spectrum analyser and the effect this will have on the ability of the instrument to accurately measure EMI.

14.4 EFFECTS AND CAUSES OF EMI

EMI can be defined as the presence of unwanted voltages or currents which can adversely affect the performance of an avionic system. The effects of EMI include errors in instrument indications (both above and below true), heterodyne whistles present on audio signals, herringbone patterns in video displays, repetitive pulse noise (buzz) on intercom and cabin phone systems, desensitising of radio and radar receivers, false indications in radar and distance-measuring equipment, unwarranted triggering of alarms, and so on. Note that, in certain circumstances, the performance of the device that emits EMI may also suffer impaired performance.

14.4.1 Sources of EMI

Some sources known to emit EMI include fluorescent lights, radio and radar transmitters, power lines, window heat controllers, induction motors, switching and light-dimming circuits, microprocessors and associated circuitry, pulsed high-frequency circuits, bus cables (but not fibre-optic cables), static discharge and lightning. The energy generated by these sources can be conducted and/or radiated as an
electromagnetic field. Unless adequate precautions are taken to eliminate the interference at source and/or to reduce the equipment’s susceptibility to EMI, the energy can then become coupled into other circuits.

Conduction is the process by which the energy is transmitted through electrically conductive paths such as circuit wiring or aircraft metallic structure. In electromagnetic field radiation, energy is transmitted through electrically non-conductive paths, such as air, plastic materials or fibreglass.

Systems which may be susceptible to electromagnetic interference include radio and radar receivers, microprocessors and other microelectronic systems, electronic instruments, control systems, audio and in-flight entertainment systems (IFEs).

Whether a system will have an adverse response to electromagnetic interference depends on the type and amount of emitted energy in conjunction with the susceptibility threshold of the receiving system. The threshold of susceptibility is the minimum interference signal level (conducted or radiated) that results in equipment performance that is indistinguishable from the normal response. If the threshold is exceeded then the performance of the equipment will become degraded. Note that when the susceptibility threshold level is greater than the levels of conducted or radiated emissions, electromagnetic interference problems do not exist. Systems to which this applies are said to be electromagnetically compatible. In other words, the systems will operate as intended and any EMI generated is at such a level that it does not affect normal operation.

### 14.4.2 Types of interference

EMI can be categorised by bandwidth, amplitude, waveform and occurrence. The bandwidth of interference is the frequency range in which the interference exists. The interference bandwidth can be narrow or broad.

Narrowband interference can be caused by such items as AC power rails, microprocessor clocks (and their harmonics), radio transmitters and receivers. These items of equipment all contain sources (e.g. clock oscillators) that work on specific frequencies. These signals (along with unwanted harmonics) can be radiated at low levels from the equipment.

Broadband interference is caused by devices generating random frequencies and noise which may be repetitive but is not confined to a single frequency or range of frequencies. Examples of this type of interference are power supplies, LCD and AMLCD (by virtue of their high-frequency AC supplies), switched-mode power supplies, switching power controllers and microprocessor bus systems.

Interference amplitude is the strength of the signal received by the susceptible system. The amplitude can be constant or can vary predictably with time, or can be totally random. For example, a 115 V AC power line can induce a stable sinusoidal waveform on adjacent 28 V DC power or signal lines. The amplitude of the interference will depend on the load current in the AC power line (recall that the magnetic field produced around a conductor is directly proportional to the current flowing in the conductor). Examples of

<table>
<thead>
<tr>
<th>Frequency range</th>
<th>Wavelength</th>
<th>Designation</th>
</tr>
</thead>
<tbody>
<tr>
<td>300 Hz to 3 kHz</td>
<td>1,000 km to 100 km</td>
<td>Extremely low frequency (ELF)</td>
</tr>
<tr>
<td>3 kHz to 30 kHz</td>
<td>100 km to 10 km</td>
<td>Very low frequency (VLF)</td>
</tr>
<tr>
<td>30 kHz to 300 kHz</td>
<td>10 km to 1 km</td>
<td>Low frequency (LF)</td>
</tr>
<tr>
<td>300 kHz to 3 MHz</td>
<td>1 km to 100 m</td>
<td>Medium frequency (MF)</td>
</tr>
<tr>
<td>3 MHz to 30 MHz</td>
<td>100 m to 10 m</td>
<td>High frequency (HF)</td>
</tr>
<tr>
<td>30 MHz to 300 MHz</td>
<td>10 m to 1 m</td>
<td>Very high frequency (VHF)</td>
</tr>
<tr>
<td>300 MHz to 3 GHz</td>
<td>1 m to 10 cm</td>
<td>Ultra high frequency (UHF)</td>
</tr>
<tr>
<td>3 GHz to 30 GHz</td>
<td>10 cm to 1 cm</td>
<td>Super high frequency (SHF)</td>
</tr>
</tbody>
</table>
random interference are environmental noise and inductive switching transients. Environmental noise is the aggregate of all electromagnetic emissions present in a particular space or area of concern at any one time. This is usually measured over a defined spectrum (e.g. 30 kHz to 30 MHz).

It is important to be aware that there is no one specific waveform that produces electromagnetic interference. Instead, it is the change from one signal level to another in conjunction with the rate at which it changes that determines the amount of electromagnetic energy released. More energy is released when the change in signal level and rate is increased.

The occurrence of EMI can be categorised as being either periodic (continuously repetitive), aperiodic (predictable but not continuous), or random (totally unpredictable).

### 14.4.3 EMI reduction

Planning for electromagnetic compatibility must be initiated in the design phase of a device or system (as discussed in Section 14.2). If this is not satisfactorily achieved, interference problems may arise. The three factors necessary to produce an EMI problem are a noise source (see Figure 14.14), a means of coupling (by conduction or radiation) and a susceptible receiver. To reduce the effects of EMI, at least one of these factors must be addressed. The following lists techniques for EMI reduction under these three headings (note that some techniques address more than one factor):

1. **Suppress interference at source.**
   - Enclose interference source in a screened metal enclosure and then ensure that the enclosure is adequately grounded.
   - Use transient suppression on relays, switches and contactors.
   - Twist and/or shield bus wires and data bus connections.
   - Use screened (i.e. coaxial) cables for audio and radio frequency signals.
   - Keep pulse rise times as slow and long as possible.
   - Check that enclosures, racks and other supporting structures are grounded effectively.

2. **Reduce noise coupling.**
   - Separate power leads from interconnecting signal wires.

![](image1.png)

**Figure 14.14** Transient switching pulses appearing on the output of a DC power supply without adequate supply filtering. Note that the AC ripple is 20 mV peak–peak while the noise spikes are up to five times this value. The noise spikes can be virtually eliminated by adding a supply filter.
• Twist and/or shield noisy wires and data bus connections.
• Fit an optical fibre data bus where possible.
• Use screened (i.e. coaxial) cables for audio and radio frequency signals.
• Keep ground leads as short as possible.
• Break interference ground loops by incorporating isolation transformers, differential amplifiers and balanced circuits.
• Filter noisy output leads.
• Physically relocate receivers and sensitive equipment away from interference source.

3. Increasing susceptibility thresholds.
   • Limit bandwidth to only that which is strictly necessary.
   • Limit gain and sensitivity to only that which is strictly necessary.
   • Ensure that enclosures are grounded and that internal screens are fitted.
   • Fit components that are inherently less susceptible to the effect of stray radiated fields.

14.5 AIRCRAFT WIRING AND CABLEING

When many potential sources of EMI are present in a confined space, aircraft wiring and cabling has a crucial role to play in maintaining electromagnetic compatibility. The following points should be observed:

1. Adequate wire separation should be maintained between noise source wiring and susceptible wiring (for example, ADF wiring should be strategically routed in the aircraft to ensure a high level of EMC).
2. Any changes to the routing of this wiring could have an adverse affect on the system. In addition, the wire separation requirements for all wire categories must be maintained.
3. Wire lengths should be kept as short as possible to keep coupling at a minimum. Where wire shielding is incorporated for lightning protection, it is important that the shield grounds (pigtails) be kept to their designed length. An inch or two added to the length will result in degraded lightning protection.

4. Equipment grounds must not be lengthened beyond design specification. A circuit ground with too much impedance may no longer be a true ground.
5. With the aid of the technical manuals, grounding and bonding integrity must be maintained. This includes proper preparation of the surfaces where electrical bonding is made.

14.6 GROUNDING AND BONDING

The electrical integrity of the aircraft structure is extremely important as a means of reducing EMI and also protecting the aircraft, its passengers, crew and systems from the effects of lightning strikes and static discharge. Grounding and bonding are specific techniques that are used to achieve this (see Figure 14.15). Grounding and bonding can also be instrumental in minimising the effects of high-intensity radio frequency fields (HIRF) emanating from high-power radio transmitters and radar equipment. Grounding and bonding resistances of less than 0.001–0.003 Ω are usually required.

14.6.1 Grounding

Grounding is defined as the process of electrically connecting conductive objects to either a conductive structure or some other conductive return path for the purpose of safely completing either a normal or fault circuit. Bonding and grounding connections are made in an aircraft in order to accomplish the following:

14.15 Bonding straps
• protect aircraft, crew and passengers against the effects of lightning discharge;
• provide return paths for current;
• prevent the development of RF voltages and currents;
• protect personnel from shock hazards;
• maintain an effective radio transmission and reception capability;
• prevent accumulation of static charge.

The following general procedures and precautions apply when making bonding or grounding connections:

• bond or ground parts to the primary aircraft structure where possible;
• make bonding or grounding connections so that no part of the aircraft structure is weakened;
• bond parts individually if feasible;
• install bonding or grounding connections against smooth, clean surfaces;
• install bonding or grounding connections so that vibration, expansion or contraction, or relative movement in normal service, will not break or loosen the connection;
• check the integrity and effectiveness of a bonded or grounded connection using an approved bonding tester.

14.6.2 Bonding

Bonding refers to the electrical connecting of two or more conducting objects that are not otherwise adequately connected. The main types of bonding are:

• Equipment bonding: low-impedance paths to the aircraft structure are generally required for electronic equipment to provide radio frequency return circuits and to facilitate reduction in EMI.
• Metallic surface bonding: all conducting objects located on the exterior of the airframe should be electrically connected to the airframe through mechanical joints, conductive hinges or bond straps, which are capable of conducting static charges and lightning strikes.
• Static bonds. All isolated conducting paths inside and outside the aircraft with an area greater than three square inches and a linear dimension over three inches that are subjected to electrostatic charging should have a mechanically secure electrical connection to the aircraft structure of adequate conductivity to dissipate possible static charges.

KEY POINT

Initial control of EMI is achieved in modern aircraft by careful design and rigorous testing. Routine maintenance helps to ensure the aircraft retains electromagnetic compatibility, thereby keeping EMI problems to a minimum.

KEY POINT

Effective grounding and bonding provide a means of ensuring the electrical integrity of the aircraft structure as well as minimising the effects of HIRF fields and the hazards associated with lightning and static discharge.

14.7 MULTIPLE-CHOICE QUESTIONS

1. Aperiodic noise is:
   (a) regular but not continuous
   (b) regular and continuous
   (c) entirely random in nature.

2. EMI can be conveyed from a source to a receiver by:
   (a) conduction only
   (b) radiation only
   (c) conduction and radiation.

3. The display produced by a spectrum analyser shows:
   (a) frequency plotted against time
   (b) amplitude plotted against time
   (c) amplitude plotted against frequency.
4. EMI can be reduced by means of:
   (a) screening only
   (b) screening and filtering
   (c) screening, bonding and filtering.

5. The effects of HIRF can be reduced by:
   (a) screening only
   (b) screening and filtering
   (c) screening, bonding and filtering.

6. The typical maximum value of bonding resistance is:
   (a) less than 0.005 $\Omega$
   (b) between 0.005 $\Omega$ and 0.05 $\Omega$
   (c) more than 0.05 $\Omega$.

7. Effective protection against lightning and static discharge damage to an aircraft requires that:
   (a) all isolated conducting parts must have high resistance to ground
   (b) all parts of the metal structure of the aircraft must be bonded to ground
   (c) all power and bus cables must be well insulated.

8. Supply-borne noise can be eliminated by means of:
   (a) a low-pass filter
   (b) a high-pass filter
   (c) a band-pass filter.

9. Noise generated by a switching circuit is worse when:
   (a) switching is fast and current is low
   (b) switching is slow and current is high
   (c) switching is fast and current is high.
This chapter provides an overview of the major avionic systems fitted to a modern passenger aircraft. The aim is to put into context the material contained in previous chapters, which underpins the operation of these complex systems, including:

- aircraft communication addressing and reporting system (ACARS)
- electronic centralised aircraft monitoring (ECAM)
- electronic flight instrument system (EFIS)
- engine indication and crew alerting system (EICAS)
- fly-by-wire (FBW)
- flight management system (FMS)
- Global Positioning System (GPS)
- inertial reference system (IRS)
- inertial navigation system (INS)
- traffic alert collision avoidance system (TCAS).

This chapter also introduces the test techniques used to detect faults on these systems:

- automatic test equipment (ATE)
- built-in test equipment (BITE).

### 15.1 Aircraft Communication Addressing and Reporting System

ACARS is a digital data link system transmitted in the VHF range (129–137 MHz). ACARS provides a means by which aircraft operators can exchange data with an aircraft without human intervention. This makes it possible for an airline to communicate with the aircraft in their fleet in much the same way as it is possible to exchange data using a land-based digital network. ACARS uses an aircraft’s unique identifier and the system has some features that are similar to those currently used for electronic mail.

The ACARS system was originally specified in the ARINC 597 standard but has been revised as ARINC 724B. A significant feature of ACARS is the ability to provide real-time data on the ground relating to aircraft performance (see Figure 15.1). This has made it possible to identify and plan aircraft maintenance activities.

**Example of a downlink ACARS message sent from a Boeing 777 aircraft**

```
ACARS mode: E Aircraft reg: N27015
Message label: H1 Block id: 3
Msg no: C36C Flight id: CO0004
Message content:-
#CFBBY ATTITUDE INDICATOR
MSG 2820121 A 0051 06SEP06 CL H PL DB
FUEL QUANTITY PROCESSOR UNIT
MSG 3180141 A 0024 06SEP06 TA I 23
PL
DISPLAYS-2 IN LEFT AIMS
MSG 2394201 A 0005 06SEP06 ES H PL MSG
2717018
```

15.1 Example of a downlink ACARS message sent from a Boeing 777 aircraft
ACARS communications are automatically directed through a series of ground-based ARINC (Aeronautical Radio Incorporated) computers to the relevant aircraft operator. The system helps to reduce the need for mundane HF and VHF voice messages and provides a system which can be logged and tracked. Typical ACARS messages cater for the transfer of routine information such as:

- passenger loads
- departure reports
- arrival reports
- fuel data
- engine performance data.

This information can be requested by the company and retrieved from the aircraft at periodic intervals or on demand. Prior to ACARS this type of information would have been transferred via VHF voice communication.

ACARS uses a variety of hardware and software components including those which are installed on the ground and those which are present in the aircraft. The aircraft ACARS components include a management unit, which deals with the reception and transmission of messages via the VHF radio transceiver, and the control unit, which provides the crew interface and consists of a display screen and printer. The ACARS Ground Network comprises the ARINC ACARS remote transmitting/receiving stations and a network of computers and switching systems. The ACARS command, control and management sub-system consists of the ground-based airline operations and associated functions including operations control, maintenance and crew scheduling.

There are two types of ACARS messages: downlink messages that originate from the aircraft; and uplink messages that originate from ground stations. The data rate is low and messages comprise plain alphanumeric characters. Frequencies used for the transmission and reception of ACARS messages are in the band extending from 129 MHz to 137 MHz (VHF), as shown in Table 15.1. Note that different channels are used in different parts of the world. A typical ACARS message (see Figure 15.2) consists of:

- mode identifier (e.g. 2)
- aircraft identifier (e.g. G-DBCC)
- message label (e.g. 5U)
- block identifier (e.g. 4)
- message number (e.g. M55A)
- flight number (e.g. BD01NZ)
- message content (see Figure 15.2).

### Table 15.1 ACARS channels

<table>
<thead>
<tr>
<th>Frequency</th>
<th>ACARS service</th>
</tr>
</thead>
<tbody>
<tr>
<td>129.125 MHz</td>
<td>USA and Canada (additional)</td>
</tr>
<tr>
<td>130.025 MHz</td>
<td>USA and Canada (secondary)</td>
</tr>
<tr>
<td>130.450 MHz</td>
<td>USA and Canada (additional)</td>
</tr>
<tr>
<td>131.125 MHz</td>
<td>USA (additional)</td>
</tr>
<tr>
<td>131.475 MHz</td>
<td>Japan (primary)</td>
</tr>
<tr>
<td>131.525 MHz</td>
<td>Europe (secondary)</td>
</tr>
<tr>
<td>131.550 MHz</td>
<td>USA, Canada, Australia (primary)</td>
</tr>
<tr>
<td>131.725 MHz</td>
<td>Europe (primary)</td>
</tr>
<tr>
<td>136.900 MHz</td>
<td>Europe (additional)</td>
</tr>
</tbody>
</table>

15.2 **EFIS**

As mentioned in Chapter 1, most modern passenger aircraft use electronic flight instrument system (EFIS) displays in what has become known as the ‘glass cockpit’ (see Figure 15.3). EFIS provides large, clear, high-resolution displays that are easy to view under wide variations of ambient light intensity. Displays can be independently selected and configured as required by the captain and first officer and the ability to display information from various data sources in a single.
display makes it possible for the crew to rapidly assimilate the information they need. A notable disadvantage of EFIS is a significant increase in EMI (see page 162). The two most commonly featured EFIS instruments are the electronic horizontal situation indicator (EHSI) and the electronic attitude direction indicator (EADI), as shown in Figures 15.5 and 15.6.

The EFIS uses input data from several sources, including:

- VOR/ILS/MLS
- TACAN (see later)
- pitch, roll, heading rate and acceleration data from an attitude heading reference system (AHRS) or conventional vertical gyro
- compass system
- radar altimeter
- air data system
- distance measuring equipment (DME)
- area navigation system (RNAV)
- vertical navigation system (VNAV)
• weather radar system (WXR)
• automatic direction finder (ADF).

A typical EFIS system comprises:
• primary flight display (PFD)
• navigation display (ND)
• display select panel (DSP)
• display processor unit (DPU)
• weather radar panel (WXP)
• multifunction display (MFD)
• multifunction processor unit (MPU).

### 15.2.1 EFIS displays

The primary flight display (PFD) is a multicolour CRT or AMLCD displaying aircraft attitude and flight control system steering commands, including VOR, localiser, TACAN or RNAV deviation; and glide slope or pre-selected altitude deviation. The PFD provides flight control system mode annunciation, auto-pilot engage annunciation, attitude source annunciation, marker beacon annunciation, radar altitude, decision height set and annunciation, fast–slow deviation or angle–altitude alert, and excessive ILS deviation.

The navigation display (ND) provides a plan view of the aircraft’s horizontal navigation situation. Data includes heading and track, VOR, ILS or RNAV course and deviation (including annunciation or deviation type), navigation source annunciation, to/from, distance/direction, time-to-go, elapsed time, course information and source annunciation from a second navigation source, and weather radar data. The ND can also be operated in an approach format or an en-route format with or without weather radar information included in the display. Operational display parameters (such as ground speed, time-to-go, time and wind direction/speed) can be selected by means of the display select panel (DSP).

The multifunction display (MFD) is a colour CRT or AMLCD (see Chapter 11). Standard functions displayed by the unit include weather radar (in which the colours green, yellow and red are used to indicate increasing levels of storm activity), pictorial navigation map, checklists and other operating data. In the event of a failure of any of these displays, the required information can be shown on the displays that remain functional.

The display processor unit (DPU)/multifunction processor unit (MPU) provides sensor input processing and switching for the necessary deflection and video signals, and power for the electronic flight displays. The DPU can drive up to two electronic flight displays with different deflection and video signals.

### KEY POINT

ACARS provides the aircraft operator with a means of delivering real-time information on the aircraft’s performance. The system operates in conjunction with the aircraft’s VHF radio and reduces the need for mundane voice traffic.

### TEST YOUR UNDERSTANDING 15.1

A message from the crew of an A319 aircraft is shown in Figure 15.7. Explain how this message was sent and why it was necessary. Also specify likely frequencies used to transmit the message.

ACARS mode: R Aircraft reg: G-EUPR
Message label: 10 Block id: 8
Msg no: M06A Flight id: BA018Z Message content:- FTX01.ABZK0BA BA1304
WE NEED ENGINEERING
TO DO PDC ON NUMBER 2
IDG
CHEERS ETL 0740
GMT

### TEST YOUR UNDERSTANDING 15.2

Describe two different types of display provided by the EFIS fitted to a modern passenger aircraft. What information appears in each of these displays?

ACARS mode: R Aircraft reg: G-EUPR
Message label: 10 Block id: 8
Msg no: M06A Flight id: BA018Z Message content:- FTX01.ABZK0BA BA1304
WE NEED ENGINEERING
TO DO PDC ON NUMBER 2
IDG
CHEERS ETL 0740
GMT
15.2.2 EFIS operation

The simplified block schematic diagram of an EFIS system is shown in Figure 15.8. The system is based on three symbol generators. These are simply three microprocessor-based computers (see Chapter 6) that process data received from a wide variety of aircraft systems (VOR, DME, IRS, etc.) and generate the signals that drive the EFIS displays (and so generate the ‘symbols’ that appear on the EFIS screens). The left symbol generator supplies the captain’s EADI and EHSI while the right symbol generator supplies the first officer’s EHSI and EADI. The centre symbol generator provides a backup system that can be used to replace the left or right symbol generator in the event of failure. To cater for the very wide variations in ambient light intensity found in the cockpit, light sensors are fitted to individual displays in order to provide automatic brightness control. Several sensors are usually fitted. For example, two on the glare shield and one on each EADI/EHSI display. In addition, a control panel is fitted in order to provide manual adjustment of the displays by the crew. Outputs from the left and centre symbol generators are sent to the digital flight data acquisition unit (DFDAU). This unit conditions the signals to produce a digital output which is sent to the digital flight data recorder (DFDR). The recorded data is stored in a crash-protected container inside the DFDR.

The DFDR is turned on automatically when the aircraft is in flight, or on the ground when an engine is running. The system may also be turned on manually by the function switch on the data management entry panel (DMEP) or tested by means of a switch on
the flight recorder control panel. The flight recorder system is monitored continuously by built-in test equipment (BITE) during operation. System failures are displayed on the flight recorder control panel and on the DFDAU and EICAS.

Each display unit uses either a colour AMLCD or a colour CRT. In the case of a CRT display, two types of scanning are used, raster scanning (see page 134) and stroke scanning. Raster scanning usually takes place at a rate of 50 Hz or 60 Hz. Stroke scanning is the technique used to display symbols and characters (superimposed on the raster scan). The colour CRT displays use electromagnetic deflection and a final anode voltage of around 18 kV. The deflection coils are mounted in a yoke around the neck of the CRT. Note that by virtue of the resistance of the deflection coils, the scanning voltage waveform has to be trapezoidal in shape rather than the linear ramp waveform (or ‘sawtooth’ wave) that would be appropriate for electrostatic deflection.

Symbols (see Figure 15.9) are displayed in various colours (for example, white for status symbols, yellow for cautionary information and red for warnings).

15.3 ENGINE INDICATION AND CREW ALERTING SYSTEM

EICAS is designed to provide all engine instrumentation and crew annunciations in an integrated format. The equivalent system on Airbus aircraft is the electronic centralised aircraft monitoring (ECAM) system.

The information supplied by EICAS/ECAM includes display of engine torque, inter-stage turbine temperature, high and low pressure gas generator RPM, fuel flow, oil temperature and pressure. As part of EICAS, graphical depiction of aircraft systems can be displayed. Such systems as electrical, hydraulic, de-icing, environmental and control surface position can
be represented. All aircraft messages relating to these systems are also displayed on EICAS.

EICAS improves reliability through elimination of traditional engine gauges and simplifies the flight deck through fewer stand-alone indicators. EICAS also reduces crew workload by employing a graphical presentation that can be rapidly assimilated. EICAS can also help to reduce operating costs by providing maintenance data.

A typical EICAS comprises two large high-resolution, colour displays together with associated control panels, two or three EICAS data concentrator units and a lamp driver unit. The primary EICAS display presents primary engine indication instruments and relevant crew alerts. It has a fixed format providing engine data including:

- RPM and temperature
- fuel flow and quantity
- engine vibration
- gear and flap details (where appropriate)
- caution alerting system (CAS) messages (colour-coded to indicate importance).

The secondary EICAS display indicates a wide variety of options to the crew and serves as a backup to the primary display. They are selectable in pages using the EICAS control panel and include the display of information relating to:

- landing gear position
- flaps/trim
- auxiliary power unit
- cabin pressurisation/anti-ice
- fuel/hydraulics
- flight control positions
- doors/pressurisation/environmental
- AC and DC electrical data.

The EICAS displays receive data bus inputs from the EICAS data conversion unit (DCU). The EICAS displays provide data bus outputs to the integrated
avionics processing system (IAPS) data concentrator units (DCUs). Note that the pilot or co-pilot can select either display. Selecting one display blanks the second display and allows data pages to be selected. The EICAS control panel is used to select pages. The information on the data buses is routed to both EICAS displays and both multi-function displays.

The DCU receives data in various formats from a variety of sensors, including the high- and low-speed ARINC 429 bus, from analogue and discrete inputs from the engines and other aircraft systems. These are concentrated and processed for transmission on system buses (ARINC or otherwise).

Outputs include crew-alerting logic, engine data to the displays, maintenance, diagnostic and aircraft data to the IAPS DCU, indicator lamp data to the lamp driver unit (LDU), aircraft system data to the flight data recorder (FDR) and data link management unit. The LDU is a dual-channel unit capable of driving up to 120 indicator lamps. Channels 1 and 2 receive digital buses from the DCU. The buses convey lamp activation words from the DCU. Channels 1 and 2 are identical and the outputs from each side are tied together (wired-OR logic). If one channel lamp sink fails, the other channel lamp sink will provide the function. The LDU monitors the lamp sinks to verify correct function and outputs the lamp sink states on a digital bus to the DCU.

The electronic routing units (ERUs) are junction boxes for the data concentrator units. The ERU splits each input signal to three output pins. The pilot ERU routes left-side airplane data and the co-pilot ERU routes right-side airplane data.

EICAS simplifies flight deck clutter by integrating the many electro-mechanical instruments that previously monitored engine and aircraft systems. Safety is increased and the pilot workload is simplified. EICAS continuously monitors the aircraft for out-of-tolerance or abnormal conditions and notifies the crew when an event occurs.

15.4 FLY-BY-WIRE

Fly-by-wire (FBW) is the name given to the electrical/electronic flight control system now used in all modern passenger aircraft. FBW was first introduced on a commercial passenger aircraft (the Airbus A320) in 1988.

 Rather than mechanical linkages operating hydraulic actuators, fly-by-wire systems move flight control surfaces (ailerons, rudders, etc.) using electrical wire connections driving motors. At the heart of the system are computers that convert the pilot’s commands into electrical signals which are transmitted to the motors, servos and actuators that drive the control surfaces. One problem with this system is the lack of ‘feel’ that the pilot experiences. Another is a concern over the reliability of FBW systems and the consequences of computer or electrical failure. Because of this, most FBW systems incorporate redundant computers as well as some kind of mechanical or hydraulic backup. FBW offers several important advantages. Computer control reduces the burden on a pilot and makes it possible to introduce automatic control. Another significant advantage of FBW is a significant reduction in aircraft weight, which in turn reduces fuel consumption and helps to reduce undesirable CO₂ emissions. Computer control can also help to ensure an aircraft is flown more precisely and always within its ‘flight protection envelope’. The crew are thus able to cope with emergency situations without running the risk of exceeding the flight envelope or over-stressing the aircraft.

Finally, FBW technology has made it possible for aircraft manufacturers to develop ‘families’ of very similar aircraft. Airbus/EADS, for instance, has the 107-seat A318 to the 555-seat A380, with comparable flight deck designs and handling characteristics. Crew training and conversion is therefore shorter, simpler and highly cost-effective. Additionally, pilots can remain current on more than one aircraft type simultaneously.
15.5 FLIGHT MANAGEMENT SYSTEM

Modern flight management systems (FMSs) provide advanced flight planning and navigation capability. FMSs utilise existing combinations of avionics equipment including GPS, VOR/DME, inertial reference/navigation systems (IRS/INS) and dead reckoning data to provide en-route, terminal and non-precision approach navigation guidance. FMSs typically provide:

- integrated automatic multi-sensor navigation
- sensor monitoring and control
- display/radar control
- moving map data display
- steering/pitch commands to the autopilot
- multiple waypoint lateral navigation (LNAV)
- optimised vertical navigation (VNAV)
- time/fuel planning and predictions based on the aircraft flight data
- data-based departure procedures (DP)
- standard terminal arrival routes (STAR) and approaches
- integrated EFIS and radar control
- system integrity and monitoring
- flight maintenance and execution.

FMSs require four main elements:

- flight management computer (FMC)
- display system (could be existing EFIS)
- data base storage unit (DBU) for waypoint storage
- control display unit (CDU) with keypad.

As with other flight safety-critical systems the FMS can be a ‘dual fit’. Each system computes aircraft
position. Cross-checks between systems ensure the validity and accuracy of flight data, offering aircrew the reassurance of dual-redundant systems for position and navigation.

Prior to departure, waypoints (including those of the origin and destination) are entered into the FMC via the CDU to define the route (as many as 100 in some systems). FMS initialisation also involves updating the FMS with operational flight parameters such as aircraft weight and fuel load.

The FMC’s navigational database includes airports and ground beacons and requires periodic updating (every 28 days with 13 update cycles per annum). The update is usually distributed on CD-ROM but requires floppy disk for installation on most aircraft (see page 157). In flight, the FMS uses its sensor inputs to calculate such variables as fuel consumption, airspeed, position and estimated time of arrival (ETA).

Vertical flight limits are maintained by a vertical navigation (VNAV) system and the aircraft’s autopilot system. VNAV monitors for correct speed and altitude (as determined in the flight plan) limits and ensures they are maintained at waypoints. By combining these automatic functions, a flight can be made almost entirely automatic, from initial take-off to final touch-down.

GPS was a spin-off from two experimental satellite navigation programmes carried out by the US Navy and Air Force and intended to facilitate precision aimed weapons and accurate troop deployment. Although the system is now available to the civilian market, it is still controlled and administered by the US Department of Defense. The system is highly accurate although, should the need arise, the US military can degrade the accuracy of the system to suit (up to 1,000 m). The main advantages of GPS are:

- accuracy
- global application
- signal fidelity.

Very precisely positioned orbiting satellites transmit very accurate, coded satellite position and time data. The receiver decodes this data and calculates its position relative to the satellite. If the receiver is moving then these characteristics must be included for accurate results. Using data from more than one satellite improves accuracy. The accuracy is ultimately based on very precise atomic clocks in each satellite. GPS consists of three segments: the space segment; the user segment; and the control segment. We shall briefly explain each of these in turn.

**KEY POINT**

The FMC requires regular updating of navigational data based on a 28-day period with 13 cycles per annum. Flight data (such as aircraft weight) must also be entered into the FMC prior to take-off.

### 15.6 GLOBAL POSITIONING SYSTEM

The Global Positioning System (GPS) provides the following positional information on a world-wide basis. The information can comprise:

- latitude
- longitude
- altitude
- time
- speed.

15.13 GPS uses 24 satellites in six orbital planes (there are four satellites in each plane)
15.6.1 Space segment

The space segment consists of a minimum of 24 operational satellites in six circular orbits 20,200 km (10,900 nautical miles) above the earth at an inclination angle of 55° with a 12-hour period. The satellites are spaced in orbit so that at any time a minimum of six satellites will be in view to users anywhere in the world (see Figure 15.13). The satellites (Figure 15.14) continuously broadcast position and time data to users throughout the world.

Transmission accuracy is maintained using atomic clocks accurate to within 0.1 s in 10,000 years. System accuracy is dependant on the perfect synchronisation of receiver and satellite clocks and the quality of the receiver clock. Note that using data from several satellites can help to reduce these errors.

15.6.2 User segment

The user segment consists of the receivers, processors and antennas that allow land, sea or airborne operators to receive the GPS satellite broadcasts and compute their precise position, velocity and time.

15.6.3 Control segment

The control segment consists of a master control station in Colorado Springs, with five monitor stations and three ground antennas located throughout the world. The monitor stations track all GPS satellites in view and collect ranging information from the satellite broadcasts. The monitor stations send the information they collect from each of the satellites back to the master control station, which computes extremely precise satellite orbits. The information is then formatted into updated navigation messages for each satellite. The updated information is transmitted to each satellite via the ground antennas, which also transmit and receive satellite control and monitoring signals.

15.6.4 GPS frequencies

Each satellite transmits two carriers; L1 at 1,575.42 MHz and L2 at 1,227.60 MHz. The L1 signal is modulated by a 1.023 MHz coarse/acquisition code (C/A) that repeats every 1 ms. Although the coded signal is repetitive it appears as random and is called pseudo random noise (PRN).

The L2 carrier is modulated by another apparently random coded PRN signal at 10.23 MHz. This signal is known as the precision (P) code and it repeats every 267 days. Each satellite is allocated a unique seven-day
segment of this code. A third signal containing navigation data is superimposed on each already complex signal containing the satellite status, ephemeris data, clock error and tropospheric and ionospheric data for error correction. Interestingly, the US control section can ‘dither’ these frequencies at any time to invalidate any known codes, thus making the GPS inoperative to those without knowledge of this dither coding. When this is done the code is known as the Y code and is only suitable for military/political applications.

With the exception of Y coding, each GPS receiver knows the modulation codes for each satellite and it is simply a matter of decoding the received signals to identify the satellite and then remove the carrier from the received signals to extract the navigation data.

**KEY POINT**

GPS provides highly accurate navigational information. The system is based on 24 satellites in six orbits with four satellites per orbit.

**TEST YOUR UNDERSTANDING 15.3**

What FMS data needs periodic updating and when should it be updated?

**TEST YOUR UNDERSTANDING 15.4**

On what does the ultimate accuracy of GPS data depend? How can this accuracy be improved?

### 15.7 INERTIAL REFERENCE SYSTEM

The inertial reference system (IRS) and inertial navigation system (INS) are methods of very accurate navigation that do not require any external input, a very useful characteristic as the system cannot then be easily liable to interference. On modern aircraft the IRS is separate and supplies data to the FMC (the latter performing the navigation function). The basic IRS consists of:

- gyroscopes
- linear accelerometers
- a navigation computer
- a clock.

Gyroscopes are instruments that sense directional deviation using the characteristics of a very fast-spinning mass to resist turning. Three such spinning masses are mounted orthogonally in a structure known as a gimbal. This frame allows the three rotating ‘gyros’ to maintain their direction of spin during aircraft movement, thereby indicating the ‘sensed’ changes. In aircraft they are used to sense angles of roll, pitch and yaw.

The accelerometers sense speed deviations (acceleration) along each of the axes. This three-dimensional accelerometer/gyro configuration gives three orthogonal acceleration components which can be vectorially summed. Combining the gyro-sensed direction change with the summed accelerometer outputs yields the directional acceleration of the vehicle.

The system clock determines the rate at which the navigation computer time integrates each directional acceleration in order to obtain the aircraft’s velocity vector. The velocity vector is then integrated with time to obtain the distance vector. These steps are continuously iterated throughout the navigation process, giving accurate positional information.

Crucial to the accuracy of the IRS is the initialisation of the system. This is the process of pre-flight gimbal and position alignment that gives a datum to measure all further in-flight movement from.

Basically, the gyros are ‘run up’ to speed, the compass heading is aligned and the latitude and longitude of the origin are entered into the computer. Any further movement of the aircraft can be calculated against this datum.

In modern avionic systems laser or optical gyros are used. These are more reliable due to containing few moving parts. In addition to this, in commercial operations, GPS data is used to further facilitate accuracy. This, of course, is not operationally necessary but can provide additional valuable information.
15.7.1 Gimballed systems

Gyros were initially located on a rotating platform connected to an outer housing via low-friction gimbals. Accelerometers were attached to each gimballed gyro axis and thus were held in a fixed orientation. Any angular motion was sensed by the rotating platform; this maintains the platform’s original orientation. Pickoffs on the gimbals measure the movement of the outer body around the steady platform and the accelerometers measure the body’s acceleration in the fixed inertial axes.

Gimballed systems had a tendency to ‘lock up’ or ‘topple’ in certain violent or fast manoeuvres. Additionally, they were dependent of mechanical/moving parts. The gimballed system’s primary advantage is its inherently lower error. Since its three orthogonal accelerometers are held in a fixed inertial orientation, only the vertically oriented one will be measuring gravity (and therefore experiencing gravity-related errors). In strap-down systems, the accelerometers all move in three axes and each experiences potential errors due to gravity.

Gimballed systems also have the advantage of simplicity of operation. The primary function of the gyro in a gimballed system is to spin and maintain a high moment of inertia, whereas strap-down gyros need to actually measure the subtended angles of motion.

15.7.2 Strap-down systems

With fewer moving parts, strap-down systems were developed using advanced computer technologies. Progress in electronics, optics and solid-state technology have enabled very accurate reliable systems to be developed. Modern commercially available equipment takes advantage of integrated circuit technologies.

Strap-down systems are fixed to the aircraft structure; the gyros detect changes in angular rate and the accelerometers detect changes in linear rate, both with respect to the fixed axes. These three axes are a moving frame of reference as opposed to the constant inertial frame of reference in the gimballed system. The system computer uses this data to calculate the motion with respect to an inertial frame of reference in three dimensions.

The strap-down system’s main advantage is the simplicity of its mechanical design. Gimballed systems require complex and expensive design for its gimbals, pickoffs and low-friction platform connections; strap-down systems are entirely fixed to the body in motion and are largely solid-state in design.

TCAS is a surveillance and avoidance system that alerts aircrew if any other aircraft enter a predetermined envelope of airspace around an aircraft. It is a secondary radar facility (transmits to and receives transmissions from other TCAS-equipped aircraft).

The evaluated traffic information is displayed as symbols on the ND. Note that altitude and vertical motion information is only available if the received signal comes from a mode-C or mode-S transponder. Otherwise the associated symbol on the ND will have no altitude information and no vertical motion arrow.

As TCAS checks the other aircraft’s relative distance permanently in short time intervals, it can therefore also calculate the other aircraft’s closure rate relative to its own aircraft. The closure rate is the most important variable and indeed a very fail-safe key to a meaningful collision prediction. Complex, trigonometric calculations of flight paths and ground speeds are unnecessary and may also result in unreliable extrapolations. Note that heading or bearing information is not required to compute a TCAS alarm.
When TCAS detects that an aircraft’s distance and closure rate becomes critical, it generates aural and visual annunciations for the pilots. If necessary, it also computes aural and visual pitch commands to resolve a conflict. If the other aircraft uses TCAS II as well, these pitch commands are coordinated with the other aircraft’s pitch commands so that both aircraft don’t ‘escape’ in the same direction. Even three aircraft can be coordinated.

It is important to be aware that TCAS provides only vertical guidance, no lateral guidance. TCAS also ignores performance limitations. In other words, when flying at maximum altitudes TCAS may still generate a climb command!

In addition to a transponder, various systems are required to run TCAS, including:

- IRS (attitude data, vertical motion data)
- gear position sensors (as the extended gear disturbs the lower directional antenna, detection of traffic flying below the aircraft must be inhibited)
- radio altimeters (TCAS must know the radio height as the alarm logic varies with the height above ground)
- the ground proximity warning system (GPWS) (overrides TCAS advisories during a wind shear or ground proximity warning).

When an intruder aircraft enters the protected area around an aircraft (see Figure 15.15), TCAS triggers an alarm. The threshold of the area is defined by the time to the closest point of approach (CPA) (the time-to-go is distance divided by closure rate, both combined vertically and horizontally). The protective area can be divided into two regions, one in which a traffic advisory (TA) message will be generated and one in which a resolution advisory (RA) message will be generated when an intruder appears.

The TA messages are given to the pilot in the form of the word ‘TRAFFIC’ displayed in yellow on the ND, and the aural voice annunciation, ‘traffic, traffic’. This is not the highest alert level. Its purpose is simply to call attention to a potential conflict.

TCAS triggers a TA as soon as an intruder enters the TA region. If no altitude data is available from the intruder aircraft, TCAS assumes the intruder’s relative altitude is within 1,200 feet. If bearing information is available, the intruder can be identified on the ND by a yellow, solid circle. Otherwise, the circle is removed and lateral distance and relative altitude with vertical motion arrow (if motion is detected) is displayed in yellow numbers under the word ‘TRAFFIC’.

RA messages are generated at the highest TCAS alert level and they provide the pilot with aural and visual pitch commands. The pilot must then disengage the autopilot as the escape manoeuvre has to be flown manually. Any flight director commands (as well as air traffic control (ATC) advisories) may have to be ignored. The pitch command of an RA always has the highest priority. Note that if no altitude data is available from the target, an RA will not occur. If bearing information is available, the intruder can be identified on the ND by a red, solid square. If bearing information is not available, the square is removed and lateral distance and relative altitude with vertical motion arrow (if motion is detected) is displayed in red numbers under the word ‘TRAFFIC’.

Although TCAS is highly regarded, it will have no angular determination warning until TCAS IV/ACAS III is developed and approved. Several options are

![Figure 15.15 TCAS Traffic Advisory (TA) and Resolution Advisory (RA) regions](image)
available, including utilisation of GPS systems and automated en-route air traffic (AERA) systems with up to 99.99 per cent accuracy rates. AERA will evaluate all aircraft positions, altitude and speed. The intention is to improve the autonomy of aircraft and thereby significantly reduce ATC involvement.

**TEST YOUR UNDERSTANDING 15.7**

Give an example of a warning indication by the TCAS system. How does the pilot receive this message?

### 15.9 AUTOMATIC TEST EQUIPMENT

Automatic test equipment (ATE) is a dedicated ground test instrument that provides a variety of different tests and functional checks on an LRU or printed circuit card. By making a large number of simultaneous connections with the equipment under test, ATE is able to gather a large amount of data very quickly, thus avoiding the need to make a very large number of manual measurements in order to assess the functional status of an item of equipment.

ATE systems tend to be dedicated to a particular avionic system and are expensive to develop and manufacture. Because of this they tend to be only used by original equipment manufacturers (OEM) and licensed repairers.

ATE systems usually incorporate computer control with displays that indicate what further action (repair or adjustment) is necessary in order to maintain the equipment. Finally, it is worth noting that individual items of equipment may often require further detailed tests and measurements following initial diagnosis using ATE.

### 15.10 BUILT-IN TEST EQUIPMENT

As the name implies, built-in test equipment (BITE) is primarily a self-test feature built into airborne equipment as an integral fault indicator. BITE is usually designed as a signal-flow type test. If the signal flow is interrupted or deviates outside accepted levels, warning alerts indicate a fault has occurred. The functions or capabilities of BITE include the following:

- real-time, critical monitoring
- continuous display presentation
- sampled recorder readout
- module and/or subassembly failure isolation
- verification of systems status
- go/no-go alarms
- quantitative displays
- degraded operation status
- percentage of functional deterioration.

The ECAM system oversees a variety of aircraft systems and also collects data on a continuous basis. While ECAM automatically warns of malfunctions, the flight crew can also manually select and monitor individual systems. Failure messages (see Figure 15.16) recorded by the flight crew can be followed up by maintenance personnel by using the system test facilities on the maintenance panel in the cockpit and on the BITE facility located on each computer. The majority of these computers are located in the aircraft’s avionics bay.

### 15.11 MULTIPLE-CHOICE QUESTIONS

1. The standard for ACARS is defined in:

   (a) ARINC 429
   (b) ARINC 573
   (c) ARINC 724.
2. Engine parameters are displayed on:
   (a) ECAM
   (b) EHSI
   (c) CDU.

3. A basic IRS platform has:
   (a) three accelerometers and two laser gyros
   (b) two accelerometers and three laser gyros
   (c) three accelerometers and three laser gyros.

4. The operational FMS database is:
   (a) updated once a month
   (b) is fed with information on aircraft weight before take-off
   (c) needs no update information.

5. The left and right cockpit displays:
   (a) are supplied from separate symbol generators at all times
   (b) are supplied from the same symbol generator
   (c) will only be supplied from the same symbol generator when all other symbol generators have failed.

6. A single failure in a fly-by-wire system should:
   (a) cause the system to revert to mechanical operation
   (b) result in immediate intervention by the flight crew
   (c) not have any effect on the operation of the system.

7. On a flight deck EFIS system, if all of the displays were missing information from a particular source, the most likely cause would be:
   (a) the symbol generator and display
   (b) the sensor, input bus or display controller
   (c) the display controller and symbol generator.

8. A central maintenance computer provides:
   (a) ground and in-flight monitoring and testing
   (b) ground and BIT testing using a portable control panel
   (c) display of system warnings and cautions.

9. The FMS navigation database is updated:
   (a) at the request of the flight crew
   (b) during pre-flight checks
   (c) every 28 days.

10. The sweep voltage waveform used on an electromagnetic CRT is:
    (a) trapezoidal
    (b) sinusoidal
    (c) sawtooth.

11. In an EFIS with three symbol generators, what is the purpose of the third symbol generator:
    (a) comparison with the pilot’s symbol generator
    (b) standby in case of failure
    (c) to provide outputs for ECAM.

12. The ACARS system uses channels in the:
    (a) HF spectrum
    (b) VHF spectrum
    (c) UHF spectrum.

13. If one EICAS CRT fails:
    (a) the remaining CRT will display primary EICAS data
    (b) the FMS CDU will display the failed CRT data
    (c) the standby CRT will automatically take over.

14. A method used in modern aircraft for reporting in-flight faults to an engineering and monitoring ground station is:
    (a) TCAS II
    (b) ACARS
    (c) GPS.
16 Aircraft data networks and AFDX

This chapter provides an introduction to modern aircraft data networks (ADNs) and avionics full-duplex (AFDX) networks in particular. It begins by considering the need for integrated modular avionic systems (IMA) and then moves on to describe the topology of various types of local area network (LAN). It is important that you have read and fully understand Chapter 4 and Chapter 15 before moving on to this chapter.

16.1 INTEGRATED MODULAR AVIONICS

First introduced in the 1990s for use with a new generation of jet fighters, IMA is a term that has become used to describe the use of a common computer network in an aircraft. IMAs represents a significant departure from traditional computer-based avionic systems that are distributed on dedicated hardware. Not only are these systems physically separated but they have no common applications programming interface (API).

As the avionic systems in modern aircraft increase, both in number and complexity, there is a need for systems to be able to communicate safely, reliably and efficiently over a shared network. A fully specified IMA system can comprise a large number of computing modules that exchange and share data over a high-speed LAN.

IMA offers the following benefits:

- improves reliability and maintainability;
- reduces the physical size and weight of equipment and cabling;
- reduces life cycle costs resulting from the use of a common set of networking parts and connectors;
- provides a common computing platform that provides distributed computational power via a real-time operating system;
- is an effective interface to avionic hardware and software applications via a standard API;
- is a system that can be quickly and easily modified and extended;
- has the ability of one or more computing modules to simultaneously support multiple avionic applications.

IMAs need to be implemented through some form of LAN; we shall look at this next.

KEY POINT

IMAs allow a large number of computer-based systems to communicate and exchange data with one another.

16.2 LOCAL AREA NETWORKS

A LAN is a network that covers a limited area and which generally provides a high data-rate capability. A LAN is invariably confined to a single site or, in the case of avionic systems, a single aircraft. The LAN provides the primary means of exchanging data and ensures the efficient use of shared resources.
In general, a LAN should:

- conform to a well-defined international standard supported by a number of manufacturers and vendors;
- support a high data-rate (e.g. 10 to 100 Mbps);
- have a range of several hundred metres using low-cost, lightweight cabling;
- be able to support a variety of independent devices connected as nodes;
- provide high standards of reliability and data integrity;
- exhibit minimum reliance on centralised components and controlling elements;
- maintain performance (i.e. data throughput without error) under conditions of high loading;
- allow easy installation and straightforward expansion;
- readily permit maintenance, reconfiguration and expansion.

### 16.3 LAN TOPOLOGY

LANs are often categorised in terms of the topology they employ. The following topologies are commonly encountered: star, ring, tree and bus (the latter is effectively a tree that has only one trunk and no branches).

In star technology a central switching element is used to connect all of the present nodes within the network. A node wishing to transmit data to another node must initiate a request to the central switching element which will then provide a dedicated path between them. Once the circuit has been established, the two nodes may then communicate as if they were connected by a dedicated point-to-point path.

Ring topology is characterised by a closed loop to which each node is attached by means of a media access device that also acts as a repeating element. Data circulates around the ring on a series of point-to-point links between the repeaters. A node wishing to transmit data must wait for its turn and then send data onto the ring in the form of a packet which must contain both the source and destination addresses, as well as the data itself. Upon arrival at the destination node, the data is copied into a local buffer. The packet then continues to circulate until it arrives back at the source node, hence providing a form of acknowledgement that the data was received by the destination node.

Bus and tree topologies both employ a multiple-access medium and thus only one device can transmit at any time. As with ring topology, transmission involves the generation of a packet containing source and destination address fields along with data. Figure 16.1 shows these various network topologies.
16.4 ETHERNET

Ethernet follows the network standards laid down in IEEE 802.3 (media access control) and has been widely accepted by a large number of manufacturers and equipment suppliers. Ethernet’s popularity stems from a number of factors, including the availability of very large-scale integration (VLSI) controllers which permit cost-effective implementation of high-speed networks.

Ethernet is based on a protocol known as ‘Carrier Sense, Multiple Access’ or CSMA/CD for short. In the simple ethernet arrangement shown in Figure 16.2, four hosts are connected to a common bus in a multiple-access (the MA of CSMA/CD) configuration. The ethernet bus medium could comprise a coaxial cable, twisted pair or optical fibre (in early ethernet systems the bus medium was usually coaxial cable). By using carrier sense (the CS of CSMA/CD) each host is able to detect the current status of the bus medium and, in particular, whether it is idle (no data present on the bus) or busy (data present on the bus).

By using collision detection (the CD of CSMA/CD) a host is able to detect whether its own transmission has coincided with that of another host (or hosts).

The basic rules adopted by each of the four hosts shown in Figure 16.2 are:

1. If data are ready for transmission, check to see whether the bus is idle and if it is then send the message, otherwise wait and attempt to send the message at some later time.
2. If, after having sent the message, it collides with a message from another host, wait and send it at some later time.

Although this simple strategy might work most of the time, there is the obvious disadvantage that when collisions do occur they will reduce the speed at which data can be transferred across the network. In a severe case, multiple re-transmission might be required and critical data might then take an unacceptably long time to reach its destination.

The strategy for handling the re-transmission of messages needs to cope with the situation in which both hosts need to re-transmit their data following a collision. This involves progressively ‘backing off’ so that one host is able to successfully transmit data before an attempt is made by the other host. To increase the success rate of a subsequent transmission, each host must select a random point within a particular time interval at which to attempt to re-transmit its data. If a second collision is then detected a further random time is then selected within an interval that is twice that of the first time interval. This technique is referred to as a binary exponential back-off strategy.

The arrangement shown in Figure 16.2 is a half-duplex system in which each host can transmit and receive but not at the same time. A better arrangement would permit full-duplex operation in which data can be sent and received at the same time using

![Multiple access bus](image-url)
16.3 Switched full-duplex configuration

A switched arrangement like that shown in Figure 16.3.

16.5 AVIONICS FULL-DUPEX SWITCHED NETWORKS

Based on mature, proven and widely supported industry standard IEEE 802.3 ethernet technology, AFDX is an implementation of ARINC standard 664 that specifies how commercial off-the-shelf (COTS) networking components can be used to provide ADNs. AFDX supports full-duplex operation with reliable high-speed performance in a switched network configuration.

The use of COTS parts and components is instrumental in reducing costs when compared with other manufacturer-specific networking solutions. AFDX was originally developed for use on the Airbus A380, but similar implementations are currently being introduced on several other new aircraft including the Boeing 787 Dreamliner.
AFDX is based on a cascaded star network configuration in which several avionic systems are connected to one or more central switches that store and forward the data from a source avionic system to one or more destination avionic systems.

In Figure 16.4 each host avionics system is connected to the switch by means of a full-duplex link. This link typically comprises two twisted pairs. One pair is used for transmit (the TX pair) and the other is used to receive (the RX pair). The switch is fitted with a buffer memory capable of storing packets of transmitted and received data.

The simplified internal arrangement of a switch is shown in Figure 16.5. The central processing unit (CPU) is responsible for the movement and correct routing of data packets, examining each incoming data packet and determining the destination address before placing the packet in the forwarding table from which it is subsequently copied to the appropriate TX buffer(s). This store and forward process is ongoing under the supervision of the CPU in the switch.

Each packet of received data is buffered prior to subsequent storage and hence collisions are effectively eliminated by means of the store and forward architecture.

In some circumstances packets of data may be delayed due to congestion in the switch, but as long as the buffer memories are made large enough the danger of overflow and consequent loss of data can be avoided.

**TEST YOUR UNDERSTANDING 16.3**

Explain the essential difference between half-duplex and full-duplex systems.

**TEST YOUR UNDERSTANDING 16.4**

Explain the need for, and function of, an AFDX switch.

**TEST YOUR UNDERSTANDING 16.5**

Explain the function of a buffer memory in an AFDX switch.

**16.6 DETERMINISM AND QUALITY OF SERVICE**

Because there is no absolute guarantee that data will be transferred within a particular time interval, standard commercial grade ethernet is insufficiently robust for use in an aerospace environment. A safety-critical network needs to be predictable in terms of the maximum delay incurred when data is passed through it. A simple analogy might be the daily commute to work.

Taking into account possible delays and hold-ups, most of us allow enough time to get to work and we can usually arrive within a window of time that will keep our employer happy. However, our journey might occasionally incur a delay that is unpredictable, such as caused by a flat tyre, a road that has been closed or a car that just won’t start. Even though we can get there on most days in good time, being able to unconditionally guarantee a particular arrival time might be impossible.

An important characteristic of a safety-critical network is that the passage of data through the network is predictable and not subject to delay or error. We require the network to be deterministic in its behaviour. Where a network conforms to a deterministic model, data flow will be entirely predictable and should occur within a guaranteed time frame. A deterministic network has a guaranteed maximum time delay for data transfer from node to node and avoids problems arising from errors, delays, jitter and packet dropping. This is usually expressed in terms of quality of service (QoS).

**KEY POINT**

QoS is the ability to guarantee a certain level of performance with respect to data flow.
### KEY POINT

AFDX extends the ethernet standard by adding QoS and deterministic behaviour together with a guaranteed dedicated bandwidth.

### KEY POINT

Where a network conforms to a deterministic model, data flow will be entirely predictable and should occur within a guaranteed time frame. A deterministic network has a guaranteed maximum time delay for data transfer from node to node, whereas a non-deterministic network does not.

### 16.7 VIRTUAL LINKS

Within the switched ethernet framework the concept of a unidirectional path from any particular source to any particular destination is important. Communication within the network takes place using the physical link that exists between the switch and each of the avionic systems. However, from a systems point of view it is useful to think of a number of logical communication links that share the physical connection that the network makes available to all of the hosts that are present. In an AFDX network, these logical links are referred to as virtual links (VLs). The data traffic over these VLs must be multiplexed in a way that ensures that the available bandwidth is used as efficiently as possible.

In a conventional ethernet switch the routing of data is based on a destination (or MAC) address. In AFDX, packets are routed using a VL identifier (VL ID). This VL ID takes the form of a 16-bit unsigned integer value that immediately follows a 32-bit field, as shown in Figure 16.6. Note that where several VLs are present, the total bandwidth supported by the VLs cannot exceed the total available bandwidth. Also note that bidirectional communication requires a complementary VL in order to preserve the same data rate for both transmission and reception. AFDX also supports a number of sub-VLs but, unlike the VLs on which they depend, the sub-VLs do not offer a guaranteed bandwidth.

In Chapter 4 we saw how the ARINC 429 standard was based on a large number of individual links between the senders and receivers of data. In such an arrangement all of the physical bandwidth of the link was available (i.e. not shared between a number of logical communication links).

The end systems shown in Figure 16.4 provide an interface between the avionics systems (i.e. the hosts) and the AFDX network. The frame associated with a particular VL must originate at one, and only one, end system. The end system can be based on conventional application-specific integrated circuit (ASIC) technology (as in the A380) or could make use of an embedded microcontroller together with appropriate support devices, such as ethernet controllers.

### TEST YOUR UNDERSTANDING 16.6

Explain the need for, and function of, an end system in an AFDX network.

### KEY POINT

In an AFDX network the communications channels along which data are moved are referred to as virtual links (VL). A VL provides a logical connection between one end system and one or more other end systems.

### TEST YOUR UNDERSTANDING 16.6

An end system provides the interface between computer-based avionics hardware and the AFDX network.
16.8 BANDWIDTH ALLOCATION

The bandwidth allocation gap (BAG) specifies the minimum interval between ethernet frames transmitted on a particular VL. BAG is specified in milliseconds (ms) and allowable values range from 1 ms to 128 ms, as shown in Table 16.1.

It is important to be able to determine the maximum bit-rate corresponding to a particular BAG and frame length (bit-rate increases with frame length but decreases with BAG). As an example, in the case of a VL with a BAG of 4 ms, ethernet packets are never sent at a rate that is faster than one packet every 4 ms. If the same VL supports a maximum frame length of \( l_{\text{max}} \) of 1,518 bytes the maximum bit-rate that can be supported by the VL in question will be given by:

\[
\text{Bit rate (max)} = l_{\text{max}} \times 8 \times 1,000 / \text{BAG} = 1,518 \times 8 \times 1,000 / 4 = 3,036 \times 10^3 \text{ bits per second or approximately 3 Mbps.}
\]

The choice of BAG for a particular VL must take into account the signals present at the ports of the avionic system concerned. For example, if a single port connected to a VL supplies data that recurs at a rate of 100 times per second we would need to select a BAG of no more than 8 ms (because the frequency that the data appears is less than 125 Hz).

### Table 16.1 Allowable values for the bandwidth allocation gap

<table>
<thead>
<tr>
<th>BAG (ms)</th>
<th>Equivalent frequency (Hz)</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>1,000</td>
</tr>
<tr>
<td>2</td>
<td>500</td>
</tr>
<tr>
<td>4</td>
<td>250</td>
</tr>
<tr>
<td>8</td>
<td>125</td>
</tr>
<tr>
<td>16</td>
<td>62.5</td>
</tr>
<tr>
<td>32</td>
<td>31.25</td>
</tr>
<tr>
<td>64</td>
<td>15.625</td>
</tr>
<tr>
<td>128</td>
<td>7.8125</td>
</tr>
</tbody>
</table>

16.9 AFDX FRAME FORMAT

AFDX protocol is based on the IEEE 802.3 frame principle (a frame is simply the basic unit of information that can be transferred using the network). The frame must encapsulate both the data (message) to be transferred as well as the source and destination addresses and other information relevant to the routing, handling and error-checking of the data.

The process of encoding and decoding an AFDX frame (see Figure 16.7) can be more easily visualised by referring to a stack of processes (or layers) through which the message must pass. These processes facilitate the assembly of the frame for transmission and the disassembly of the frame for reception. A byte is added to the AFDX frame payload to uniquely identify the frame and the order in which it is generated.

The transmission stack starts when an avionic system sends a message to one of its outgoing end system ports. It ends when the complete message frame has been assembled with all necessary headers, ready for placement on the VL. Reception is essentially the reverse of transmission. The process starts when the complete message frame appears on the VL and ends with the various headers removed and the message transferred to the relevant incoming end system port.

The AFDX payload can vary in length between 1 and 1,471 bytes. This yields an AFDX frame size that varies from 64 bytes (minimum) to 1,518 bytes (maximum), as depicted in Figure 16.7. You might like to check the arithmetic for yourself! Note that additional padding is added when the length of the AFDX payload is less than 17 bytes.

The preamble, prior to the transmission of the actual frame, signals the start of the transmission of a new message on the network. The preamble consists of a series of alternating 0 and 1 bits that give the receiving end systems time for synchronisation in preparation for the reception of the actual frame. At the end of the
preamble, the transmitting end system transmits the start frame delimiter (SFD) to signal the start of the actual frame.

The first part of the frame is the ethernet MAC destination address in which the AFDX VL ID is encoded in the last two bytes. The destination address is followed by the MAC source address. The two-byte protocol Type field follows the source and destination addresses. In AFDX this field always has the value 0x0800, which signifies the use of Internet Protocol, Version 4 (IPv4).

The ethernet payload follows the Type field and it contains the IP and UDP structures as well as the AFDX payload, followed by the sequence number (SN). The SN is initially set to 0 during start-up or reset and is then incremented on a continuous basis until it reaches 255. After reaching 255 the SN wraps back to 1 and then begins to increment once again.

The last field of the ethernet frame is the four-byte frame check sequence (FCS). The transmitting end system appends a cyclic redundancy checksum (CRC), which appears as a trailing FCS. The CRC is calculated over the entire frame and the receiving end system then uses an identical algorithm to recalculate the checksum and compare it with the received FCS. If any difference is detected the receiving end system flags an error and the entire received frame is discarded.

Ethernet specifies a minimum idle period between transmissions of frames known as the inter-frame gap (IFG). This gap is strictly not required for an AFDX system but is retained for compatibility. The IFG is specified as 96 bit periods. So, for example, on a 10 Mbit/s network, the IFG idle time accounts for a period of 9.6 µs.

16.7 AFDX frames

KEY POINT

The order in which a message is passed through the AFDX transmit protocol stack is UDP layer, IP network layer (where the ethernet header is added) and VL layer. The order is reversed when a message is being received and passed through the AFDX receive protocol stack.

16.10 REDUNDANCY, RELIABILITY AND INTEGRITY CHECKING

AFDX uses a simple transport layer protocol known as user datagram protocol (UDP). The protocol uses a simple transmission model and operates without any handshaking. It can thus be unreliable and, although this might not be a problem for use as an internet protocol (IP) it is unsuitable for use in critical avionic applications. With basic UDP there is no guarantee of delivery, ordering or duplicate protection. AFDX seeks to overcome this problem by using effective integrity checking and redundancy management techniques.

AFDX incorporates a number of features that are designed to improve its overall reliability, making it suitable for operation within a safety-critical avionic environment. In addition to the features discussed earlier (such as bandwidth management, deterministic behaviour and CRC error checking), AFDX employs integrity checking to ensure that the SNs of successive frames are in strict order before passing the packet into the end system or dropping the packet because it
is a replica of a packet that has already been received. This process is referred to as *redundancy management.*

In addition, AFDX supports a second redundant network that runs alongside the first network. The redundant network is capable of transmitting and receiving an exact replica of the data in the first network. However, since ultimately only one valid datastream is required by an end system application, a significant improvement in reliability can be gained.

When a redundant network is present, the two AFDX networks are referred to as Network A (or Red Network) and Network B (or Blue Network), as shown in Figure 16.8. The second—redundant—network protects the system against potential errors arising from a number of causes, including cable faults, defective connectors, fault switches, noise and radio frequency interference (RFI).

Several powerful software applications are available that can monitor the overall performance of an AFDX network. One such application, CoPilot AFDX, available from Ballard Technology, is shown in Figure 16.9. This software will allow you to monitor, record, filter, export and generate data bus activity with displays that can be configured in a wide variety of different formats (including virtual instrument displays). Engineers can also inject errors and evaluate system performance under simulated fault conditions.

Data can also be collected and saved for later analysis. This feature is invaluable when dealing with intermittent and transient network faults.

**TEST YOUR UNDERSTANDING 16.7**

What information is included in an AFDX frame?

**TEST YOUR UNDERSTANDING 16.8**

1. What is the length of the inter-frame gap in a 100 Mbit/s AFDX network?
2. How long does it take to transmit a maximum-length AFDX frame in a 10 Mbit/s AFDX network?
16.9 A typical display produced by Ballard Technology’s CoPilot system

**KEY POINT**

The AFDX frame format supports a payload of between 17 and 1,471 bytes. If the AFDX payload is smaller than 17 bytes, a padding field is added between the AFDX payload and the SN fields.

**TEST YOUR UNDERSTANDING 16.9**

Which of the following statements are true:

1. Integrity checking is used to detect and eliminate invalid frames.
2. Redundancy management is used to detect and drop replica frames.
3. Padding is added when an AFDX payload is very long.
4. Bit rate increases with BAG but decreases with frame length.
5. The BAG specifies the maximum time interval between successive ethernet frames.
**TEST YOUR UNDERSTANDING 16.10**

What is the name given to each of the following?

1. The minimum period of time between the transmission of two consecutive frames on a virtual link.
2. The minimum indivisible unit of information that can be transmitted on a network.
3. A byte of data added to an AFDX payload to manage redundancy and eliminate duplicate messages.

---

**16.11 MULTIPLE-CHOICE QUESTIONS**

1. In a simple ethernet arrangement a host is able to detect whether a bus is idle or busy by means of:
   - (a) parity checking
   - (b) a status byte
   - (c) carrier sense.

2. In an AFDX network the links from each host to the switch are:
   - (a) simplex
   - (b) half-duplex
   - (c) full-duplex.

3. Within an AFDX switch a buffer is used:
   - (a) for received data only
   - (b) for transmitted data only
   - (c) for both received and transmitted data.

4. The back-off strategy for a simple ethernet system is based on:
   - (a) re-transmission at regular time intervals
   - (b) re-transmission at a random time within a given time interval
   - (c) re-transmission immediately following the detection of a collision.

5. What is the maximum BAG for a VL that supplies messages at a rate of 400 per second:
   - (a) 2 ms
   - (b) 4 ms
   - (c) 8 ms.

6. What is the maximum bit-rate that can be supported by an AFDX virtual link in which the maximum frame length is 256 bytes and the bandwidth allocation gap is 128 ms:
   - (a) 4,000 bits per second
   - (b) 8,000 bits per second
   - (c) 16,000 bits per second.

7. Allowable bandwidth allocation gaps in AFDX can range from:
   - (a) 1 to 8 ms
   - (b) 2 to 64 ms
   - (c) 1 to 128 ms.

8. Within an AFDX network, the ethernet frames associated with a particular VL can originate at:
   - (a) multiple end systems
   - (b) one, and only one, end system
   - (c) each end system present in the network.

9. Within the transmit protocol stack the ethernet header is added by the:
   - (a) UDP transport layer
   - (b) IP network layer
   - (c) link layer.

10. Within the AFDX frame the FCS appears:
    - (a) after the sequence number
     - (b) immediately after the message field
     - (c) after the IP address and before the message field.

11. The order in which a message is passed through the AFDX transmit protocol stack is:
    - (a) UDP transport layer, IP network layer, link layer
     - (b) link layer, IP network layer, UDP transport layer
     - (c) IP network layer, UDP transport layer, link layer.
12. The fundamental network architecture used by an AFDX network is:
   (a) bus
   (b) tree
   (c) cascaded star.

13. In an AFDX network, the length of the FCS is:
   (a) one byte
   (b) two bytes
   (c) four bytes.

14. An AFDX frame sequence number can take a value between:
   (a) 0 and 15
   (b) 1 and 128
   (c) 0 and 255.

15. In an AFDX network the length of the UDP header is:
   (a) four bytes
   (b) six bytes
   (c) eight bytes.

16. The order of successive frames received by an end system can be checked using:
   (a) a checksum
   (b) a parity check
   (c) a sequence number.

17. A pad field is introduced into the AFDX payload whenever a payload message is:
   (a) less than 17 bytes
   (b) more than 17 bytes
   (c) more than 17 and less than 65 bytes.

18. Integrity checking is used to:
   (a) ensure that frames are received in the correct sequence
   (b) drop any replica frames that have already been received
   (c) ensure that all frames conform to the correct size and format.

19. Redundancy management is used to:
   (a) eliminate invalid or erroneous frames
   (b) drop replica frames that have already been received
   (c) ensure that all frames conform to the correct format.

20. Sequence number zero is:
   (a) used for test purposes only
   (b) reserved for end system reset
   (c) used as a means of padding the payload.
This chapter will provide you with an introduction to the techniques used in the development, testing and verification of the very large-scale logic systems used in modern avionic equipment.

Such systems are usually fabricated on a single silicon chip and may often comprise many hundreds of thousands of individual logic elements that need to be connected in a particular way so that they fulfil the requirements of the system. However, as logic systems become increasingly more complex, a number of problems arise, including:

• the need to be able to simulate, thoroughly test and verify the logic prior to manufacturing the device in which the logic will eventually be embedded;
• the need to be able to describe the logic in a manner that is both understandable and unambiguous;
• the need to take into account the limitations (particularly those related to speed and propagation delay) of the logic elements that will be employed in the target system;
• the need to be able to create logical components suitable for reuse in other complex logic systems.

Before reading this chapter it is important that you have read and fully understand Chapter 5 and Chapter 9.

17.1 THE NEED FOR HARDWARE DESCRIPTION LANGUAGES

Modern large-scale (LSI) and very large-scale integration (VLSI) based systems can be extremely complex. Being able to describe the logical function of such systems can be a very demanding task as conventional techniques (such as truth tables, logic diagrams and Boolean algebra) quickly become cumbersome and error-prone. In the design process there's also a need to take into account internal propagation delays and other limitations of real-world logic devices. This is just not possible using the conventional logic visualisation techniques (such as Boolean algebra and truth tables) that we met earlier in this book.

Hardware description language (HDL) seeks to remedy this problem by providing a formal and rigorous description of a digital logic circuit. HDL provides a means of describing the operation and logical function of a circuit as well as its architecture and behaviour. By forming an HDL description of a circuit we are able to exhaustively test and verify the circuit without having to manufacture any physical hardware.

Not only does HDL use standard text-based constructs to describe the operation of logic elements, but it can also take into account the timing (and more particularly the time delays) associated with real logic devices. This becomes invaluable when logic circuits are required to operate at high speed or when the appearance of unwanted transient logic states may have an undesirable or unpredictable effect on the behaviour of a logic system, the hardware to which it is connected or the avionic systems in which it is used. We will be returning to this important topic later in Section 17.10.

The first major implementation of HDL was in 1985 with the advent of *Verilog*. Two years later, with
the increasing use of very high-speed integrated circuits (VHSIC), a request from the US Department of Defense led to the development of VHDL (VHSIC HDL). Since then, VHDL and Verilog have dominated among the array of software-based design tools available to the advanced digital designer.

17.1 MSI and LSI devices can contain a very large number of individual logic elements connected to perform complex logic operations

the KEY POINT
HDL enables the logic designer to model a device, simulate it and then refine its performance before committing the design to physical hardware.

17.2 ENTITIES AND ENTITY DECLARATIONS

In a complex logic system where many components and logical sub-systems can be present it is essential for each individual component to be seen (and can thus be interacted with) by all of the other components present. Thus a primary requirement of any logic system description language is a construct that provides us with a rigorous definition of the component’s interface. In VHDL this is referred to as an entity.

A VHDL entity must be declared before it can be used. This declaration must begin with a unique name for the entity and then must specify the entity’s input and output ports. For example, the following code fragment is an entity declaration of a basic half-adder (see Figure 17.2):

```vhdl
ENTITY half_adder IS
  PORT( x, y: IN bit;
       sum, carry: OUT bit);
END half_adder;
```

The code fragment provides us with the following information:

1. The name of the entity is `half_adder`.
2. The entity has two inputs named `x` and `y`.
3. The entity has two outputs named `sum` and `carry`.
4. The inputs and outputs are all `bit` (binary digit) type (see later).

The `PORT` statement specifies the interface to the entity in terms of both the direction of data flow and the type of signal. Notice also that, at this stage, we have not provided any clues as to the behaviour of the entity. We need to do this separately with some further code statements. Note that VHDL allows for both concurrent and sequential signal assignment.

Here’s another example of a VHDL entity; this time in the form of an OR gate. Take a look at the code and then try your hand at Test your understanding 17.1.
ENTITY three_input_OR IS
  PORT( a, b, c: IN bit;
       y: OUT bit);
END three_input_OR;

17.3 BEHAVIOURAL DECLARATIONS

Other than the names we chose for our entities, the two declarations that we met in the previous section provide no clues as to the underlying logic functions. In order to do this we need some additional code to specify the behaviour of our entity. Here is how this could be done for the half-adder entity:

ARCHITECTURE half_adder_behaviour OF half_adder IS
  BEGIN
    PROCESS (x; y)
    BEGIN
      sum <= x XOR y;
      carry <= x AND y;
    END PROCESS;
  END half_adder_behaviour;

Notice how we have used standard logical expressions XOR and AND in the code (see Chapter 5). Now let’s consider a slightly more complicated arrangement like the one shown in Figure 17.4. This half-adder has an additional enable (EN) input which is taken ‘high’ to enable the logic but when taken low both of the outputs (SUM and CARRY) remain in the ‘low’ state. Here is the new entity declaration and its associated behavioural code:

ENTITY half_adder IS
  PORT( x, y, en: IN bit;
       sum, carry: OUT bit);
END half_adder;

ARCHITECTURE half_adder_behaviour OF half_adder IS
  BEGIN
    PROCESS (x; y)
    BEGIN
      IF en = ‘1’ THEN
        sum <= x XOR y;
        carry <= x AND y;
      END IF;
    END PROCESS;
  END half_adder_behaviour;

17.4 TEST YOUR UNDERSTANDING 17.1

Use the code fragment for the OR gate entity to answer the following questions:

1. What is the name of the VHDL entity?
2. How many inputs and outputs does the entity have?
3. What data type do the inputs and outputs have?
4. Sketch the logic symbol for the entity.

17.4 TEST YOUR UNDERSTANDING 17.2

Write a VHDL entity declaration for (a) an inverter; and (b) a two-input AND gate.

KEY POINT

At the structural level, VHDL describes a system as a collection of interconnected logic gates and components.
ELSE
    sum <= '0';
    carry <= '0';
END IF;
END PROCESS;
END half_adder_behaviour;

Note how the IF ... THEN ... ELSE ... END IF construct is used to make a logical decision based on the state of the enable (EN) input.

**TEST YOUR UNDERSTANDING 17.3**

What changes would have to be made to the VHDL code for the half-adder shown in Figure 17.4 if its enable (EN) input was active-low rather than active-high?

### 17.4 VHDL DESIGN FLOW

When designing with VHDL as an aid it is essential to adopt a structured approach. This usually involves a series of stages starting with a detailed specification and ending with verification and implementation. Typical stages in the design flow are:

1. **Conception.** Based on an objective needs analysis, the initial stage involves developing a comprehensive understanding of the required function of the logic system. It will help you to arrive at a detailed specification as well as a definitive list of signals with which the system will be able to interact with external hardware. Because complex logic designs are invariably hierarchical in nature, VHDL provides an excellent framework for defining modules and their interfaces.

2. **Coding.** The next stage is that of actually developing the VHDL code. This involves describing each of the VHDL components in terms of how they will interact with other components. The stage also involves specifying the required library modules as well as any existing code that can be re-used and incorporated into the new design.

3. **Compilation.** Having completed the coding, the next stage is that of analysing the code for syntax errors and compatibility with other modules. If
no errors are identified, the compilation process will continue to the point at which the VHDL component can be simulated using a test-bench procedure.

4. Simulation. Simulation will allow you to check that a VHDL design works as originally planned without actually committing the design to hardware. The VHDL simulator allows you to define and apply inputs to the design and to check that the required outputs are produced. It will also allow you to experiment with the timing delays that are inherent in real-world logic devices and ensure that the component’s logical operation is independent of timing considerations and internal gate delays.

5. Synthesis. Synthesis involves converting the intermediate VHDL code into components that can be assembled using the target technology. With ASIC devices, for example, the VHDL programming environment will export a net list that specifies how the individual gates should be interconnected in order to realise the desired logic function.

6. Fitting, placement and routing. This penultimate step in the process involves the physical realisation of the component in hardware rather than software. The process differs according to the semiconductor technology and may lead to a production-scale run of devices.

7. Verification. Finally, the design needs to be tested within the system into which it will be connected. This involves assembly onto the target avionics platform as well as carrying out further tests in order to assess the performance of the component when subjected to real-world circuit delays caused by stray reactances, electrical loading and other factors (including being able to continue to perform to specification at the extreme limits of temperature and supply voltage).

17.5 VHDL PROGRAM STRUCTURE

VHDL programs must conform to a well-defined structure. This structure describes the architecture of a device at several different levels, notably its internal structure or behaviour as well as how it appears to the outside world. The notion of an entity, which we met earlier, is important. You might like to think of it as ‘wrapper’ for the architecture, hiding the internal details but yet still providing all of the necessary ‘hooks’ for other logic modules to connect to it and make use of it. The following points are worth noting in relation to the structure of a VHDL program:

- In the source text of a VHDL program, the entity declaration and architecture definition must be separated.
- VHDL uses a number of reserved keywords such as ENTITY, PORT, IS, IN, OUT, END, ARCHITECTURE, BEGIN, WHEN, ELSE, and NOT. Note that, for clarity, we have shown these capitalised in the code examples but they would be the same in lower case.
- Comments in VHDL must begin with two hyphens (--) and end at the end of a line.
- Identifiers begin with a letter and may contain letters, digits and underscores (but note that two underscores may not be used together or be the last character in an identifier).
- Keywords and identifiers in VHDL code are not case sensitive.

Finally, because VHDL is not usually case-sensitive and white space is neglected, you are likely to encounter some minor variations in style, layout and presentation when examining samples of VHDL code.

17.6 VHDL SIGNAL MODES AND TYPES

As explained in the previous section, a VHDL entity is simply a declaration of a component’s inputs and outputs so that it can be ‘seen’ from the outside world and thus be interacted with. At the same time, the inner workings of the entity (i.e., its behaviour and architecture) are completely hidden from the external view. This is a powerful concept: once an entity has been designed and tested it can be easily incorporated into many other logic systems. Because we have no need to concern ourselves with what goes on inside
an entity we are only interested in what the entity does and how to connect to it!

There are a few more signal modes than the simple IN (input) and OUT (output) that we met in the earlier VHDL examples. Here is a list of allowed modes:

- **IN** – the signal is an input to the entity.
- **OUT** – the signal is an output of the entity (note that this signal is only available to external entities and it has no meaning inside the entity’s architecture.
- **BUFFER** – the signal is an output of the entity and its value can also be read and used inside the entity’s architecture (unlike OUT).
- **INOUT** – the signal can be used as an input or an output of the entity. This mode is typically used for tri-state signal lines which can be used both for input and output (but not at the same time!).

In VHDL, all signals, variables, and constants must have an associated type which specifies the permissible range of values for the object. VHDL provides several predefined types, including:

- **bit** – a binary digit having the value 0 or 1.
- **bit_vector** – the signal is a vector of bit values (e.g. bits 0 to 7 of a byte). Bit vectors helping to simplify the VHDL code when dealing with groups of bits.
- **std_logic** and **std_ulogic** – these are logic signals that can have one of nine different properties, including unknown, uninitialised, forcing and weak logic states (see below).
- **std_logic_vector** and **std_ulogic_vector** – as above but for vectors of bit values.
- **Boolean** – a logic signal that can exist in two states, TRUE and FALSE.
- **integer** – a number that can take one of a range of integer values.
- **real** – a number that can take one of a range of real values.
- **character** – a printable character, such as ‘@’.
- **time** – a value that indicates the time.

In a real-world logic system the logic levels are rarely perfect representations of the ideal logic 0 and logic 1 levels. VHDL takes this into account with its **std_logic** and **std_ulogic** data types that are defined in the relevant IEEE library. Thus std_logic and std_ulogic and their bit vector counterparts are preferred over the more basic bit types. The range of real-world logic conditions that are catered for include:

- **U** – an uninitialised value
- **X** – a forcing unknown
- **0** – a forcing logic 0
- **1** – a forcing logic 1
- **Z** – high impedance (tri-state)
- **W** – a weak unknown
- **L** – a low state (or weak logic 0)
- **H** – a high state (or weak logic 1)
- **-** – don’t care.

### 17.7 VHDL OPERATORS

Like most conventional programming languages VHDL supports a variety of operators divided into different classes in order of precedence. These operators include those that are associated with many of the logic functions that we have introduced in this book, such as **AND, OR and NOT**; others allow us to perform conventional arithmetic operations such as +, -, and /. The list below shows how these (and other) operators are arranged in order of precedence (the highest order of precedence is for Class 7 and the lowest is for Class 1):

- **Class 1** (logical operators)
  - **AND, OR, NAND, NOR, XOR, XNOR**
- **Class 2** (relational operators)
  - **=, /=, <=, =>, <<=, >>=**
- **Class 3** (shift operators)
  - **SLL, SRL, SLSR, LSL, ASLR, ARL, ROR**
- **Class 4** (addition operators)
  - **+, =**
- **Class 5** (unary operators)
  - **+, -**
- **Class 6** (multiplying operators)
  - ***, MOD, REM**
- **Class 7** (miscellaneous operators)
  - ****, **ABS, NOT**

As examples of the use (and importance of) precedence, consider the following expressions, when p
and \( q \) are both \texttt{std_ulogic_vector} data types with values 1010 and 0110, respectively:

\[
\begin{align*}
\text{p AND q} & \quad \text{evaluates to 0010} \\
\text{NOT p AND q} & \quad \text{evaluates to 0100} \\
\text{p AND NOT q} & \quad \text{evaluates to 1000} \\
\text{p AND SLA q} & \quad \text{evaluates to 1000 (SLA means 'shift left arithmetic')} \\
\text{NOT p AND ROR q} & \quad \text{evaluates to 0001 (ROR means 'rotate right logical')} \\
\end{align*}
\]

### TEST YOUR UNDERSTANDING 17.5

What do each of the expressions evaluate to when \( x \) and \( y \) are both \texttt{std_ulogic_vector} data types with values 0011 and 0100, respectively?

1. \( p \text{ AND } q \)
2. \( \text{NOT } p \text{ OR NOT } q \)
3. \( \text{SLA } p \text{ AND NOT } q \)

### 17.8 LOGIC DECISIONS AND PROGRAM FLOW

VHDL incorporates structures that support logical decisions and aid program flow. Since many readers will already be familiar with constructs such as \texttt{IF ... THEN} and \texttt{BEGIN ... END} and since their action should be reasonably self-explanatory we will not explain these further other than to illustrate their use with the aid of some examples. The first example shows the VHDL code for the positive edge-triggered D-type bistable data latch shown in Figure 17.6. This code fragment uses the \texttt{std_logic} data type:

```vhdl
LIBRARY ieee;
USE ieee.std_logic_1164.all;

ENTITY d_bistable IS
    port(clk, clr, d : IN std_logic;
         q : OUT std_logic);
END d_bistable;

ARCHITECTURE d_bistable behavioural OF d_bistable IS
BEGIN
    d_bistable_process (clk, clr)
    BEGIN
        IF (clr = '1') THEN
            q <= '0';
        ELSEIF (clk'event AND clk = '1') THEN
            q <= d;
        END IF;
    END d_bistable_process;
END d_bistable behavioural;
```

In the foregoing example the D-type bistable has inputs, \( \texttt{clk} \), \( \texttt{clr} \) and \( \texttt{d} \). There is only one output, \( \texttt{q} \). This information can be gleaned from the \texttt{ENTITY} declaration (and the \texttt{PORT} statement in particular).

The architecture statement tells us about the behaviour of the D-type bistable. The first part of the compound \texttt{IF ... THEN} statement examines the state of the \( \texttt{clr} \) input and resets the \( \texttt{q} \) output (to logic 0) if the \( \texttt{clr} \) input is logic 1. The second, \texttt{ELSEIF}, part of the statement examines the state of the clock. On a rising edge of the clock (this is when the clock is changing and goes to logic 1) the state of the \( d \) input is transferred to the \( q \) output. If \( \texttt{d} \) is at logic 1 the \( q \) output will go to logic 1. If \( \texttt{d} \) is at logic 0 the \( q \) output will go to logic 0. If this isn’t clear I suggest that you look again at the example, on a line-by-line basis.

The VHDL \texttt{std_logic} uses arrays to cater for multiple data lines. For example, here is the code for the 4-bit D-type bistable data latch shown in Figure 17.7 (note that the device has four data bit inputs and four data bit outputs together with common clock and clear inputs):
LIBRARY ieee;
USE ieee.std_logic_1164.all;

ENTITY d_bistable IS
  port(clk, clr, : IN std_logic;
       d : IN bit_vector(3 down to 0);
       q : OUT bit_vector(3 down to 0);
  END d_bistable;

ARCHITECTURE d_bistable_behaviour OF d_bistable IS
  BEGIN
    d_bistable_process (clk, clr)
    BEGIN
      IF (clr = '1') THEN
        q <= '0';
      ELSEIF (clk'event AND clk = '1') THEN
        q <= d;
      END IF;
    END d_bistable_process;
  END d_bistable_behaviour;

Notice how the IN bit_vector() keyword defines four data input lines (corresponding to bits 3, 2, 1 and 0) while the corresponding four data lines are defined by the OUT bit_vector() keyword. This greatly simplifies the VHDL code when dealing with groups of bits, bytes and complete data words.

KEY POINT
An architecture's external interface signals (i.e. its ports) are inherited from the port declaration within its corresponding entity declaration.

KEY POINT
A key feature of VHDL is the ability to describe how an entity appears to the outside world while at the same time keeping all of its internal details hidden.

17.9 SIMULATION AND THE TEST BENCH

Simulation (see Figure 17.8) is critical in establishing the performance of an HDL model under a range of different conditions. To simulate an HDL component, the designer makes use of a top-level simulation environment known as a test bench. The test bench code must be written separately from the component's declaration and it should include precise definitions of all signal and clock waveforms that will be applied to the component during the simulation process. The test bench code is event driven, with events occurring precisely as and when dictated by the test bench code.

An HDL simulator will usually provide the designer with a comprehensive display that shows how signals change with time and from which the time dependency of output and intermediate signals can be observed. The designer can start or stop the display at any desired time or by adding a series of break points that halt the simulation so the logic states can be examined.

It is a mistake to think of HDL as simply another programming language. Despite some obvious similarities (e.g. the use of a compiler) there are some very significant differences. The most important of these differences is that most programming languages are inherently procedural (single-threaded) and incapable of handling a number of events at the same time. HDLs, on the other hand, need to be able to model a large number of parallel processes, all of which could
A VHDL simulation environment. In this example a 4-bit counter has been declared as a VHDL entity and the resulting waveform analysis obtained.

Test bench analysis of the APU starter logic that we introduced in Chapter 5.
potentially occur at the same instant in time. An HDL therefore needs to have the characteristics of a concurrent, multi-threaded language.

Figure 17.9 shows a test bench analysis of the APU starter logic that we first met in Chapter 5. If you examine the code carefully you will notice that the test bench code defines three input signals (apu_start, apu_shutdown, and apu_running) and one output signal (apu_starter). In the waveform analysis the three input signals are respectively referred to as stim1, stim2, and stim3, and the output appears as res1. If you have time you might like to confirm that the VHDL code has been simulated correctly by referring back to Figure 5.15.

17.10 TIMING

An important aspect of VHDL is its ability to accurately model the timing delays that are inherent in real-world logic devices. To illustrate this important point, Figure 17.11 shows the digital timing analysis of a simple half-adder arrangement based on standard logic devices. In less-critical low-speed applications the delay in a signal passing through the half-adder arrangement can be tolerated, but for high-speed applications the delay, due to the finite time taken for a change in logic level to reach the output of the half-adder, can produce spurious logical states that could in some circumstances prove problematic. Notice how, in Figure 17.13, the Sum output is delayed by 45 ns following the change to Input_A. This delay results from the propagation delay associated with the standard 7408, 7404 and 7408 gates (approximately 15 ns each).

Propagation delay can be easily modelled in VHDL by defining a constant gate delay within an architecture declaration. The following code fragment (see Figure 17.12) shows how this can be done using:

```
ARCHITECTURE dataflow OF xor_gate IS
   CONSTANT gate_delay : time := 15ns;
BEGIN
   c <= (a xor b) after gate_delay;
END ARCHITECTURE;
```

KEY POINT

Simulation allows an HDL description of a logic design to pass design verification prior to manufacture and implementation.

KEY POINT

Although there might be some obvious similarities, VHDL is not a general-purpose programming language like C++ or Pascal. Instead it should be thought of as a means of describing a logic system in relation to its function, data flow, behaviour and structure.

TEST YOUR UNDERSTANDING 17.6

Describe the means by which propagation delay can be simulated within a VHDL test bench.
17.11 Digital timing analysis of a half-adder using conventional TTL logic

17.12 VHDL and test bench code for simulating an exclusive-OR (XOR) gate with a propagation delay of 15 ns
17.11 MULTIPLE-CHOICE QUESTIONS

1. The VHDL structural level describes a system as:
   (a) a collection of interconnected gates and components
   (b) a set of logic signals and levels
   (c) a list of signal names and logical expressions.

2. The input and output signals of a VHDL entity are defined in:
   (a) the entity declaration
   (b) a series of sub-programs
   (c) a separate architecture declaration.

3. A VHDL entity comprises an entity declaration followed by:
   (a) an architectural description
   (b) a truth table for the logic
   (c) a description of the semiconductor technology used.

4. VHDL allows:
   (a) only concurrent signal assignment
   (b) only sequential signal assignment
   (c) both concurrent and sequential signal assignment.

5. Comments in VHDL code start with:
   (a) a single exclamation mark (!)
   (b) a single semi-colon (;)
   (c) two adjacent hyphens (--).

6. In VHDL the std_logic type is defined:
   (a) in a header file
   (b) in the relevant IEEE file
   (c) in the entity declaration.

7. Which one of the following comes earlier in the development of a VHDL program:
   (a) Simulation
   (b) Coding
   (c) Verification.

8. In VHDL code, signals that have not already been initialised are denoted by the letter:
   (a) U
   (b) X
   (c) Z.

9. The assignment operator in VHDL is represented by:
   (a) =
   (b) =>
   (c) <=.

10. When program statements are executed in parallel they are said to be:
    (a) concurrent
    (b) sequential
    (c) random.

TEST YOUR UNDERSTANDING 17.7

Explain the need for and use of bit vectors in VHDL code.

17.13 Corresponding logic waveforms generated by the test bench code shown in Figure 17.12
11. Which one of the following is an example of a VHDL data type:

(a) In  
(b) Buffer  
(c) Boolean.

12. When \( x = 101 \) and \( y = 011 \) the VHDL expression \( \neg x \land y \) will evaluate to:

(a) 001  
(b) 010  
(c) 110.

13. The internal workings of a VHDL entity:

(a) are hidden from other entities  
(b) appear within the entity declaration  
(c) are defined in an external IEEE library.

14. In VHDL the sum, \( s \), output of a half-adder would be coded as:

(a) \( s = p + q \)  
(b) \( s \Rightarrow p \land q \)  
(c) \( s \Leftarrow p \oplus q \).
# Appendix 1

## Abbreviations and acronyms

<table>
<thead>
<tr>
<th>Abbreviation</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>ACARS</td>
<td>aircraft communication addressing and reporting system</td>
</tr>
<tr>
<td>ACAS</td>
<td>airborne collision avoidance system</td>
</tr>
<tr>
<td>ACIA</td>
<td>asynchronous communications interface adaptor</td>
</tr>
<tr>
<td>ACM</td>
<td>aircraft condition monitoring</td>
</tr>
<tr>
<td>ACMS</td>
<td>aircraft condition monitoring system</td>
</tr>
<tr>
<td>ACR</td>
<td>avionics computing resource</td>
</tr>
<tr>
<td>ACU</td>
<td>aviation computing unit</td>
</tr>
<tr>
<td>ADAPT</td>
<td>air traffic management data acquisition, processing and transfer</td>
</tr>
<tr>
<td>ADC</td>
<td>analogue to digital converter</td>
</tr>
<tr>
<td>ADF</td>
<td>automatic direction finder</td>
</tr>
<tr>
<td>ADI</td>
<td>attitude direction indicator</td>
</tr>
<tr>
<td>ADIRS</td>
<td>air data/inertial reference system</td>
</tr>
<tr>
<td>ADIRU</td>
<td>air data inertial reference unit</td>
</tr>
<tr>
<td>ADM</td>
<td>air data module</td>
</tr>
<tr>
<td>ADN</td>
<td>aircraft data network</td>
</tr>
<tr>
<td>ADR</td>
<td>air data reference</td>
</tr>
<tr>
<td>ADS</td>
<td>air data system</td>
</tr>
<tr>
<td>ADSB</td>
<td>automatic dependent surveillance broadcast</td>
</tr>
<tr>
<td>AEEC</td>
<td>Airlines Electronic Engineering Committee</td>
</tr>
<tr>
<td>AFC</td>
<td>automatic frequency control</td>
</tr>
<tr>
<td>AFCS</td>
<td>auto flight control system (autopilot)</td>
</tr>
<tr>
<td>AFDX</td>
<td>avionics full duplex (switched ethernet)</td>
</tr>
<tr>
<td>AFS</td>
<td>automatic flight system (autopilot)</td>
</tr>
<tr>
<td>AGL</td>
<td>above ground level</td>
</tr>
<tr>
<td>AHRS</td>
<td>attitude/heading reference system</td>
</tr>
<tr>
<td>AHS</td>
<td>attitude heading system</td>
</tr>
<tr>
<td>AI</td>
<td>Airbus Industries</td>
</tr>
<tr>
<td>AIAA</td>
<td>American Institute of Aeronautics and Astronautics</td>
</tr>
<tr>
<td>AIDS</td>
<td>aircraft integrated data system</td>
</tr>
<tr>
<td>AIMS</td>
<td>airplane information management system</td>
</tr>
<tr>
<td>AIS</td>
<td>aeronautical information system</td>
</tr>
<tr>
<td>AIV</td>
<td>anti-icing valve</td>
</tr>
<tr>
<td>ALT</td>
<td>altitude</td>
</tr>
<tr>
<td>ALU</td>
<td>arithmetic logic unit</td>
</tr>
<tr>
<td>AMD</td>
<td>advisory map display</td>
</tr>
<tr>
<td>AMI</td>
<td>airline modifiable information</td>
</tr>
<tr>
<td>AMLCD</td>
<td>active matrix liquid crystal display</td>
</tr>
<tr>
<td>ANSI</td>
<td>American National Standards Institute</td>
</tr>
<tr>
<td>ANSIR</td>
<td>advanced navigation system inertial reference</td>
</tr>
<tr>
<td>AOA</td>
<td>angle of attack</td>
</tr>
<tr>
<td>AP</td>
<td>autopilot</td>
</tr>
<tr>
<td>APATSI</td>
<td>airport air traffic system interface</td>
</tr>
<tr>
<td>API</td>
<td>application programming interface</td>
</tr>
<tr>
<td>APIC</td>
<td>advanced programmable interrupt controller</td>
</tr>
<tr>
<td>APM</td>
<td>advanced power management</td>
</tr>
<tr>
<td>APP</td>
<td>approach</td>
</tr>
<tr>
<td>APR</td>
<td>auxiliary power reserve</td>
</tr>
<tr>
<td>APU</td>
<td>auxiliary power unit</td>
</tr>
<tr>
<td>ARINC</td>
<td>Aeronautical Radio Incorporated</td>
</tr>
<tr>
<td>ARTAS</td>
<td>advanced radar tracker and server</td>
</tr>
<tr>
<td>ARTS</td>
<td>automated radar terminal system</td>
</tr>
<tr>
<td>ASAAC</td>
<td>Allied Standard Avionics Architecture Council</td>
</tr>
<tr>
<td>Abbreviation</td>
<td>Description</td>
</tr>
<tr>
<td>--------------</td>
<td>-------------</td>
</tr>
<tr>
<td>ASCB</td>
<td>Aircraft System Common Data Bus</td>
</tr>
<tr>
<td>ASCII</td>
<td>American Standard Code for Information Interchange</td>
</tr>
<tr>
<td>ASI</td>
<td>Airspeed Indicator</td>
</tr>
<tr>
<td>ASIC</td>
<td>Application-Specific Integrated Circuit</td>
</tr>
<tr>
<td>ASR</td>
<td>Aerodrome Surveillance Radar</td>
</tr>
<tr>
<td>ATA</td>
<td>Actual Time of Arrival</td>
</tr>
<tr>
<td>ATC</td>
<td>Air Traffic Control</td>
</tr>
<tr>
<td>ATE</td>
<td>Automatic Test Equipment</td>
</tr>
<tr>
<td>ATFM</td>
<td>Air Traffic Flow Management</td>
</tr>
<tr>
<td>ATI</td>
<td>Air Transport Indicator</td>
</tr>
<tr>
<td>ATLAS</td>
<td>Abbreviated Test Language for Avionics Systems</td>
</tr>
<tr>
<td>ATM</td>
<td>Air Traffic Management</td>
</tr>
<tr>
<td>ATN</td>
<td>Aeronautical Telecommunications Network</td>
</tr>
<tr>
<td>ATR</td>
<td>Air Transportable Racking</td>
</tr>
<tr>
<td>ATS</td>
<td>Air Traffic Services</td>
</tr>
<tr>
<td>ATSU</td>
<td>Air Traffic Services Unit</td>
</tr>
<tr>
<td>AVLAN</td>
<td>Avionics Local Area Network</td>
</tr>
<tr>
<td>AWLU</td>
<td>Aircraft Wireless Local Area Network Unit</td>
</tr>
<tr>
<td>BAG</td>
<td>Bandwidth Allocation Gap</td>
</tr>
<tr>
<td>BC</td>
<td>Bus Controller</td>
</tr>
<tr>
<td>BCD</td>
<td>Binary Coded Decimal</td>
</tr>
<tr>
<td>BER</td>
<td>Bit Error Rate/Bit Error Ratio</td>
</tr>
<tr>
<td>BGA</td>
<td>Ball Grid Array</td>
</tr>
<tr>
<td>BGW</td>
<td>Basic Gross Weight</td>
</tr>
<tr>
<td>BIC</td>
<td>Backplane Interface Controller</td>
</tr>
<tr>
<td>BIOS</td>
<td>Basic Input/Output System</td>
</tr>
<tr>
<td>BIST</td>
<td>Built-In Self-Test</td>
</tr>
<tr>
<td>BIT</td>
<td>Built-In Test</td>
</tr>
<tr>
<td>BITE</td>
<td>Built-In Test Equipment</td>
</tr>
<tr>
<td>BUU</td>
<td>Bus Interface Unit</td>
</tr>
<tr>
<td>BP</td>
<td>Base Pointer</td>
</tr>
<tr>
<td>BPRZ</td>
<td>Bipolar Return to Zero</td>
</tr>
<tr>
<td>BPS</td>
<td>Bits Per Second</td>
</tr>
<tr>
<td>BPV</td>
<td>Bypass Valve</td>
</tr>
<tr>
<td>BSU</td>
<td>Bypass Switch Unit</td>
</tr>
<tr>
<td>C/PDLC</td>
<td>Controller/Pilot Data Link Communications</td>
</tr>
<tr>
<td>CAA</td>
<td>Civil Aviation Authority</td>
</tr>
<tr>
<td>CABLAN</td>
<td>Cabin Local Area Network</td>
</tr>
<tr>
<td>CADC</td>
<td>Central Air Data Computer</td>
</tr>
<tr>
<td>CAI</td>
<td>Computer Aided Instruction</td>
</tr>
<tr>
<td>CAN</td>
<td>Controller Area Network</td>
</tr>
<tr>
<td>CAS</td>
<td>Collision Avoidance System</td>
</tr>
<tr>
<td>CAS</td>
<td>Crew Alerting System</td>
</tr>
<tr>
<td>CAT</td>
<td>Clear-Air Turbulence</td>
</tr>
<tr>
<td>CCA</td>
<td>Circuit Card Assembly</td>
</tr>
<tr>
<td>CDDI</td>
<td>Copper Distributed Data Interface</td>
</tr>
<tr>
<td>CDI</td>
<td>Course Deviation Indicator</td>
</tr>
<tr>
<td>CDROM</td>
<td>Compact Disk Read-Only Memory</td>
</tr>
<tr>
<td>CDS</td>
<td>Common Display System</td>
</tr>
<tr>
<td>CDU</td>
<td>Control Display Unit</td>
</tr>
<tr>
<td>CEATS</td>
<td>Central European Air Traffic Service</td>
</tr>
<tr>
<td>CFDS</td>
<td>Central Fault Display System</td>
</tr>
<tr>
<td>CH</td>
<td>Compass Heading</td>
</tr>
<tr>
<td>CIDIN</td>
<td>Common ICAO Data Interchange Network</td>
</tr>
<tr>
<td>CIDS</td>
<td>Cabin Intercommunication Data System</td>
</tr>
<tr>
<td>CISC</td>
<td>Complex Instruction Set Computer</td>
</tr>
<tr>
<td>CLK</td>
<td>Clock</td>
</tr>
<tr>
<td>CMC</td>
<td>Central Maintenance Computer</td>
</tr>
<tr>
<td>CMOS</td>
<td>Complementary Metal Oxide Semiconductor</td>
</tr>
<tr>
<td>CMP</td>
<td>Configuration Management Plan</td>
</tr>
<tr>
<td>CMS</td>
<td>Centralised Maintenance System</td>
</tr>
<tr>
<td>CMU</td>
<td>Communications Management Unit</td>
</tr>
<tr>
<td>COMPAS</td>
<td>Computer Orientated Metering, Planning and Advisory System</td>
</tr>
<tr>
<td>COTS</td>
<td>Commercial Off-The-Shelf</td>
</tr>
<tr>
<td>CPA</td>
<td>Closest Point of Approach</td>
</tr>
<tr>
<td>CPGA</td>
<td>Ceramic Pin Grid Array</td>
</tr>
<tr>
<td>CPM</td>
<td>Core Processing Module</td>
</tr>
<tr>
<td>CPU</td>
<td>Central Processing Unit</td>
</tr>
<tr>
<td>CRC</td>
<td>Cyclic Redundancy Check</td>
</tr>
<tr>
<td>CRM</td>
<td>Crew Resource Management</td>
</tr>
<tr>
<td>CRT</td>
<td>Cathode Ray Tube</td>
</tr>
<tr>
<td>CS</td>
<td>Code Segment</td>
</tr>
<tr>
<td>CSMA/CD</td>
<td>Carrier Sense, Multiple Access</td>
</tr>
<tr>
<td>CTO</td>
<td>Central Technical Operations</td>
</tr>
<tr>
<td>CVR</td>
<td>Cockpit Voice Recorder</td>
</tr>
<tr>
<td>DA</td>
<td>Drift Angle</td>
</tr>
<tr>
<td>DAC</td>
<td>Digital to Analogue Converter</td>
</tr>
<tr>
<td>DADC</td>
<td>Digital Air Data Computer</td>
</tr>
<tr>
<td>DATAC</td>
<td>Digital Autonomous Terminal Access Communications System</td>
</tr>
<tr>
<td>DBRITE</td>
<td>Digital Bright Radar Indicator Tower Equipment</td>
</tr>
<tr>
<td>DCE</td>
<td>Data Circuit Terminating Equipment</td>
</tr>
<tr>
<td>DCU</td>
<td>Data Concentrator Unit</td>
</tr>
<tr>
<td>DDR</td>
<td>Digital Data Recorder</td>
</tr>
<tr>
<td>DECU</td>
<td>Digital Engine Control</td>
</tr>
<tr>
<td>DEOS</td>
<td>Digital Engine Operating System</td>
</tr>
<tr>
<td>DEU</td>
<td>Digital Electronics Unit</td>
</tr>
<tr>
<td>DFDAU</td>
<td>Digital Flight Data Acquisition Unit</td>
</tr>
<tr>
<td>DFDR</td>
<td>Digital Flight Data Recorder</td>
</tr>
<tr>
<td>DFGC</td>
<td>Digital Flight Guidance Computer</td>
</tr>
<tr>
<td>DFGS</td>
<td>Digital Flight Guidance System</td>
</tr>
<tr>
<td>DFLD</td>
<td>Database Field Loadable Data</td>
</tr>
<tr>
<td>Abbreviation</td>
<td>Description</td>
</tr>
<tr>
<td>--------------</td>
<td>-------------</td>
</tr>
<tr>
<td>DG</td>
<td>directional gyro</td>
</tr>
<tr>
<td>DGPS</td>
<td>differential Global Positioning System</td>
</tr>
<tr>
<td>DH</td>
<td>decision height</td>
</tr>
<tr>
<td>DI</td>
<td>destination index</td>
</tr>
<tr>
<td>DIL</td>
<td>dual in-line</td>
</tr>
<tr>
<td>DIMM</td>
<td>dual inline memory module</td>
</tr>
<tr>
<td>DIP</td>
<td>dual in-line package</td>
</tr>
<tr>
<td>DITS</td>
<td>digital information transfer system</td>
</tr>
<tr>
<td>DLS</td>
<td>DME-based landing system</td>
</tr>
<tr>
<td>DMA</td>
<td>direct memory access</td>
</tr>
<tr>
<td>DME</td>
<td>data management entry panel</td>
</tr>
<tr>
<td>DME</td>
<td>distance measuring equipment</td>
</tr>
<tr>
<td>DO</td>
<td>design organisation</td>
</tr>
<tr>
<td>DP</td>
<td>decimal point</td>
</tr>
<tr>
<td>DP</td>
<td>departure procedures</td>
</tr>
<tr>
<td>DPM</td>
<td>data position module</td>
</tr>
<tr>
<td>DPU</td>
<td>display processor unit</td>
</tr>
<tr>
<td>DRAM</td>
<td>dynamic random access memory</td>
</tr>
<tr>
<td>DS</td>
<td>data segment</td>
</tr>
<tr>
<td>DSCS</td>
<td>door and slide control system</td>
</tr>
<tr>
<td>DSP</td>
<td>digital signal processing</td>
</tr>
<tr>
<td>DSP</td>
<td>display select panel</td>
</tr>
<tr>
<td>DTE</td>
<td>data terminal equipment</td>
</tr>
<tr>
<td>DTOP</td>
<td>dual threshold operation</td>
</tr>
<tr>
<td>DU</td>
<td>display units</td>
</tr>
<tr>
<td>DUATS</td>
<td>direct user access terminal system</td>
</tr>
<tr>
<td>EADI</td>
<td>electronic attitude direction indicator</td>
</tr>
<tr>
<td>EARTS</td>
<td>en-route automated radar tracking system</td>
</tr>
<tr>
<td>EAS</td>
<td>express air system</td>
</tr>
<tr>
<td>EAT</td>
<td>expected approach time</td>
</tr>
<tr>
<td>EATMS</td>
<td>enhanced air traffic management system</td>
</tr>
<tr>
<td>ECAM</td>
<td>electronic centralised aircraft monitoring</td>
</tr>
<tr>
<td>ECB</td>
<td>electronic control box</td>
</tr>
<tr>
<td>ECC</td>
<td>error checking and correcting</td>
</tr>
<tr>
<td>ECL</td>
<td>emitter-coupled logic</td>
</tr>
<tr>
<td>ECM</td>
<td>electronic counter measures</td>
</tr>
<tr>
<td>ECP</td>
<td>extended capabilities port</td>
</tr>
<tr>
<td>ECS</td>
<td>environmental control system</td>
</tr>
<tr>
<td>ECU</td>
<td>electronic control unit</td>
</tr>
<tr>
<td>EEC</td>
<td>electronic engine control</td>
</tr>
<tr>
<td>EEPROM</td>
<td>electrically erasable programmable read-only memory</td>
</tr>
<tr>
<td>EFCS</td>
<td>electronic flight control system</td>
</tr>
<tr>
<td>EFIS</td>
<td>electronic flight instrument system</td>
</tr>
<tr>
<td>EGPWS</td>
<td>enhanced ground proximity warning system</td>
</tr>
<tr>
<td>EHSI</td>
<td>electronic horizontal situation indicator</td>
</tr>
<tr>
<td>EIA</td>
<td>Electronic Industries Association</td>
</tr>
<tr>
<td>EICAS</td>
<td>engine indication and crew alerting systems</td>
</tr>
<tr>
<td>EIDE</td>
<td>enhanced integrated drive electronics</td>
</tr>
<tr>
<td>EIS</td>
<td>electronic instrument system</td>
</tr>
<tr>
<td>EL</td>
<td>elevation-station</td>
</tr>
<tr>
<td>ELAC</td>
<td>elevator and aileron computer</td>
</tr>
<tr>
<td>ELS</td>
<td>electronic library system</td>
</tr>
<tr>
<td>EM</td>
<td>emulate processor</td>
</tr>
<tr>
<td>EMC</td>
<td>electromagnetic compatibility</td>
</tr>
<tr>
<td>EMI</td>
<td>electromagnetic interference</td>
</tr>
<tr>
<td>EOC</td>
<td>end of conversion</td>
</tr>
<tr>
<td>EP</td>
<td>emulate processor</td>
</tr>
<tr>
<td>EPP</td>
<td>enhanced parallel port</td>
</tr>
<tr>
<td>EPROM</td>
<td>erasable programmable read-only memory</td>
</tr>
<tr>
<td>EROPS</td>
<td>extended range operations</td>
</tr>
<tr>
<td>ERU</td>
<td>electronic routing unit</td>
</tr>
<tr>
<td>ES</td>
<td>end system (AFDX)</td>
</tr>
<tr>
<td>ES</td>
<td>extra segment</td>
</tr>
<tr>
<td>ESD</td>
<td>electrostatic discharge</td>
</tr>
<tr>
<td>ESD</td>
<td>electrostatic sensitive device</td>
</tr>
<tr>
<td>ETA</td>
<td>estimated time of arrival</td>
</tr>
<tr>
<td>ETOPS</td>
<td>extended range twin-engine operations</td>
</tr>
<tr>
<td>EU</td>
<td>execution unit</td>
</tr>
<tr>
<td>FAA</td>
<td>Federal Aviation Administration</td>
</tr>
<tr>
<td>FAC</td>
<td>flight augmentation computer</td>
</tr>
<tr>
<td>FADEC</td>
<td>full authority digital engine control</td>
</tr>
<tr>
<td>FAMIS</td>
<td>full aircraft management/inertial system</td>
</tr>
<tr>
<td>FAR</td>
<td>Federal Aviation Regulations</td>
</tr>
<tr>
<td>FBL</td>
<td>fly-by-light</td>
</tr>
<tr>
<td>FBW</td>
<td>fly-by-wire</td>
</tr>
<tr>
<td>FC</td>
<td>flight control</td>
</tr>
<tr>
<td>FCC</td>
<td>Federal Communications Commission</td>
</tr>
<tr>
<td>FCC</td>
<td>flight control computer</td>
</tr>
<tr>
<td>FCGC</td>
<td>flight control and guidance computer</td>
</tr>
<tr>
<td>FCS</td>
<td>flight control system</td>
</tr>
<tr>
<td>FCS</td>
<td>frame check sequence (AFDX)</td>
</tr>
<tr>
<td>FCU</td>
<td>flight control unit</td>
</tr>
<tr>
<td>FD</td>
<td>flight director</td>
</tr>
<tr>
<td>FDI</td>
<td>flight data acquisition unit</td>
</tr>
<tr>
<td>FDC</td>
<td>flight director computer</td>
</tr>
<tr>
<td>FDD</td>
<td>floppy disk drive</td>
</tr>
<tr>
<td>FDDI</td>
<td>fibre distributed data interface</td>
</tr>
<tr>
<td>FDMU</td>
<td>flight data management unit</td>
</tr>
<tr>
<td>FDR</td>
<td>flight data recorder</td>
</tr>
<tr>
<td>FDS</td>
<td>flight director system</td>
</tr>
<tr>
<td>FET</td>
<td>field effect transistor</td>
</tr>
<tr>
<td>FFS</td>
<td>full flight simulator</td>
</tr>
<tr>
<td>FG</td>
<td>flight guidance</td>
</tr>
<tr>
<td>FGC</td>
<td>flight guidance computer</td>
</tr>
<tr>
<td>FGI</td>
<td>flight guidance by digital ground image</td>
</tr>
<tr>
<td>FGS</td>
<td>flight guidance system</td>
</tr>
<tr>
<td>Term</td>
<td>Definition</td>
</tr>
<tr>
<td>------</td>
<td>------------</td>
</tr>
<tr>
<td>FIFO</td>
<td>first-in first-out</td>
</tr>
<tr>
<td>FIR</td>
<td>flight information region</td>
</tr>
<tr>
<td>FIS</td>
<td>flight information system</td>
</tr>
<tr>
<td>FL</td>
<td>flight level</td>
</tr>
<tr>
<td>FLIR</td>
<td>forward looking infrared</td>
</tr>
<tr>
<td>FLS</td>
<td>field loadable software</td>
</tr>
<tr>
<td>FM</td>
<td>flight management</td>
</tr>
<tr>
<td>FMC</td>
<td>flight management computer</td>
</tr>
<tr>
<td>FMCDU</td>
<td>flight management control and display unit</td>
</tr>
<tr>
<td>FMCS</td>
<td>flight management computer system</td>
</tr>
<tr>
<td>FMGC</td>
<td>flight management guidance computer</td>
</tr>
<tr>
<td>FMS</td>
<td>flight management system</td>
</tr>
<tr>
<td>FOG</td>
<td>fibre-optic gyros</td>
</tr>
<tr>
<td>FSC</td>
<td>fuel system controller</td>
</tr>
<tr>
<td>G</td>
<td>giga ((10^9) multiplier)</td>
</tr>
<tr>
<td>G/S</td>
<td>glide slope</td>
</tr>
<tr>
<td>GA</td>
<td>general aviation</td>
</tr>
<tr>
<td>GBST</td>
<td>ground-based software tool</td>
</tr>
<tr>
<td>GG</td>
<td>graphics generator</td>
</tr>
<tr>
<td>GHz</td>
<td>gigahertz ((10^9) Hz)</td>
</tr>
<tr>
<td>GMT</td>
<td>Greenwich Mean Time</td>
</tr>
<tr>
<td>GND</td>
<td>ground</td>
</tr>
<tr>
<td>GNSS</td>
<td>Global Navigation Satellite System</td>
</tr>
<tr>
<td>GPM</td>
<td>ground position module</td>
</tr>
<tr>
<td>GPS</td>
<td>Global Positioning System</td>
</tr>
<tr>
<td>GPWS</td>
<td>ground proximity warning system</td>
</tr>
<tr>
<td>GS</td>
<td>ground speed</td>
</tr>
<tr>
<td>HALS</td>
<td>high approach landing system</td>
</tr>
<tr>
<td>HDD</td>
<td>head down display</td>
</tr>
<tr>
<td>HDG</td>
<td>heading</td>
</tr>
<tr>
<td>HDL</td>
<td>hardware description language</td>
</tr>
<tr>
<td>Hex</td>
<td>hexadecimal</td>
</tr>
<tr>
<td>HFDS</td>
<td>head-up flight display system</td>
</tr>
<tr>
<td>HGS</td>
<td>head-up guidance system</td>
</tr>
<tr>
<td>HIRF</td>
<td>high-energy radiated field/high-intensity radiated field</td>
</tr>
<tr>
<td>HIRL</td>
<td>high intensity runway lights</td>
</tr>
<tr>
<td>HM</td>
<td>health monitoring</td>
</tr>
<tr>
<td>HMCUDU</td>
<td>hybrid multifunction control display unit</td>
</tr>
<tr>
<td>HPA</td>
<td>high power amplifier</td>
</tr>
<tr>
<td>HSI</td>
<td>horizontal situation indicator</td>
</tr>
<tr>
<td>HUD</td>
<td>head-up display</td>
</tr>
<tr>
<td>HUGS</td>
<td>head-up guidance system</td>
</tr>
<tr>
<td>HW</td>
<td>hardware</td>
</tr>
<tr>
<td>Hz</td>
<td>Hertz (cycles per second)</td>
</tr>
<tr>
<td>I/O</td>
<td>input/output</td>
</tr>
<tr>
<td>IAC</td>
<td>integrated avionics computer</td>
</tr>
<tr>
<td>IAPS</td>
<td>integrated avionics processing system</td>
</tr>
<tr>
<td>IAS</td>
<td>indicated air speed</td>
</tr>
<tr>
<td>IBC</td>
<td>individual blade control</td>
</tr>
<tr>
<td>IBR</td>
<td>integrated blade rotor</td>
</tr>
<tr>
<td>ID</td>
<td>identification/identifier</td>
</tr>
<tr>
<td>IC</td>
<td>integrity checking (AFDX)</td>
</tr>
<tr>
<td>IDE</td>
<td>integrated drive electronics</td>
</tr>
<tr>
<td>IFE</td>
<td>in-flight entertainment</td>
</tr>
<tr>
<td>IFF</td>
<td>identification, friend or foe</td>
</tr>
<tr>
<td>IFG</td>
<td>inter-frame gap (AFDX)</td>
</tr>
<tr>
<td>IFOG</td>
<td>interferometric fibre optic gyro</td>
</tr>
<tr>
<td>IFPS</td>
<td>International Flight Plan Processing System</td>
</tr>
<tr>
<td>IFR</td>
<td>instrument flight rules</td>
</tr>
<tr>
<td>IHF</td>
<td>integrated human interface function</td>
</tr>
<tr>
<td>IHUMS</td>
<td>integrated health and usage monitoring system</td>
</tr>
<tr>
<td>ILS</td>
<td>instrument landing system</td>
</tr>
<tr>
<td>IMA</td>
<td>integrated modular avionics</td>
</tr>
<tr>
<td>IMU</td>
<td>inertial measurement unit</td>
</tr>
<tr>
<td>INS</td>
<td>inertial navigation system</td>
</tr>
<tr>
<td>IOAPIC</td>
<td>input/output advanced programmable input controller</td>
</tr>
<tr>
<td>IOM</td>
<td>input/output module</td>
</tr>
<tr>
<td>IP</td>
<td>internet protocol</td>
</tr>
<tr>
<td>IPC</td>
<td>instructions per cycle</td>
</tr>
<tr>
<td>IPR</td>
<td>intellectual property right</td>
</tr>
<tr>
<td>IPX/SPX</td>
<td>inter-network packet exchange/sequential packet exchange</td>
</tr>
<tr>
<td>IR</td>
<td>infrared</td>
</tr>
<tr>
<td>IRQ</td>
<td>interrupt request</td>
</tr>
<tr>
<td>IRS</td>
<td>inertial reference system</td>
</tr>
<tr>
<td>IRU</td>
<td>inertial reference unit</td>
</tr>
<tr>
<td>ISA</td>
<td>industry standard architecture</td>
</tr>
<tr>
<td>ISA</td>
<td>inertial sensor assembly</td>
</tr>
<tr>
<td>ISAS</td>
<td>integrated situational awareness system</td>
</tr>
<tr>
<td>ISDB</td>
<td>integrated signal data base</td>
</tr>
<tr>
<td>ISDU</td>
<td>inertial system display unit</td>
</tr>
<tr>
<td>ISO</td>
<td>International Standards Organisation</td>
</tr>
<tr>
<td>IVSI</td>
<td>instantaneous vertical speed indicator</td>
</tr>
<tr>
<td>IWF</td>
<td>integrated warning function</td>
</tr>
<tr>
<td>JAA</td>
<td>Joint Airworthiness Authority</td>
</tr>
<tr>
<td>JAR</td>
<td>Joint Airworthiness Requirement</td>
</tr>
<tr>
<td>JEDEC</td>
<td>Joint Electron Device Engineering Council</td>
</tr>
<tr>
<td>k</td>
<td>kilo ((10^3) multiplier)</td>
</tr>
<tr>
<td>kHz</td>
<td>kilohertz ((10^3) Hz)</td>
</tr>
<tr>
<td>KIAS</td>
<td>indicated airspeed in knots</td>
</tr>
<tr>
<td>Knot</td>
<td>nautical miles/hour</td>
</tr>
<tr>
<td>KT</td>
<td>knots</td>
</tr>
<tr>
<td>LAAS</td>
<td>local area augmentation system</td>
</tr>
<tr>
<td>Abbreviation</td>
<td>Description</td>
</tr>
<tr>
<td>--------------</td>
<td>-------------</td>
</tr>
<tr>
<td>LAN</td>
<td>local area network</td>
</tr>
<tr>
<td>LATAN</td>
<td>low-altitude terrain-aided navigation</td>
</tr>
<tr>
<td>LBA</td>
<td>logical block addressing</td>
</tr>
<tr>
<td>LCC</td>
<td>leadless chip carrier</td>
</tr>
<tr>
<td>LCD</td>
<td>liquid crystal display</td>
</tr>
<tr>
<td>LDU</td>
<td>lamp driver unit</td>
</tr>
<tr>
<td>LED</td>
<td>light emitting diode</td>
</tr>
<tr>
<td>LFC</td>
<td>laminar flow control</td>
</tr>
<tr>
<td>LGC</td>
<td>landing gear control</td>
</tr>
<tr>
<td>LIDAR</td>
<td>light radar</td>
</tr>
<tr>
<td>LNAV</td>
<td>lateral navigation</td>
</tr>
<tr>
<td>LOC</td>
<td>localiser</td>
</tr>
<tr>
<td>LORADS</td>
<td>long range radar and display system</td>
</tr>
<tr>
<td>LRM</td>
<td>line replaceable module</td>
</tr>
<tr>
<td>LRU</td>
<td>least recently used</td>
</tr>
<tr>
<td>LRU</td>
<td>line replaceable unit</td>
</tr>
<tr>
<td>LSAP</td>
<td>loadable software aircraft part</td>
</tr>
<tr>
<td>LSB</td>
<td>least significant bit</td>
</tr>
<tr>
<td>LSD</td>
<td>least significant digit</td>
</tr>
<tr>
<td>LSI</td>
<td>large-scale integration</td>
</tr>
<tr>
<td>LSS</td>
<td>lightning sensor system</td>
</tr>
<tr>
<td>M</td>
<td>mega (10^6 multiplier)</td>
</tr>
<tr>
<td>MAC</td>
<td>media access controller</td>
</tr>
<tr>
<td>MASI</td>
<td>mach airspeed indicator</td>
</tr>
<tr>
<td>MAU</td>
<td>modular avionics unit</td>
</tr>
<tr>
<td>MCDU</td>
<td>microprocessor controlled display units</td>
</tr>
<tr>
<td>MCP</td>
<td>mode control panel</td>
</tr>
<tr>
<td>MCU</td>
<td>modular component unit</td>
</tr>
<tr>
<td>MDAU</td>
<td>maintenance data acquisition unit</td>
</tr>
<tr>
<td>MEL</td>
<td>minimum equipment list</td>
</tr>
<tr>
<td>MFD</td>
<td>multifunction flight display</td>
</tr>
<tr>
<td>MFDS</td>
<td>multifunction display system</td>
</tr>
<tr>
<td>MHRS</td>
<td>magnetic heading reference system</td>
</tr>
<tr>
<td>MHX</td>
<td>main heat exchanger</td>
</tr>
<tr>
<td>MHz</td>
<td>megahertz (10^6 Hz)</td>
</tr>
<tr>
<td>MIPS</td>
<td>millions of instructions per second</td>
</tr>
<tr>
<td>MLS</td>
<td>microwave landing system</td>
</tr>
<tr>
<td>MLW</td>
<td>maximum landing weight</td>
</tr>
<tr>
<td>MMI</td>
<td>man machine interface</td>
</tr>
<tr>
<td>MMM</td>
<td>mass memory module</td>
</tr>
<tr>
<td>MMS</td>
<td>mission management system</td>
</tr>
<tr>
<td>MNPS</td>
<td>minimum navigation performance specification</td>
</tr>
<tr>
<td>MOS</td>
<td>metal oxide semiconductor</td>
</tr>
<tr>
<td>MOSFET</td>
<td>metal oxide semiconductor field effect transistor</td>
</tr>
<tr>
<td>MP</td>
<td>monitor processor</td>
</tr>
<tr>
<td>MPT</td>
<td>memory protocol translator</td>
</tr>
<tr>
<td>MPU</td>
<td>multifunction processor unit</td>
</tr>
<tr>
<td>MRC</td>
<td>modular radio cabinets</td>
</tr>
<tr>
<td>MRO</td>
<td>maintenance/repair/overhaul</td>
</tr>
<tr>
<td>MSB</td>
<td>most significant bit</td>
</tr>
<tr>
<td>MSD</td>
<td>most significant digit</td>
</tr>
<tr>
<td>MSI</td>
<td>medium-scale integration</td>
</tr>
<tr>
<td>MSL</td>
<td>mean sea level</td>
</tr>
<tr>
<td>MSU</td>
<td>mode select unit</td>
</tr>
<tr>
<td>MSW</td>
<td>machine status word</td>
</tr>
<tr>
<td>MT</td>
<td>maintenance terminal</td>
</tr>
<tr>
<td>MTBF</td>
<td>mean time between failure</td>
</tr>
<tr>
<td>MTBO</td>
<td>mean time between overhaul</td>
</tr>
<tr>
<td>MTC</td>
<td>message transmit cycle</td>
</tr>
<tr>
<td>MTC</td>
<td>mission and traffic control systems</td>
</tr>
<tr>
<td>MTOW</td>
<td>maximum take-off weight</td>
</tr>
<tr>
<td>MTU</td>
<td>maximum transfer unit</td>
</tr>
<tr>
<td>NASA</td>
<td>National Aeronautics and Space Administration</td>
</tr>
<tr>
<td>NCD</td>
<td>no computed data</td>
</tr>
<tr>
<td>ND</td>
<td>navigation display</td>
</tr>
<tr>
<td>NDB</td>
<td>navigation data base</td>
</tr>
<tr>
<td>NetBIOS</td>
<td>network basic input output system</td>
</tr>
<tr>
<td>NIC</td>
<td>network interface controller</td>
</tr>
<tr>
<td>NMI</td>
<td>non-maskable interrupt</td>
</tr>
<tr>
<td>NMS</td>
<td>navigation management system</td>
</tr>
<tr>
<td>NMU</td>
<td>navigation management unit</td>
</tr>
<tr>
<td>NRZ</td>
<td>non-return to zero</td>
</tr>
<tr>
<td>NVM</td>
<td>non-volatile memory</td>
</tr>
<tr>
<td>NVS</td>
<td>noise and vibration suppression</td>
</tr>
<tr>
<td>OAT</td>
<td>outside air temperature</td>
</tr>
<tr>
<td>OBI</td>
<td>omni bearing indicator</td>
</tr>
<tr>
<td>OBRM</td>
<td>onboard replacement module</td>
</tr>
<tr>
<td>OBS</td>
<td>omni bearing selector</td>
</tr>
<tr>
<td>ODS</td>
<td>operations display system</td>
</tr>
<tr>
<td>OEI</td>
<td>one engine inoperative</td>
</tr>
<tr>
<td>OEM</td>
<td>original equipment manufacturer</td>
</tr>
<tr>
<td>OLDI</td>
<td>on-line data interchange</td>
</tr>
<tr>
<td>OMS</td>
<td>on-board maintenance system</td>
</tr>
<tr>
<td>OS</td>
<td>operating system</td>
</tr>
<tr>
<td>OSS</td>
<td>option selectable software</td>
</tr>
<tr>
<td>PA</td>
<td>physical address</td>
</tr>
<tr>
<td>PAC</td>
<td>PCI AGP controller</td>
</tr>
<tr>
<td>PAPI</td>
<td>precision approach path indicator</td>
</tr>
<tr>
<td>PBGA</td>
<td>plastic ball grid array</td>
</tr>
<tr>
<td>PCA</td>
<td>preconditioned air system</td>
</tr>
<tr>
<td>PCB</td>
<td>printed circuit board</td>
</tr>
<tr>
<td>PCC</td>
<td>Purser Communication Center</td>
</tr>
<tr>
<td>PCHK</td>
<td>parity check(ing)</td>
</tr>
<tr>
<td>PCI</td>
<td>peripheral component interconnect</td>
</tr>
<tr>
<td>PCMCIA</td>
<td>Personal Computer Memory Card International Association</td>
</tr>
<tr>
<td>PDL</td>
<td>portable data loader</td>
</tr>
<tr>
<td>Abbreviation</td>
<td>Description</td>
</tr>
<tr>
<td>--------------</td>
<td>--------------------------------------------------</td>
</tr>
<tr>
<td>PFD</td>
<td>primary flight display</td>
</tr>
<tr>
<td>PGA</td>
<td>pin grid array</td>
</tr>
<tr>
<td>PIC</td>
<td>pilot in command</td>
</tr>
<tr>
<td>PISO</td>
<td>parallel-input-serial-output</td>
</tr>
<tr>
<td>PLCC</td>
<td>plastic leadless chip carrier</td>
</tr>
<tr>
<td>PM</td>
<td>protected mode</td>
</tr>
<tr>
<td>PMAT</td>
<td>portable maintenance access terminal</td>
</tr>
<tr>
<td>PMO</td>
<td>program management organisation</td>
</tr>
<tr>
<td>PMS</td>
<td>performance management system</td>
</tr>
<tr>
<td>PMSM</td>
<td>power management state machine</td>
</tr>
<tr>
<td>PNF</td>
<td>pilot non flying</td>
</tr>
<tr>
<td>POST</td>
<td>power-on self-test</td>
</tr>
<tr>
<td>PP</td>
<td>pre-processor</td>
</tr>
<tr>
<td>PQFP</td>
<td>plastic quad flat package</td>
</tr>
<tr>
<td>PRF</td>
<td>pulse repetition frequency</td>
</tr>
<tr>
<td>PRI</td>
<td>primary</td>
</tr>
<tr>
<td>PROM</td>
<td>programmable read-only memory</td>
</tr>
<tr>
<td>PSM</td>
<td>power supply module</td>
</tr>
<tr>
<td>PSU</td>
<td>power supply unit</td>
</tr>
<tr>
<td>PWB</td>
<td>printed wiring board</td>
</tr>
<tr>
<td>QAR</td>
<td>quick access recorder</td>
</tr>
<tr>
<td>QFP</td>
<td>quad flat pack</td>
</tr>
<tr>
<td>QoS</td>
<td>quality of service</td>
</tr>
<tr>
<td>R/T</td>
<td>receiver/transmitter</td>
</tr>
<tr>
<td>RA</td>
<td>radio altitude</td>
</tr>
<tr>
<td>RA</td>
<td>resolution advisory</td>
</tr>
<tr>
<td>RAM</td>
<td>random access memory</td>
</tr>
<tr>
<td>RCDI</td>
<td>rate of climb/descent indicator</td>
</tr>
<tr>
<td>RF</td>
<td>radio frequency</td>
</tr>
<tr>
<td>RFC</td>
<td>request for communication</td>
</tr>
<tr>
<td>RFI</td>
<td>radio frequency interference</td>
</tr>
<tr>
<td>RIMM</td>
<td>RAM bus in-line memory module</td>
</tr>
<tr>
<td>RISC</td>
<td>reduced instruction set computer</td>
</tr>
<tr>
<td>RLG</td>
<td>ring laser gyro</td>
</tr>
<tr>
<td>RM</td>
<td>redundancy management (AFDX)</td>
</tr>
<tr>
<td>RMI</td>
<td>radio magnetic indication</td>
</tr>
<tr>
<td>RNAV</td>
<td>area navigation</td>
</tr>
<tr>
<td>RNP</td>
<td>required navigation performance</td>
</tr>
<tr>
<td>ROM</td>
<td>read-only memory</td>
</tr>
<tr>
<td>RSN</td>
<td>redundancy sequence number</td>
</tr>
<tr>
<td>SAARU</td>
<td>secondary attitude/air data reference unit</td>
</tr>
<tr>
<td>SAP</td>
<td>service access point</td>
</tr>
<tr>
<td>SAR</td>
<td>successive approximation register</td>
</tr>
<tr>
<td>SAT</td>
<td>static air temperature</td>
</tr>
<tr>
<td>SATCOM</td>
<td>satellite communications</td>
</tr>
<tr>
<td>SATNAV</td>
<td>satellite navigation</td>
</tr>
<tr>
<td>SC</td>
<td>start conversion</td>
</tr>
<tr>
<td>SCMP</td>
<td>software configuration management plan</td>
</tr>
<tr>
<td>SDD</td>
<td>system definition document</td>
</tr>
</tbody>
</table>

**APPENDIX 1**
<table>
<thead>
<tr>
<th>Abbreviation</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>UDP</td>
<td>user datagram protocol</td>
</tr>
<tr>
<td>UHF</td>
<td>ultra high frequency</td>
</tr>
<tr>
<td>ULSI</td>
<td>ultra large-scale integration</td>
</tr>
<tr>
<td>UMS</td>
<td>user modifiable software</td>
</tr>
<tr>
<td>USB</td>
<td>universal serial bus</td>
</tr>
<tr>
<td>UTP</td>
<td>unshielded twisted pair</td>
</tr>
<tr>
<td>UV</td>
<td>ultraviolet</td>
</tr>
<tr>
<td>UVPROM</td>
<td>ultraviolet programmable read-only memory</td>
</tr>
<tr>
<td>VAC</td>
<td>volts, alternating current</td>
</tr>
<tr>
<td>VAS</td>
<td>virtual address space</td>
</tr>
<tr>
<td>VDC</td>
<td>volts, direct current</td>
</tr>
<tr>
<td>VFR</td>
<td>visual flight rules</td>
</tr>
<tr>
<td>VG</td>
<td>vertical gyro</td>
</tr>
<tr>
<td>VGA</td>
<td>video graphics adapter</td>
</tr>
<tr>
<td>VHF</td>
<td>very high frequency</td>
</tr>
<tr>
<td>VHSIC</td>
<td>very high-speed integrated circuit</td>
</tr>
<tr>
<td>VIA</td>
<td>versatile integrated avionics</td>
</tr>
<tr>
<td>VL</td>
<td>virtual link (AFDX)</td>
</tr>
<tr>
<td>VLF</td>
<td>very low frequency</td>
</tr>
<tr>
<td>VLSI</td>
<td>very large-scale integration</td>
</tr>
<tr>
<td>VME</td>
<td>versatile module Eurocard</td>
</tr>
<tr>
<td>VNAV</td>
<td>vertical navigation</td>
</tr>
<tr>
<td>VOR</td>
<td>very high frequency omni-range</td>
</tr>
<tr>
<td>VPA</td>
<td>virtual page address</td>
</tr>
<tr>
<td>VSI</td>
<td>vertical speed indicator</td>
</tr>
<tr>
<td>WAAC</td>
<td>wide angle airborne camera</td>
</tr>
<tr>
<td>WORM</td>
<td>write-once read-many</td>
</tr>
<tr>
<td>WX</td>
<td>weather</td>
</tr>
<tr>
<td>WXP</td>
<td>weather radar panel</td>
</tr>
<tr>
<td>WXR</td>
<td>weather radar</td>
</tr>
<tr>
<td>ZIF</td>
<td>zero insertion force</td>
</tr>
<tr>
<td>ZIP</td>
<td>zig-zag in-line package</td>
</tr>
</tbody>
</table>
Appendix 2
Revision papers

These revision papers are designed to provide you with practice for examinations. The questions are typical of those used in CAA and other examinations. Each paper has 20 questions and each should be completed in 25 minutes. Calculators and other electronic aids must not be used.

REVISION PAPER 1

1. Typical displays on an EHSI are:
   (a) engine indications and warnings
   (b) VOR, heading and track
   (c) VOR, altitude and rate of climb.

2. EMI can be conveyed from a source to a receiver by:
   (a) conduction only
   (b) radiation only
   (c) conduction and radiation.

3. The hexadecimal number A7 is equivalent to:
   (a) 107
   (b) 147
   (c) 167.

4. A NAND gate with its output inverted has the same logical function as:
   (a) an OR gate
   (b) a NOR gate
   (c) an AND gate.

5. Which of the following types of ADC is the fastest:
   (a) flash type
   (b) dual slope type
   (c) successive approximation type.

6. Noise generated by a switching circuit is worse when:
   (a) switching is fast and current is low
   (b) switching is slow and current is high
   (c) switching is fast and current is high.

7. The circuit shown in Figure A2.1 is:
   (a) a clock generator
   (b) a ramp generator
   (c) a sine wave oscillator.

8. Which computer bus is used to specify memory locations:
   (a) Address bus
   (b) Control bus
   (c) Data bus.

---

AA22..11 See Paper 1, Question 7
9. Figure A2.2 shows a bus interface. At which point will the data appear in parallel format:
   (a) X  
   (b) Y  
   (c) Z.

13. Adjacent blue and red phosphors are illuminated on the screen of a colour CRT. The resulting colour produced will be:
   (a) cyan  
   (b) yellow  
   (c) magenta.

14. When compared with TTL devices, CMOS logic devices use:
   (a) less power and have lower noise immunity  
   (b) more power and have lower noise immunity  
   (c) less power and have higher noise immunity.

15. The integrated circuit shown in Figure A2.3 is supplied in a:
   (a) DIL package  
   (b) PGA package  
   (c) PLCC package.

10. Which aircraft standard applies to fibre-optic networks:
   (a) ARINC 429  
   (b) ARINC 573  
   (c) ARINC 636.

11. GPS uses:
   (a) 12 satellites in three orbital planes  
   (b) 24 satellites in six orbital planes  
   (c) 48 satellites in 12 orbital planes.

12. A significant advantage of fibre-optic networks in modern passenger aircraft is:
   (a) reduced weight  
   (b) lower installation costs  
   (c) ease of maintenance.

16. The purpose of the items shown in Figure A2.4 is:
   (a) to ensure electrical integrity of the aircraft ground  
   (b) to provide a return path for AC power supplies  
   (c) to provide shielding for nearby data cables.

17. An R–2R ADC has values of resistance:
   (a) whose precision must be accurate  
   (b) whose relative precision must be accurate  
   (c) whose precision are unimportant.
18. An ALU is an example of:
   (a) LSI technology
   (b) MSI technology
   (c) SSI technology.

19. Which one of the following devices is most susceptible to damage from stray static charges:
   (a) a TTL logic gate
   (b) a MOSFET transistor
   (c) a silicon-controlled rectifier.

20. A CMOS logic gate is operated from a 15 V supply. If a voltage of 9 V is measured at the input of the gate this would be equivalent to:
   (a) a logic 0 input
   (b) a logic 1 input
   (c) an indeterminate input.

**REVISION PAPER 2**

1. When expressed in hexadecimal an octal value of 54 is the same as:
   (a) 2C
   (b) 2F
   (c) 4F.

2. A heading reference of 320° in a word label format would appear as:
   (a) 000010011
   (b) 011010000
   (c) 001000111.

3. The cone of acceptance of an optical fibre and a light source is measured between:
   (a) the two outer angles
   (b) the diameter of the core
   (c) the longitudinal axis of the core and the outer angle.

4. The flight director system receives information from:
   (a) attitude gyro, engines, radar altimeter
   (b) attitude gyro, VOR/localiser, compass system
   (c) compass system, weather radar, radar altimeter.

5. In the logic circuit shown in Figure A2.5, A = 1, B = 1, C = 1 and D = 1. The outputs X and Y will then be:
   (a) X = 0 and Y = 0
   (b) X = 0 and Y = 1
   (c) X = 1 and Y = 0.

6. The logic device shown in Figure A2.6 is:
   (a) a standard TTL device
   (b) a low-speed CMOS logic device
   (c) a low-power Schottky TTL device.

7. The method of data encoding used in an ARINC 429 bus is known as:
   (a) bipolar return to zero
   (b) universal asynchronous serial
   (c) synchronous binary coded decimal.
8. The integrated circuits shown in Figure A2.7 are:
   (a) RAM devices
   (b) UV-EPROM devices
   (c) flash memories.

9. The output of a spectrum analyser is shown in Figure A2.8. Which of the features shown is the second harmonic:
   (a) A
   (b) B
   (c) C.

10. A level-C software classification is one in which a failure could result in:
    (a) aircraft loss
    (b) fatal injuries to passengers or crew
    (c) minor injuries to passengers or crew.

11. The logic gate arrangement shown in Figure A2.9 will produce the:
    (a) OR logic function
    (b) AND logic function
    (c) NAND logic function.

12. The logic circuit arrangement shown in Figure A2.10 is:
    (a) a two to four line encoder
    (b) a two to four line decoder
    (c) a two to two line multiplexer.

13. Data is converted from serial to parallel and parallel to serial by means of:
    (a) a parallel register
    (b) a shift register
    (c) a synchronous counter.
14. The logic device shown in Figure A2.11 is:

(a) a four to three line encoder  
(b) an eight to three line encoder  
(c) a four to eight line multiplexer.

15. A group of bits transmitted at the same time is referred to as:

(a) a clock signal  
(b) parallel data  
(c) serial data.

16. A typical characteristic of CMOS logic is:

(a) low power dissipation  
(b) high voltage handling  
(c) high power dissipation.

17. A character-generator ROM is used in conjunction with:

(a) a GPS receiver  
(b) a CRT controller  
(c) a seven-segment indicator.

18. The feature marked R in Figure A2.12 is:

(a) a bus cable  
(b) a stub cable  
(c) a fibre-optic connection.

19. The main constituents of a computer are:

(a) ALU, accumulator, registers  
(b) CPU, ROM, RAM, I/O  
(c) CPU, ALU, accumulator, clock.

20. In order to produce an AND gate from a NOR gate you would need to:

(a) invert the output  
(b) invert each of the inputs  
(c) invert the output and each of the inputs.

**REVISION PAPER 3**

1. The EADI displays:

(a) pitch and roll attitudes  
(b) heading and weather radar  
(c) pitch, roll and waypoints.

2. On an EHSI in weather radar mode, a severe storm would be shown as:

(a) orange areas with black or yellow surrounds  
(b) blue areas with white background  
(c) red areas with black surrounds.

3. Which feature in Figure A2.12 is used to prevent problems with reflection and mismatch:
4. The number of individual addresses that can be addressed by a processor that has a 16-bit address bus is:

(a) 16,384
(b) 32,768
(c) 65,536.

5. In order to produce a NAND gate from an AND gate you would need to:

(a) invert the output
(b) invert each of the inputs
(c) invert the output and each of the inputs.

6. The truth table shown in Figure A2.13 is for:

(a) an OR gate
(b) a NOR gate
(c) a NAND gate.

7. If one EICAS display fails:

(a) the remaining CRT will display primary EICAS data
(b) the FMS CDU will display the failed CRT data
(c) the standby CRT will automatically take over.

8. The typical wavelength of light in an optical fibre is:

(a) 575 nm
(b) 635 nm
(c) 1,300 nm.

9. A monomode optical fibre has:

(a) a larger diameter core than a multimode fibre
(b) a smaller diameter core than a multimode fibre
(c) the same diameter core as a multimode fibre.

10. A basic ARINC 429 data word has a length of:

(a) 8 bits
(b) 16 bits
(c) 32 bits.
11. Electronic engine control software is an example of:
   (a) DFLD
   (b) LSAP
   (c) OSS.

12. Figure A2.14 shows a logic gate arrangement. In order for X and Y to both be at logic 1:
   (a) all inputs should be at logic 0
   (b) all inputs should be at logic 1
   (c) inputs B and C should be at logic 1.

13. The BCD data field of ARINC 429 is contained within bits:
   (a) 1–8
   (b) 1–10
   (c) 11–29.

14. To create a bidirectional communications link within an ARINC 429 system:
   (a) only one data bus connection is required
   (b) two data bus connections are required
   (c) four data bus connections are required.

15. The binary number 10100111 is equivalent to:
   (a) 107 decimal
   (b) 147 decimal
   (c) 167 decimal.

16. Weather radar is an example of:
   (a) Class B software
   (b) Class C software
   (c) Class D software.

17. GPS consists of the following segments:
   (a) space, user and control
   (b) latitude, longitude, time
   (c) carrier, modulation, encoding.

18. The octal number 127 is equivalent to:
   (a) 1001011 binary
   (b) 1101001 binary
   (c) 1010111 binary.

19. ACARS signals are transmitted at:
   (a) HF in the range 11 MHz to 14 MHz
   (b) VHF in the range 118 MHz to 136 MHz
   (c) UHF in the range 405 MHz to 420 MHz.

20. An advantage of a dual-slope ADC is:
   (a) a fast conversion time
   (b) an inherent ability to reject noise
   (c) the ability to operate without a clock.

REVISION PAPER 4

1. Fibre-optic data cables are:
   (a) bidirectional
   (b) unidirectional
   (c) simplex.

2. In a static memory circuit:
   (a) the memory is retained indefinitely
   (b) the memory is lost as soon as power is removed
   (c) the memory needs to be refreshed constantly, even when power is on.

3. An example of a ‘write once and read many’ mass storage device is:
   (a) a CD-ROM
   (b) a floppy disk
   (c) a dynamic RAM.
4. The Q output of an R-S bistable is at logic 0. This means that the bistable is:
   (a) set
   (b) reset
   (c) in a high-impedance state.

5. In an analogue to digital converter, the input voltage:
   (a) can vary continuously in voltage level
   (b) can have two possible voltage levels
   (c) can only have one fixed voltage level.

6. Electromagnetic compatibility is achieved by:
   (a) using smoothed and well-regulated DC supplies
   (b) coating all equipment enclosures with conductive paint
   (c) shielding, screening, earthing, bonding and interference filters.

7. The display shown in Figure A2.15 is:
   (a) EICAS
   (b) EFIS PFD
   (c) FMS CDU.

8. An ARINC 629 data bus cable uses:
   (a) a pair of twisted wires
   (b) a single wire and ground
   (c) a coaxial cable with a single screened conductor.

9. Losses in optical fibre data cables increase when:
   (a) a low data rate is used
   (b) the cable is kept as short as possible
   (c) the cable is bent around a small radius.

10. Fibre-optic cables use:
    (a) a reflective cladding
    (b) a refractive cladding
    (c) an opaque cladding.

11. An LCD uses what type of power supply:
    (a) AC voltage
    (b) current-limited DC current
    (c) voltage-limited DC voltage.

12. The hexadecimal equivalent of binary 10110011 is:
    (a) 31
    (b) B3
    (c) 113.

13. The truth table shown in Figure A2.16 is for:
    (a) a NOR gate
    (b) a NAND gate
    (c) an exclusive-OR gate.

\[
\begin{array}{ccc}
A & B & Y \\
0 & 0 & 1 \\
0 & 1 & 0 \\
1 & 0 & 0 \\
1 & 1 & 0 \\
\end{array}
\]

14. The operational data base of the FMS may have to be modified in flight:
    (a) by the pilot
    (b) automatically by the DADC
    (c) it cannot be modified in flight.
15. On an EFIS system the weather radar is displayed on:
   (a) the EADI
   (b) the EHSI
   (c) the FMC CDU.

16. A method used in modern aircraft for reporting in-flight faults to an engineering and monitoring ground station is:
   (a) TCAS II
   (b) ACARS
   (c) TAWS.

17. When compared with an LCD, a CRT display offers the advantage that:
   (a) the resolution and focus are better
   (b) it can be viewed over a large angle
   (c) it uses low voltages and is more energy efficient.

18. The logic arrangement shown in Figure A2.17 is equivalent to:
   (a) an OR gate
   (b) an AND gate
   (c) a NAND gate.

A2.17 See Paper 4, Question 18

19. The logic arrangement shown in Figure A2.18 acts as:
   (a) a decoder
   (b) a multiplexer
   (c) a shift register.

A2.18 See Paper 4, Question 19

20. The pins on a DIL packaged integrated circuit are numbered:
   (a) clockwise starting at pin-1
   (b) clockwise starting at pin-14
   (c) anticlockwise starting at pin-1.

REVISION PAPER 5

1. Rate of climb is indicated by the:
   (a) altimeter
   (b) HSI
   (c) VSI.

2. Which one of the following avionic systems is capable of displaying engine data:
   (a) AFCS
   (b) EADI
   (c) EICAS.

3. The denary number 63 is equivalent to the binary number:
   (a) 11011
   (b) 110111
   (c) 111111.
4. The binary number 10010011 is equivalent to the hexadecimal number:
(a) B3
(b) 93
(c) C3.

5. In order to minimise the effect of reflections caused by a mismatch, a bus cable should be:
(a) terminated at each end
(b) kept as short as possible
(c) fitted with repeaters at regular intervals.

6. The logic device shown in Figure A2.19 is:
(a) a quad two-input NOR gate
(b) a quad two-input NAND gate
(c) a triple three-input NOR gate.

7. The typical maximum clock frequency for a standard TTL logic device is:
(a) 2 MHz
(b) 10 MHz
(c) 35 MHz.

8. Which one of the following gives the range of values that can be indicated by an unsigned byte:
(a) 0 to 255
(b) –128 to +127
(c) 0 to 65,535.

9. The core of a monomode optical fibre has a typical diameter of:
(a) 5 µm
(b) 25 µm
(c) 50 µm.

10. Which one of the following classes of semiconductor device is most susceptible to static voltages:
(a) VLSI microprocessors
(b) bipolar junction transistors
(c) silicon-controlled rectifiers.

11. Which one of the following aircraft software applications has the highest level of criticality:
(a) DME
(b) GPS
(c) WXR.

12. Real-time monitoring of critical systems is a function of:
(a) BITE
(b) FMS
(c) EFIS.

13. The fundamental network architecture used in an AFDX network is:
(a) bus
(b) tree
(c) cascaded star.

14. Within an AFDX network, the ethernet frames associated with a particular virtual link can originate at:
(a) multiple end systems
(b) one, and only one, end system
(c) each end system present in the network.
15. In an AFDX network the links from each host to the switch are:
   (a) simplex
   (b) half-duplex
   (c) full-duplex.

16. What is the maximum bandwidth allocation gap for a virtual link that supplies messages at a rate of 250 per second:
   (a) 2 ms
   (b) 4 ms
   (c) 8 ms.

17. The VHDL standard logic type \( L \) is:
   (a) a weak low
   (b) a forcing logic 0
   (c) an uninitialised logic state.

18. In VHDL code a Boolean data type can have values:
   (a) 0 and 1
   (b) FALSE and TRUE
   (c) low and high.

19. When \( X = 011 \) and \( Y = 110 \) the VHDL expression \( X \land \neg Y \) will evaluate to:
   (a) 001
   (b) 110
   (c) 010.

20. Which one of the following gives the order of precedence of VHDL operators (highest first):
   (a) logical; relational; shift
   (b) relational; logical; shift
   (c) shift; relational; logic.

**REVISION PAPER 6**

1. The standard for ACARS is defined in:
   (a) ARINC 429
   (b) ARINC 664
   (c) ARINC 724.

2. The hexadecimal number E3 is equivalent to the binary number:
   (a) 11100111
   (b) 11100011
   (c) 11100111.

3. The binary coded decimal number 10010010 is equivalent to the decimal number:
   (a) 92
   (b) B2
   (c) 146.

4. Which one of the symbols shown in Figure A2.20 is for a two-input OR gate:
   (a) A
   (b) B
   (c) C.
5. The resolution of a DAC depends on:

(a) the speed at which the device operates
(b) the accuracy of the reference voltage used
(c) the number of bits used in the conversion process.

6. Which one of the following gives the length of an ARINC 429 data word:

(a) 16 bits
(b) 32 bits
(c) 64 bits.

7. The truth table shown in Figure A2.21 is for:

(a) a two-input AND gate
(b) a two-input OR gate
(c) a two input XOR gate.

<table>
<thead>
<tr>
<th>A</th>
<th>B</th>
<th>Y</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
</tbody>
</table>

8. The logic circuit shown in Figure A2.22 is equivalent to:

(a) a two-input AND gate
(b) a two-input OR gate
(c) a two input XOR gate.

9. The symbol shown in Figure A2.23 is:

(a) a two-input AND gate
(b) a two-input OR gate
(c) a two input XNOR gate.

A2.23 See Paper 6, Question 9

10. How many 16K × 4-bit DRAM devices are needed to provide 64K bytes of storage:

(a) 4
(b) 8
(c) 16.

11. Bus arbitration is required in order to:

(a) avoid bus contention
(b) prevent memory loss
(c) reduce errors caused by noise and EMI.

12. The clock oscillator in a microprocessor system provides:

(a) a sine wave signal of accurately controlled frequency
(b) a square wave signal of accurately controlled frequency
(c) a train of rectangular pulses derived from a free-running oscillator.

13. In a microprocessor system, faster processing can be achieved by means of:

(a) instruction pipelining
(b) a complex instruction set
(c) a multiplexed address/data bus.

14. What type of network is shown in Figure A2.24:

(a) bus
(b) ring
(c) star.
15. AFDX is defined in:

(a) ARINC 429
(b) ARINC 573
(c) ARINC 664.

16. Within an AFDX switch each end system is connected by means of:

(a) shared bus cables and shared RX and TX buffers
(b) individual bus cables and shared RX and TX buffers
(c) individual bus cables and separate RX and TX buffers.

17. The VHDL standard logic type Z is:

(a) a weak low
(b) a weak unknown
(c) a high-impedance state.

18. Comments within VHDL code start with:

(a) !
(b) ;
(c) --.

19. The last part of an AFDX frame contains:

(a) the MAC start and destination addresses and VL identifiers
(b) the AFDX payload and sequence number
(c) the frame check sequence and checksum.

20. The inter-frame gap in AFDX is equivalent to:

(a) 17-bit periods
(b) 31-bit periods
(c) 96-bit periods.
Appendix 3

Answers

ANSWERS TO REVIEW QUESTIONS

Chapter 1
1. b
2. a
3. c
4. a
5. a
6. b
7. b
8. b
9. a
10. a
11. a
12. a
13. b
14. b
15. a
16. c
17. c
18. b
19. a
20. a
21. c
22. b
23. b
24. a
25. a
26. c
27. b
28. c

Chapter 2
1. b
2. c
3. a
4. b
5. a
6. c
7. b
8. c
9. c
10. c
11. b
12. a
13. a

Chapter 3
1. a
2. b
3. b
4. b
5. c
6. c
7. b
8. c
9. c
10. a
11. b
12. c
13. b
Chapter 5

1. b
2. b
3. c
4. b
5. a
6. a
7. b
8. c
9. a
10. b
11. b
12. c
13. c
14. a
15. c
16. b
17. c

Chapter 6

1. b
2. a
3. b
4. a
5. b
6. b
7. b
8. c
9. a
10. b
11. c
12. a
13. b

Chapter 7

1. a
2. c
3. b
4. b
5. c
6. a
7. c
8. a
9. a
10. c
11. b
12. b
13. a
14. b
15. a
16. c
17. b
18. c
19. b
20. b
21. a
22. c

Chapter 8

1. a
2. a
3. b
4. c
5. a
6. b
7. a
8. c
9. b
10. a
11. b
12. c
13. a
14. b
15. b

Chapter 4

1. b
2. c
3. b
4. a
5. a
6. c
7. a
8. c
9. a
10. b
11. b
12. c
13. c
14. a
15. c
16. a
17. a
Chapter 9
1. c
2. a
3. c
4. a
5. b
6. b
7. a
8. b

Chapter 10
1. b
2. c
3. a
4. c
5. a
6. c
7. b
8. c
9. a
10. a
11. c
12. b
13. b
14. b
15. c
16. a

Chapter 12
1. c
2. c
3. c
4. c
5. c
6. a
7. a
8. a

Chapter 13
1. c
2. b
3. c
4. c
5. b
6. a
7. b

Chapter 14
1. a
2. c
3. c
4. c
5. c
6. a
7. b
8. a
9. c

Chapter 15
1. c
2. a
3. c
4. b
5. c
6. c
ANSWERS TO REVISION PAPERS

Revision paper 1

1. b  
2. c  
3. c  
4. c  
5. a  
6. c  
7. a  
8. a  
9. c  
10. c  
11. b  
12. a  
13. c  
14. c  
15. c  
16. a  
17. b  
18. a  
19. b  
20. c

Revision paper 2

1. a  
2. b  
3. c  
4. b  
5. c  
6. c  
7. a  
8. b  
9. b  
10. c  
11. b  
12. b  
13. b  
14. b  
15. b  
16. a  
17. b  
18. b  
19. b  
20. b

Chapter 16

1. c  
2. c  
3. c  
4. b  
5. b  
6. c  
7. c  
8. b  
9. b  
10. a  
11. a  
12. c  
13. c  
14. c  
15. c  
16. c  
17. c  
18. a  
19. b  
20. b

Chapter 17

1. a  
2. a  
3. a  
4. c  
5. c  
6. b  
7. b  
8. a  
9. c  
10. a  
11. c  
12. b  
13. a  
14. c
<table>
<thead>
<tr>
<th>Revision paper 3</th>
<th>Revision paper 5</th>
</tr>
</thead>
<tbody>
<tr>
<td>1. a</td>
<td>1. c</td>
</tr>
<tr>
<td>2. c</td>
<td>2. c</td>
</tr>
<tr>
<td>3. c</td>
<td>3. c</td>
</tr>
<tr>
<td>4. c</td>
<td>4. b</td>
</tr>
<tr>
<td>5. a</td>
<td>5. a</td>
</tr>
<tr>
<td>6. c</td>
<td>6. b</td>
</tr>
<tr>
<td>7. a</td>
<td>7. c</td>
</tr>
<tr>
<td>8. c</td>
<td>8. a</td>
</tr>
<tr>
<td>9. b</td>
<td>9. a</td>
</tr>
<tr>
<td>10. c</td>
<td>10. a</td>
</tr>
<tr>
<td>11. b</td>
<td>11. b</td>
</tr>
<tr>
<td>12. a</td>
<td>12. a</td>
</tr>
<tr>
<td>13. c</td>
<td>13. c</td>
</tr>
<tr>
<td>14. b</td>
<td>14. b</td>
</tr>
<tr>
<td>15. c</td>
<td>15. c</td>
</tr>
<tr>
<td>16. c</td>
<td>16. b</td>
</tr>
<tr>
<td>17. a</td>
<td>17. a</td>
</tr>
<tr>
<td>18. c</td>
<td>18. b</td>
</tr>
<tr>
<td>19. b</td>
<td>19. a</td>
</tr>
<tr>
<td>20. b</td>
<td>20. c</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Revision paper 4</th>
<th>Revision paper 6</th>
</tr>
</thead>
<tbody>
<tr>
<td>1. a</td>
<td>1. c</td>
</tr>
<tr>
<td>2. b</td>
<td>2. b</td>
</tr>
<tr>
<td>3. a</td>
<td>3. a</td>
</tr>
<tr>
<td>4. b</td>
<td>4. a</td>
</tr>
<tr>
<td>5. a</td>
<td>5. c</td>
</tr>
<tr>
<td>6. c</td>
<td>6. b</td>
</tr>
<tr>
<td>7. c</td>
<td>7. c</td>
</tr>
<tr>
<td>8. a</td>
<td>8. b</td>
</tr>
<tr>
<td>9. c</td>
<td>9. c</td>
</tr>
<tr>
<td>10. b</td>
<td>10. c</td>
</tr>
<tr>
<td>11. a</td>
<td>11. a</td>
</tr>
<tr>
<td>12. b</td>
<td>12. b</td>
</tr>
<tr>
<td>13. a</td>
<td>13. a</td>
</tr>
<tr>
<td>14. c</td>
<td>14. b</td>
</tr>
<tr>
<td>15. b</td>
<td>15. c</td>
</tr>
<tr>
<td>16. b</td>
<td>16. c</td>
</tr>
<tr>
<td>17. b</td>
<td>17. c</td>
</tr>
<tr>
<td>18. b</td>
<td>18. c</td>
</tr>
<tr>
<td>19. b</td>
<td>19. c</td>
</tr>
<tr>
<td>20. c</td>
<td>20. c</td>
</tr>
</tbody>
</table>
Appendix 4

Serial data communications: RS-232

Although dated and superseded by faster and more effective methods of transferring data from one device to another, the RS-232 standard (first defined in 1962) is still in use today in a variety of ‘legacy’ equipment. This Appendix explains what the standard is and how it works.

THE RS-232 STANDARD

The RS-232 standard was first defined by the Electronic Industries Association (EIA) as a recommended standard (RS) for interfacing a modem to a computer system. Later, the revised and improved RS-232D standard brought it in-line with international standards CCITT V24, V28 and ISO IS2110.

The standard relates essentially to two types of equipment: data terminal equipment (DTE) and data circuit terminating equipment (DCE). Data terminal equipment (i.e. a PC) is capable of sending and/or receiving data via a serial interface. It is thus said to ‘terminate’ the serial link. Data circuit terminating equipment (formerly known as data communications equipment), on the other hand, facilitates serial data communications.

Serial I/O involves transmitting a stream of bits, one after another, from a PC to a peripheral device and vice versa. Since parallel (8-, 16- or 32-bit) data is present on the system bus, serial I/O is often more complex than parallel I/O. Serial input data must be converted to parallel (byte-wide) data which can be presented to the system data bus. Conversely, the parallel data on the bus must be converted into serial data before it can be output from the port. In the first case, conversion can be performed with a serial-input–parallel-output (SIPO) shift register; in the second case a parallel-input–serial-output (PISO) shift register is required.

Serial data may be transferred in either synchronous mode or asynchronous mode. In the former case, transfers are carried out in accordance with a common clock signal (the clock must be available at both ends of the transmission path). Asynchronous operation, on the other hand, involves transmission of data in small packets; each packet containing the necessary information required to decode the data which it contains. Clearly this technique is more complex but it has the considerable advantage that a separate clock signal is not required.

As with programmable parallel I/O devices, a variety of different names are used to describe programmable serial I/O devices, including asynchronous communications interface adaptor (ACIA) and universal asynchronous receiver/transmitter (UART). Both types of device have common internal features including registers for buffering the transmitted and received data and controlling the format of each data word.

Signals produced directly by serial I/O devices are invariably TTL compatible. Furthermore, such signals are unsuitable for anything other than the shortest of data transmission paths (e.g. within an equipment enclosure). Serial data transmission over any appreciable distance requires additional line drivers to provide buffering and level shifting between the serial I/O
device and the physical medium. Additionally, line receivers are required to condition and modify the incoming signal to TTL levels.

The signals present within the RS-232 interface fall into one of the following three categories.

**Data (e.g. TXD, RXD)**

RS-232 provides for two independent serial data channels (described as primary and secondary). Both of these channels provide for full duplex operation (i.e. simultaneous transmission and reception).

**Handshake control (e.g. RTS, CTS)**

Handshake signals provide the means by which the flow of serial data is controlled, allowing, for example, a DTE to open a dialogue with the DCE prior to actually transmitting data over the serial data path.

**Timing (e.g. TC, RC)**

For synchronous (rather than the more usual asynchronous) mode of operation, it is necessary to pass clock signals between the devices. These timing signals provide a means of synchronising the received signal to allow successful decoding.

Note that, in practice, few RS-232 implementations make use of the secondary channel and, since asynchronous (non-clocked) operation is almost invariably used with modern computer systems, only eight or nine of the RS-232 signals are used.

**RS-232 CONNECTORS**

A computer serial interface is usually implemented using a standard nine-way or 25-way D-connector (see Figures A4.1 and A4.2). The computer (acting as the DTE) is fitted with a male connector and the peripheral device (the DCE) normally uses a female
connector. When you need to link two computers together, they must both adopt the role of DTE while thinking that the other is a DCE. This little bit of trickery is enabled by means of a **null-modem** which works by swapping over the TXD and RXD, CTS and RTS, DTR and DSR signals.

**RS-232 DATA REPRESENTATION**

In most RS-232 systems, data is transmitted asynchronously as a series of small packets, each of which represents a single ASCII (or control) character. ASCII characters are represented by seven bits. The upper-case letter ‘A’, for example, is represented by the seven-bit binary word 1000001. In order to send the letter ‘A’ via an RS-232 system, extra bits must be added to signal the start and end of the data packet. These are known as the **start bit** and **stop bits**, respectively. In addition, you can include a further bit to provide a simple even or odd **parity** error-detecting facility.

One of the most commonly used schemes involves the use of one start bit, one parity bit and two stop bits. The commencement of the data packet is signalled by the start bit, which is always low irrespective of the contents of the packet. The start bit is followed by the seven data bits representing the ASCII character concerned. A parity bit is added to make the resulting number of 1s in the group either odd (**odd parity**) or even (**even parity**). Finally, two stop bits are added. These are both high.

The complete asynchronously transmitted data word thus comprises 11 bits (note that only seven of these actually contain data). In binary the word can be represented as: 01000001011. In this case, even parity has been used and thus the ninth (parity bit) is reset (0).

The voltage levels employed in an RS-232 interface are markedly different from those used within a microcomputer system. A positive voltage (between +3 V and +25 V) is used to represent a logic 0 (or **SPACE**) while a negative voltage (between −3V and −25V) is used to represent a logic 1 (or **MARK**).

**RS-232 VOLTAGE LEVELS**

The level shifting (from TTL to RS-232 signal levels and vice versa) is invariably accomplished using line driver and line receiver chips, the most common examples being the 1488 and 1489 devices. The principal electrical specification for the RS-232 standard is as follows:

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Specification</th>
</tr>
</thead>
<tbody>
<tr>
<td>Maximum line driver output voltage (open circuit)</td>
<td>±25 V</td>
</tr>
<tr>
<td>Maximum line driver output current (short circuit)</td>
<td>±500 mA</td>
</tr>
<tr>
<td>Minimum line impedance 3 kΩ</td>
<td>(in parallel with 2.5 nF)</td>
</tr>
<tr>
<td>Line driver SPACE output voltage (3 kΩ &lt; R&lt;sub&gt;L&lt;/sub&gt; &lt; 7 kΩ)</td>
<td>+5 V to +15 V</td>
</tr>
<tr>
<td>Line driver MARK output voltage (3 kΩ &lt; R&lt;sub&gt;L&lt;/sub&gt; &lt; 7 kΩ)</td>
<td>−5 V to −15 V</td>
</tr>
<tr>
<td>Line driver output (idle state)</td>
<td>MARK</td>
</tr>
<tr>
<td>Line receiver output with open circuit input</td>
<td>logic 1</td>
</tr>
<tr>
<td>Line receiver output with input 3 V</td>
<td>logic 0</td>
</tr>
<tr>
<td>Line receiver output with input −3 V</td>
<td>logic 1</td>
</tr>
</tbody>
</table>

**TROUBLESHOOTING RS-232**

Troubleshooting an RS-232 system usually involves the following basic steps:

1. Check the physical connection between the computer (the DTE) and the DCE. Where both devices are computers (i.e. both configured as DTEs) a patch box or null modem should be inserted for correct operation.
2. Check that the correct cable has been used. Note that RS-232 cables are provided in a variety of forms: four-way (for **dumb terminals**), nine-way (for normal asynchronous data communications), 15-way (for synchronous communications) and 25-way (for universal applications).
3. Check that the same data word format and baud rate has been selected at each end of the serial link (note that this is most important and it often...
explains why an RS-232 link fails to operate even though the hardware and cables have been checked.

4. Activate the link and investigate the logical state of the data (TXD and RXD) and handshaking (RTS, CTS, etc.) signal lines using a line monitor, breakout box or interface tester. Lines may be looped back to test each end of the link.

5. If in any doubt, refer to the equipment manufacturer’s data in order to ascertain whether any special connections are required and to ensure that the interfaces are truly compatible. Note that some manufacturers have implemented quasi-RS-232 interfaces which make use of TTL signals but which may not be fully electrically compatible.

6. The communications software should be initially configured for the least complex protocol (e.g. basic 7-bit ASCII character transfer at a low speed such as 4,800 baud with no handshaking). When a successful link has been established, more complex protocols may be attempted in order to increase the data transfer rate or improve upon data checking.

---

**KEY POINT**

You can normally distinguish a DTE device from a DCE device by examining the type of connector fitted. A DTE device is normally fitted with a male connector while a DCE device is invariably fitted with a female connector.

---

**KEY POINT**

There is a subtle difference between the bit rate as perceived by the computer and the baud rate (i.e. the signalling rate in the transmission medium). The reason is simply that additional start, stop and parity bits must accompany the data so it can be recovered from the asynchronous data stream. For example, a typical PC serial configuration might use a total of 11 bits to convey each 7-bit ASCII character. In this case, a line baud rate of 600 baud implies a useful data transfer rate of a mere 382 bits per second.
Index

ACARS 175–6, 176, 176
ADC 26, 34–7
address bus: AMD 29050 101, 101; connecting system 70–1; CPU 89, 93; data storage 73–4, 75; Intel processors 95, 97, 99, 99
AFDX (avionics full-duplex switched network): arrangement and function 194, 194–5; bandwidth allocation gap 197, 197; deterministic quality of service 195–6; frame format 200; frame transmission 197–8, 198; integrity and reliability checking 198–9, 199, 200; virtual links 196–7
Airbus: A320 9, 11–12, 177; A380 194
aircraft integrated data system 83–4, 84
air data instruments 2, 4
airspeed indicators 2, 3
altimeter 2, 3
altitude indicator 2, 3
AMLCD (active matrix LCD) 132, 132–3, 143
analogue to digital converter (ADC) 34–7, 35, 36, 37
AND gates 54
angle of attack sensor 5
ARINC: 419 49; 429 44–7, 46, 46, 47–8, 48; 561 50; 573 50; 575 50; 615 50; 629 50, 84; 636 127; 664 194; 708 50; 717 84
artificial horizon 2, 3
ASCII 23
ASI 2, 3
auxiliary power unit (APU) 61, 61–2
backplane bus system 81–2
bidirectional bus 40, 41, 41–2, 42
binary, natural 17; conversions 17, 17–18, 21–2; Gray code conversion 113, 114; one’s complement 19; two’s complement 19
binary coded decimal 18, 47, 113
carrier sense, multiple access (CSMA/CD) 193–4, 193–4
clock computer 83, 83
coding systems: binary coded decimal 47, 113; Gillham code 114, 115; Gray code 113, 114
cockpit layout 11, 11–12
class D amplifier 65
computer systems: instruction options 80–1, 80–1; instruction sets 79; main components 70, 70–1, 71; mnemonics 79–80; programming 78
coupler panel 43, 44
cPU: AMD 29K series 100–1, 101; Intel 80286/80386/80486 96–8, 97; Intel interrupt handling 98–9; Intel Pentium processors 99, 99–100; Intel x86 processors 94–6, 95, 96, 96, 97; internal architecture 87–90, 88, 90, 91; microprocessor operation 91, 92, 92–4, 93–4
CRT (cathode ray tube) 133–5, 134–8, 137–9, 180
data buses: AMD 29050 101, 101; connecting system 70–1
bus cable 43, 43
bus interface 42–3, 43, 44
bus systems: architecture 41, 42; ARINC 429 44–7, 46, 46, 47–8, 48; protocols 41, 42; serial data transfer 42–4, 43, 44; standards (non-ARINC 429) 49–51
bus terminator 43
control bus 71, 89–90
cpu: AMD 29K series 100–1, 101; Intel 80286/80386/80486 96–8, 97; Intel interrupt handling 98–9; Intel Pentium processors 99, 99–100; Intel x86 processors 94–6, 95, 96, 96, 97; internal architecture 87–90, 88, 90, 91; microprocessor operation 91, 92, 92–4, 93–4
cRT (cathode ray tube) 133–5, 134–8, 137–9, 180
DAC 31–4
binary counter 64, 64
bistables: D-type 62, 63, 209; J-K 62–4, 63–5; R-S 62, 62, 73
BNR encoding 47, 47–8, 48
Boeing 9, 177, 183; 757 1, 10, 180; 767 12; 777 127
Boolean algebra 55–6
CAD 26, 34–7
ADC 26, 34–7
address bus: AMD 29050 101, 101; connecting system 70–1; CPU 89, 93; data storage 73–4, 75; Intel processors 95, 97, 99, 99
AFDX (avionics full-duplex switched network): arrangement and function 194, 194–5; bandwidth allocation gap 197, 197; deterministic quality of service 195–6; frame format 200; frame transmission 197–8, 198; integrity and reliability checking 198–9, 199, 200; virtual links 196–7
Airbus: A320 9, 11–12, 177; A380 194
aircraft integrated data system 83–4, 84
air data instruments 2, 4
airspeed indicators 2, 3
altimeter 2, 3
altitude indicator 2, 3
AMLCD (active matrix LCD) 132, 132–3, 143
analogue to digital converter (ADC) 34–7, 35, 36, 37
AND gates 54
angle of attack sensor 5
ARINC: 419 49; 429 44–7, 46, 46, 47–8, 48; 561 50; 573 50; 575 50; 615 50; 629 50, 84; 636 127; 664 194; 708 50; 717 84
artificial horizon 2, 3
ASCII 23
ASI 2, 3
auxiliary power unit (APU) 61, 61–2
backplane bus system 81–2
bidirectional bus 40, 41, 41–2, 42
binary, natural 17; conversions 17, 17–18, 21–2; Gray code conversion 113, 114; one’s complement 19; two’s complement 19
binary coded decimal 18, 47, 113

data representation 71, 71–2
data storage: RAM (Random access memory) 72–6, 73–5, 74, 76; ROM (Read only memory) 76, 76–7, 77
decimal numbers 16–17; binary coded decimal 18, 47, 113; conversions 17, 17–18, 20, 22
decoders 115–17, 115–17
de Morgan’s Theorem 56
digital flight data recorder 179–80
digital information transfer system (DITS) 44–5
digital to analogue converter (DAC) 31–4, 31–4, 32–3
display processor unit 9, 178
displays: AMLCD (active matrix LCD) 132, 132–3; CRT 133–5, 134–8, 137–9; LCD 141, 142–3, 143; LED 139, 139–40, 140–1
display select panel 8
DO-178B/ED-12B 154–5
dual-slope ADC 37, 37

EADI 169, 170
EEPROM 77
EPIS 7–9, 176–8
EHSI 6, 7
EICAS 9–10, 180–2
electromagnetic compatibility (EMC): avionic equipment 165, 165–6; grounding and bonding connections 172–3; spectrum analysis 166–9, 166–9; wiring and cable routing 172
electromagnetic interference (EMI): frequency bands 169, 170; generation of 162–4, 162–4; reduction measures 171–2; sources of 169–70; types of 170–1
electronic attitude and direction indicator (EADI) 6, 6
electronic centralised aircraft monitor 9, 9, 189
electronic flight instrument system (EFIS): components 7–9, 176–8; displays 8, 177, 178; operations of 179, 179–80
electronic horizontal situation indicator (EHSI) 6, 7
electrostatic sensitive device (ESD): sensitive devices 148–9, 149; static electricity 146–8, 148; warnings and handling 149–51, 149–51
EMC 165–6
EMI 169, 170
encoders 117, 117–18
engine indicating and crew alerting system (EICAS) 9–10, 10, 180, 180–2, 181
EPROM 77
ESD 148–9
eternet 193–4, 193–4
Exclusive-NOR gates 55
Exclusive-OR gates 54–5
fan-in/fan-out 112–13
Flash ADC 34–5, 35
flight director systems (FDS) 6–7
flight instruments, basic 2, 3, 4–5, 5
flight management system (FMS) 10–11, 11, 182, 183, 183–4
fly-by-wire (FBW) 180
glide slope 6
GPS (global positioning system) 184–5, 184–6
hexadecimal numbers 21–2; computer programs 71, 78; conversions 22–3
horizontal situation indicator 3, 4
inertial reference system 186–7
instrument landing system (ILS) 6, 7
integrated circuits 105–6, 105–9, 106–9, 107, 108
integrated modular avionics (IMA) 191

LCD 141, 142–3, 143
LED 139, 139–40, 140–1
line replacement units (LRU) 41, 41, 42–3, 42–3
local area networks (LAN) 191–2, 192
localiser 6, 8
logic circuits: binary counters 64, 64; bistables 62–3, 63, 209–10, 209–10; buffers 54; combinational 57–8; inverted outputs/inputs 55, 55; inverters 54; landing gear door 57–8, 57–9; logic gates 54–5, 54–5, 112; majority vote 56, 56, 57; monostables 60–2, 61; shift registers 64, 65; tri-state logic 60, 60
logic families 65, 65, 66, 67–8
logic systems: hardware description language (HDL) 203–4, 210, 212; VHDL 204–10, 211–12, 212
magnetic compass 3, 4
Manchester-encoded data 43, 44
memory cell: bipolar 72–3, 73; MOS 72–3, 73
memory cell matrix 73–4, 74, 76, 76
monostables 60–2, 61
MSI logic 112–21, 112–21, 113, 114
multi-function display 9, 178
multi-function processor unit 9
multiplexers 119–21, 119–21

NAND gates 54
navigation display 7–8, 8, 178, 188
NOR gates 54
number systems: ASCII 23; binary 17–19, 22–3; comparative values 21, 24–8; decimal 16–19, 20, 22; hexadecimal 21–3; octal 19–21
octal numbers 19–21
OR gates 54
OT PROM (one-time programmable ROM) 76

pitot tube 5
primary flight display 7–8, 8, 178
priority encoder 35

quantisation 30, 31

RAM (Random access memory) 72–6, 73–5, 74, 76
ramp-type ADC 36, 36–7
ROM (Read only memory) 76, 76–7, 77
RS-232 Standard 241–4

self-clocking 43, 45
serial data bus 42–4, 43
shielded twisted pair (STP) 43
shift register 64, 65

signals, data: analogue 30, 30; analogue to digital conversion 34–7; digital 30, 30; digital to analogue conversion 31–4, 31–4, 32–3; quantisation 30, 31
software: AFDX performance 199, 200; certification 154, 154–5, 156; criticality levels 153–4, 154; database field loadable data (DFLD) 157–8; data verification 160; field loadable software (FLS) 155–6, 157–8; transfer methods and validation 157–60, 160

source/destination identifier (SDI) 44, 47, 48, 49
static port 5
STP 43
stub cable 43, 44
successive approximation ADC 35–6, 36

TACAN 8
TCAS 187–9, 188
terminal controller 43, 44
test equipment: automatic 189; built-in 189
tri-state logic 60, 60
TTL logic 65, 66–8, 67
turn and bank indicator 3

unidirectional bus 40, 41, 42, 44–5

vertical speed indicator 3, 4
VHDL 203–10, 211–12, 212
VHSL devices 106, 107; see also VHDL
VME bus 82, 82
VOR 7, 8
VSI 3, 4

weather radar panel 9