Embedded Microcomputer Systems: Real Time Interfacing

Download as pdf or txt
Download as pdf or txt
You are on page 1of 7

51629_00_TOC_RSE.

qxd 2/2/06 4:55 PM Page iii

Embedded
Microcomputer
Systems
Real Time Interfacing
Second Edition

Jonathan W. Valvano
University of Texas at Austin

Australia • Canada • Mexico • Singapore • Spain • United Kingdom • United States


51629_00_TOC_RSE.qxd 2/2/06 4:55 PM Page xiii

Contents

1 Microcomputer-Based 1.10
1.11
Choosing a Microcontroller
Exercises 54
53

Systems 1 1.12 Lab Assignments 56


1.1 Computer Architecture 2
1.2 Embedded Computer Systems 6 2 Design of Software
1.3 The Design Process 10 Systems 58
1.3.1 Top-Down Design 10
1.3.2 Bottom-Up Design 14
2.1 Quality Programming 58
2.1.1 Quantitative Performance
1.4 Digital Logic and Open Collector 15
Measurements 59
1.5 Digital Representation of Numbers 20 2.1.2 Qualitative Performance
1.5.1 Fundamentals 20 Measurements 59
1.5.2 8-Bit Numbers 22 2.2 Assembly Language Programming 60
1.5.3 Character Information 23
2.2.1 Introduction 60
1.5.4 16-Bit Numbers 23
2.2.2 Assembly Language Syntax 62
1.5.5 Fixed-Point Numbers 25
2.2.3 Memory and Register Transfer
1.6 Common Architecture of the 6811 and Operations 64
the 6812 27 2.2.4 Indexed Addressing Mode 66
1.6.1 Registers 28 2.2.5 Arithmetic Operations 69
1.6.2 Terminology 29 2.2.6 Extended Precision Arithmetic Instructions
1.6.3 Addressing Modes 30 on the 6812 74
1.6.4 Numbering Scheme Used by Freescale for the 2.2.7 Shift Operations 75
6811 and the 6812 33 2.2.8 Logical Operations 77
1.7 6811 Architecture 33 2.2.9 Subroutines and the Stack 78
1.7.1 6811 Family 33 2.2.10 Branch Operations 82
1.7.2 MC68HC711E9 35 2.2.11 Assembler Pseudo-ops 84
1.7.3 MC68HC11D3 37 2.2.12 Memory Allocation 88
1.8 6812 Architecture 37 2.3 Self-Documenting Code 91
1.8.1 6812 Family 37 2.3.1 Comments 91
1.8.2 MC9C12C32 38 2.3.2 Naming Convention 94
1.8.3 MC68HC812A4 41 2.4 Abstraction 95
1.8.4 MC68HC912B32 42 2.4.1 Definitions 95
1.9 Parallel I/O Ports 43 2.4.2 6811 Timer Details 96
1.9.1 Basic Concepts of Input and 2.4.3 6812 Timer Details 96
Output Ports 43 2.4.4 Time Delay Software Using the Built-in
1.9.2 Introduction to I/O Programming and the Timer 97
Direction Register 46 2.4.5 Moore Finite State Machine Traffic Light
1.9.3 Our First Design Problem 47 Controller 98
xiii
51629_00_TOC_RSE.qxd 2/2/06 4:55 PM Page xiv

xiv  Contents

