ebook img

Programming Embedded Systems with C and GNU Development Tools PDF

313 Pages·2007·1.97 MB·English
Save to my drive
Quick download
Download
Most books are stored in the elastic cloud where traffic is expensive. For this reason, we have a limit on daily download.

Preview Programming Embedded Systems with C and GNU Development Tools

SECOND EDITION Programming Embedded Systems with C and GNU Development Tools Michael Barr and Anthony Massa Programming Embedded Systems with C and GNU Development Tools, Second Edition by Michael Barr and Anthony Massa Copyright © 2007, 1999 O’Reilly Media, Inc. Printed in the United States of America. Printing History: January 1999: First Edition. October 2006: Second Edition. ISBN-10: 0-596-00983-6 ISBN-13: 978-0-596-00983-0 [M] [12/07] Contents Foreword. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . xi Preface . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .xiii 1. Introduction . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1 What Is an Embedded System? 1 Variations on a Theme 4 Embedded Design Examples 8 Life As an Embedded Software Developer 11 The C Language: The Lowest Common Denominator 13 A Few Words About Hardware 15 2. Getting to Know the Hardware . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 19 Understanding the Big Picture 19 Hardware Basics 21 Examine the Landscape 28 Learn How to Communicate 32 Getting to Know the Processor 34 Study the External Peripherals 38 Initialize the Hardware 39 3. Your First Embedded Program . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 43 Hello, World! 43 The Blinking LED Program 44 The Role of the Infinite Loop 51 4. Compiling, Linking, and Locating . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 53 The Build Process 54 Building the Blinking LED Program 61 A Quick Look at Makefiles 66 5. Downloading and Debugging . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 70 Downloading the Blinking LED Program 70 Remote Debuggers 77 Emulators 84 Other Useful Tools 86 Dig into the Hardware 92 6. Memory . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 93 Types of Memory 93 Direct Memory Access 98 Endian Issues 98 Memory Testing 102 Validating Memory Contents 114 Using Flash Memory 118 7. Peripherals . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 122 Control and Status Registers 122 The Device Driver Philosophy 130 Device Driver Design 140 8. Interrupts . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 142 Overview 142 Interrupt Map 148 Interrupt Service Routine 150 The Improved Blinking LED Program 155 Summary of Interrupt Issues 161 9. Putting It All Together. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 164 Application Overview 164 Working with Serial Ports 166 Command-Line Interface Processing 167 10. Operating Systems. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 173 History and Purpose 173 The Scheduler 174 Tasks 180 Task Synchronization 185 Message Passing 190 Other Functionality 191 Interrupt Handling 191 Real-Time Characteristics 192 To Use or Not to Use an RTOS 194 Additional Resources 197 11. eCos Examples . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 198 Introduction 198 Task Mechanics 199 Mutex Task Synchronization 202 Semaphore Task Synchronization 205 Message Passing 210 eCos Interrupt Handling 213 12. Embedded Linux Examples . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 219 Introduction 219 Accessing Hardware in Linux 220 Task Mechanics 220 Mutex Task Synchronization 222 Semaphore Task Synchronization 224 Message Passing 227 13. Extending Functionality . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 232 Common Peripherals 232 Networking for All Devices Great and Small 242 14. Optimization Techniques . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 248 Increasing Code Efficiency 249 Decreasing Code Size 252 Problems with Optimizing Compilers 254 Reducing Memory Usage 255 Power-Saving Techniques 256 Limiting the Impact of C++ 259 A. The Arcom VIPER-Lite Development Kit. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 263 B. Setting Up Your Software Development Environment . . . . . . . . . . . . . . . . . 266 C. Building the GNU Software Tools . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 271 D. Setting Up the eCos Development Environment . . . . . . . . . . . . . . . . . . . . . . 274 E. Setting Up the Embedded Linux Development Environment . . . . . . . . . . . 277 Index . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 285 Foreword 1 If you mention the word embedded to most people, they’ll assume you’re talking about reporters in a war zone. Few dictionaries—including the canonical Oxford English Dictionary—link embedded to computer systems. Yet embedded systems underlie nearly all of the electronic devices used today, from cell phones to garage door openers to medical instruments. By now, it’s nearly impossible to build any- thing electronic without adding at least a small microprocessor and associated software. Vendors produce some nine billion microprocessors every year. Perhaps 100 or 150 millionofthosegointoPCs.That’sonlyaboutonepercentoftheunitsshipped.The other 99 percent go into embedded systems; clearly, this stealth business represents the very fabric of our highly technological society. And use of these technologies will only increase. Solutions to looming environmen- tal problems will surely rest on the smarter use of resources enabled by embedded systems.Oneonlyhastolookatthenetworkof32-bitprocessorsinToyota’shybrid Prius to get a glimpse of the future. Though prognostications are difficult, it is absolutely clear that consumers will con- tinue to demand ever-brainier products requiring more microprocessors and huge increasesinthecorrespondingsoftware.Estimatessuggestthatthefirmwarecontent ofmostproductsdoublesevery10to24months.Whilethedemandformorecodeis increasing, our productivity rates creep up only slowly. So it’s also clear that the industry will need more embedded systems people in order to meet the demand. Whatskillswillthesepeopleneed?InthePCworld,onemustbeacompetentC/C++ programmer.Butembeddeddevelopersmusthaveadeepunderstandingofboththe programminglanguagesandthehardwareitself;noonecandesign,code,andtestan interrupt service routine, for instance, without knowing where the interrupts come from, how the hardware prioritizes them, the tricks behind servicing that hardware, and machine-level details about saving and preserving the system’s context. A firm- ware developer must have detailed insight into the hardware implementation of his system’s peripherals before he can write a single line of driver code. InthePCworld,themagicofthehardwareishiddenbehindanextensiveAPI.Inan embeddedsystem,thatAPIisalwayswrittenbytheengineersthataredevelopingthe product. In this book, Michael Barr and Anthony Massa show how the software and hard- ware form a synergistic gestalt. They don’t shy away from the intricacies of inter- rupts and I/O, or priority inversion and mutexes. Theauthorsappropriatelydemonstratebuildingembeddedsystemsusingavarietyof open source tools, including the GNU compiler suite, which is a standard tool widely used in this industry. eCos and Linux, both free/open source products, are used to demonstrate small and large operating systems. Theoriginalversionofthisbookusedanx86targetboard,whichhasbeenreplaced in this edition by an ARM-based product. Coincidently, as this volume was in pro- duction,Intelmadeanend-of-lifeannouncementforallofitsembeddedx86proces- sors.ReaderscanbeassuredthattheARMwillbearoundforaverylongtime,asit’s supported by an enormous infrastructure of vendors. The hardware is inexpensive and easily available; the software is free. Together they represent the mainstream of embedded systems development. Readers can be sure they’ll use these tools in the future. Buy the development kit, read the book, and execute the examples. You’ll get the hands-onexperiencethatemployersdemand:buildingandworkingwithrealembed- ded applications. —Jack Ganssle Preface 2 First figure out why you want the students to learn the subject and what you want them to know, and the method will result more or less by common sense. —Richard Feynman Embedded software is in almost every electronic device in use today. There is soft- warehiddenawayinsideourwatches,DVDplayers,mobilephones,antilockbrakes, and even a few toasters. The military uses embedded software to guide missiles, detectenemyaircraft,andpilotUAVs.Communicationsatellites,deep-spaceprobes, and many medical instruments would’ve been nearly impossible to create without it. Someone has to write all that software, and there are tens of thousands of electrical engineers,computerscientists,andotherprofessionalswhoactuallydo.Wearetwo ofthem,andweknowfromourpersonalexperiencesjusthowharditcanbetolearn the craft. Eachembeddedsystemisunique,andthehardwareishighlyspecializedtotheappli- cationdomain.Asaresult,embeddedsystemsprogrammingcanbeawidelyvarying experienceandcantakeyearstomaster.However,onecommondenominatoracross almost all embedded software development is the use of the C programming lan- guage. This book will teach you how to use C in any embedded system. Even if you already know how to write embedded software, you can still learn a lot from this book. In addition to learning how to use C more effectively, you’ll also benefit from the detailed explanations and source code associated with common embedded software problems. Among the advanced topics covered in the book are memory testing and verification, device driver design and implementation, real-time operating system internals, and code optimization techniques. Why We Wrote This Book Each year, globally, approximately one new processor is manufactured per person. That’s more than six billion new processors each year, fewer than two percent of whicharethePentiumsandPowerPCsattheheartofnewpersonalcomputers.You may wonder whether there are really that many computers surrounding us. But we bet that within five minutes you can probably spot dozens of products in your own homethatcontainprocessors:televisions,stereos,MP3players,coffeemakers,alarm clocks, VCRs, DVD players, microwaves, dishwashers, remote controls, bread machines, digital watches, and so on. And those are just the personal possessions— manymoresuchdevicesareusedatwork.Thefactthateveryoneofthoseproducts contains not only a processor, but also software, is the impetus for this book. One of the hardest things about this subject is knowing when to stop writing. Each embedded system is unique, and we have therefore learned that there is an excep- tiontoeveryrule.Nevertheless,wehavetriedtoboilthesubjectdowntoitsessence and present the things that programmers definitely need to know about embedded systems. Intended Audience ThisisabookaboutprogrammingembeddedsystemsinC.Assuch,itassumesthat thereaderalreadyhassomeprogrammingexperienceandisatleastfamiliarwiththe syntax of the C language. It also helps if you have some familiarity with basic data structures,suchaslinkedlists.Thebookdoesnotassumethatyouhaveagreatdeal of knowledge about computer hardware, but it does expect that you are willing to learn a little bit about hardware along the way. This is, after all, a part of the job of an embedded programmer. While writing this book, we had two types of readers in mind. The first reader is a beginner—muchaswewereonce.Hehasabackgroundincomputerscienceorengi- neering and a few years of programming experience. The beginner is interested in writing embedded software for a living but is not sure just how to get started. After reading the first several chapters, he will be able to put his programming skills to workdevelopingsimpleembeddedprograms.Therestofthebookwillactasarefer- ence for the more advanced topics encountered in the coming months and years of his career. Thesecondreaderisalreadyanembeddedsystemsprogrammer.Sheisfamiliarwith embeddedhardwareandknowshowtowritesoftwareforitbutislookingforaref- erence book that explains key topics. Perhaps the embedded systems programmer hasexperienceonlywithassemblylanguageprogrammingandisrelativelynewtoC. In that case, the book will teach her how to use the C language effectively in an embeddedsystem,andthelaterchapterswillprovideadvancedmaterialonreal-time operating systems, peripherals, and code optimizations. Whetheryoufallintooneofthesecategoriesornot,wehopethisbookprovidesthe information you are looking for in a format that is friendly and easily accessible.

See more

The list of books you might like

Most books are stored in the elastic cloud where traffic is expensive. For this reason, we have a limit on daily download.