ebook img

Programming the 6502 PDF

1983·70.6 MB·English
by  ZaksRodnay
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 the 6502

Rodnay Zaks PROGRAMMING THE 6502 PROGRAMMING THf:6502 RODNAYZAKS FOURTH EDITION Incorporating Answers to the Exercises BERKELEY • PARIS • DUSSELDORF Cover art: Daniel Le Noury Every effort has been made to supply complete and accurate information. However, Sybex assumes no responsibility for its use, nor for any infringements of patents or other rights of third parties which would result. No license is granted by the equipment manufac- turers under any patent or patent right. Manufacturers reserve the right to change circuitry at any time without notice. Copyright © 1983 SYBEX Inc. 2344 Sixth Street, Berkeley, CA 94710. World rights reserved. No part of this publication may be stored in a retrieval system, copied, transmit- ted, or reproduced in any way, including, but not limited to photocopy, photography, mag- netic or other recording, without the prior agreement and written permission of the publisher. ISBN 0-89588-135-7 Library of Congress Card Number: 83-61686 First Edition published 1978. Fourth Edition 1983 Printed in the United States of America 10 9 8 7 6 5 4 3 2 CONTENTS PREFACE . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .. vii I. BASIC CONCEPTS ................................ 7 Introduction. What is Programming? Flowcharting. Information Representation. II. 6502 HARDWARE ORGANIZATION ............... 38 Introduction. System Architecture. Internal Organization of the 6502. The Instruction Execution Cycle. The Stack. The Paging Concept. The 6502 Chip. Hardware Summary. III. BASIC PROGRAMMING TECHNIQUES ............ 53 Introduction. Arithmetic Programs. BCD Arithmetic. Important Self-Test. Logical Operations. Subroutines. Summary. IV. THE 6502 INSTRUCTION SET ..................... 99 PART J-OVERALL DESCRIPTION Introduction. Classes of Instructions. Instructions A vailable on the 6502. PART 2-THE INSTRUCTIONS Abbreviations. Description ofE ach Instruction. V. ADDRESSING TECHNIQUES .................... 188 Introduction. Addressing Modes. 6502 Addressing Modes. Using the 6502 Addressing Modes. Summary. VI. INPUT/OUTPUT TECHNIQUES .................. 211 Introduction. Input/Output. Parallel Word Transfer. Bit Serial Transfer. Basic I/O Summary. Communicating with Input/Output Devices. Peripheral Summary. Input/Output Scheduling. Summary. Exercises. v VII. INPUT IOUTPUT DEVICES ........••.•••........ 254 Introduction. The Standard PIO (6520). The Internal Control Register. The 6530. Programming a PIO. The 6522. The 6532. Summary. VIn. APPLICATION EXAMPLES ..................... 262 Introduction. Clear a Section of Memory. Polling I/O Devices. Getting Characters In. Testing a Character. Brocket Testing. Parity Generation. Code Conversion: ASCII to BCD. Find the Largest Element of a Table. Sum of N Elements. A Checksum Computation. Count the Zeroes. A String Search. Summary. IX. DATA STRUCTURES ............................ 275 PART I-DESIGN CONCEPTS Introduction. Pointers. Lists. Searching and Sorting. Summary. Data Structures. PART 2-DESIGN EXAMPLES Introduction. Data Representation for the List. A Simple List. Alphabetic List. Binary Tree. A Hashing Algorithm. Bubble-Sort. A Merge Algorithm. Summary. X. PROGRAM DEVELOPMENT .•..••.••.••........ 343 Introduction. Basic Programming Choices. Software Support. The Pro- gram Development Sequence. The Hardware Alternatives. Summary of Hardware Alternatives. Summary ofH ardware Resources. The Assembler. Macros. Conditional Assembly. Summary. XI. CONCLUSION ••...•.•..•••.•.......•.....•.••.• 368 Technological Development. The Next Step. APPENDICES ....••.•.....••••••••..•..........••....... 371 A. Hexadecimal Conversion Table B. 6502 Instruction-Set: Alphabetic C. 6502 Instruction-Set: Binary D. 6502 Instruction-Set: Hexadecimal and Timing E. ASCII Table F. Relative Branch Table G. HexOpcodeListing H. Decimal to BCD Conversion I. Answers to the Exercises INDEX ......................................... 1,402 D ••••••• vi PREFACE This book has been designed as a complete self-contained text to learn programming, using the 6502. It can be used by a person who has never programmed before, and should also be of value to anyone using the 6502. For the person who has already programmed, this book will teach specific programming techniques using (or working around) the specific characteristics of the 6502. This text covers the elementary to intermediate techniques required to start pro- gramming effectively. This text aims at providing a true level of competence to the person who wishes to program using this microprocessor. Nat- urally, no book will teach effectively how to program, unless one actually practices. However, it is hoped that this book will take the reader to the point where he feels that he can start program- ming by himself and solve simple or even moderately complex problems using a microcomputer. This book is based on the author's experience in teaching more than 1000 persons how to program microcomputers.' As a result, it is strongly structured. Chapters normally go from the simple to the complex. For readers who have already learned elementary programming, the introductory chapter may be skipped. For others who have never programmed, the final sections of some chapters may require a second reading. The book has been de- signed to take the reader systematically through all the basic concepts and techniques required to build increasingly complex programs. It is, therefore, strongly suggested that the ordering of the chapters be followed. In addition, for effective results, it is important that the reader attempt to solve as many exercises as possible. The difficulty within the exercises has been carefully graduated. They are designed to verify that the material which has been presented is really understood. Without doing the pro- gramming exercises, it will not be possible to realize the full value of this book as an educational medium. Several of the exer- cises may require time, such as the multiplication exercise for example. However, by doing these, you (cid:0) (cid:0) (cid:0) (cid:0) (cid:0) actually program and learn by doing. This is indispensable. For those who will have acquired a taste for programming when reaching the. end of this volume, companion volumes' are available: vii -"6502 Applications" covers input/output. -"Advanced 6502 Programming" covers complex algorithms. Other books in this series cover programming for other popular microprocessors. For those who wish to develop their hardware knowledge, it is suggested that the reference books "From Chips to Systems" (ref. C201A) and "Microprocessor Interfacing Techniques" (ref. C207) be consulted. The author would like to thank Rockwell International,. who pro- vided access to one of the first ASM65 development systems. The contents of this book have been checked carefully and are believed to be reliable. However, inevitably, some typographical or other er.rors will be found. The author will be grateful for any comments by alert readers so that future editions may benefit from their experience. Any other suggestions for improvements, such as other programs desired, developed, or found of value by readers, will be appreciated. PREFACE TO THE FOURTH EDmON In the five years since this book was originally published, the audience of 6502 microprocessor users has grown exponentially, and it continues to grow. This book has expanded with its audience. The Second Edition increased in size by almost 100 pages, with most of the new material being added to Chapters 1 and 9. Additional improvements have been made continually throughout the book. In this Fourth Edition, answers to the exercises have been included as an appen- dix (Appendix I). These answers appear in response to the request of many readers, who wanted to make sure that their knowledge of 6502 programming was thorough. I would like to thank the many readers of the previous editions who have contributed valuable suggestions for improvement. Special acknowledgements are due to Eric Novikoff and Chris Williams for their contributions to the answers to the exercises, as well as to the complex programming examples in Chapter 9. Special thanks also go to Daniel J. David, for his many suggested improvements. A number of changes and enhancements are also due to the valuable analysis and comments pro- posed by Philip K. Hooper, John Smith, Ronald Long, Charles Curlay, N. Harris, John McClenon, Douglas Thusty, Fletcher Carson, and Pro- fessor Myron Calhoun. viii

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.