2.4.6 Mealy Finite State Machine Robot 3.5.3 Gadfly Keyboard Interface Using Latched
Controller 101 Input 158
2.5 Modular Software Development 104 3.5.4 Gadfly ADC Interface Using Simple
2.5.1 Local Variables in Assembly Input 159
Language 104 3.5.5 Gadfly External Sensor Interface Using
2.5.2 Modules 109 Input Handshake 161
2.5.3 Dividing a Software Task into Modules 113 3.5.6 Gadfly Printer Interface Using Output
2.5.4 Rules for Developing Modular Software in Handshake 163
Assembly Language 116 3.5.7 Gadfly Synchronous Serial Interface to a
2.6 Layered Software Systems 118 Temperature Sensor 164
2.7 Device Drivers 119 3.6 Serial Communications Interface (SCI)
2.7.1 Basic Concept of Device Drivers 119 Device Driver 173
2.7.2 Design of a Serial Communications 3.6.1 Transmitting in Asynchronous Mode 174
Interface (SCI) Device Driver 121 3.6.2 Receiving in Asynchronous Mode 175
2.8 Object-Oriented Interfacing 122 3.6.3 6811 SCI Details 177
3.6.4 6812 SCI Details 178
2.8.1 Encapsulated Objects Using
3.6.5 SCI Device Driver 179
Standard C 122
2.8.2 Object-Oriented Interfacing 3.7 Exercises 181
Using C++ 123 3.8 Lab Assignments 187
2.8.3 Portability Using Standard C
and C++ 124
2.9 Threads 126
2.9.1 Single-Threaded Execution 126
4 Interrupt Synchronization
2.9.2 Multithreading and Reentrancy 126 189
2.10 Recursion 128 4.1 What Are Interrupts? 190
2.11 Debugging Strategies 128 4.1.1 Interrupt Definition 190
2.11.1 Debugging Tools 128 4.1.2 Interrupt Service Routines 191
2.11.2 Debugging Theory 129 4.1.3 When to Use Interrupts 192
2.11.3 Functional Debugging 131 4.1.4 Interthread Communication 192
2.11.4 Performance Debugging 133 4.2 Reentrant Programming 197
2.11.5 Profiling 136
4.3 First-In–First-Out Queue 204
2.12 Exercises 137 4.3.1 Introduction to FIFOs 204
2.13 Lab Assignments 141 4.3.2 Two-Pointer FIFO Implementation 205
4.3.3 Two-Pointer/ Counter FIFO
3 Interfacing Methods 142 Implementation
4.3.4 FIFO Dynamics
208
209
3.1 Introduction 142 4.4 General Features of Interrupts on the
3.1.1 Performance Measures 142 6811/6812 210
3.1.2 Synchronizing the Software with the 4.4.1 6811 Interrupts 212
State of the I/O 143 4.4.2 6812 Interrupts 213
3.1.3 Variety of Available I/O Ports 146 4.5 Interrupt Vectors and Priority 214
3.2 Handshake protocols 148 4.5.1 MC68H11E Interrupt Vectors and
3.2.1 6811 Handshake Protocol 148 Priority 214
3.2.2 MC68HC812A4 Key Wakeup 4.5.2 MC68HC812A4 Interrupt Vectors and
Interrupts 149 Priority 216
3.2.3 MC9S12C32 Key Wakeup Interrupts 150 4.5.3 MC68HC912B32 Interrupt Vectors and
3.3 Blind Cycle Counting Priority 217
Synchronization 151 4.5.4 MC9S12C32 Interrupt Vectors and
3.3.1 Blind Cycle Printer Interface 151 Priority 218
3.3.2 Blind Cycle ADC Interface 152 4.6 External Interrupt Design
3.4 Gadfly or Busy Waiting Approach 219
Synchronization 153 4.7 Polled Versus Vectored
3.5 Parallel I/O Interface Examples 155 Interrupts 221
3.5.1 Blind Cycle Printer Interface 156 4.8 Keyboard Interface Using
3.5.2 Blind Cycle ADC Interface 157 Interrupts 223
51629_00_TOC_RSE.qxd 2/2/06 4:55 PM Page xv

 Contents xv

4.9 Printer Interface Using IRQ 6.1.4 Period Measurement 283


