ebook img

The Art of Assembly Language Programming using PIC Technology. Core Fundamentals PDF

452 Pages·2018·36.945 MB·
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 The Art of Assembly Language Programming using PIC Technology. Core Fundamentals

The Art of Assembly Language Programming using PIC Technology Core Fundamentals Theresa Schousek © 2018 Elsevier Inc. ISBN: 978-0-12-812617-2 Contents Preface .....................................................................................................................xiii CHAPTER 1 Introduction .........................................................................1 Practical Applications .....................................................................1 Why Assembly? ..............................................................................2 Core Families (“Baseline,” “Midrange,” “Enhanced Midrange,” “High Performance”) ...................................................3 Baseline ...................................................................................3 Midrange .................................................................................4 Enhanced Midrange ................................................................4 High Performance ...................................................................4 Data Sheet—Walk Through ............................................................5 Straight Line Program Implementation ..........................................7 Think of a Number ..................................................................7 Double It..................................................................................8 Add 10 (Decimal) ....................................................................8 Halve It ....................................................................................8 Subtract Original Number .......................................................8 Compare Output to 5 ...............................................................8 Looped Code Implementation ........................................................8 Microchip Tools ............................................................................10 Microchip Microcontroller Course Information ...........................10 Jargon Note—Italics .....................................................................11 Word Search ..................................................................................11 Binary Puzzle ................................................................................12 Further Reading ............................................................................12 CHAPTER 2 Microchip 8-Bit Architecture .........................................13 The Microprocessor ......................................................................13 System Clock ................................................................................13 Execution Cycle ............................................................................15 Instruction Flow Pipelining ..........................................................16 Bus for Data and Program ............................................................16 Hardware Interfaces ......................................................................16 Input/Output Interface ...........................................................17 Comparator Interface ............................................................18 Timer 0 Interface ...................................................................18 Flash Programming Interface ................................................18 Oscillator Output ...................................................................19 Master Clear Reset ................................................................20 Hardware Organization of Memory Address Space .....................20 Data Memory and File Registers ..................................................20 Arithmetic Logic Unit (ALU) and the W Register .......................20 Prototyping ...................................................................................22 Word Search ..................................................................................23 Puzzle: Oscillator ..........................................................................25 Further Reading ............................................................................25 CHAPTER 3 Instruction Sets ................................................................27 Instruction Set Comparison for PICmicro 10F, 12F, 16F, 18F Controllers .............................................................27 Common 33 Instruction Set for PICmicro Controllers .................27 Instructions ............................................................................28 Registers ................................................................................35 Ports.......................................................................................39 Timers ....................................................................................39 Addressing ....................................................................................40 Direct .....................................................................................40 Indirect ..................................................................................40 Indexed/Relative ....................................................................41 Code Example ...............................................................................41 Paging Consideration ....................................................................42 Word Search: Instruction Set ........................................................43 Puzzle: Instruction Set ..................................................................43 Further Reading ............................................................................45 CHAPTER 4 Beginning Code ................................................................47 Subroutines ...................................................................................47 Macros ..........................................................................................48 Elementary Programs ....................................................................49 ACC Convention ...................................................................49 8-Bit Data Transfer ................................................................49 16-Bit Data Transfer ..............................................................50 8-Bit Addition........................................................................50 8-Bit Subtraction ...................................................................50 8-Bit Multiply by Two (Rotate Left 1 Bit) ............................51 8-Bit Multiply by Four (Shift Left 2 Bits) ............................51 8-Bit Divide by Two (Rotate Right 1 Bit) .............................52 Mask Off Most Significant 4 Bits .........................................52 Mask Off Least Significant 4 Bits .........................................52 Clear a Memory Location .....................................................53 Set a Memory Location to All Ones ......................................53 Find Larger of Two Numbers ................................................53 Find Smaller of Two Numbers ..............................................54 Program Counter Addressing ........................................................54 Application Notes .........................................................................54 Interrupts and Jump Tables (AN514) ............................................54 Stacks (AN534) ............................................................................55 Calculate Timing ...........................................................................56 Word Search: Beginning Code......................................................57 Puzzle: Number Square ................................................................57 Further Reading ............................................................................58 Reference ......................................................................................58 CHAPTER 5 Looping Code ....................................................................59 Loops Introduction ........................................................................59 8-Bit Sum of Data .........................................................................62 Looped Code Example .................................................................64 Partial Straight Line Code Example .............................................66 Macros for Page and Bank Switching (AN586) ...........................67 Long Conditional Branch Vectors (AN581) .................................68 Word Search: Loops Code ............................................................69 Puzzle: Loops Code ......................................................................70 Further Reading ............................................................................71 CHAPTER 6 Embedded Control Fundamentals ..................................73 Embedded Control ........................................................................73 Electrical Wiring Diagrams ..........................................................73 Breadboards ..................................................................................74 Basic Input and Output (I/O) ........................................................75 Specialized Input/Output ..............................................................78 Timer Modules and Registers .......................................................78 Hardware Alone ....................................................................79 Hardware and Software .........................................................79 Software Alone ......................................................................79 Development Boards .....................................................................79 Word Search: Embedded Control .................................................80 Puzzle: Flustered ...........................................................................80 Further Reading ............................................................................81 CHAPTER 7 Fundamentals of Good Practice .....................................83 Structured Programming ...............................................................83 Software Design Patterns ..............................................................84 Reusable Code Guidelines ............................................................84 Ordered Lists ................................................................................85 Ordered Lists Example ..........................................................85 Structured Systems Development (SSD): Four Basic Structures ............................................................................87 Programming Flowcharts ......................................................88 Warnier-Orr Diagrams ...........................................................88 State Machine Diagrams .......................................................89 Pseudocode ............................................................................92 SysML ...................................................................................92 Word Search: Program Design and Development ......................105 Puzzle: Spiral ..............................................................................106 Further Reading ..........................................................................108 CHAPTER 8 Data and Control Structures .........................................109 Assembly Language Concepts ....................................................109 Config Word ........................................................................109 Using DEFINE ....................................................................110 Program Structures .....................................................................111 Subprograms .......................................................................111 Subroutines ..........................................................................111 Macros .................................................................................111 Procedures ...........................................................................111 Functions .............................................................................112 Recursive Procedures ..........................................................112 Termination .........................................................................112 Data Structures ............................................................................112 Handling Data in ASCII ......................................................113 Character Coded Data .........................................................113 Character Operations ...........................................................115 Character Operations ...........................................................116 Control Structures .......................................................................118 Function...............................................................................118 Sequence .............................................................................119 Alternation (or Multiple Selections) ...................................119 Repetition (or Iteration).......................................................120 Word Search: Data Structures .....................................................121 Puzzle: Jigsaw Sudoku 66h.........................................................122 Further Reading ..........................................................................122 References ...................................................................................122 CHAPTER 9 Logic and Numbering Systems .....................................123 Boolean Algebra .........................................................................123 Logical Operators ................................................................124 Polynomial Systems ....................................................................129 Decimal System ..................................................................129 Binary, Octal, Hexadecimal, Decimal .................................129 Binary System .....................................................................130 Octal System .......................................................................131 Hexadecimal System ...........................................................132 Mixed Radix Systems .........................................................133 Multibyte Integers .......................................................................134 Hexadecimal to Binary Conversions ...................................134 Little-Endian vs. Big-Endian ..............................................134 Signed and Unsigned Integers ....................................................134 Signed and Unsigned...........................................................134 Floating Point ..............................................................................137 BCD as a Type ............................................................................137 Binary Coded Decimal ........................................................137 ASCII—Single-Byte Characters .................................................138 ASCII ..................................................................................138 Unicode—Multibyte Characters .................................................138 Unicode ...............................................................................138 Word Search ................................................................................139 Puzzle: Diamond 22h ..................................................................140 Further Reading ..........................................................................140 CHAPTER 10 Mathematical Operations ..............................................141 #Include Mathematical Routines ................................................141 Application Notes in Standard and High Performance Microprocessors ..........................................................................141 Single and Double Precision Arithmetic .............................142 Signed Arithmetic................................................................142 Select Optimization: Speed or Memory ..............................142 Conditional Assembly .........................................................143 HI/LO Conventions .............................................................143 Specific Math Utility Routines ...................................................143 Advanced Macro Features ...................................................143 Featured 8-Bit MCU Boards .......................................................147 Automotive Networking Development Board .....................147 Curiosity Development Board .............................................147 Curiosity High Pin Count (HPC) Development Board .......148 Explorer 8 Development Kit ...............................................149 PICDEM Lab II Development Platform .............................150 Word Search: Mathematical Operations .....................................151 Puzzle: Number Tower................................................................152 Further Reading ..........................................................................152 CHAPTER 11 Word Search Solution ...................................................153 CHAPTER 12 Puzzle Solutions .............................................................163 APPENDIX A Instruction Sets ..............................................................173 APPENDIX B ASCII Characters ............................................................195 APPENDIX C Decimal-Binary-Hexadecimal Characters ..................203 APPENDIX D Best Practices ................................................................211 APPENDIX E ..........................................................................................213 APPENDIX F ..........................................................................................301 Index ......................................................................................................................437 Preface PURPOSE AND SCOPE The purpose of this textbook is to give a thorough introduction to Microchip Assembly Language Programming for a wide range of users. Microchip’s most basic 33 instructions are used heavily throughout the text. It is recommended that the new user, regardless of 8-bit processor selection, self-restrict their use to the basic 33 instructions until these are second nature. This will prove to be the best approach to learning assembly language. This book provides a basic introduction to get the reader up to speed quickly. It provides beginning code development chapters on such things as basic data transfers, addition, and subtraction. Application notes for more complex mathematical routines, multiplication and division are presented for use as a practical solution. For the novice and returning programmers, there is also a chapter on Mathematical Numbering Systems. The chapters on arithmetic are reserved for the end of the book so as to not overwhelm the newest of users. Practical use and selection of specific evaluation boards, recommended by Microchip, is briefly presented with a cost, and feature, analysis. Fundamentals of good design practice are presented using tried and true approaches of flowcharting, Warnier-Orr diagrams, and State Machines. In addition, a separate chapter is dedicated to SysML, by way of introduction, with a thorough case example. A new text on the market is recommended for those expecting to use SysML daily in their business. The hardware interface is presented in a chapter on Embedded Control. Focus is on basic “electronic glue” used on 8-bit processors. Most of the interfaces can be used directly from this text. With only a modicum of electronic hardware changes, such as actual values of components, that will be required. PROGRAM CONVERSION PROCESS; FROM PROGRAM TO INDIVIDUAL BITS Complexity of computer programs is shown in Fig. 1. This diagram starts with the most fundamental element of a computer; the two states of 5 and 0 V. These are interpreted by the computer as a logical 1, for 5 V, and a logical 0, for 0 V or ground. The logical bits are then grouped by sequences of 8 bits, known as bytes. The binary strings are then grouped as clusters of 8 bits, or 1 byte; each byte defined by two hexadecimal digits from 0 through F. These binary strings are organized in groups of two nybbles; known as Machine Language. Each successive bubble, in Fig. 1, then introduces a higher level of programming. Assembly Language occupies the sweet spot between Machine Language and High level Language where knowledge of the embedded device is required and optimal efficient code can be produced. High Level Language Assembly Language Machine Language Hexadecimal code: 6Eh 1 byte = 2 nybbles Binary sequence: 01101110b 8 bits = 1 byte Binary bit: 0/1 Two logical States: 0/5volt No/yes Off/on FIG. 1 The circle of languages and their position on the complexity scale. The compiler converts a high level language such as C, C++, FORTRAN, and Python into machine language. Each level of programming then requires “translation” ultimately to Machine Language, as shown in Fig. 2. This begins with Assembly Language, which is converted to Machine Language by the use of an assembler and linker. The linker is not a separate language, per se. It is a necessary step in the process of converting the program, as written by the user, into nybbles to be read by the computer. AUTHOR’S NOTE Congratulations, you have arrived! This is the greeting that I anticipated when first starting my journey into Assembly Language. Those who came before me learned assembly as their first language. Assembly was a rite of passage. I started

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.