Interrupts 226 6.1.5 Pulse-Width Measurement 288
4.10 Power System Interface Using XIRQ 6.2 Output Compare 294
Synchronization 229 6.2.1 General Concepts 294
6.2.2 Output Compare Details 295
4.11 Interrupt Polling Using
6.2.3 Square-Wave Generation 298
Linked Lists 231 6.2.4 Pulse-Width Modulation 301
4.11.1 6811 Interrupt Polling Using Linked 6.2.5 Delayed Pulse Generation 303
Lists 232
6.3 Frequency Measurement 304
4.11.2 6812 Interrupt Polling Using Linked
6.3.1 Frequency Measurement Concepts 304
Lists 234
6.3.2 Frequency Measurement with
4.12 Fixed Priority Implemented Using ∆f100Hz 305
One Interrupt Line 235 6.4 Conversion Between Frequency and
4.13 Fixed Priority Implemented Using Period 306
XIRQ 237 6.4.1 Using Period Measurement to Calculate
4.14 Round-Robin Polling 238 Frequency 306
4.15 Periodic Polling 238 6.4.2 Using Frequency Measurement to Calculate
4.15.1 MC68HC711E9 Periodic Interrupts 240 Period 307
4.15.2 MC68HC812A4 Periodic Interrupts 243 6.5 Measurements Using Both Input
4.15.3 MC9S12C32 Periodic Interrupts 245 Capture and Output Compare 307
4.16 Exercises 249 6.5.1 Period Measurement with ∆p1ms 307
4.17 Lab Assignments 254 6.5.2 Frequency Measurement with
∆f0.1Hz 309
6.6 Pulse Accumulator 311
5 Threads 255 6.6.1 MC68711E9 Pulse Accumulator
5.1 Multithreaded Preemptive Details 311
6.6.2 MC9S12C32 Pulse Accumulator
Scheduler 256
Details 312
5.1.1 Round-Robin Scheduler 257
6.6.3 Frequency Measurement 313
5.1.2 Other Scheduling Algorithms 262
6.6.4 Pulse-Width Measurement 314
5.1.3 Dynamic Allocation of Threads 262
6.7 Pulse-width Modulation on the
5.2 Semaphores 262
MC9S12C32 314
5.2.1 Spin-Lock Semaphore
Implementation 263 6.8 Exercises 318
5.2.2 Blocking Semaphore Implementation 265 6.9 Lab Assignments 323
5.3 Applications of Semaphores 267
5.3.1 Thread Synchronization or
Rendezvous 268 7 Serial I/O Devices 326
5.3.2 Resource Sharing, Nonreentrant Code or
7.1 Introduction and Definitions 326
Mutual Exclusion 268
5.3.3 Thread Communication Between Two 7.2 RS232 Specifications 332
Threads Using a Mailbox 268 7.3 RS422/USB/RS423/RS485 Balanced
5.3.4 Thread Communication Between Many Differential Lines 334
Threads Using a FIFO Queue 268 7.3.1 RS422 Output Specifications 337
5.4 Fixed Scheduling 269 7.3.2 RS422 Input Specifications 338
5.5 Exercises 274 7.3.3 RS485 Half-Duplex Channel 338
5.6 Lab Assignments 275 7.4 Other Communication Protocols 339
7.4.1 Current Loop Channel 339
7.4.2 Introduction to Modems 339
6 Timing Generation and 7.4.3 Optical Channel 340
7.4.4 Digital Logic Channel 340
Measurements 276 7.5 Serial Communications Interface 341
6.1 Input Capture 276 7.5.1 Transmitting in Asynchronous
6.1.1 Basic Principles of Input Capture 276 Mode 341
6.1.2 Input Capture Details 277 7.5.2 Receiving in Asynchronous Mode 343
6.1.3 Real Time Interrupt Using an Input 7.5.3 MC68HC711E9 SCI Details 345
Capture 281 7.5.4 MC9S12C32 SCI Details 346
51629_00_TOC_RSE.qxd 2/2/06 4:55 PM Page xvi

xvi  Contents

7.6 SCI Software Interfaces 349 8.5.6 Interfacing EM Relays, Solenoids, and DC
7.6.1 Full Duplex Serial Channel 349 Motors 425
7.6.2 Use of Data Terminal Ready (DTR) 8.5.7 Solid-State Relays 430
to Interface a Printer 352 8.6 Stepper Motors 431
7.6.3 Use of XON/XOFF to Interface 8.6.1 Stepper Motor Example 431
a Printer 354 8.6.2 Basic Operation 434
7.7 Synchronous Transmission and Receiving 8.6.3 Stepper Motor Hardware Interfaces 438
Using the SPI 355 8.6.4 Stepper Motor Shaft Encoder 441
7.7.1 SPI Fundamentals 355 8.7 Exercises 443
7.7.2 MC68HC711E9 SPI Details 358 8.8 Lab Assignments 446
7.7.3 MC9S12C32 SPI Details 359

7.8
7.7.6 SPI Applications
Exercises 368
361
9 Memory Interfacing 448
7.9 Lab Assignments 370 9.1 Introduction 448
9.2 Address Decoding 451
9.2.1 Full-Address Decoding 452
8 Parallel Port 9.2.2
9.2.3
Minimal-Cost Address Decoding 454
Special Cases When Address Decoding 457
Interfaces 375 9.2.4 Flexible Full-Address Decoder 458
8.1 Input Switches and Keyboards 375 9.2.5 Integrated Address Decoder on the
8.1.1 Interfacing a Switch to the Computer 375 MC68HC812A4 459
8.1.2 Hardware Debouncing Using a 9.3 Timing Syntax 461
Capacitor 377 9.3.1 Available and Required Time Intervals 461
8.1.3 Software Debouncing 381 9.3.2 Timing Diagrams 463
8.1.4 Basic Approaches to Interfacing 9.4 General Memory Bus Timing 463
Multiple Keys 386 9.4.1 Synchronous Bus Timing 464
8.1.5 Sixteen-Key Electronic Piano 389 9.4.2 Partially Asynchronous Bus Timing 465
8.1.6 4 by 4 Scanned Keyboard 393 9.4.3 Fully Asynchronous Bus Timing 466
8.1.7 Multiplexed/Demultiplexed Scanned 9.5 External Bus Timing 468
Keyboard 396 9.5.1 Synchronized Versus Unsynch-ronized
8.2 Output LEDs 398 Signals 468
8.2.1 Single LED Interface 400 9.5.2 Freescale MC68HC11A8 External Bus
8.2.2 Seven-Segment LED Interfaces 402 Timing 469
8.2.3 Scanned Seven-Segment LED 9.5.3 Freescale MC68HC812A4 External
Interface 402 Bus Timing 472
8.2.4 Scanned LED Interface Using the 7447 9.5.4 Freescale MC9S12C32 External
Seven-Segment Decoder 405 Bus Timing 477
8.2.5 Integrated LED Interface Using the MC14489 9.6 General Approach to Interfacing 483
Display Driver 408 9.6.1 Interfacing to a 6811 483
8.3 Liquid Crystal Displays 410 9.6.2 Interfacing to a 6812 in Expanded
8.3.1 LCD Fundamentals 410 Narrow Mode 484
8.3.2 Simple LCD Interface with the 9.6.3 Interfacing to a 6812 in Expanded
MC14543 412 Wide Mode 485
8.3.3 Scanned LCD Interface with the 9.7 Memory Interface Examples 487
MC145000, MC145001 414 9.7.1 32K PROM Interface 487
8.3.4 Parallel Port LCD Interface with the 9.7.2 8K RAM Interface 492
HD44780 Controller 416 9.7.3 32K by 16-bit PROM Interface to a
8.4 Transistors Used for Computer- MC68HC812A4 505
Controlled Current Switches 419 9.7.4 8K by 16-bit RAM Interface 507
8.5 Computer-Controlled Relays, Solenoids, 9.7.5 Extended Address Data Page Interface to the
and DC Motors 421 MC68HC812A4 509
8.5.1 Introduction to Relays 421 9.7.6 Extended Address Program Page Interface to
8.5.2 Electromagnetic Relay Basics 422 the MC68HC812A4 511
8.5.3 Reed Relays 424 9.8 Dynamic RAM (DRAM) 514
8.5.4 Solenoids 424 9.9 Exercises 514
8.5.5 Pulse-Width Modulated DC Motors 424 9.10 Lab Assignments 523
51629_00_TOC_RSE.qxd 2/2/06 4:55 PM Page xvii

 Contents xvii

11.4.3 Three-Bit DAC with an R-2R Ladder 564


10 High-Speed I/O 11.4.4 Twelve-Bit DAC with a DAC8043 566
Interfacing 524 11.4.5 DAC Selection 567
11.4.6 DAC Waveform Generation 570
10.1 The Need for Speed 524 11.5 Analog-to-Digital Converters 573
10.2 High-Speed I/O Applications 525 11.5.1 ADC Parameters 573
10.2.1 Mass Storage 525 11.5.2 Two-Bit Flash ADC 574
10.2.2 High-Speed Data Acquisition 526 11.5.3 Successive Approximation ADC 575
10.2.3 Video Displays 527 11.5.4 Sixteen-Bit Dual Slope ADC 576
10.2.4 High-Speed Signal Generation 527 11.5.5 Sigma Delta ADC 577
10.2.5 Network Communications 527 11.5.6 ADC Interface 578
10.3 General Approaches to High-Speed 11.6 Sample and Hold 579
Interfaces 528 11.7 BiFET Analog Multiplexer 580
10.3.1 Hardware FIFO 528 11.8 ADC System 582
10.3.2 Dual Port Memory 529
11.8.1 ADC Block Diagram 582
10.3.3 Bank-Switched Memory 529
11.8.2 Power and Grounding for the ADC
10.4 Fundamental Approach to DMA 530 System 584
10.4.1 DMA Cycles 530 11.8.3 Input Protection for High-Speed CMOS
10.4.2 DMA Initiation 531 Analog Inputs 584
10.4.3 Burst Versus Cycle Steal DMA 531 11.9 Multiple-Access Circular Queue 585
10.4.4 Single-Address Versus Dual-Address
11.10 Internal ADCs 587
DMA 532
10.4.5 DMA Programming 534 11.10.1 6811 ADC System 587
11.10.2 6812 ADC System 589
10.5 LCD Graphics 535
11.10.3 ADC Software 591
10.5.1 LCD Graphics Controller 535
11.11 Exercises 593
10.5.2 Practical LCD Graphics Interface 538
10.6 Exercises 539 11.12 Lab Assignments 595
10.7 Lab Assignments 540
12 Data Acquisition
11 Analog Interfacing 541 Systems 597
11.1 Resistors and Capacitors 541 12.1 Introduction 597
11.1.1 Resistors 541 12.1.1 Accuracy 599
11.1.2 Capacitors 542 12.1.2 Resolution 601
11.2 Operational Amplifiers 12.1.3 Precision 601
(Op Amps) 543 12.1.4 Reproducibility or Repeatability 602
11.2.1 Op Amp Parameters 543 12.2 Transducers 602
11.2.2 Threshold Detector 546 12.2.1 Static Transducer Specifications 602
11.2.3 Simple Rules for Linear Op Amp 12.2.2 Dynamic Transducer Specifications 606
Circuits 547 12.2.3 Nonlinear Transducers 607
11.2.4 Linear Mode Op Amp Circuits 549 12.2.4 Position Transducers 608
11.2.5 Instrumentation Amplifier 553 12.2.5 Velocity Measurements 609
11.2.6 Current-to-Voltage Circuit 555 12.2.6 Force Transducers 611
11.2.7 Voltage-to-Current Circuit 555 12.2.7 Temperature Transducers 612
11.2.8 Integrator Circuit 555 12.3 DAS Design 617
11.2.9 Derivative Circuit 556 12.3.1 Introduction and Definitions 617
11.2.10 Voltage Comparators with 12.3.2 Using Nyquist Theory to Determine
Hysteresis 556 Sampling Rate 618
11.2.11 Analog Isolation 557 12.3.3 How Many Bits Does One Need for the
11.3 Analog Filters 558 ADC? 621
11.3.1 Simple Active Filter 558 12.3.4 Specifications for the Analog Signal
11.3.2 Butterworth Filters 559 Processing 621
11.3.3 Bandpass and Band-Reject Filters 560 12.3.5 How Fast Must the ADC Be? 626
11.4 Digital-to-Analog Converters 561 12.3.6 Specifications for the S/H 626
11.4.1 DAC Parameters 561 12.4 Analysis of Noise 627
11.4.2 DAC Using a Summing Amplifier 563 12.4.1 Thermal Noise 627
51629_00_TOC_RSE.qxd 2/2/06 4:55 PM Page xviii

xviii  Contents

12.4.2 Shot Noise 630 14.3 Design and Implementation of


12.4.3 1/f, or Pink Noise 630 a Controller Area Network
12.4.4 Galvanic Noise 630 (CAN) 700
12.4.5 Motion Artifact 630 14.3.1 The Fundamentals of CAN 700
12.4.6 Electromagnetic Field Induction 631 14.3.2 Details of the 9S12C32 CAN 703
12.4.7 Techniques to Measure Noise. 631 14.3.3 9S12C32 CAN Device Driver 706
12.4.8 Techniques to Reduce Noise 633
14.4 Inter-Integrated Circuit (I2C)
12.5 Data Acquisition Case Studies 635
Network 709
12.5.1 Temperature Measurement 635
14.4.1 The Fundamentals of the I2C
12.5.2 EKG Data Acquisition System 639
Network 709
12.5.3 Position Measurement System 642
14.4.2 I2C Synchronization 712
12.6 Exercises 643 14.4.3 9S12 I2C Details 714
12.7 Lab Assignments 650 14.4.4 9S12 I2C Single Master
Example 717
13 Microcomputer-Based 14.5 Modem Communications
14.5.1 FSK Modem 718
718

Control Systems 652 14.5.2 Phase-Encoded Modems 721


14.5.3 Quadrature Amplitude Modems 722
13.1 Introduction to Digital Control
14.6 X-10 Protocol 723
Systems 652
14.7 Universal Serial Bus (USB) 730
13.2 Open-Loop Control Systems 653
14.7.1 Introduction 730
13.2.1 Open-Loop Control of a Toaster 654
14.7.2 Modular USB Interface 734
13.2.2 Open-Loop Robotic Arm 654
14.7.3 Integrated USB Interface 735
13.3 Simple Closed-Loop Control
14.8 Exercises 735
Systems 659
14.9 Lab Assignments 739
13.3.1 Bang-Bang Temperature Control 659
13.3.2 Closed-Loop Position Control System Using
Incremental Control 661
13.4 PID Controllers 663 15 Digital Filters 742
13.4.1 General Approach to a PID 15.1 Basic Principles 743
Controller 663
15.2 Simple Digital Filter
13.4.2 Design Process for a PID Controller 666
13.4.3 Velocity PID Controller 668
Examples 745
13.4.4 Proportional-Integral Controller with a 15.3 Impulse Response 752
PWM actuator 669 15.4 High-Q 60-Hz Digital Notch Filter 755
13.5 Fuzzy Logic Control 672 15.5 Effect of Latency on Digital Filters 760
13.5.1 DAC, ADC Fuzzy Controller 675 15.6 High-Q Digital High-Pass Filters 762
13.5.2 PWM Fuzzy Controller 681 15.7 Digital Low-Pass Filter 763
13.5.3 Temperature Controller Using
15.8 Direct-Form Implementations 765
Fuzzy Logic 687
13.6 Exercises 691 15.9 Exercises 766
13.7 Lab Assignments 694 15.10 Lab Assignments 767

14 Simple Networks 696 Appendix 1 769


14.1 Introduction 696 Appendix 2 789
14.2 Communication Systems Based
on the SCI Serial Port 698 Index 802

You might also like