# UTIAS

# **UNIVERSITY OF TORONTO**

# **INSTITUTE FOR AEROSPACE STUDIES**

4925 Dufferin Street, Toronto, Ontario, Canada, M3H 5T6

# **Robust Robotics**

prepared by

Team 67 – Wednesday

Yu Zheng (999911225) Luyuan Chen (999516082) Ran(Carrie) Yan (999888126)

prepared for

Prof. M.R. Emami

A technical report submitted for AER201 – Engineering Design

TA: Rail-Ip



# 1. Acknowledgement

We would like to express our gratitude to all those help us to complete this design project. We are very grateful to our supervisor Prof. M. Reza Emami and TA, Rail-Ip who gave us technical support and encouragement helped all time of the design process as well as their critical advises.

We also appreciate the class of Engineering Science 1T6 and 1T5 for they generously share their experience and resource throughout the entire project to help us overcome many problems. Lastly, we would like to give our sincere gratitude to our friends and family who patiently supported our completion of the project.

## 2. Abstract

"Robust Robotics" is the robotic prototype that was design and constructed over the entire semester in response to the project proposal, the LED Candlelight Test machine. It is required an autonomous robot that can turn on/off candlelights and detect at maximum 9 candlelights and can efficiently detect the presence of candlelights mounted on the machine, inspect their functionality and record the information gathered. The robot has to count the number of candlelights in testing and identify whether the candlelight is flickering, non-flickering and non-functional. All constraints demonstrated must be satisfied. On top of that, the machine is expected to be reliable, portable and elegant.

This report contains the complete design and construction process of the robot. It also contains the detail description for final prototype of each subsystem including Electromechanical, Circuit and Microcontroller. Further improvement suggestions are given for further interest to strengthen the design. Other related information of robot such as budget, schedule, integration and operating process are included as well.

The machine did not fully perform the design task in the demonstration but was acceptable. It turns on/off all the candlelights expectedly and correctly detect 8 out of 9 functions within 8 (s), which was far below the limited 90 (s). The only failure is due to the calibration mistake in microcontroller code, which can be fixed in 5 minutes. The robot is reliable given that it went through more than 100 times of testing before the final demonstration. Nevertheless, the robot meets all the requirements and constrains, further, some of the bonus features are also implemented.

Table of Content

| 1. Acknowledgement                                                                                            | 3                                                                                                                               |
|---------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------|
| 2. Abstract                                                                                                   | 4                                                                                                                               |
| Table of Content                                                                                              | 5                                                                                                                               |
| 1 Symbols and abbroviations                                                                                   | 0                                                                                                                               |
| 1. Symbols and abbi eviations                                                                                 |                                                                                                                                 |
| 2. Introduction                                                                                               |                                                                                                                                 |
| 3. Market survey                                                                                              |                                                                                                                                 |
| 4. Objectives and constraints                                                                                 |                                                                                                                                 |
| 4.1 Objectives                                                                                                |                                                                                                                                 |
| 4.2 Constrains                                                                                                | 14                                                                                                                              |
| 5 Machanisms                                                                                                  | 15                                                                                                                              |
| 5.1 Switch gear                                                                                               | 15                                                                                                                              |
| 5.2 Relav                                                                                                     |                                                                                                                                 |
| 5.3 Rack and pinion                                                                                           |                                                                                                                                 |
| 5.4. Theory                                                                                                   |                                                                                                                                 |
| 6 Pudget                                                                                                      | 22                                                                                                                              |
| 0. Duuget                                                                                                     |                                                                                                                                 |
| 7. Division of problem                                                                                        |                                                                                                                                 |
| 7.1 Electromechanical Subsystem                                                                               | 24                                                                                                                              |
| 7.2 Circuit subsystem                                                                                         | 25                                                                                                                              |
| 7.3 Microcontroller subsystem                                                                                 | 25                                                                                                                              |
| 8. Electromechanical subsystem                                                                                |                                                                                                                                 |
| 8.1 Introduction                                                                                              | 26                                                                                                                              |
| 8.2 Tray                                                                                                      | 27                                                                                                                              |
| 8.2.1 Assessment of the problem                                                                               | 27                                                                                                                              |
| 8.2.2 Solution                                                                                                | 28                                                                                                                              |
| 8.3 Switch mechanisms                                                                                         |                                                                                                                                 |
| 8.3.1 Assessment of the problem                                                                               | 20                                                                                                                              |
|                                                                                                               |                                                                                                                                 |
| 8.3.2 Solution                                                                                                |                                                                                                                                 |
| <ul> <li>8.3.2 Solution</li> <li>8.4 Detection mechanism</li> <li>8.4 1 Assocrament of the problem</li> </ul> |                                                                                                                                 |
| <ul> <li>8.3.2 Solution</li> <li>8.4 Detection mechanism</li> <li>8.4.1 Assessment of the problem</li></ul>   |                                                                                                                                 |
| <ul> <li>8.3.2 Solution</li> <li>8.4 Detection mechanism</li></ul>                                            |                                                                                                                                 |
| <ul> <li>8.3.2 Solution</li></ul>                                                                             | 30<br>31<br>35<br>35<br>35<br>36<br>40<br>40                                                                                    |
| <ul> <li>8.3.2 Solution</li></ul>                                                                             | 30<br>31<br>35<br>35<br>36<br>40<br>40<br>42                                                                                    |
| <ul> <li>8.3.2 Solution</li></ul>                                                                             | 30<br>31<br>35<br>35<br>36<br>40<br>40<br>40<br>42<br>42                                                                        |
| <ul> <li>8.3.2 Solution</li></ul>                                                                             | 30<br>31<br>35<br>35<br>36<br>40<br>40<br>40<br>42<br>42<br>42<br>42                                                            |
| <ul> <li>8.3.2 Solution</li></ul>                                                                             | 30<br>31<br>35<br>35<br>36<br>40<br>40<br>40<br>42<br>42<br>42<br>42<br>42<br>42                                                |
| <ul> <li>8.3.2 Solution</li></ul>                                                                             | 30<br>31<br>35<br>35<br>36<br>40<br>40<br>40<br>42<br>42<br>42<br>42<br>42<br>42<br>42                                          |
| <ul> <li>8.3.2 Solution</li></ul>                                                                             | 30<br>31<br>35<br>35<br>36<br>40<br>40<br>40<br>42<br>42<br>42<br>42<br>42<br>42<br>42<br>42<br>42<br>42<br>42<br>42<br>43      |
| <ul> <li>8.3.2 Solution</li></ul>                                                                             | 30<br>31<br>35<br>35<br>36<br>40<br>40<br>40<br>42<br>42<br>42<br>42<br>42<br>42<br>42<br>42<br>42<br>42<br>42<br>42<br>43<br>3 |
| <ul> <li>8.3.2 Solution</li></ul>                                                                             | 30<br>31<br>35<br>35<br>36<br>40<br>40<br>40<br>42<br>42<br>42<br>42<br>42<br>42<br>42<br>42<br>42<br>42<br>42<br>42<br>42      |

| 9.1  | Overview                                                                               | 45   |
|------|----------------------------------------------------------------------------------------|------|
| 9.1. | 1 Problem assessment                                                                   | 45   |
| 9.2  | Solution                                                                               | 46   |
| 9.2. | 1 Pin assignment of the PIC microcontroller                                            | 46   |
| 9.2. | 2 User interface                                                                       | 47   |
| 9.2. | 3 Count the number of the lights mounted                                               | 50   |
| 9.2. | 4 Identify the functionality of the light mounted                                      | 51   |
| 9.2. | 5 Display the information of qualified operation                                       | 54   |
| 9.2  | 6 Real Time Clock                                                                      | 56   |
| 9.2  | 7 Permanent loa                                                                        | 59   |
| 9.2  | 8 PC interface                                                                         |      |
| 9.2  | 9 Future Improvement                                                                   | 63   |
| 5.2. |                                                                                        |      |
| 10.  | Circuit Subsystem                                                                      | 65   |
| 10.1 | Problem Assessment                                                                     | 65   |
| 10.  | 1.1 Sensor System                                                                      | 65   |
| 10.  | 1.2 Power Supply                                                                       | 65   |
| 10.  | 1.3 Actuator Driving Circuit                                                           | 65   |
| 10.  | 1.4 Cable management and Safety Ensured                                                | 65   |
| 10.  | 1.5 Emergency stop                                                                     | 65   |
| In a | dvance, implement an emergency STOP button to cease all operations as long as the      | STOP |
| but  | ton pressed. All dynamical parts will stop immediately expect the PIC, the power of PI | C is |
| inde | ependent of effect of Emergency STOP                                                   | 65   |
| 10.2 | Solution                                                                               | 66   |
| 10.  | 2.1 Light Sensing Circuitry:                                                           | 66   |
| 10.  | 2.2 Presence Sensing Circuity:                                                         | 69   |
| 10.  | 2.3 Actuator Driving Circuit                                                           | 70   |
| 10.  | 2.4 Power Supply                                                                       | 71   |
| 10.  | 2.5 Emergency Stop and Power Line Board                                                | 73   |
| 10.  | 2.6 Signal Selection through implementation of multiplexer                             | 75   |
| 10.  | 2.7 Protect Integrated Circuit/PIC                                                     | 76   |
| 10.  | 2.8 Wire Management                                                                    | 77   |
| 10.  | 2.9 Suggestions for Improvement of the subsystem:                                      |      |
|      |                                                                                        |      |
| 11.  | Integration                                                                            | 81   |
| 11.1 | Photodiode and microswitch:                                                            | 81   |
| 11.2 | Soldering board allocation                                                             | 81   |
| 11.3 | Driving circuit driving actuators:                                                     | 82   |
| 11.4 | Integration and Calibration between Circuit and Microcontrollers                       | 82   |
| 12.  | Accomplished Schedule                                                                  | 83   |
| 13.  | Description of Overall Machine and Operating Procedure                                 | 85   |
| 13.1 | Basic Feature                                                                          | 85   |
| 13.2 | Functionality                                                                          | 85   |
| 13.  | 2.1 Operation                                                                          | 85   |
| 13.  | 2.2 Tray and its cover                                                                 | 85   |
| 13.  | 2.3 Candlelights Switch System                                                         | 86   |
| 13.  | 2.4 Real Time Clock                                                                    | 86   |
| 13.  | 2.5 2.5 Notification of Emergency STOP ON                                              | 86   |
|      |                                                                                        |      |

| 13.3        | 3.C  | Pperating Procedure:                                  | 86 |
|-------------|------|-------------------------------------------------------|----|
| 13          | .3.1 | 3.1 Operation Messages on LCD screen                  | 86 |
| 13          | .3.2 | 3.2 Before the operation                              | 87 |
| 13          | .3.3 | 3.3 In process                                        | 88 |
| 14.         | Sys  | tem Issues and Improvements:                          |    |
| 14.1        | Por  | rtability                                             | 89 |
| 14.2        | То   | gle Emergency Button SHOULD be changed to pressed one | 89 |
| 14.3        | PIC  | 18 replacs PIC 16:                                    | 89 |
| <b>15</b> . | Con  | clusion                                               |    |
| <b>16</b> . | Ref  | erence                                                |    |
| 17.         | App  | oendix                                                |    |

Intentionally left blank

# 1. Symbols and abbreviations

| Abbreviation | Description                                            |  |
|--------------|--------------------------------------------------------|--|
| AC           | Alternative Current                                    |  |
| DC           | Direct Current                                         |  |
| V            | Volt                                                   |  |
| Α            | Ampere                                                 |  |
| mA           | Milliamp                                               |  |
| GND          | Ground                                                 |  |
| Logic High   | 5 (V) signal                                           |  |
| Logic Low    | 0 (V) signal                                           |  |
| IC           | Integrated Circuit                                     |  |
| LCD          | Liquid Crystal Display                                 |  |
| LED          | Light Emitting Diode                                   |  |
| PIC          | Microchip <sup>®</sup> Peripheral Interface Controller |  |
| L Registers  | Registers used to store light status                   |  |
| EEPROM       | Electrically Erasable Programmable Read Only Memory    |  |
| I/O          | Input/output                                           |  |
| UI           | User Interface                                         |  |

# 2. Introduction

Automated quality assurance is one of the most important technic used in all industries. The common requirements for automated function checking machines are accuracy, efficiency, speed and reliability of operation. There are a lot different types available in the market, each one of them are tailored to specialized usage. The client, as a LED candlelight-manufacturing firm, required a machine that can automatically test the functionality of LED candlelights.

"Robust Robotics" is a an automated machine that is designed and constructed over the last 3 months to fulfill the requirement specified in the request for proposal. The prototype is expected to test the 3 functionalities of LED candlelights, namely Pass (candlelights flicker), Flicker Fail (candlelights are constantly on) and LED Fail (candlelights are constantly off). The machine shall be able to test 9 candlelights simultaneously. When the tray is not fully loaded, the machine is responsible for counting the candlelights mounted.

Our machine is a well-designed one, it not only satisfies all the requirement and constraints, but also designed to be elegant, robust and user-friendly. The machine can complete the whole operation within 90 seconds, with test 90.1% accuracy (73/81 tests passed). Moreover, it records the operation time accurate to seconds. It writes up to 4 sets of operational outcome including running time, performance of all candlelights and number of lights to EEPROM, also known as the permanent log.

In the design, workload is divided into 3 subsystems, the electromethanical subsystem, the circuit subsystem and the microcontroller subsystem. Yu Zheng is responsible for the design and construction of the mechanisms and all the structural part of the machine as well as interconnecting the moving parts and sensor modules. Ran Yan is responsible for fabricating all circuits of the machine, including circuit to drive motors, manipulating inputs from the sensor array and the main hub for power and outputs. Luyuan Chen is responsible for the microcontroller coding, designing the logic of the operation and UI.

The first section of the report, the project backgrounds and perspectives are provided. Later in the section, the budget and split of functions in detail are presented in detail. The second section gives specific information on the design of each of the subsystems. Last section contains the integration process, system improvement suggestions, accomplished schedule and conclusion.

## 3. Market survey

The LED candlelight industry has gone through a boom since they were introduced to the market. The LED lights have lots of advantages over the normal lights, because of its high efficiency in terms of its power consumed (it does not give out much hear as conventional light bulbs do) and it does not radiate harmful material. In the massproduced industry like LED manufacturing, even the highest final passes yield would generate an enormous amount of units that are not functional. A fast and accurate method of testing each unit is to be implemented. Thus the Automated Test Equipment (ATE) is developed to help the factories accomplish quality assurance quickly and accurately without manpower.

Current existing machines did not match the need stated in the design RFP, for the devices that are being selling are large and expensive. The price listed is typically around \$2000 – 50000 CDN on the Alibaba.com. Furthermore, the machines use 380V industrial electricity. The typical machines has high accurate rate and can test over 10k LEDs per hour. In our case, not only this gigantic machine dissatisfied the requirement of the RFP, but also unnecessary to buy one for the purpose specified.



Figure 3.1. Existing industry solution to LED testing

The RFP requires a light capacity test machine, which only take 9 lights each round. Therefore a brand new design shall be proposed to match the requirement of the RFP and the constraints, criteria. The following sections gives the detailed design of the test machine.

# 4. Objectives and constraints

## 4.1 Objectives

The machine is required to complete follow objects

- Test 9 candlelights in a single operation
- Identify the functionality of each of the candlelight
- Can operate regardless of the ambient condition
- Easily accessible Emergency Stop button
- LCD should provide information of the operation

## 4.2 Constrains

- Must fit in 50  $\times$ 50  $\times$ 50 cm<sup>3</sup> envelope at all operation times
- Weight must be less than 6 kilograms
- Maximum cost: \$230 CDN
- Time: entire operation process must be limited in 90 second
- No human interaction after START
- Tray can be separated from the machine and no power supply, actuator or electronic components attached to it
- Safety: no present hazard
- No need for dismantling and installing any part during transporting and loading candlelights

Acceptance criteria in decision-making

AHP Analysis

# 5. Mechanisms

#### 5.1 Switch gear

As one of the major components of machine, the machine must be able to handle the operation of candlelight's switch. This requires the combination of mechanical and electrical to determine when and how to turn off or on the switch. Currently, some machines have been created to perform similar function. One of the designs will be presented and gained insight of its mechanism below.

#### Bertho's pointless switch machine

The most important design of this switch machine is the method for controlling the machine to either turn on or turn off the switch. It present the similar function that is needed for our Operating switch gear, because the light must be turned on before the testing and turned off after all the operation.

This machine contains the motor as drive gear to provide the power and it is activated by red pushed bottom. The rotate gear has a small bar used to flip the switch from one side to the other side. When the switch is flipped to another side, it changes the rotate direction of small bar on the rotate gear, and every time when the switch is flipped, the rotate direction will change as well.

Bertho's pointless switch machine is highly effective for the change of rotate direction and switch flipped motion. However, in this machine, the switch is connect to circuit as one part of machine to change the rotate direction, and it is distinctly different from the light switch, which is separated from the switch flipping mechanism. Moreover, Bertho's pointless switch machine uses the complicated circuit without microcontroller to achieve the change of rotate direction. Additionally, the switch of candlelight is small, which means the interaction surface is too small to ensure the bar can be use to flip from one side to the other side. Therefore, this mechanism must be modify including the using microcontroller to simplify the circuit and change rotate direction, the dimension and shape of bar, operation precision.



Figure 5.1.1. Example of the Bertho's pointless switch



Figure 5.1.2. Example of the Bertho's pointless switch

## 5.2 Relay

In researching the method to turn on/off the switch, the relay perform the circuitcontrolled way to achieve the on-off switch of another circuit. As show in the figure \*\*, the entire system contains two circuit, the right circuit control the switch of left circuit. Once the right circuit is connected, the current go through the spule creating a magnetic force to attract the metal plate above the spule (the iron bar inside the spule is used to reinforce the magnetic force). However, this relay can only produce attractive force, and it is not suitable for the switch of candlelight, which need equal force to turn on/off the switch. But it still provides us with better understanding of applying electromechanical to control the switch.



Figure 5.2.1. Example of a relay switch



Figure 5.2.2 Example of a relay switch

## 5.3 Rack and pinion



Figure 5.3.1. The rack and pinion mechanism

The rack and pinion is the mechanism that can convert the rotation motion into the linear motion. In other words, this mechanism can change of rotational force such as motor to provide the linear direction force. A rack and pinion gear system is basically the combination of two gears. The pinion is traditional round gear while the rack is the straight gear. The gears are meshed with each other, when one of the gear more, it drives the motion of the other gear. The example of "rack and pinion" gear system can be seen on the rack railway, which is designed to travel up the steep inclines. The mechanism provides the force for train to overcome the large gravity force.



Figure 5.3.2. The application of 'rack and pinion', rack railway

## 5.4. Theory

The following theories and equations are used for understand the parameters of robot.

## Moment of inertia:

Basically the moment of inertia is measure of sluggishness or inertness of a body to the change in its state of rest or rotation. It depends upon mass with respect to axis of rotation. The unit is defined as  $kg * m^2$ .

Definition for point bodies:

$$I = m r^2$$

For the collection of object, the moment of inertia is just the sum or integration over the entire body.

$$I = \sum I = m r^2$$
 Or  $I = \int r^2 dm$ 

## Torque

The torque is a measurement of how much a force acting on an object causing the rotational motion of object. The object rotates about a fixed axis, called pivot point. The force "F", and the distance from the pivot to the point where the force acts in called the arm moment arm, label as "r".

The torque is defined as:

 $\tau = F \times r$ 

Where both F and r are the vector, torque is the cross product of these two vector.

## **Electrical relation is the circuit**

Two main formulas is used in the calculation in the circuit part:

$$R = \frac{V}{I}$$
$$P = VI$$

where R, V, I and P donated as the resistance, voltage, current and power respectively.

# 6. Budget

The pricing of all parts are provided in the chart below

# Circuit and Microcontroller

| Item                            | Location                                        | Supplier                     | Number | Unit Price (\$) | Total Price (\$) |
|---------------------------------|-------------------------------------------------|------------------------------|--------|-----------------|------------------|
| Transistor TIP142N              | H-Bridge                                        | Project Kit                  | 2      | 2               | 4                |
| Transistor TIP147N              | H-Bridge                                        | Project Kit                  | 2      | 2               | 4                |
| Diode 1N4001                    | H-Bridge                                        | Project Kit                  | 4      | 0.2             | 1                |
| Capacitor 104                   | H-Bridge                                        | Project Kit                  | 1      | 0.3             | 0                |
| Photodiode BPW34                | Light Sensor                                    | Creatron Inc.                | 9      | 1.5             | 14               |
| Operational Amplifier LM358     | Light Sensor                                    | Project Kit<br>Creatron Inc. | 5      | 1               | 5                |
| Socket 2×4 Pins                 | Light Sensor                                    | Project Kit<br>Creatron Inc. | 5      | 0.30/2          | 1                |
| Microswitch                     | Presence Sensor                                 |                              | 9      | 0.3             | 3                |
| NAND gate 74HC00N               | Presence Sensor                                 | Project Kit<br>Creatron Inc. | 5      | 1.2             | 6                |
| Socket 2×7 Pins                 | Presence Sensor                                 |                              | 5      | 0.15            | 1                |
| 1×9 Jumper Wires(Male-Male)     | Presence Sensor                                 | Creatron Inc.                | 1      | 5.3             | 5                |
| Resistors(1k,5.6k,10k,47k,100k) | All Circuits                                    | Creatron Inc.                | 40     | 0.1/10          | 0                |
| Connecting Wires                | All Circuits                                    | Creatron Inc.                | 20     | 0.13            | 3                |
| White Soldering Board (large)   | Light Sensor                                    | Creatron Inc.                | 1      | 3.5             | 4                |
| White Soldering Board (small)   | H bridge, Presence<br>Sensor,<br>Emergency Stop | Creatron Inc.                | 3      | 2.5             | 8                |
| Green Soldering Board           | Light sensor,<br>Signal Selection               | Creatron Inc.                | 2      | 1.5             | 3                |
| Emergency Stop Button           | Emergency Stop                                  | Creatron Inc.                | 1      | 1.2             | 1                |
| Socket 2×20 Pins                | Emergency Stop                                  | Creatron Inc.                | 2      | 0.15            | 0                |
| Multiplexer CD4067BE            | Signal Selection                                | Creatron Inc.                | 2      | 1.5             | 3                |
| Power Supply                    |                                                 | Canadian<br>Computer         | 1      | 15.5            | 16               |
| 1×9 Jumper Wires(Female-Male)   | PIC                                             | Creatron Inc.                | 3      | 4.8             | 14               |
| Black Tape                      | All Citcuit                                     | Creatron Inc.                | 1      | 1.25            | 1                |

| Devbugger                                          |  | Project Kit | 1 | 75 | 75 |
|----------------------------------------------------|--|-------------|---|----|----|
| Total for circuit & microcontroller part \$ 170.75 |  |             |   |    |    |

# Electromechanical

| Material                                     | Place in machine                            |    |  |
|----------------------------------------------|---------------------------------------------|----|--|
| Wood                                         | Switch mechanism, base, tray, motor support | 7  |  |
| Aluminum                                     | Skeleton of the frame, switch mechanism     | 10 |  |
| Acrylic                                      | Wall of frame                               | 10 |  |
| Plastic                                      | Wall of frame                               | 3  |  |
| Mental plate                                 | Switch mechanism                            | 3  |  |
| Screw and nut & nail                         | Frame, switch mechanism                     | 4  |  |
| DC motor & gear and rack Switch mechanism 15 |                                             | 15 |  |
| Total for electromechanical part: \$ 52      |                                             |    |  |

Total Budget for all parts: \$ 222.75

# 7. Division of problem

The construction of entire robot was split into three main composts including electromechanical system, the circuit system and the microcontroller system. All the members should not only be responsible to the design of their own parts but also should help the other members with the debugging works. Before the integration, all the members focus on their work base of the direction of main design of robots. During the integration, the circuit members and programming member helped each other on the calibration of robot while the electromechanical member work with circuit member on design the placement of various circuits and sensor and the DevBugger. All three members discussed the change of idea, improvement problems.

## 7.1 Electromechanical Subsystem

| Task                                | Member(s)                             |
|-------------------------------------|---------------------------------------|
| Before the integration              |                                       |
| General design of robot             | All members                           |
| Detail design of mechanism          | Electromechanical member              |
| Calculation of torque and dimension | Electromechanical member              |
| Selection of motor and construction | Electromechanical member              |
| required material                   |                                       |
| Fabrication of robot                | Electromechanical member              |
| During the integration              |                                       |
| Change of design                    | All members                           |
| Calibration of mechanism            | Electromechanical member              |
| Placement of sensor and circuit     | Electromechanical and circuit members |

# 7.2 Circuit subsystem

| Task                                   | Member(s)                       |
|----------------------------------------|---------------------------------|
| General design of circuit              | Circuit member                  |
| Circuit schematics (motor & sensor)    | Circuit member                  |
| Calculation of resistance, current and | Circuit member                  |
| voltage                                |                                 |
| Acquire sensor, power supply and other | Circuit member                  |
| electric elements                      |                                 |
| Soldering circuit                      | Circuit member                  |
| During the integration                 | <u> </u>                        |
| Circuit testing                        | Circuit and programming members |
| Debugging circuit                      | Circuit and programming members |

 Table 7.2. Responsibility on Circuit subsystem

# 7.3 Microcontroller subsystem

| Task                               | Member(s)          |
|------------------------------------|--------------------|
| General design of code             | Programming member |
| Writing the pseudo code            | Programming member |
| Pin assignment and user interface  | Programming member |
| Write the code for the motor and   | Programming member |
| sensor                             |                    |
| Code on the devbugger              | Programming member |
| During the integration             |                    |
| Calibration of delay for motor and | Programming member |
| sensor                             |                    |
| Code for the bonus feature         | Programming member |

 Table 7.3. Responsibility on microcontroller subsystem

# 8. Electromechanical subsystem

## 8.1 Introduction

The function of electromechanical subsystem is to provide the overall frame and mechanisms required in the machine. To be specific, the mechanisms in our robot include switch mechanism and candlelight detection mechanism. The electromechanical member is responsible to design the mechanisms of the robot as well as the arrangement of circuit board and power supply. In this section, the entire machine is decomposed into three main parts base on the technological working process of the machine. The detail of design and potential improvement will also be discussed in following.

The overall view of the robot is showed in the Figure 8.1.1 and Figure 8.1.2.



Figure 8.1.1. Overview of the machine



Figure 8.1.2 Back of the machine

# 8.2 Tray

8.2.1 Assessment of the problem

The tray is served as the platform to hold and fix the candlelights in the prescribed position. If the candlelights cannot be fixed, the candlelights tends to deviate from the original position during the operating process, then the counting number of candlelights and the completing test operation are impossible to finish. The design of tray should be easily assessable to the operator to load in the candlelights and supply the tray to the machine. To sum up, the tray should be reliable to fix the candlelights and convenient to operate.

# 8.2.2 Solution



**Figure 8.2.1.** 3X3 tray



Figure 8.2.2. Grid of the tray

The three by three grid is decided to be used for the tray as showed in the **Figure 8.1.2.** To solve the first problem, which is fixing the candlelight in particular position, the problem is decomposed into three-sub problem. First, to avoid the candlelight move horizontally, the size of each grid is almost the same as the size of the candlelight, so that it can prevent the candlelight move horizontally during operating. Second, to prevent the candlelight rotate in the grid, a special designed base is attached to the tray as found in the **Figure 8.2.2** For each grid, the base contains two holes to allow the stand bar of candlelight to insert inside. The reason why the base is semicircle is another half space is used for the switch mechanism, which implies that the operator who is responded to load the candlelights in the tray should orientate the candlelights to allow the switch of candlelights expose. Third, to

keep the candlelight stay in the grid instead of jumping out, the cover in need, the detail design of cover will be discussed in the detection mechanism because it contains the sensors.

### 8.3 Switch mechanisms

### 8.3.1 Assessment of the problem

The switch mechanism is the most important part in this robot because it serve the essential function of the robot, turn on/off the candlelights. Without the switch mechanism, the other parts of robot become meaningless. The design of switch mechanism should be reliable and simple. Also, the time spent on turn/off the candlelight should be as less as possible to satisfy constrain that the total operation time must less than 90s. Therefore, the design problem of switch mechanism is identified as following:

- To keep the switch mechanism as simple as possible in order to reduce the mistakes, all the candlelights should be turned on/off at once.
- The friction force tends to cause the jam during turning on/off the candlelights
- The selection of mechanism to drive the force with two directions.



Figure 8.3.1. Switch mechanism

## 8.3.2 Solution

The entire switch mechanism is showed in the **Figure 8.3.1.** The follow subsections will describe the design to solve each problem.

#### 8.3.2.1 Solution to A – moveable base plate

As showed in the **Figure 8.3.1**, there are nine pairs of small blocks sticking on the plate, which is moveable; each pair of wood blocks is in the position exactly under the switch of candlelight. The separation of each pairs of blocks is same to make is possible to turn on/off all the candlelights together. When the tray is supplied in the machine, the exposed switch of candlelights will fall in the gap between two blocks as shown in the **Figure 8.3.2**. When the operation begins, the plate is drive to the right, and then the left

side block hit the switch of candlelight pushing it to right and turn of the candlelight. After finish the detection operation, the plate move back to turn off all the candlelight in the same way.



Figure 8.3.1. Moveable base plate



Figure 8.3.2. The tray supplied above the moveable plate

## 8.3.2.2 Solution to B - mental drawer slide

This idea come from the drawer because the friction to put out the drawer is small no matter how heavy it is. As showed in the **Figure 8.3.2**, two drawer slides is refitted to match the size of our design, between them is connected the moveable base plate. This design can prevent the plate vacillate to left and right when the driving force is provide, and the friction force needed to overcome is reduced sharply.



Figure 8.3.3. Mental drawer slide

## 8.3.2.3 Solution to C - rack and pinion

To provide the horizontal force for both two sides, the linear actuator rack and pinion is employed. The pinion is connected to the motor, when the motor rotates; it causes the pinion drive the rack to move, thereby translating the rotation motion of motor to linear motion of rack. Finally, the rack attaching to the plated and drive the plate moves horizontally for both directions. In the **Figure 8.3.4**, it gives the overall view of this mechanism.



Figure 8.3.4. Rack and pinion

## 8.4 Detection mechanism

8.4.1 Assessment of the problem

From the RFP, the machine should be able to detect the total number of candlelights and the inspected functionality of each candlelight with three possible states in the test. Again, to keep the mechanism simple, we do not use and moving part here; instead, we use nine sensors to detect nine candlelights respectively. This design focus on the position of sensor and the problem is summarized below:

- Since the light sensor is sensitive, small difference of light intensity may cause the different result of change of sensors. The turn on candlelights may affect each other in the detection process.
- The selection of sensor that can count the total number of candlelights.

• The sensor can only detect the light intensity with no more than 5cm far away from the candlelight. It raises the problem that how to put the tray into the machine without affect the sensor.

#### 8.4.2. Solution

8.4.2.1 Solution to A and C – foldable cover

To separate the candlelight for each grid, we come out the design that using the cover with similar structure of the tray. The cover can fold with hinge attaching to the sidewall. When the cover is close, as showed in the **Figure 8.4.1**, each candlelight can be isolate form other candlelights. Therefore, the sensor will not receive the light from other candlelights. The light sensor is fixed in the middle of grid as shown in the **Figure 8.4.2**. With the folded cover, the tray can put in machine without considering the limitation of space that the distance between light sensor and candlelight must less than 5cm. There is a lock on the cover used to ensure the micro switch is pressed when the cover is closed as well as fixed the tray to prevent the tray moving.


Figure 8.4.1. Foldable cover



Figure 8.4.2 Sensor in the cover



Figure 8.4.3. Lock of the cover

### 8.4.2.2 Solution to B – Micro switch

The miniature snap-action switch is decided to be used to test the number of candlelight instead of IR sensor is because of its reliability and durability, unlike IR sensor which require high position accuracy. Micro switch only need little physical force to actuate through the use of tipping-point mechanism. **Figure 8.4.4** shows that, the micro switch is attached to the one side of grid of cover. When the cover is fold down, the candlelight in the grid of tray press the actuator of micro switch and create the signal to tell the pic board that there is the candlelight in that position. If the grid of tray is empty, the actuator will not change and no signal created.



Figure 8.4.4. Micro switch in the cover

# 8.5 Frame

## 8.5.1Assessment of the problem

The machine contains not only the mechanisms but also the circuit; the circuit parts contain a large number of electric wires that tend to affect the moving parts. Also, for safety consideration, the frame of machine should contain the wall to prevent the electric wire expose outside causing the potential risk. The material selected for the wall should also be paid more attention, since the machine the design to test the LED candlelight intensity, the light comes from outside tends to affect the sensor. In addition, the material should be as light as possible to satisfy the weight constrain.

## 8.5.2Solution

**Figure 8.1.1** shows that the frame, like a box, encloses all the circuit, PIC board, power supply and the mechanisms in side the frame. All the electric wire is stay above the entire the mechanisms to prevent the wire affect the moving part of machine. The material used as the skeleton of the frame is aluminum, and the wall of the frame is acrylic and plastic. The acrylic is substantial enough that it can be used to support the PIC board and circuit without deformation. The plastic cover is non- transparent so that it can block the light from the environment. The wall is established at four side of machine left one side to allow operator to put in the tray.

All the circuit and the PIC board are fixed on the acrylic board inside the machine. To let the operator more convenient to control the machine, the keyboard and screen are isolated from the Devbugger board and fixed outside the frame as well as the emergency stop bottom as showed in the **Figure 8.5.1**.



Figure 8.5.1. Keypad, screen and emergency button

# 8.6 Supporting calculation

8.6.1 Candlelight

- Weight of candlelight:  $10 \pm 0.1g$
- Height without the head of lamp: 1.8cm
- Total height: 3.3cm
- Demeter: 3.8cm
- Distance between random two supporting arms: 2.8cm
- Position of switch: 0.5cm away from one of the supporting arms

8.6.2 Tray

- Size of entire tray: 17cm x 19cm x 1.8cm
- Size of each grid of the tray: 5.3cm x 5.3cm x 1.8cm with cylindrical hole 3.8cm diameter
- 8.6.3 Moveable base plate
  - Distance between two woodblocks on the plate: 1cm

# 8.6.4 DC motor

- Maximum Force required to turn on candlelights (9 candlelights): 4N \* 9 = 36N
- Friction force  $\approx 5$ N
- Total force required = 36N + 5N = 41N = 4.18kg
- Demeter of gear: 1.5cm
- Total required torque = force x length = 4.18kg X 1.5 cm = 6.27 kg\*cm
- Selected motor: Zheng DC motor
- Information of motor: 12V, 50rpm, 110oz-in(7.5kg\*cm)
- Since 7.5kg > 6.27kg, the DC motor can turn on/off candlelights.

8.6.5 Foldable cover

- Size: 16cm x 18cm x 1.8cm
- Rotatable angle:  $\leq 60^{\circ}$

8.7 Suggestion for the improvement of the electromechanical subsystem

8.7.1 Summary of solutions and corresponding actuator

| Components of machine | Solution            | Actuator |  |  |
|-----------------------|---------------------|----------|--|--|
| Tray                  | 3X3 squared tray    | No use   |  |  |
|                       | Moveable base plate | No use   |  |  |
| Switch mechanism      | Mental drawer slide | No use   |  |  |
|                       | Rack and pinion     | DC motor |  |  |
| Detection mechanism   | Foldable cover      | No use   |  |  |
|                       | Micro switch        | No use   |  |  |
| Frame                 | Box                 | No use   |  |  |

After testing the robot's functionalities, some improvements can be implemented to improve the robot's reliability and utility rate of space.

# 8.7.2 Tray

The 3X3 tray limits the cover of tray should also be 3X3 squared which require large space to allow the cover to fold. If the linear tray is applied, less space is need to fold the cover, which means the size of entire machine can be smaller increasing the utility rate of space.

# 8.7.3 Mental drawer slide

The problem of mental drawer slide is the weight; it contributes most of the weight of switch mechanism. The material used is mental, which has high sturdiness but is not required for this mechanism. The material can change to reduce the weight of machine.

#### 8.7.4 DC motor

DC motor is the only actuator that is connected the rack and pinion, which is used to turn on/off the switch of candlelight. The property of DC motor is that it can only be controlled with its running time instead of the number of rotation. Another property is that, the rotational speed depends on the applied force, the larger force, and the slower rotational speed. These two properties cause the microcontroller member takes a long time to calibrate the time required to turn on/off the candlelight.

In this robot, the time setup for running the motor is constant no matter how many candlelights is used to test. Such that, it cause the problem that if only fewer candlelights is tested, the force required to turn on the switch become smaller, the motor will over rotate and tend to cause the defection of candlelights. The improvement is that, since we test the number of candlelight first before the turning on the switch, the force can change according to how many candlelights inside the tray. This requires more programming from microcontroller member, but it can increase the durability of machine and prevent the defection of candlelights.

# 9. Microcontroller subsystem

# 9.1 Overview

The microcontroller acts like the brain of the machine, for it output control command to every electric circuit, and make decision from the information feed to it. The Microchip PIC16F877 microcontroller is chosen to be the only microcontroller used in the project that handles all functions of the candle light test machine. In all, the microcontroller is responsible for interacting with 1 motor controlled by H-bridge circuit (cross cite here), 2 multiplexers (Ti CD4067, Appendix), 9 photo-diodes and 9 microswitches. Additionally, the microcontroller controls several peripheral devices including the LCD display, a 4\*4 keyboard, real time clock (RTC), Electric Erasable Programmable Read Only Memory (EEPROM) on the DevBugger V1.2 board.

# 9.1.1 Problem assessment

The microcontroller should able to accomplish required tasks specified in the request for proposal. There are also optional/ bonus tasks outlined in the RFP.

Required function:

- User interface allows user to interact with the machine in order to fulfill function
- Count the number of lights mounted on the tray
- Identify the functionality of the light mounted
- Display the information of qualified operation

Optional function:

- Real Time Clock (RTC), machine should able to display the time/time elapsed for the operation
- Provide the permanent log function, store at least 4 set of data stored
- PC interfacing, the microcontroller shall transfer the data to PC connected

User interface serves as a means for the machine to communicate with user. User interface shall provide useful information respectively in each phase of the operating cycle. After all the operation done, the user interface should give feedback to the user, displaying comprehensive information of the operation, i.e, the number of lights and the functionality of each light as required by the RFP.

# 9.2 Solution

# 9.2.1 Pin assignment of the PIC microcontroller

The PIC16F877 provide 33 I/O ports, most of which are used in the design, the specific pin assignment are shown below, and for further references.

| Р      | # | Buffer | I/O | A/D | Usage                             |
|--------|---|--------|-----|-----|-----------------------------------|
|        | 0 | TTL    | N/A | N/A | Light sensor                      |
| PORTA  | 1 | TTL    | N/A | N/A | N/A                               |
|        | 2 | TTL    | Ι   | Α   | N/A                               |
|        | 3 | TTL    | N/A | N/A | N/A                               |
|        | 4 | ST     | N/A | N/A | N/A                               |
|        | 5 | TTL    | N/A | N/A | N/A                               |
|        | 0 | TTL/ST | Ι   | D   | Emergency switch interrupt        |
|        | 1 | TTL    | Ι   | D   | Keypad interrupt                  |
| m      | 2 | TTL    | N/A | N/A | N/A                               |
| Ε      | 3 | TTL    | N/A | N/A | N/A                               |
| OF     | 4 | TTL    | Ι   | D   | Keypad input                      |
| Р      | 5 | TTL    | Ι   | D   | Keypad input                      |
|        | 6 | TTL/ST | Ι   | D   | Keypad input                      |
|        | 7 | TTL/ST | Ι   | D   | Keypad input                      |
|        | 0 | ST     | Ι   | D   | Microswitch input (from Mux)      |
|        | 1 | ST     | 0   | D   | Multiplexer selection bit D       |
| ۲)     | 2 | ST     | 0   | D   | Multiplexer selection bit C       |
| ST(    | 3 | ST     | Ι   | D   | I <sup>2</sup> C synchronous, RTC |
| 10     | 4 | ST     | Ι   | D   | I <sup>2</sup> C synchronous, RTC |
| 4      | 5 | ST     | N/A | N/A | N/A                               |
|        | 6 | ST     | 0   | D   | Multiplexer selection bit B       |
|        | 7 | ST     | 0   | D   | Multiplexer selection bit A       |
|        | 0 | ST/TTL | 0   | D   | Motor control forward             |
| $\cap$ | 1 | ST/TTL | 0   | D   | Motor control reverse             |
| ۲      | 2 | ST/TTL | 0   | D   | RS (LCD control)                  |
| łO     | 3 | ST/TTL | 0   | D   | E (LCD control)                   |
| Ц      | 4 | ST/TTL | 0   | D   | LCD data output                   |
|        | 5 | ST/TTL | 0   | D   | LCD data output                   |

|   | 6 | ST/TTL | 0   | D   | LCD data output |
|---|---|--------|-----|-----|-----------------|
|   | 7 | ST/TTL | 0   | D   | LCD data output |
|   | 0 | ST/TTL | N/A | N/A | N/A             |
| Ш | 1 | ST/TTL | N/A | N/A | N/A             |
|   | 2 | ST/TTL | N/A | N/A | N/A             |



Table 9.2.1.1. Pin assignment

Figure 9.2.1.1. Arrangement of PIC16F877 PDIP packaging chip

### 9.2.2 User interface

The input from the user is collect by a 4\*4 keypad with the MM74C922 encoder, which output a 4-bit signal from the 16-key keypad. The 4-bit digital signal is connected to **PORTB<7:4>** on the microcontroller board. User can follow very simple instruction

displayed on the screen to operate the machine. At most of the times, user only have to press either A, B or C. The sample display prompt is given as



Figure 9.2.2.1. Sample screen prompt

The 4-bit binary signal is feed into the microcontroller, and the key detection module will examine the user input. Three keys are used in the project, namely A, B and C. The code only checks the difference between those three keys. After the key pressed by the user is identified, the microcontroller branched to different function modules and sends control to the machine and perform specific task. As shown in figure 1.3.2.1, when A is pressed, the machine enters the working phase (whose detail will be provided in later chapters). B is responsible for the Data logging function required, which gives user the information about the number of lights mounted and the performance/ functionality of each light. The logging module also provide the function to go through up to 4 cycles done in the past by reading the EEPORM. The function of C key is to provide the user an accurate time display; the function is fulfilled by the RTC (real time clock).

| 1        | <u>2</u> | <u>3</u> | A        | <u>0</u> | 1        | <u>2</u> | <u>3</u> |
|----------|----------|----------|----------|----------|----------|----------|----------|
| <u>4</u> | <u>5</u> | <u>6</u> | <u>B</u> | 4        | <u>5</u> | <u>6</u> | 2        |
| 2        | <u>8</u> | <u>9</u> | <u>C</u> | <u>8</u> | 2        | Α        | <u>B</u> |
| *        | <u>0</u> | <u>#</u> | D        | <u>C</u> | D        | E        | F        |

Figure 9.2.2.2 Key selection signal

To output information to the user, a LCD display unit follows HD47780 protocol is used. The PIC microcontroller uses I/O ports to send instructions and data, 4 bits at a time. The complete control mechanism can be found in the **Appendix**.

The LCD display is programmed to show user specific information at different stage of operation. For example, when <A> is pressed to run the machine, the LCD would display the machine is running. After the operation is done, it will display the details about the operation, providing information like the time elapsed in operation and the result. The flow of display on the LCD is shown below.



Figure 9.2.2.3. Flow of LCD display

When the machine is initiated or recovered from emergency stop, the machine will display "Team\_67 Tester" and the current time and data. After 2s, the screen prompts user to select desired function, whether to start the operation, see the log of recently tested run and to see the time. When the machine enters run mode, the screen will notify user what is running. In specific, it will show "Turning on" when the motor is

moving and light is being on; "Checking spot" will be shown when the machine checks the presence of the spots. Then, when the A/D module (see later section for detail) is running, it will show "Checking Light" and the spot number of the spot that is being inspected. After the operation is done, the result page will show the time used in operation. In following screens, the number of lights mounted and the functionality for individual light is presented.

As shown in the flow, the screen will display "Emergency" when the Emergency Button mounted on the machine is pressed. This is done by the interrupt service. Once the emergency button is pressed, the circuit will cut the power of all moving part and send one 5 (V), high signal to **PORTB<0>**, which is the port for external interrupt implemented on PIC16F877 chip. The INTF (RB0/INT external interrupt flag bit) on INTCON is automatically set to 1 and the program will branch to address 0x04 where the interruption code is located. The code snippet for displaying the "Emergency" is located in the interruption code.

#### 9.2.3 Count the number of the lights mounted

There are 9 sets of sensors used in the project, each of which is responsible for one of the spots on the tray (refer to the sensor part for detail). As there are 9 analog input and 9 digital input and the ports are not enough to be assigned, it is decided that the multiplexer (specifically Texas Instrument CD4067 [Appendix] 16 to 1 multiplexer/demultiplexer) is used. The multiplexer (referred as "mux" in following text) utilize a 4-bit binary selection signal to choose the channel connected to output. The microswitch circuit is designed to output a 5 (V) (high) signal when the microswitch is closed, the circuit outputs a 0 (V) (low) otherwise. The 9 microswitch circuits is connected to the mux and can be output through the common output on the multiplexer chip. The selection signals are sent from PORTC<7:6> and PORTC<2:1> while the common output is connected to **PORTC<0>**. The working cycle starts when the selection signal is set, makes the common output connect to the specific microswitch circuit. Then, by reading the status of the RC0 port is the presence of light at that spot determined. In general, when a light is mounted at a spot on the tray, the microswitch on that spot will give a high signal. When the signal is selected by the mux, the RC0 port is pulled high and thus notifies the microcontroller that a light is present in the spot. The circuit is made that has the debouncing function, so the microcontroller is not responsible for the debouncing of the input (with respect to microcontroller). The algorithm of counting is provided below in **Figure 1.3.3**, the flow can be found in **Figure 1.3.5.1** (description of reading all L registers).

| Check_n | umber   |         |        |    |     |   |     |    |    |    |      |     |         |          |   |
|---------|---------|---------|--------|----|-----|---|-----|----|----|----|------|-----|---------|----------|---|
|         | banksel | PORTA   |        |    |     |   |     |    |    |    |      |     |         |          |   |
|         | clrf    | LED_Cou | nter   |    |     |   |     |    |    |    |      |     |         |          |   |
|         | btfss   | l1, 0   | ; skip | if | the | 0 | bit | of | ι1 | is | set, | add | counter | otherwis | е |
|         | incf    | LED_Cou | nter   |    |     |   |     |    |    |    |      |     |         |          |   |
|         | btfss   | 12, 0   | ; skip | if | the | 0 | bit | of | 12 | is | set, | add | counter | otherwis | e |
|         | incf    | LED_Cou | nter   |    |     |   |     |    |    |    |      |     |         |          |   |
|         | btfss   | 13, 0   | ; skip | if | the | 0 | bit | of | 13 | is | set, | add | counter | otherwis | е |
|         | incf    | LED_Cou | nter   |    |     |   |     |    |    |    |      |     |         |          |   |
|         | btfss   | 14, 0   | ; skip | if | the | 0 | bit | of | 14 | is | set, | add | counter | otherwis | е |
|         | incf    | LED_Cou | nter   |    |     |   |     |    |    |    |      |     |         |          |   |
|         | btfss   | 15, 0   | ; skip | if | the | 0 | bit | of | ι5 | is | set, | add | counter | otherwis | е |
|         | incf    | LED_Cou | nter   |    |     |   |     |    |    |    |      |     |         |          |   |
|         | btfss   | 16, 0   | ; skip | if | the | 0 | bit | of | 16 | is | set, | add | counter | otherwis | е |
|         | incf    | LED_Cou | nter   |    |     |   |     |    |    |    |      |     |         |          |   |
|         | btfss   | 17,0    | ; skip | if | the | 0 | bit | of | 17 | is | set, | add | counter | otherwis | е |
|         | incf    | LED_Cou | nter   |    |     |   |     |    |    |    |      |     |         |          |   |
|         | btfss   | 18,0    | ; skip | if | the | 0 | bit | of | 18 | is | set, | add | counter | otherwis | e |
|         | incf    | LED_Cou | nter   |    |     |   |     |    |    |    |      |     |         |          |   |
|         | btfss   | 19,0    | ; skip | if | the | 0 | bit | of | 19 | is | set, | add | counter | otherwis | е |
|         | incf    | LED_Cou | nter   |    |     |   |     |    |    |    |      |     |         |          |   |
|         | return  |         |        |    |     |   |     |    |    |    |      |     |         |          |   |

Figure 9.2.3.1. Code for counting LEDs

#### 9.2.4 Identify the functionality of the light mounted

It is requested by the RFP to identify three status of the LED candlelight, flicker failure (the light is constant on), led failure (the light is constant off) and pass (light flickers). The identification cannot be done by digital signal input, so the Analog-to-Digital Converter Module built in the microcontroller is used. As discussed in the previous section, the signal of sensor is feed from the multiplexer. The sensor chosen is photo-diode which is very sensitive to light intensity. To be specific, it gives a large range of voltage output when in different environment. The sensitivity of photodiodes gives makes it easy to utilize A/D module to assess the functionality of the lights. The A/D converter transforms an analog signal into a 10-bit digital signal. To be specific, the A/D converter works at a specific frequency, which is the sample rate. The 10-bit binary signal is split into two registers, which are ADRESH and ADRESL. The voltage of input signal is often around 2.5 (V) so only the low eight bits stored in the ADRESL is checked. The working scheme of the A/D module in the case of ours in as follows, details about the module is also discussed below.



Figure 9.2.4.1. Work flow of the A/D module

The voltage range of output from photodiode placed on a flickering light would be 0.9 to 3.0 (V) in our case. It is possible to select a voltage in between to act as the reference voltage. The reference voltage is carefully selected and calibrated for each spot on the tray to provide most accurate measuring. In one operation cycle (checking one light), 99 data point is taken consecutively with an interval of 0.01 (s) each. Then the voltage of each point is compared to the reference voltage. As shown in the flow chart, there is a register called "Counter", which is set to 100 when initialized. When the light has a status of "flicker failure", or the light is constant on, the voltage input will is always higher than the reference voltage resulting in the counter get accumulated to 199. In contrast, in the case of LED failure, the counter will be 1 after the operation because of the fact that the voltage input will be constantly lower than the reference. Lastly, anything in between would dictate a flickering light (as "PASS"). Thus the status of light can be identified.

To store the information collected from the sensor, 9 separate registers are used. They are named from L1 to L9; each one of them follows a specific format convention:

| Pass   | Flicker failure | LED failure | No light |
|--------|-----------------|-------------|----------|
| 0b1000 | 0b0100          | 0b0010      | 0b0001   |
|        |                 |             |          |

**Table 9.2.4.1.** Format convention of storing light status

The one-hot coding would make it easy to check and read. The 9 registers are initialized to be 0b0001 assuming no light is mounted at all spots. After making sure there is no light present at the spot, the code is change to 0b0000 for further changes. The specific flow is shown below.

```
setInitialValueForLightResigters
              b'0001'
                            ; LSB: 0001 as initial value: constant off light
   movlw
   movwf
               ι1
   btfsc
             PORTC,0
                           ; skip if the port is not set, proceed if the port is set
                           ; clear the 0 digit of the l1 register
   bcf
              l1, 0
*****
; Check functions
*****
regLight_1
   ; check the led register and log the info onto the l* register
   ; the l* register already cleared if the light is present
   btfsc
              LED, 1 ; skip if the 1st bit not set, set l* register otherwise
              l1, 1
   bsf
                     ; skip if the 2nd bit not set, set l* register otherwise
   btfsc
              LED, 2
   bsf
              l1, 2
              LED, 3
                     ; skip if the 2nd bit not set, set l* register otherwise
   btfsc
   bsf
              l1, 3
   return
```

Figure 9.2.4.2. Code for manipulating data storage

Also, to minimize the time used in operation, when the spot is empty, the most time consuming A/D conversion phase is skipped.



Figure 9.2.4.3. Schematic of storing data in memory

9.2.5 Display the information of qualified operation

At the end of each operation, the LCD display would display the information of: time used in the operation, number of light and status of presence of the operation and the functionality of lights. The result reading is done by checking the bits of L1 to L9 registers (discussed above). Working flow accompany with the code for displaying message is provided below.



Figure 9.2.5.1. Flow of assessing L register

| ;******<br>; Displ<br>;****** | *******<br>ay macro<br>******** | ***************************************             | ;*****<br>; Writ<br>;***** | ************************************** | ************************************** |
|-------------------------------|---------------------------------|-----------------------------------------------------|----------------------------|----------------------------------------|----------------------------------------|
| Display                       | macro                           | Message                                             | WR_DATA                    |                                        |                                        |
|                               | local                           | Loop_                                               | bsf                        | RS                                     |                                        |
|                               | local                           | ena_                                                | movwt                      | dat                                    |                                        |
|                               | CLIT                            | Table_Counter                                       | movt                       | dat,w                                  |                                        |
| 1                             | CLTW                            | Table Country H                                     | andlw                      | ØXFØ                                   |                                        |
| LOOD_                         | MOVT                            | Table_Counter,w                                     | addlw                      | 4                                      |                                        |
|                               | call                            | Message                                             | movwf                      | PORTD                                  |                                        |
|                               | xorlw                           | B'00000000'; check WORK reg to see if 0 is returned | bsf                        | E                                      | ;                                      |
|                               | bttsc                           | STATUS, Z                                           | call                       | lcdLongDelay                           | ;                                      |
|                               | goto                            | end_                                                | bcf                        | E                                      | ; [_]                                  |
|                               | call                            | WR_DATA                                             | swapf                      | dat,w                                  |                                        |
|                               | incf                            | Table_Counter,F                                     | andlw                      | 0xF0                                   |                                        |
|                               | goto                            | loop_                                               | addlw                      | 4                                      |                                        |
| end_                          |                                 |                                                     | movwf                      | PORTD                                  |                                        |
|                               | endm                            |                                                     | bsf                        | E                                      | ;                                      |
|                               |                                 |                                                     | call                       | lcdLongDelay                           | ;                                      |
|                               |                                 |                                                     | bcf                        | E                                      | ; [_]                                  |
|                               |                                 |                                                     | return                     |                                        |                                        |

Figure 9.2.5.2. Code to write to screen

As can see in the code, the display module uses a table entry for data, write it separately in a loop to display whole messages.

9.2.6 Real Time Clock

A DS1307 real time clock chip with a 3 (V) battery forms the basis of the real time clock function. The microcontroller communicates to the chip by the I<sup>2</sup>C communication protocol on I/O ports **PORTC**<**3:4**>. The specifications of the DS1307 chip are given in the **Appendix**. The real time module provides two functions: provide real time and act as timer.

The real time clock is initialized to the real time at it is first programmed. Then with the additional power supply, it runs regardless of the power of the board. When used as a timer, the time stamp is recorded at the beginning of each operation cycle. After the whole cycle is done, another stamp is recorded. The time elapsed of the operation is the difference between the two stamps. Furthermore, by converting the number into ASCII code, it is able to output the number onto the screen.



Figure 9.2.6.1. Algorithm of Real Time Clock

```
; Setup RTC with time defined by user
set_rtc_time
      rtc_resetAll
                    ; reset rtc
      rtc_set 0x00,
                    B'10000000'
      ;set time
      rtc_set 0x06,
                    B'00010100'
                                 ; Year
                                 ; Month
      rtc_set 0x05,
                    B'00000010'
      rtc_set 0x04,
                    B'00101000'
                                 ; Date
      rtc_set 0x03,
                    B'00000001'
                                 ; Day
      rtc_set 0x02,
                                 ; Hours
                    B'00010011'
                    B'00100101'
                                 ; Minutes
      rtc_set 0x01,
      rtc_set 0x00,
                    B'00110000'
                                 ; Seconds
      return
```

Figure 9.2.6.2. Time setting of RTC, which is only needed once before battery runs out

| chec | kTimeElapsed | d             |                                           |
|------|--------------|---------------|-------------------------------------------|
|      | ; first chee | ck the minute | e by subtract them                        |
|      | clrf tota    | alSecond      | ; init the register                       |
|      | ;Get minute  |               |                                           |
|      |              |               |                                           |
|      | rtc_read     | 0x01          | ;Read Address 0x01 from DS1307min         |
|      | movfw        | 0x78          | ; minute right now                        |
|      | movwf        | Temp          |                                           |
|      | movfw        | minute        | ; minute read when starting in W          |
|      | subwf        | Temp, w       | ; place the result in w                   |
|      | call         | multiplyByTe  | en                                        |
|      | call         | multiplyByS:  | ix : time the minute by 60 -> second in W |
|      | movwf        | totalSecond   |                                           |
|      |              |               |                                           |
|      | : calculate  | second        |                                           |
|      | rtc read     | 0×00          | : read the seconds                        |
|      | movfw        | 0x77          | : 10digit to w                            |
|      | movwf        | Temp          | , iouigit to w                            |
|      | movfw        | tenSecond     |                                           |
|      | subwf        | Temp W        | · place the result in w                   |
|      | call         | multinlyByTe  |                                           |
|      | adduf        | totalSocond   |                                           |
|      | auuwi        | LOLA LSECONU, | , '                                       |
|      | movfw        | 0x78          | : 10digit to w                            |
|      | movwf        | Temp          | ,                                         |
|      | movfw        | oneSecond     |                                           |
|      | subwf        | Temp W        | · place the result in w                   |
|      | adduf        | totalSecond   | f                                         |
|      | audwi        | tota iseconu, |                                           |
|      | recurn       |               |                                           |

Figure 9.2.6.3. Algorithm of getting time from RTC

## 9.2.7 Permanent log

The purpose of permanent log function is to keep long-term record for future reference. The registers provided in the PIC microcontroller lost its information stored when the power is cut. However, the EEPROM module would record the information even after the power is cutoff and even returned on because of its special structure. The EEPROM on the PIC16F877 chip is a 16\*16 memory array, with each trunk of 2-bit hexadecimal data. The data structure we utilize the EEPROM is displayed as follows, this table represent one row of the memory space within EEPROM

| 0                                                | 1  | 2  | 3  | 4  | 5  | 6  | 7  | 8  | 9  | А  | B-F |
|--------------------------------------------------|----|----|----|----|----|----|----|----|----|----|-----|
| NR                                               | L1 | L2 | L3 | L4 | L5 | L6 | L7 | L8 | L9 | TS | N/A |
| Table 1.3.7. Schematics of data stored in EEPROM |    |    |    |    |    |    |    |    |    |    |     |

NR: Number of operation, from 0 to 15 ideally

TS: Total seconds used during operation

After one operation cycle is done, the EEPROM write module is called to write all 9 L registers data into the EEPROM. While there is a need to read from the EEPROM, the values of 9 L registers is load back to the 9 registers for the generic L registerchecking module (see **Figure 9.2.5.1** for detail). The working flow is displayed below.



Figure 9.2.7.1. Method of writing to EEPROM

```
; REEPROM module
writeEEPROM
   ; you have to set the EADDR register yourslef in the code
   ; you have to set the EDATA by yourself
   banksel
              EECON1
   bsf
              STATUS, RP1
   bsf
              STATUS, RP0
                            ; bank3
   btfsc
              EECON1, WR
                            ; wait for write to finish
   goto
              $-1
   banksel
              EEADR
   bcf
              STATUS, RP1
                            ; bank2
   movf
              EADDR, W
   movwf
              EEADR
   movf
              EDATA, W
   movwf
              EEDATA
              STATUS, RP1
   bsf
                            ; bank3
   bcf
              EECON1, EEPGD
   bsf
              EECON1, WREN
              INTCON, GIE
   bcf
   movlw
              0x55
   movwf
              EECON2
   movlw
              0xAA
   movwf
              EECON2
              EECON1, WR
   bsf
   bsf
              INTCON, GIE
   btfsc
              EECON1, WR
                            ; wait for write to finish
   goto
              $-1
   banksel
              PORTA
   return
```

Figure 9.2.7.2. Code for writing to EEPROM



Figure 9.2.7.3. Method of reading from EEPROM

# 9.2.8 PC interface

The PC interface serves as a easy of recording the information on PC. IT utilizes the Universal Synchronous Asynchronous Receiver Transmitter module provided on the PIC16F877 chip. The communication occurs at a baud rate of 9600 bits per second, with 8 bits of data transferred serially through the RS232 port on the DevBugger board. HyperTerminal is required on target computer to act as the receiver as well as the decoder of the data.

#### 9.2.9 Future Improvement

There is no perfect written code and actually there are a lot improvement can be made to the microcontroller code we have.

#### 9.2.9.1 Division of functions in different modules

The style of code we have in this project is only one main file that contains all the code needed. However, the code is hard to debug and do maintenance to, for its unneeded complexity. Sometimes it is simply hard to look for the snippet desired in the file that has over 2000 lines of code. So the first improvement will be separate the code into different files.

Also, as can see from the code provided in the **Appendix**, every function of manipulating L registers is copied 9 times to accommodate the need for each of the registers (like the address, performance counter, etc.). Writing the functions generically can do another improvement. By saying

"Generic", one mean there will be only one function to handle the operation on 9 L registers. By assigning specific address to L registers in CBlocks, one can access the registers by referring to its address. The generic L register modules can take in that address as a parameter and directly control the register. This will reduce the code to 1/9 of its original size and improve efficiency.

#### 9.2.9.2 Motor control

According to the design, a powerful 12 (V) driven DC motor is used to turn the lights ready for inspection on and off. The method being used right now is just assigning digital signal to the H-bridge and delay for a certain amount of time. However, due to the unpredictability of DC motors, the stop position cannot be controlled perfectly. Once the DC motor runs over position, the gears start to wear out. Improvement on this part will be introducing interrupt service accompany IR beam cut sensors. Once the IR beam is cut, the interrupt flag is raised and thus the microcontroller can stop the motor at its most

optimized position. This improvement not only reduces the ware of the system but also provide better performance in terms of turning the lights on and off.

### 9.2.9.3 Data structure optimization

The data encoding used in the project is always one hot, ie the representation is setting only one of the bits in the however long binary string. This is good for simplifying the code checking the binary value but it is very inefficient. The reason is that in an 8-bit binary number, only 8 pieces of information can be recorded. However, if the encoding follows the conventional binary number, 256 values can be encoded. That is a big difference. In other words, the information stored in the L registers can actually be stored in only one register. Also, in the EEPROM data memory, we stored about 40 one hot coded binary number, consuming one-sixth space provided in the EEPROM. If the efficient encoding is used, we can use only  $4 \sim 10$  memory spots for the same amount data. The efficient storage method can significantly reduces the space needed for storing data. In later development, compared to the method that is current using, this method can extend the data space to a large extent.

# 10. Circuit Subsystem

## 10.1 Problem Assessment

Circuits behave like a linkage between the PIC microcontroller and the electromechanical. The responsible for circuity part can be summarized as:

## 10.1.1 Sensor System

Design light sensing circuit and presence sensing circuit, which detect external condition variations and transfer into voltage variations. The voltage variation outputs can be regarded as digital or analog signals. The output signals are sent to PIC to analyze.

10.1.2 Power Supply

Provide noise-free, stable power to all electronic pieces including sensors, actuators, and microcontrollers.

### 10.1.3 Actuator Driving Circuit

Force the machine parts or the candlelight switches to move dynamically.

10.1.4 Cable management and Safety Ensured

Properly manage the wires to make the machine portable, stable and no potential electric shock hazards.

10.1.5 Emergency stop

In advance, implement an emergency STOP button to cease all operations as long as the STOP button pressed. All dynamical parts will stop immediately expect the PIC, the power of PIC is independent of effect of Emergency STOP.

# 10.2 Solution

10.2.1 Light Sensing Circuitry:



Figure 10.2.1.1. circuit (photodiode)





Figure 10.2.2.1. Photodiode BPW34

Light sensing circuits are powered by 5V supply.

We selected photodiode BPW34 as our sensing devices to detect candlelights intensity. Compared with the circuit for phototransistor, though price of photodiode (\$1.5) is higher than phototransistor (\$1.2), the photodiode circuit as a whole is much simpler and cheaper. And the shape for photodiodes is square, which is easy to immobile.

LM358 operational amplifiers were applied to magnify output voltages to an detectable magnitude for PIC. When there is a non-flicker always-on candlelight, the output voltage will be around 3.3V. If it is flickering, the voltage ranges from 2.4V to 3.2V.Light sensing circuits were fabricated and soldered according to figure

#### 10.2.1.2 BPW34 photodiodes can detect lighting intensity:

The resistance of photodiode varies with the changing of amount of light cast on it. Locating the candlelight's wick around 0.5 centimeters from the photodiodes, when the candlelight flicker, the output voltage is fluctuating between 2.5V and 3.4V.

Also, the distance from the candlelight's wick to the photodiodes matters. If the distance is 3 centimeters or more, with constantly on candlelight, the voltage is always less than 0.6V--it is too low for PIC to recognize. If around 2 centimeters, the voltage is  $1.2 \sim 2.2$  (V). Only with distance less than 1 centimeter, the output voltage will be large enough. This factor is taken into consideration when we integrate the circuit with electromechanical part.

#### 10.2.1.3 Soldering Board Section to Hold Photodiodes:

Instead of just connecting the photodiodes to jumper wires, placing them on a specific "holder" is more fixed and stable. Hence, we decided to solder them onto soldering board sections. An entire soldering board was cut apart into appropriate size by hand drill. Also, the connecting wires from the board of photodiodes to the main light sensing board are soldered.

Under the implementation of soldering board as the "holder", the relative position between the photodiode and the candlelights is identical among all 9 sensors.



Figure 10.2.1.2. Photodiode soldered onto a soldering board section 10.2.1.4 Color Coded Wires:

In this circuit, for the wires connecting between photodiodes and main circuit board, the black wires denotes the anodes for photodiodes BPW34 which will be connected to the ground, while the red for cathode, connecting to the non-inverting input of LM358 Chip.

On the main circuit board, the white wire is supposed to connect to 5V voltage power supply and the black one is to ground. All blue wires are signal outputs from photodiodes, and they will be sent to PIC as analog signals.



Figure 10.2.1.3. Photodiode wire color coded

10.2.2 Presence Sensing Circuity:

10.2.2.1



**Figure 10.2.1.1.** circuit (microswitch) Functionality:

Presence sensing circuits are powered by 5V supply. Microswitches take advantages because they requires less about the accuracy of postion, compared with IR sensor, which emitter and collector must be "face-towards-face" or it will not work. Besides, higher than 4V voltage are always regarded as digital signal 1 by microcontroller. The microswitches output changes from 0V to 5V when get pressed. Implementation of NAND gates renders the output signal non-bounce.



Figure 10.2.2.1. microswitch

### 10.2.2.2 Color Coded Wires:

In this circuit, for the wires connecting between microswitches and main circuit board, the colorful wires is connected port 1 to ground, while yellow wires connects port 2 to 2 denoted in the microswitch circuit. Similarly, purple wires connects port 3 to 3.

On the main microswitch circuit board, the white wire is supposed to connect to 5V voltage power supply and the black one is to ground. All blue wires are signal outputs from microswitch, and they will be sent to PIC as digital signals.

10.2.3 Actuator Driving Circuit



Figure 10.2.3.1. Bipolar H-Bridge Circuit

# 10.2.3.1 Functionality

H-Bridge circuit is powered by 12V DC voltage, and the direction control signal is given by PIC.

It is designed to actuate DC motor for candlelights switching system.

10.2.3.2 Color Coded Wires:

The yellow wires are supposed to connect to PIC. They are the controlling signals inputs. And wires colored blue are connected to poles of DC motor. According to our convention, white wire is connected to 12V +Vcc, and black one to ground.

10.2.4 Power Supply






10.2.5 Emergency Stop and Power Line Board





Figure 10.2.5.2. emergency stop and power board

#### 10.2.5.1 Functionality

The purpose of power board as well as Emergency STOP board is to manage all power inputs and guarantee common ground of all circuits. Two  $2 \times 20$  sockets are installed to allow power output from power board. The red line on upper part of the board is 5V power line and the lower one is 12V. Blue line denotes common ground and the orange wire connects both ground lines together.

The red line is from ATX12V power supply and it provides 5V, similarly, the yellow one is 12V. (As we noted before, the power supply output wires are color coded)Purple lines connects the board to port 1 and 2 of microswitch on both sides, and the orange lines connects to port 3. When all operations going on, meaning the emergency stop is OFF, port 1 and port 2 are connected while port 3 is open. The power outputs from power supply are connected to 5V/12V power lines to power all parts of robot except PIC. (PIC is connected to 12V from power supply directly. Therefore, even the emergency stop turns on, the PIC still works and LCD can display message such as "Emergency!")

When emergency stop on, port 1 is connected to port 3.

## 10.2.5.2 Emergency STOP button Selection



**Figure 10.2.5.3.** Emergency stop button The maximum current allowance for emergency button we selected is 6A. (big enough)

As measured by multimeter, the current from two microswitch board are usually 0.12A and 0.25A respectively. And current from light sensing board are 0.23A in total. The current from H-bridge driving circuit is 0.4A usually. From all information about current indicated above, the total amount of current through the button is always less than 1A; thus the button selected always works in safety.

#### 10.2.6 Signal Selection through implementation of multiplexer

#### 10.2.6.1 Functionality

As PIC16 input ports are not enough for 9 analog signals and 9 digital signals from sensing Circuit plus one more digital signal input from Emergency STOP board, two CD4067BE multiplexers are applied in our circuitry. One for selecting nine digital signals from microswitch presence sensing circuit, and the other for analog signals from photodiode light sensing circuit.

Sockets are installed to facilitate the signal input for multiplexers. The port we selected in utility is 2 to 10 as labeled clearly on the side of sockets.

## 10.2.6.2 Color Coded Wires

Selection signals inputs are denoted by yellow and labelled. The output signals from multiplexers are both blue with tape labeling "Microswitch" or "Light". Also, as convention, the ground is denoted by black wire while power input white wire.

#### 10.2.7 Protect Integrated Circuit/PIC

In general, buffers are applied to current protect. It transfer a voltage from a first circuit, which has a high output impedance level, to a second circuit with a low input impedance. The interposed buffer amplifier protects the second circuit from loading the first circuit unacceptably and interfering with its desired operation.

In our robot, all voltages designed in the circuit are accorded with every electronic components data sheet and they can work safely. So for protection of IC and PIC, we focus on the current part. Corresponding to the principle of electromagnetic, if two chips connected, the current between them will negotiate by themselves; thus there is no hazard.

In our circuit, all signal outputs from sensing circuits are sent to 16-to-1 multiplexer for selection. For photodiode circuit, the output is from LM358, an operational amplifier chip. While for microswitch circuit, it is from 74HC00, a NAND logic gate. According to those, all connections are chip-to-chip. The current itself will negotiate. The working safety of circuit is guaranteed even without any buffers.For the signals sent to PIC microcontroller after selection in multiplexer, this a chip-to-chip connection, the current will be restricted in safety range. We dont need any buffers in this part.

# 10.2.8 Wire Management

All wires are color coded as we stated above.



Figure 10.2.8.1. Color coded wires and labeled wires

Besides, we labeled all wires with white tapes. In particular, for blue output wires, "M" denotes microswitch, and "L" denotes light sensor. Moreover, connecting wires are tied together to make our circuit neat and tidy.

Power supply output lines are cut, stripped, and soldered to our power board (Emergency STOP board) for stability, since connecting by jumper wires are unstable and jumpers wires are tend to burn out easily when a little large current through it.

10.2.9 Suggestions for Improvement of the subsystem:

10.2.9.1 Replace H-bridge with Integrated Circuit L298N:

Taken into account economy and portability factors, it would be better if we can replace H-bridge with L298 IC. L298 is much lighter than H-bridge and also takes less room. Meanwhile, L298 IC costs less than we complete a H-bridge circuit. Fabricating a H-bridge circuit, we need a soldering board(\$3), 4 transistors (\$1.5 each), 4 diodes (0.5 each), and some resistors (price negligible), which means at least \$11 in total. Compare with L298, whose price is around \$8, it is obvious the latter is a better alternative.

#### 10.2.9.2 2.9.2 Microswitch Circuit:

We chose the microswitch circuit without bouncing when gets pressed. Compared the circuit with the one with bouncing, it needs one more NAND gate. We can simplify the circuit by replacing non-bouncing microswitch with the bouncing one. It wont influence our detect results as the bouncing time is very short and the PIC is not sensitive to that short-time variation. However, the problem of bouncing circuit is that the connection from the output of microswitch to multiplexer is no longer a chip-to-chip connection. Then buffers may be in need to provide current protection.



With the implementation of PCB, overall cost of circuits part can be reduced as well as the space designed for circuit board and the weight of total circuitry. Also, the connecting wires are more manageable with printed circuit board. Currently, the circuit boards design has a priority of modularity. This determines debugging and repairing relatively easy. Moreover, the PCB board has to be designed and fabricated specifically. That may be time-consuming and hard to realize since we only focus on a small project regarding machine.

10.2.9.4 Photodiode to photoresistor:

10.2.9.3



Figure 10.2.9.2. Photoresistor Cicuit

The above scheme is photoresistor circuit. Photoresistor is much simpler and lighter compared with photodiode circuit. Despite that the reaction time is longer and it

works non-linearly, if the reference resistor chosen appropriate, this circuit works as well as the photodiode circuit we used in our design currently.

,

## 11. Integration

Integration and Calibration between Circuit and Electromechanical Components: the integration between circuits and electromechinical components includes functionally integrating photodiodes and microswitches to mechanical structures, and connecting them to circuit boards, connecting motor to actuator driving board, placing and fixing all soldering board onto the machine, and installing human interface elements such as Emergency STOP button.

## 11.1 Photodiode and microswitch:

Photodiodes were soldered onto soldering board sections, and then the soldering board sections are align in order, and glued onto the machine in the fixed relative position towards candlelights. Since the relative positions are nearly same for all nine candlelights, it would be easy for the microcontroller part to set reference voltage. Meanwhile, the microswitches were also glued onto the machine by super glue 502.



Figure. photodiode and microswitch integrated with tray cover

## 11.2 Soldering board allocation

All soldering boards, 5 in total as well as the Devbugger board are placed onto a transparent resin board and fixed by proper screws as a circuity panel. The circuity panel is placed at the back of machine, and it functions as a holder for all circuits as well as a

shelter for closure of machine itself.

#### 11.3 Driving circuit driving actuators:

Motors are connected to driving circuit, like H-bridge, L298 IC circuit to obtain power and control. In our case, the DC motor is connected to the H-bridge driving board on circuity panel, with PIC sending enable digital signals to H-bridge, the motor can successfully rotate forward and in the reverse direction.

## 11.4 Integration and Calibration between Circuit and Microcontrollers

The microcontroller board, namely the Devbugger board is powered by +5V voltage independent of emergency stop button, and it also need to be grounded. The bridge between the bus on Devbugger board and circuit boards is a 40-pin IDE cable. All controlling signals output from bus through this cable to circuits and all detecting signals are collected into the cable then send to the PIC. The main problem between microcontroller part and circuit part is about floating signals. Once a signal sent into PIC is floating, it may influence the whole performance of the PIC. Floating voltage signal is a voltage not connected by any conducting path such as resistors to ground. To avoid unexpected behavior due to floating voltage, all ports not in use are grounded.

# 12. Accomplished Schedule

In this section, the chronological Gantt chart proposed in the project proposal is revisited and reflected upon. As noticed in the project time line, only the electromechanical subsystem followed the preset schedule. Both microcontroller and circuit subsystem member failed to stick to the schedule, owing to the uncertainty associated in the process of integration.





Figure 12. Project accomplished schedule (top), planned schedule (bottom)

# 13. Description of Overall Machine and Operating Procedure

#### 13.1 Basic Feature

Name: Robust Robotics

Dimension:  $30 \text{cm} \times 30 \text{cm} \times 40 \text{ cm}$ 

Weight: 5.5 kg

Cost: \$ 222.75 Canadian dollars

Maximum Candlelights tested in a single run: nine

Operation Time: 8~9 seconds

#### 13.2 Functionality

13.2.1 Operation

Our robot test the functionality of maximum 9 candlelights. All operation takes around 10 seconds. After the tray loaded by candlelights (it is regarded as standby mode), DC motors works to actuate the flipping switching system to open all candlelights. The microswitch goes to detect the presence of candlelights, then the total number of candlelights loaded is displayed on LCD. Afterwards, photodiode light sensing circuit works to test the functionality of existing candlelights. The spot without candlelights will be skipped to ensure efficiency. Once all detection completed, the motor moves in reverse direction to send all parts of machine including the candlelights to standby mode.

#### 13.2.2 Tray and its cover

The three by three tray is served as a platform to hold and fix the candlelights. With the tray cover implemented, it can immobile the candlelights in particular position during operation, which means it prevents horizontal, vertical and rotary movements of candlelights. Two holes at the bottom of the tray are responsible of avoiding horizontal and rotary movements while the tray cover makes sure candlelights not shift vertically.

Microswitches and photodiodes are glued onto the cover of the tray by super glue.

#### 13.2.3 Candlelights Switch System

The switch system of our robot is reliable and simple, also it can avoid jam caused by friction forces during operations. Three parts-- a moveable base plate, mental drawer slide and rack with pinion, compose it. Mental drawer slide works with rack and pinion, and they are driven by motor to remove the moveable base plate forth and back. With the movement of base plate, the wood blocks stuck to the base plate encounter the switches to force them on/off.

#### 13.2.4 Real Time Clock

It can display current time and date in second accuracy on LCD screen and even external power supply cut off, it still works and maintains in right time and date.

#### 13.2.5 2.5 Notification of Emergency STOP ON

When the Emergency STOP on, meaning all operations cease immediately. The message "Emergency!" will be sent to PIC and displayed on LCD screen.



Figure 13.1. Display on LCD screen when emergency stop ON

## 13.3 3.Operating Procedure:

13.3.1 3.1 Operation Messages on LCD screen



The above figures indicate all instructions on LCD and machine working flow.

## 13.3.2 3.2 Before the operation

The machine is normally in standby mode. Load maximum 9 candlelights onto the tray, make sure their positions fixed the holes at the bottom of the tray. Put the tray back to machine, and lock the tray.

Load the candlelights as the picture below instructed:



Figure 13.2 . Instruction for candlelights loading

## 13.3.3 3.3 In process

All operations are autonomous once we start the machine. The entire operation is normally completed within 10 seconds. Upon completion of the operation, a termination message will be displayed on the LCD screen.

## 3.4 After Operation

After all operation, the machine are back to "stand-by" condition, we can unload candlelights from the machine and read the results from LED screen on the left side.

First, the screen displays the total number of candlelights aligned on the tray.

After press any key to continue, it goes to display the testing results in order.

"N" means no candlelights there;

"F" means flicker failure, candlelights are constantly on;

"P" means pass, candlelights flicker;

"L" means LED failure, candlelights are constantly off.

For example, "FLPPNNLPF" on LCD screen means candlelights at port 1 and 9 are constantly on; while ones at port 2 and 7 are constantly off; Candlelights at port 3, 4, 8 functions well while there is no candlelights loaded at port 5 and 6.

# 14. System Issues and Improvements:

## 14.1 Portability

The machine we designed weighs 5.5 kilograms and dimension 30\*30\*40 (in centimeter). It complies with constraints but still too heavy and cumbersome. In order to make it more portable, some lighter material can be chosen to fabricate the frame of our machine and shell of it. In particular, it is higher practical to replace all resin board we used with firm cardboard. In addition, installing wheels underneath the machine is doable. Besides, we have found a smaller and lighter, also cheapter power supply online. It can took place of the one which we currently used.

## 14.2 Toggle Emergency Button SHOULD be changed to pressed one

As mentioned by our TA, push button, compared with toggle one, would be expected to implementing emergency stop. Because if something urgent and really dangerous happens, pressing a button on is more assessable than toggling one. Taken into account the purpose of emergency stop button, the pushed one is more suitable.



Figure . Push Button in desire

## 14.3 PIC18 replacs PIC 16:

Without installation of multiplexer, there will be 19 input signals, of which 9 are analog from photodiode circuit, 9 are digital signals from microswitch circuit and the rest one are digital signal from emergency stop board. Besides, 2 output digital signals are intended to enable and control the H-bridge and the DC motor.

PIC 16 only have eight analog ports, which is not enough without the help of multiplexer. While PIC 18 can be applied to provide enough analog and digital ports with multiplexer required.

Employment of multiplexer helps lower machine budget, reduce the weight of machine as soldering board is rather heavy compared with other components. In addition, owing to the chosen multiplexer is 16 to 1, there are some ports leaving unused, which suggests they need to be grounded to avoid floating voltage effect. This means a lot of extra work and harden debugging. After all, PIC 18 is more suitable than PIC 16 for our design machine.

## **15.** Conclusion

"Robust Robotics" is an autonomous candlelight-testing machine, which was designed and constructed over the past four months. This machine is capable of testing the functionality of at most 9 candlelights in a single run, opening the switches of candlelights, testing, after that turning off the candlelights and returning to the original state. It satisfies all the constraint and requirements stated previously and it can operates reliably throughout the testing process.

The construction of design can be categorized into three: fabrication of the tray, fabrication of switching system, assembly of the sensing system and motor system, and the closure mechanism. Candlelights are loaded onto the tray and once operation starts, switching system driven by DC motor turns on all candlelights except those failing LED (constantly off). Once the candlelights on, the sensing system works to detect the presence of candlelights and distinguish their functionality. The result of each candlelight will be sent to PIC microcontroller one by one. As long as all nine ports information collected, the switching system continues to work, while the motor rotates in reverse direction to turn off all candlelights.

The design performs consistently and it performed two high-qualified runs during public demonstration. It successfully test eight out of nine candlelights functionality except the one loaded at port 5 and displays results onto LED screen after operation accomplished. The total operation time for one run is around 9 seconds, which is under the limitation of 90 seconds.

In addition, "Robust Robotics" also has extra design features, such as real time clock, closure of the design, and it enjoys the potential of extendibility to more than nine candlelights testing. Nevertheless, the design has some issues and some improvement can be made to optimize its performance and functionality. Firstly, the toggle emergency stop button should be changed to push one in order to optimize its functionality when emergency happens. Secondly, the material used to closing all machine can be reselected considering that the machine is not light enough and it is possible to make it more portable. Last but not least, replacing PIC 16 with PIC 18 is practical in order to reduce the number of circuits.

# 16. Reference

[1] M.Reza Emami "Multidiscipline Engineering Design from Theory to Practice", University of Toronto, 2014.

[2] R. Emami, "Aer 201 Lecture Slides," 2014. [Online]. Available: http://sps.aerospace.utoronto.ca/courses/aer201/Pages/LectureNotes.aspx

[3] Digikey, "Digikey," 2014. [Online]. Available: http://www.digikey.ca/

[4] "Most useless machine upgrade," 7 August 2011 . [Online]. Available:http://hackaday.com/2011/08/07/most-useless-machine-upgrade-nowwith-a-button/.

[5] T. Fischer, "Roulette Barrel Gun," 29 November 2011. [Online]. Available: http://upload.wikimedia.org/wikipedia/commons/b/bb/Relais\_Animation.gif. [Accessed 28 Jan 2014].

[6] Creatron Inc., Lilypad Light Sensor. [Online] available: http://www.creatroninc.com/index.php/lilyp-398464.html

[7] [Online]. Available: http://upload.wikimedia.org/wikipedia/commons/b/bb/Relais\_Animation.gif. [Accessed 28 Jan 2014].

[8] Darmawaskita HArtono, Measure light intensity with an 8-bit microcontroller. [Online] available: http://electronicdesign.com/lighting/measure-light-intensity-8bit-microcontroller

[9] Makeblock, Switch Test Machine by using makeblock. [Online] available: https://www.youtube.com/watch?v=35s8QObG7bo

[10] RACK AND PINION GEAR SYSTEMS. [Online] available: http://www.technologystudent.com/gears1/gears4.htm

[11] Rotational Inertia. [Online] available: http://physics.info/rotational-inertia/

[12] WHAT IS TORQUE. [Online] available: http://www.physics.uoguelph.ca/tutorials/torque/Q.torque.intro.html

[13] From Radio Receivers to LED Flashlights: An LED Odyssey. [Online] available: http://www.coastportland.com/blog/receivers-to-led-flashlights-ledodyssey-infographic/

# 17. Appendix

| Assembly code for microcontroller<br>list p=16f877                               | ; list directive to   |  |  |  |  |
|----------------------------------------------------------------------------------|-----------------------|--|--|--|--|
| <pre>define processor     #include <n16f877_inc></n16f877_inc></pre>             | • processor specific  |  |  |  |  |
| variable definitions                                                             |                       |  |  |  |  |
| #include <rtc_macros.inc><br/>CONFIG CP OFF &amp; WDT OFF &amp;</rtc_macros.inc> | BODEN ON & PWRTE ON & |  |  |  |  |
| _HS_OSC & _WRT_ENABLE_ON & _CPD_OFF                                              | & _LVP_OFF            |  |  |  |  |
| ; vaiables for RS232 module                                                      |                       |  |  |  |  |
| offset EQU 0x20<br>temp FOU 0x21                                                 |                       |  |  |  |  |
| sel_0 EQU <b>b'0000'</b>                                                         |                       |  |  |  |  |
| sel_1 EQU <b>b'1000'</b>                                                         |                       |  |  |  |  |
| sel_3 EQU <b>b</b> '1100'                                                        |                       |  |  |  |  |
| sel_4 EQU <b>b'0010'</b>                                                         |                       |  |  |  |  |
| sel_6 EQU <b>b</b> '0110'                                                        |                       |  |  |  |  |
| sel_7 EQU <b>b'0111'</b>                                                         |                       |  |  |  |  |
| Set_o LQU D 0001                                                                 |                       |  |  |  |  |
| cblock 0x22                                                                      |                       |  |  |  |  |
| ; variables to store data                                                        |                       |  |  |  |  |
| l1<br>12                                                                         |                       |  |  |  |  |
| 13                                                                               |                       |  |  |  |  |
| 14                                                                               |                       |  |  |  |  |
| 16                                                                               |                       |  |  |  |  |
| 17                                                                               |                       |  |  |  |  |
| 19                                                                               |                       |  |  |  |  |
| COUNTH                                                                           |                       |  |  |  |  |
| COUNTM                                                                           |                       |  |  |  |  |
| COUNIL<br>Table Counter                                                          |                       |  |  |  |  |
| lcd_tmp                                                                          |                       |  |  |  |  |
| lcd_d1<br>lcd_d2                                                                 |                       |  |  |  |  |
| COM                                                                              |                       |  |  |  |  |

```
dat
       shiftCount
       delayCount
       Temp
       Time
       ; variable for timer
       minute
       tenSecond
       oneSecond
       ; store intermidiate value
       totalSecond
       dig1
       dig10
       LED Counter
       ; variables for adcon
       Threshold ; for the light sensor
                 ; for identifying the behavior
       Counter
       Loop
                 ; count the looping
       LED
                 ; for display infomation on LCD
       ; MUX
       mux
       : EEPROM code
       EADDR
       EDATA
       turn
   endc
   ;Declare constants for pin assignments (LCD on PORTD)
       #define RS PORTD,2
       #define E
                 PORTD, 3
; Display macro
Display macro
              Message
              loop_
       local
       local
              end
       clrf
              Table Counter
       clrw
              Table_Counter,W
       movf
loop_
       call
              Message
```

95

```
xorlw
               B'00000000'; check WORK reg to see if 0 is
returned
               STATUS, Z
       btfsc
               end_
       goto
               WR DATA
       call
               Table Counter, F
       incf
               loop_
       goto
end
       endm
tableAccess macro ENTRY
    bcf STATUS ,C
    movwf Temp
    movlw HIGH ENTRY
    movwf PCLATH
   movf Temp, w
    addlw LOW ENTRY
    btfsc STATUS ,C
       incf PCLATH ,f
    movwf PCL
    endm
        ORG
                  0x0000
                             ;RESET vector must always be
at 0x00
        goto
                  init
                             ;Just jump to the main code
section.
        ORG
                   0x0004 ; the interupt code
interupt
    ; the interupt set when rb0 set to high on emergency
    banksel
               INTCON
           INTCON, INTF; the interupt comes from
    btfss
rb0 changepic1
    goto
            $+4
           INTCON, INTF ; clear the flag
displayEmergency ; and fall into a loop
    bcf
    goto
until another interupt is called
    nop
    btfss PORTB, 0 ; if the portb is set,
meaning emergency, display message
           $-2
    goto
    ; go back work
    goto DisplayOptions
```

```
displayEmergency
   Call
            Clear Display
   Display
            Emergency_msg
   nop
   return
; Delay: ~160us macro
LCD DELAY macro
   movlw
         0xFF
   movwf
         lcd d1
   decfsz lcd d1,f
   goto
         $-1
   endm
; helper functions
shiftLeft macro count
   movlw
         count
         shiftCount
   movwf
   call
         shiftLeft 0
   endm
shiftLeft 0
   Call
        HalfS
         b'00011000'
   movlw
   call
         WR INS
   decfsz shiftCount, f
   goto
         $-4
   return
shiftRight macro count
   movlw
         count
   movwf
         shiftCount
   call
         shiftRight 0
   endm
shiftRight_0
   Call
         HalfS
   movlw
         b'00011100'
   call
         WR INS
   decfsz shiftCount, f
```

goto

\$-4

```
return
```

```
delayForTimeInterval macro time ; time unit: 0.5s
   movlw
          time
   movwf
          delayCount
   call
          delay
   endm
delay
          HalfS
   call
          delayCount, f
   decfsz
   goto
          $-2
   return
BCD_Converter
   CLRF
          dig1
   movwf
          dig1
   clrf
          dig10
   movlw
          0xA
          dig1, F
   subwf
          STATUS, C
   btfss
          Divide_Done
   goto
   incf
          dig10
   goto
          $-4
Divide Done
   addwf
          dig1, F
   movlw
          0x30
          dig10, F
   addwf
   addwf
          dig1, F
   return
; DisplayRS macro
DisplayRS macro Message
       ; the macrofunction to display table message on the
screen
       ; modified from Display
              loopRS
       local
       local
              endRS_
```

```
Table_Counter
       clrf
       clrw
loopRS_
       movf
              Table_Counter,W
       call
              Message
              B'00000000'; check WORK reg to see if 0 is
       xorlw
returned
       btfsc
              STATUS, Z
              endRS
       qoto
              RS Write
       call
              Table_Counter, F
       incf
       goto
              loopRS
endRS_
       endm
; Initialize LCD
init
        ;; setting up the interupt
        banksel
                     INTCON
                     INTCON, GIE
        bsf
        bsf
                     INTCON, INTE ; enable rb0
interrupt
        ;; remember to set b0 as input
        ; +Summury for Pin out
        ; +Last update, Apr9, 1138 UTC
        ;
         ; +A: 8 ports
         ||- RA0:5 set to ADC function
         ||- All 6 are input, pass through ADC
         ||- T0D0:
        ;
         +B: 8 ports
        ; ||- RB7:4, RB1: keyboard input
         ||- RB0,2,3 ----> Interupt function
         ||- TODO: N/A
        ; |
        ; +C: 8 ports
```

|           | ;   - RC0: light number check<br>;   - RC3:4: RTC<br>;   - RC5:7, 2:1: Free -> RC7,6,2,1 for mux1<br>;   - TODO: |                                                                           |                           |  |  |  |  |
|-----------|------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------|---------------------------|--|--|--|--|
|           | ; +D: 8 ports<br>;   - RD7:2: LCD<br>;   - RD1:0: Motor                                                          |                                                                           |                           |  |  |  |  |
|           | ;   - Not used                                                                                                   |                                                                           |                           |  |  |  |  |
|           | banksel<br>movlw<br>movwf<br>clrf<br>clrf<br>clrf<br>clrf<br>clrf                                                | PORTA<br><b>b</b> '0000010'<br>ADCON1<br>PORTA<br>PORTB<br>PORTC<br>PORTD | ; set up the adcon1       |  |  |  |  |
|           | banksel                                                                                                          | TRISA                                                                     |                           |  |  |  |  |
| inputs    | movlw<br>movwf<br>movlw<br>movwf                                                                                 | <b>b'000111'</b><br>TRISA<br><b>b'11111111'</b><br>TRISB                  | ; Set required keypad     |  |  |  |  |
|           | movlw<br>movwf                                                                                                   | <b>b'00100001'</b><br>TRISC                                               |                           |  |  |  |  |
|           | clrf<br>clrf<br>bsf                                                                                              | TRISD<br>TRISE<br>TRISE, 1                                                | ; All port D is output    |  |  |  |  |
|           | ; initaiate the l* variables<br><b>call</b> setInitialValueForLightResigters                                     |                                                                           |                           |  |  |  |  |
| in lcd.as | banksel<br>call<br>sm; importe<br>call<br>call                                                                   | PORTA<br>initRTC<br>ed by lcd.inc)<br>InitLCD<br>initRS                   | ;Initialize the LCD (code |  |  |  |  |

| goto                                                                                     | Main                                                                                                                                                        |  |
|------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| ;*************************************                                                   | **************                                                                                                                                              |  |
| ;*************************************                                                   | *****************                                                                                                                                           |  |
| <b>Call</b><br>Display<br>delayForT:                                                     | Clear_Display<br>Welcome_Msg<br>imeInterval 4                                                                                                               |  |
| DisplayOptions<br><b>call</b><br>Display<br><b>call</b><br>Display                       | Clear_Display<br>Menu_1<br>Switch_Lines<br>Menu_2                                                                                                           |  |
| ;shiftLef <sup>.</sup><br>movlw<br>call                                                  | t h'03'<br><b>b'0000010'</b><br>WR_INS                                                                                                                      |  |
| KeyInputDetection                                                                        |                                                                                                                                                             |  |
| <b>btfss</b> PORTB,1 ;Wait until data is available from the keypad                       |                                                                                                                                                             |  |
| goto<br>btfsc<br>goto<br>btfsc<br>goto<br>btfsc<br>goto<br>btfsc<br>goto<br>goto<br>goto | <pre>PORTB,1 ;Wait until key is released<br/>\$-1<br/>PORTB,7<br/>C_PRESSED<br/>PORTB,6<br/>B_PRESSED<br/>PORTB,5<br/>A_PRESSED<br/>KeyInputDetection</pre> |  |
| A_PRESSED                                                                                |                                                                                                                                                             |  |
| btfss<br>goto                                                                            | PORTB,4<br>KeyInputDetection                                                                                                                                |  |
| call                                                                                     | setInitialValueForLightResigters                                                                                                                            |  |
| ; read the<br>rtc_read<br><b>movfw</b><br><b>movwf</b><br>rtc_read                       | e RTC initial input<br>0x01<br>0x78<br>minute<br>0x00                                                                                                       |  |

0x77 movfw movwf tenSecond movfw 0x78 movwf oneSecond ; PORTD,0 ff, PORTD,1 ; motor control rev call Clear\_Display Display Motor\_fwd\_msg call Motor\_On\_Forward ;delayForTimeInterval 6 call Motor Off **DisplayOptions** ;goto ; check the spot call Clear Display Display Spoting Msg call Switch Lines call checkMicroswitch ; it gets all spot checking done! call Clear\_Display : check the number call Check\_number ; check the functionality Clear Display call Display Light Checking msg call Switch Lines "1" movlw call WR DATA call selectMux 1 call Set\_Value

**b**'01010100' movlw ;5\*153/255 = 3v is the reference value for the light sensor threshold ; use 192 3.75v Threshold movwf btfss l1, 0 call Convert AD call regLight 1 "2" movlw call WR DATA call selectMux 2 call Set\_Value ;5\*153/255 = 3v is the movlw **b**'01010010' reference value for the light sensor threshold ; use 192 3.75v Threshold movwf 12, 0 btfss Convert AD call call regLight\_2 าวา movlw call WR DATA call selectMux 3 call Set Value ;5\*153/255 = 3v is the movlw **b**'01011000' reference value for the light sensor threshold ; use 192 3.75v Threshold movwf btfss 13, 0 call Convert\_AD call regLight 3 "4" movlw call WR DATA call selectMux 4 call Set Value

movlw **b**'01011000' ;5\*153/255 = 3v is the reference value for the light sensor threshold ; use 192 3.75v movwf Threshold btfss 14, 0 call Convert AD call regLight\_4 "5" movlw call WR\_DATA call selectMux 5 call Set Value movlw **b**'01111000' ;5\*153/255 = 3v is the reference value for the light sensor threshold ; use 192 3.75v Threshold movwf ; **15**, 0 btfss Convert AD call call regLight\_5 "6" movlw call WR DATA call selectMux\_6 call Set\_Value **b**'01011000' movlw ;5\*153/255 = 3v is the reference value for the light sensor threshold ; use 192 3.75v movwf Threshold **16**, 0 btfss call Convert AD call regLight\_6 "7" movlw call WR\_DATA call selectMux 7 call Set Value

movlw **b**'01010000' ;5\*153/255 = 3v is the reference value for the light sensor threshold ; use 192 3.75v movwf Threshold ; btfss 17, 0 call Convert AD call regLight 7 "8" movlw call WR DATA call selectMux 8 call selectMux 8 call Set Value movlw **b**'01011000' ;5\*153/255 = 3v is the reference value for the light sensor threshold ; use 192 3.75v movwf Threshold btfss **18**, 0 call Convert\_AD call regLight 8 "Q" movlw call WR\_DATA call selectMux 9 call Set\_Value **b**'01011000' movlw Threshold movwf btfss 19, 0 call Convert AD call regLight\_9 ; turn the lights back off Clear\_Display call Motor\_rev\_msg Display call Motor\_On\_Reverse call shortDelay call shortDelay call Motor\_Off

|         | ; time calcu | lation                     |           |           |
|---------|--------------|----------------------------|-----------|-----------|
|         | call         | checkTimeElapsed           | : time    | stored in |
| dia10.  | dia1         |                            |           |           |
|         | movfw        | totalSecond                |           |           |
|         | call         | BCD Converter              |           |           |
|         | call         | Clear Display              |           |           |
|         | Call         |                            |           |           |
|         |              |                            |           |           |
|         | ee11         | Clean Dicplay              |           |           |
|         |              |                            |           |           |
|         | ;DISPLAY     | Done_Msg                   |           |           |
|         | Display      | lime_Done_Msg ;            | display t | ine "time |
| used: % | a s"         |                            |           |           |
|         | movtw        | dig10                      |           |           |
|         | call         | WR_DATA                    |           |           |
|         | movfw        | digl                       |           |           |
|         | call         | WR_DATA                    |           |           |
|         | Display      | Time_Done2_Msg             |           |           |
|         | call         | Switch_Lines               |           |           |
|         | Display      | Done_2                     |           |           |
|         | goto         | RESULTS                    |           |           |
|         |              |                            |           |           |
| B_PRESS | ED           |                            |           |           |
|         |              |                            |           |           |
|         | movfw        | totalSecond                |           |           |
|         | call         | BCD_Converter              |           |           |
|         | call         | Clear_Display              |           |           |
|         | ;Display     | Done_Msg                   |           |           |
|         | Display      | <pre>Time_Done_Msg ;</pre> | display t | he "time  |
| used: % | d s"         |                            |           |           |
|         | movfw        | dig10                      |           |           |
|         | call         | WR_DATA                    |           |           |
|         | movfw        | dig1                       |           |           |
|         | call         | WR_DATA                    |           |           |
|         | Display      | Time_Done2_Msg             |           |           |
|         | call         | Switch_Lines               |           |           |
|         | Display      | Done 2                     |           |           |
| cal     | L RESL       | JLTS                       |           |           |
|         |              |                            |           |           |
| C_PRESS | ED           |                            |           |           |
|         | btfsc        | PORTB,6                    |           |           |
|         | goto         | KeyInputDetection          |           |           |
|         | btfss        | PORTB, 5                   |           |           |
|         | goto         | KeyInputDetection          |           |           |
|         | btfss        | PORTB, 4                   |           |           |
|         | goto         | KeyInputDetection          |           |           |

goto show RTC Motor On Forward bsf PORTD, 0 call shortDelay ;call shortDelay call Motor Off return Motor On Reverse bsf PORTD, 1 return Motor\_Off ; tune PORTD, 0 bcf PORTD, 0 return Check number banksel PORTA clrf LED Counter btfss l1, 0 ; skip if the 0 bit of l1 is set, add counter otherwise LED Counter incf btfss l2, 0 ; skip if the 0 bit of l2 is set, add counter otherwise incf LED Counter btfss 13, 0 ; skip if the 0 bit of l3 is set, add counter otherwise LED\_Counter incf ; skip if the 0 bit of l4 is btfss l4, 0 set, add counter otherwise incf LED Counter btfss 15,0 ; skip if the 0 bit of 15 is set, add counter otherwise LED\_Counter incf ; skip if the 0 bit of 16 is btfss 1<mark>6,</mark> 0 set, add counter otherwise incf LED Counter btfss 17,0 ; skip if the 0 bit of 17 is set, add counter otherwise LED Counter incf ; skip if the 0 bit of 18 is btfss 18, O set, add counter otherwise incf LED\_Counter

; skip if the 0 bit of 19 is btfss 19,0 set, add counter otherwise incf LED Counter return Check\_function call Convert AD Display Status Msg movfw LED call WR DATA return RESULTS ; ?check?? call Check number btfss PORTB,1 ;Wait until jsondata is available from the keypad qoto \$-1 PORTB,1 btfsc ;Wait until key is released \$-1 aoto call Clear Display Switch Lines ;call ; display the number of lights ; P57 on notebook Display Ouantitv movfw LED Counter call BCD Converter movfw dia1 call WR DATA ;; display specfic data call Switch Lines ; call logMicroswitch ; ;; delay ; delayForTimeInterval 6 btfss ;Wait until jsondata is PORTB,1 available from the keypad goto \$-1 ;Wait until key is released btfsc PORTB,1
goto \$-1 call Clear Display ; display behavior Clear\_Display call Status Msg Display Switch Lines call call logLights btfss ;Wait until jsondata is PORTB,1 available from the keypad goto \$-1 btfsc PORTB,1 ;Wait until key is released \$-1goto call Clear\_Display ;; ;; testing the rs code here ;; ;DisplayRS Status Msg delayForTimeInterval ; 6 call Clear\_Display DisplayOptions goto ; Look up table Welcome Msg tableAccess Welcome\_log Welcome log dt "Team 67 tester", 0 Menu\_1 tableAccess Menu log 2 Menu\_log\_2 dt "<A> Start", 0 Menu 2 tableAccess Menu log Menu\_log dt "<B> Log <C>:Time", 0 Spoting\_Msg tableAccess Spoting log Spoting\_log dt "Checking Spot", 0

Time\_Msg tableAccess Time log Time log dt "Return in 1 seconds", 0 Time Done Msg tableAccess Time Done log Time\_Done\_log dt "Time used: ", 0 Time\_Done2\_Msg tableAccess Time\_Done2\_log Time\_Done2\_log dt "s", 0 Status Msg tableAccess Status log Status\_log dt "Light status: ", 0 Done 2 tableAccess Done\_2\_log Done 2 log dt "<Any key> Result", 0 Quantity tableAccess QualityLog OualityLog dt "Lights: ", 0 Quality\_light\_good tableAccess QualityGoodLightLog QualityGoodLightLog dt "Flashlight1:", 0 Light\_Checking\_msg tableAccess Light Checking log Light Checking\_log dt "Checking Light ", 0 Motor\_fwd\_msg tableAccess Motor\_fwd\_log Motor fwd log dt "Turning on", 0 Motor\_rev\_msg

```
tableAccess Motor_rev_log
Motor_rev_log
   dt "Turning off", 0
Emergency_msg
   tableAccess Emergency log
Emergency_log
   dt "Emergency!", 0
Reset msg
   tableAccess Reset_log
Reset_log
   dt "Reset!", 0
; LCD control
Switch Lines
      movlw
            B'11000000'
      call
            WR INS
      return
Clear Display
      movlw
            B'0000001'
      call
            WR INS
      return
; Delay 0.5s
HalfS
   local HalfS 0
    movlw 0x88
    movwf COUNTH
    movlw 0xBD
    movwf COUNTM
    movlw 0x03
    movwf COUNTL
HalfS_0
    decfsz COUNTH, f
    goto
         $+2
    decfsz COUNTM, f
         $+2
    goto
    decfsz COUNTL, f
```

```
goto
             HalfS_0
      goto $+1
      nop
      nop
        return
shortDelay
    local
            shortDelay_0
      movlw 0x28
      movwf COUNTH
      movlw 0x5
      movwf COUNTM
      movlw 0x3
      movwf COUNTL
shortDelay_0
      decfsz COUNTH, f
      goto $+2
      decfsz COUNTM, f
      goto
           $+2
      decfsz COUNTL, f
      goto shortDelay_0
      goto $+1
      nop
      nop
        return
AD_Delay
    local AD Delay 0
      movlw 0x88
      movwf COUNTH
      movlw 0x0C
      movwf COUNTM
      movlw 0x01
                          ;12d38,77112 1E1F
                                               11a0
      movwf COUNTL
AD_Delay_0
      decfsz COUNTH, f
      goto
             $+2
      decfsz COUNTM, f
             $+2
      goto
      decfsz COUNTL, f
```

```
goto
            AD_Delay_0
     goto $+1
     nop
     nop
       return
0neS
       local
               0neS_0
     movlw 0x10
     movwf COUNTH
     movlw 0x7A
     movwf COUNTM
     movlw 0x06
     movwf COUNTL
OneS 0
   banksel
               PORTB
     decfsz COUNTH, f
     goto
            $+2
     decfsz COUNTM, f
     goto
            $+2
     decfsz COUNTL, f
     goto
            OneS 0
     goto $+1
     nop
     nop
       return
;****** LCD-related subroutines ******
    InitLCD
   bcf STATUS, RP0
   bsf E ; E default high
    ;Wait for LCD POR to finish (~15ms)
   call lcdLongDelay
   call lcdLongDelay
   call lcdLongDelay
   ;Ensure 8-bit mode first (no way to immediately
guarantee 4-bit mode)
```

```
; -> Send b'0011' 3 times
   movlw
          b'00110011'
   call
          WR INS
   call lcdLongDelay
   call lcdLongDelay
          b'00110010'
   movlw
   call
          WR INS
   call lcdLongDelay
   call lcdLongDelay
   ; 4 bits, 2 lines, 5x7 dots
   movlw
          b'00101000'
   call
          WR INS
   call lcdLongDelay
   call lcdLongDelay
   ; display on/off
          b'00001100'
   movlw
   call
          WR INS
   call lcdLongDelay
   call lcdLongDelay
   ; Entry mode
   movlw
          b'00000110'
   call
          WR INS
   call lcdLongDelay
   call lcdLongDelay
   ; Clear ram
   movlw
          b'00000001'
   call
          WR INS
   call lcdLongDelay
   call lcdLongDelay
   return
   ;ClrLCD: Clear the LCD display
ClrLCD
   movlw
          B'0000001'
   call
          WR INS
   return
   ; Write command to LCD - Input : W , output : -
   *****
WR INS
```

```
bcf
           RS
                           ;clear RS
                           ;W --> com
   movwf
           com
   andlw
           0xF0
                           ;mask 4 bits MSB w = X0
   movwf
           PORTD
                           ;Send 4 bits MSB
   bsf
           E
                           ;
           lcdLongDelay
   call
                           ;___
   bcf
                                      ; [__]
           E
   swapf
           com,w
   andlw
           0xF0
                           ;1111 0010
   movwf
           PORTD
                           ;send 4 bits LSB
   bsf
           E
                                      ;
   call
           lcdLongDelay
                           ;___
   bcf
           Е
                                      ;
                                        call
           lcdLongDelay
   return
    *****
   ; Write data to LCD - Input : W , output : -
    *****
WR DATA
           RS
   bsf
   movwf
           dat
   movf
           dat,w
   andlw
           0xF0
   addlw
           4
   movwf
           PORTD
   bsf
           E
                           ;
   call
           lcdLongDelay
                           ;____
   bcf
                                      ;
           E
                                        swapf
           dat,w
   andlw
           0xF0
   addlw
           4
           PORTD
   movwf
   bsf
           E
           lcdLongDelay
   call
                                      ;
   bcf
                                        E
   return
lcdLongDelay
   movlw h<sup>'</sup>20'
   movwf lcd_d2
LLD LOOP
   LCD DELAY
   decfsz lcd d2,f
   goto LLD LOOP
   return
```

; Initilization of both LCD and RTC initRTC ;Set SDA and SCL to high-Z first as required for I2C STATUS, RP0 bsf bsf TRISC,4 TRISC,3 bsf ; select bank 0 bcf STATUS, RP0 ;Set up I2C for communication call i2c\_common\_setup ;rtc resetAll ;Used to set up time in RTC, load to the PIC when RTC is used for the first time ;call set rtc time return show\_RTC Clear\_Display call ;Get year "2" ;First line shows movlw 20\*\*/\*\*/\*\* WR DATA call "0" movlw call WR DATA :Read Address 0x06 from rtc read 0x06 DS1307---year movfw 0x77 call WR DATA 0x78 movfw WR\_DATA call "/" movlw call WR DATA ;Get month :Read Address 0x05 from rtc read 0x05 DS1307---month

0x77 movfw call WR DATA movfw 0x78 call WR DATA "/" movlw call WR DATA ;Get day rtc read ;Read Address 0x04 from 0x04 DS1307---day movfw 0x77 call WR DATA movfw 0x78 call WR\_DATA ;Next line displays movlw **B'11000000'** (hour):(min):(sec) \*\*:\*\*:\*\* call WR INS ;Get hour ;Read Address 0x02 from rtc\_read 0x02 DS1307---hour movfw 0x77 call WR\_DATA movfw 0x78 call WR DATA 0.10 movlw call WR DATA ;Get minute rtc\_read ;Read Address 0x01 from 0x01 DS1307---min movfw 0x77 call WR DATA movfw 0x78 call WR DATA  $0 \neq 0$ movlw call WR\_DATA ;Get seconds ;Read Address 0x00 from rtc\_read 0x00 DS1307---seconds movfw 0x77 call WR DATA 0x78 movfw

## call WR\_DATA

call OneS ;Delay for exactly one
seconds and read DS1307 again

goto DisplayOptions

> rtc resetAll ;reset rtc rtc\_set 0x00, **B'10000000'** ;set time rtc set 0x06, **B**'00010100' ; Year rtc\_set 0x05, **B'**00000100' ; Month rtc\_set 0x04, **B'00001000'** ; Date rtc\_set 0x03, **B'00000010'** ; Day ; Hours rtc\_set 0x02, **B**'00000100' rtc\_set 0x01, **B'01010101'** ; Minutes **B'00110000'** rtc set 0x00, : Seconds return

```
; Delay 0.01s
ShortDelav
  local
        ShortDelay 0
    movlw 0x88
    movwf COUNTH
    movlw 0x0B
    movwf COUNTM
    movlw 0x00
    movwf COUNTL
ShortDelay_0
    decfsz COUNTH, f
    goto
        $+2
```

```
decfsz COUNTM, f
goto $+2
decfsz COUNTL, f
goto HalfS_0
goto $+1
nop
nop
return
```

```
; time calculation
```

```
multiplyByTen
```

| movwf  | Temp  |   |
|--------|-------|---|
| addwf  | Temp, | 1 |
| movfw  | Temp  |   |
| return |       |   |

```
multiplyBySix
```

| movwf  | Temp  |   |
|--------|-------|---|
| addwf  | Temp, | 1 |
| movfw  | Temp  |   |
| return |       |   |

| che  | ckTimeElap<br>; first c<br><b>clrf</b> t<br>;Get minu | sed<br>heck the minute<br>otalSecond<br>te | e by subtract them<br>; init the register |
|------|-------------------------------------------------------|--------------------------------------------|-------------------------------------------|
|      | _rtc_read                                             | 0×01                                       | ;Read Address 0x01 from DS1307            |
| ——m: | ın<br><b>movf</b> w                                   | 0×78                                       | ; minute right now                        |

| \a/                  | movwf<br>movfw                                              | Temp<br>minute ; minute read when starting in                                                                                    |
|----------------------|-------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|
| vv                   | subwf                                                       | Temp, w ; place the result in w                                                                                                  |
| 60 -                 | <pre>call call -&gt; second in movwf</pre>                  | <pre>multiplyByTen multiplyBySix ; time the minute by W totalSecond</pre>                                                        |
|                      | ; calculate<br>rtc_read<br>movfw<br>movwf<br>movfw<br>subwf | <pre>second<br/>0x00 ; read the seconds<br/>0x77 ; 10digit to w<br/>Temp<br/>tenSecond<br/>Temp, w ; place the result in w</pre> |
|                      | call<br>addwf                                               | multiplyByTen<br>totalSecond, f                                                                                                  |
|                      | movfw<br>movwf                                              | 0x78 ; 10digit to w                                                                                                              |
|                      | movfw<br>subwf<br>addwf<br>return                           | oneSecond<br>Temp, w ; place the result in w<br>totalSecond, f                                                                   |
| ;**><br>; Ar<br>;**> | k*************<br>halog digita<br>k****************         | **************************************                                                                                           |
| com                  | banksel<br>call                                             | ADCON0<br>Set_Value<br>b'11010001' use BA2                                                                                       |
|                      | movew<br>movwf<br>call<br>:movlw                            | ADCON0<br>AD_CONV<br>b'00000000'                                                                                                 |
| ;;;                  | ;xorwf<br>btfss                                             | ADRESH, W<br>ADRESH, 7 ; if the msb of adresh is                                                                                 |
| 0, 1                 | test the 6th                                                | digit                                                                                                                            |
| ;<br>;               | ;btfss                                                      | ADRESH, 6 ; if the 5th digit is zero                                                                                             |
| nonz                 | zero, set 1                                                 |                                                                                                                                  |
| ÷                    | ;btfss                                                      | SIAIUS, Z                                                                                                                        |
| ;                    | yoro<br>movlw                                               | ₽⊤4<br>"0" : light off or empty                                                                                                  |
| ;                    | movwf                                                       | LED                                                                                                                              |
| ;                    | goto                                                        | ENDLP                                                                                                                            |

| <pre>movlw b'11000111';<br/>xorwf Counter, W<br/>htfss STATUS 7</pre> |
|-----------------------------------------------------------------------|
| xorwf Counter, W<br>htfss STATUS 7                                    |
| htfss STATUS 7                                                        |
| SCI33 STRICS, Z                                                       |
| goto \$+4                                                             |
| <pre>movlw b'0010' ;"2" ; constant light on</pre>                     |
| movwf LED                                                             |
| aoto \$+10: aoto nop                                                  |
| movlw b'0000001':                                                     |
| <b>xorwf</b> Counter, W                                               |
| https STATUS, 7                                                       |
| aoto \$+4                                                             |
| movlw <b>b</b> '0100' · "1" · constant light off                      |
| mover LED                                                             |
|                                                                       |
| $p_{10}$ $p_{10}$ $p_{10}$ $p_{10}$ $p_{10}$ $p_{10}$                 |
| mover LED                                                             |
|                                                                       |
| , goto LINDEP                                                         |
|                                                                       |
|                                                                       |
| recurn                                                                |
| ;ENDLP<br>; movfw LED<br>; call WR_DATA<br>; goto ENDLP               |
| AD CONV                                                               |
| <b>bsf</b> ADCON0. GO :start conversion and                           |
| wait for it to complete                                               |
| btfsc ADCON0.GO                                                       |
| aoto \$-1                                                             |
| movf ADRESH W                                                         |
| <pre>subwf Threshold. W :x/5*1023</pre>                               |
| <b>btfss</b> STATUS. C :C = 0. threshold > w                          |
| aoto \$+2                                                             |
| qoto \$+3                                                             |
| decf Counter F                                                        |
| <b>aoto</b> \$+2                                                      |
| incf Counter, F                                                       |
| call AD Delav :HalfS                                                  |
| <b>movlw b'01100010'</b> : should be 49                               |
| xorwf Loop. W                                                         |
| btfss STATUS. 7                                                       |
| aoto \$+2                                                             |
| <b>aoto</b> \$+3                                                      |

|                                           | incf<br>goto<br>return                     | Loop, F<br>AD_CONV                                    |                                               |
|-------------------------------------------|--------------------------------------------|-------------------------------------------------------|-----------------------------------------------|
| Set_Valı                                  | ue<br>movlw                                | h'01100100'                                           | counter start from 50                         |
| and inc                                   | reament or<br>movwf                        | decreament<br>Counter                                 |                                               |
|                                           | ; the refe                                 | erence is set to                                      | o individual light                            |
|                                           | movlw<br>movwf<br>movlw<br>movwf<br>return | <b>b</b> '00000000'<br>Loop<br><b>b</b> '0000'<br>LED |                                               |
| ;*******<br>; RS232<br>;*******<br>initRS | ***********<br>PC interfa<br>********      | **************************************                | *******<br>*****                              |
|                                           | bsf<br>clrf                                | STATUS,RP0<br>TRISD                                   | ; select bank 1                               |
| 10MHz os                                  | ;Setup USA<br>movlw<br>scillator           | ART for RS232<br>d'15'                                | ; BAUD rate 9600, assuming                    |
|                                           | clrf                                       | TXSTA                                                 | ; 8 bits data ,no,1 stop                      |
| enable                                    | bcf<br>bsf                                 | STATUS, RPØ<br>RCSTA, SPEN                            | ; select bank 0<br>; Asynchronous serial port |
|                                           | bsf                                        | STATUS, RP0                                           | ; select bank 1                               |
| ;*****                                    | return<br>**** Send v<br>bcf<br>clrf       | velcome message<br>STATUS,RP0<br>offset               | **************************************        |

# RS\_Write

; move anything into W, single charactor and log it onto the screen

```
qoto
                   $
       movwf
                TXREG
                             ; Send contents of W to
RS232
                            ; Go to bank with TXSTA
       bsf
                STATUS, RP0
       btfss
                TXSTA,1
                             ; check TRMT bit in TXSTA
(FSR) until TRMT=1
       goto
                $-1
                STATUS, RP0
                            ; Go back to bank 0
       bcf
       return
;******** Table containing welcome message
*****
TAB
   tableAccess TAB_log
TAB log
   dt "Team 67_tester", 0
; Integrating function
******
; TODO: 1. Code for microswitch checking
; TODO: 2. Light sensor ----> 3cm: 2v
; TODO: 3. Logging
; LOGGING
setInitialValueForLightResigters
              b'0001'; LSB: 0001 as initial value:
   movlw
constant off light
   movwf
              l1
              12
   movwf
              13
   movwf
              14
   movwf
              15
   movwf
   movwf
              16
   movwf
              ι7
   movwf
              18
              19
   movwf
   clrf
              Threshold
   return
```

: Mux control selectMux ; select the input port using the signal provided in W ; selectionSignal: 1001 ; RB023, RC5 as selecion -> RC5, RB3, RB2, RB0 ; TODO: select RC as output, in init section ; setting the selection ; if the selectionSignal = 0000, needed to clear the bit first ; bcf STATUS, RP0 bsf STATUS, RP1 ; select bank 1 ; banksel TRISC TRISC, 7 bcf TRISC, 6 bcf bcf TRISC, 2 bcf TRISC, 1 STATUS, RP0 bcf ; bcf STATUS, RP1 ; select bank 0 ; PORTC banksel PORTC, 7 bcf PORTC, 6 bcf bcf PORTC, 2 bcf PORTC, 1 PORTB, 2 ;bcf PORTB, 0 ;bcf ;delayForTimeInterval 4 btfsc mux, 3 PORTC, 7 bsf btfsc mux, 2 bsf PORTC, 6 btfsc mux, 1 PORTC, 2 bsf btfsc mux, 0 PORTC, 1 bsf

## return

| selectMux_1<br>movlw<br>movwf<br>call<br>return | <b>b'0100'</b><br>mux<br>selectMux |
|-------------------------------------------------|------------------------------------|
| selectMux_2<br>movlw<br>movwf<br>call<br>return | <b>b'1100'</b><br>mux<br>selectMux |
| selectMux_3<br>movlw<br>movwf<br>call<br>return | <b>b'0010'</b><br>mux<br>selectMux |
| selectMux_4<br>movlw<br>movwf<br>call<br>return | <b>b'1010'</b><br>mux<br>selectMux |
| selectMux_5<br>movlw<br>movwf<br>call<br>return | <b>b'0110'</b><br>mux<br>selectMux |
| selectMux_6<br>movlw<br>movwf<br>call<br>return | <b>b'1110'</b><br>mux<br>selectMux |
| selectMux_7<br>movlw<br>movwf<br>call<br>return | <b>b'0001'</b><br>mux<br>selectMux |
| selectMux_8                                     |                                    |

```
b'1001'
   movlw
   movwf
              mux
   call
               selectMux
   return
selectMux 9
              b'0101'
   movlw
   movwf
              mux
   call
               selectMux
   return
******
: Check microswitches
checkMicroswitch
   ; RC0 is for checking the presence of the led lights
   ; by switching the selection signal of the mux, read
the port
   ; register the status on l* registers
   ; 0001 no light
   ; 0000 wait for further inspection of function
              TRISC
   banksel
   bsf
              TRISC, 0
   banksel
              TRISB
   bsf
              TRISB, 2
   banksel
               PORTC
    bcf
               PORTC, 0
;
    check spot 1
              b'0000'
   movlw
   movwf
              mux
   call
               selectMux
   call
               selectMux 1
              "1"
   movlw
   call WR DATA
   call
               AD_Delay; shortDelay
   btfsc
               PORTC,0
                             ; skip if the port is not
set, proceed if the port is set
   bcf
               l1, 0
                              ; clear the 0 digit of the
l1 register
```

```
; check spot 2
                PORTC, 0
                            ; clear portc to prevent
    bcf
interference
   movlw
                b'1000'
    movwf
                mux
    call
                selectMux
    call
                selectMux 2
                "2"
    movlw
    call WR DATA
    call
               AD_Delay; shortDelay
    btfsc
                PORTC,0
                                ; skip if the port is not
set, proceed if the port is set
   bcf
                l2, 0
                                ; clear the 0 digit of the
ll register
    ; check spot 3
                PORTC, 0
    bcf
    movlw
                b'0100'
    movwf
                mux
   call
                selectMux
    call
                selectMux 3
                "3"
    movlw
    call WR DATA
    call
                AD_Delay; shortDelay
    btfsc
                PORTC,0
                                ; skip if the port is not
set, proceed if the port is set
    bcf
                13, 0
                               ; clear the 0 digit of the
ll register
    ; check spot 4
                PORTC, 0
    bcf
                b'1100'
    movlw
    movwf
                mux
    call
                selectMux
    call
                selectMux_4
                "4"
    movlw
    call WR_DATA
               AD Delay; shortDelay
    call
                                ; skip if the port is not
    btfsc
                PORTC.0
set, proceed if the port is set
```

```
14, 0
    bcf
                                 ; clear the 0 digit of the
l1 register
    ; check spot 5
                PORTC, 0
    bcf
                b'0010'
    movlw
    movwf
                mux
    call
                selectMux
    call
                selectMux 5
                "5"
    movlw
    call WR DATA
    call
                AD Delay; shortDelay
    btfsc
                PORTC,0
                                 ; skip if the port is not
set, proceed if the port is set
    bcf
                15, 0
                                 ; clear the 0 digit of the
l1 register
    banksel
                PORTB
    ; check spot 6
                PORTC, 0
    bcf
    movlw
                b'1010'
    movwf
                mux
    call
                selectMux
    call
                 selectMux_1 ;selectMux_6
                "6"
    movlw
    call WR DATA
    call
                AD Delay; shortDelay
    btfsc
                PORTB, 3
                                 ; skip if the port is not
set, proceed if the port is set
                16, 0
    bcf
                                 ; clear the 0 digit of the
l1 register
    ; check spot 7
                PORTC, 0
    bcf
    movlw
                b'0110'
    movwf
                mux
    call
                selectMux
                 selectMux_2 ;selectMux_7
    call
                "7"
    movlw
    call WR DATA
    call
                AD Delay; shortDelay
```

```
PORTB, 3
    btfsc
                                 ; skip if the port is not
set, proceed if the port is set
    bcf
                l7, 0
                                ; clear the 0 digit of the
l1 register
     ;check spot 8
    bcf
                PORTC, 0
                b'0111'
    movlw
    movwf
                mux
    call
                selectMux
    call
                 selectMux 3 ;selectMux 8
                "8"
    movlw
    call WR DATA
    call
                AD_Delay; shortDelay
                                ; skip if the port is not
    btfsc
                PORTB, 3
set, proceed if the port is set
    bcf
                18, 0
                                ; clear the 0 digit of the
ll register
    ; check spot 9
                PORTC, 0
    bcf
                b'0001'
    movlw
    movwf
                mux
    call
                selectMux
    call
                 selectMux 4
                               ;selectMux_9
                "9"
    movlw
    call WR DATA
    call
                AD Delay; shortDelay
    btfsc
                PORTB, 3
                                 ; skip if the port is not
set, proceed if the port is set
    bcf
                19, 0
                                ; clear the 0 digit of the
l1 register
    ; needed to clear up the mux selection
                b'0000'
    movlw
    movwf
                mux
    call
                selectMux
    call
                selectMux 1
    call
                Clear Display
    return
```

| logMicroswitch |        |   |      |    |       |    |         |
|----------------|--------|---|------|----|-------|----|---------|
| btfsc          | l1, 0  | ; | skip | if | l1,0  | is | cleared |
| (present),     |        |   |      |    |       |    |         |
| call           | write0 |   |      |    |       |    |         |
| btfss          | l1, 0  |   |      |    |       |    |         |
| call           | write1 |   |      |    |       |    |         |
| nop            |        |   |      |    |       |    |         |
| btfsc          | l2, 0  | ; | skip | if | l1,0  | is | cleared |
| (present),     |        |   |      |    |       |    |         |
| call           | write0 |   |      |    |       |    |         |
| btfss          | l2, 0  |   |      |    |       |    |         |
| call           | write1 |   |      |    |       |    |         |
| btfsc          | l3, 0  | ; | skip | if | l1,0  | is | cleared |
| (present),     |        |   |      |    |       |    |         |
| call           | write0 |   |      |    |       |    |         |
| btfss          | l3, 0  |   |      |    |       |    |         |
| call           | write1 |   |      |    |       |    |         |
| nop            |        |   |      |    |       |    |         |
| btfsc          | l4, 0  | ; | skip | if | l1,0  | is | cleared |
| (present),     |        |   |      |    |       |    |         |
| call           | write0 |   |      |    |       |    |         |
| btfss          | l4, 0  |   |      |    |       |    |         |
| call           | write1 |   |      |    |       |    |         |
| nop            |        |   |      |    |       |    |         |
| btfsc          | l5, 0  | ; | skip | if | l1,0  | is | cleared |
| (present),     |        |   |      |    |       |    |         |
| call           | write0 |   |      |    |       |    |         |
| btfss          | l5, 0  |   |      |    |       |    |         |
| call           | write1 |   |      |    |       |    |         |
| nop            |        |   |      |    |       |    |         |
| btfsc          | l6, 0  | ; | skip | if | l1,0  | is | cleared |
| (present),     |        |   |      |    |       |    |         |
| call           | write0 |   |      |    |       |    |         |
| btfss          | l6, 0  |   |      |    |       |    |         |
| call           | write1 |   |      |    |       |    |         |
| nop            | _      |   |      | _  | _     |    | _       |
| btfsc          | 17, 0  | ; | skip | if | l1,0  | is | cleared |
| (present),     |        |   |      |    |       |    |         |
| call           | write0 |   |      |    |       |    |         |
| btfss          | l7, 0  |   |      |    |       |    |         |
| call           | writel |   |      |    |       |    |         |
| nop            | 10 5   |   |      |    | 1.4.5 |    |         |
| bttsc          | ι8, 0  | ; | skip | 1† | ι1,0  | 15 | cleared |
| (present),     |        |   |      |    |       |    |         |
| call           | write0 |   |      |    |       |    |         |

| btfss<br>call<br>non                                                   | l8 <b>, 0</b><br>write1                |                   |                    |                      |                 |     |
|------------------------------------------------------------------------|----------------------------------------|-------------------|--------------------|----------------------|-----------------|-----|
| btfsc                                                                  | l9, 0                                  | ; ski             | p if l1,           | 0 is cle             | eared           |     |
| call<br>btfss                                                          | write0<br>l9 <b>,</b> 0                |                   |                    |                      |                 |     |
| call<br>nop<br>return                                                  | write1                                 |                   |                    |                      |                 |     |
| write1<br>movlw<br>call<br>return                                      | "1"<br>WR_DATA                         |                   |                    |                      |                 |     |
| write0<br>movlw<br>call<br>return                                      | <mark>"0"</mark><br>WR_DATA            |                   |                    |                      |                 |     |
| ;*************************************                                 | ************************************** | ******            | *****              |                      |                 |     |
| ;*************************************                                 | *******                                | ******            | ******             |                      |                 |     |
| ; check the register                                                   | led regist                             | er and            | log the            | info ont             | to the          | l*  |
| ; the l* represent                                                     | gister alre                            | ady cle           | ared if            | the ligh             | nt is           |     |
| <b>btfsc</b><br>l* register oth                                        | LED, 1 ;<br>erwise                     | skip if           | the 1st            | bit not              | t set,          | set |
| bsf<br>btfsc                                                           | l1, 1<br>LED, 2 ;                      | skip if           | the 2nd            | bit not              | t set,          | set |
| l* register oth                                                        | erwise<br>l1, 2                        | okin if           | the Jud            | bit pod              |                 | cot |
| l* register oth<br>bsf<br>return                                       | erwise<br>l1, 3                        | SKIP II           | the zha            | DIL NOU              | L Set,          | set |
| <pre>regLight_2     ; check the register     ; the l* re present</pre> | e led regist<br>gister alre            | er and<br>ady cle | log the<br>ared if | info ont<br>the ligh | to the<br>nt is | l*  |
| p. 000110                                                              |                                        |                   |                    |                      |                 |     |

```
btfsc
                LED, 1
                       ; skip if the 1st bit not set, set
l* register otherwise
    bsf
                l2, 1
    btfsc
                LED, 2
                        ; skip if the 1st bit not set, set
l* register otherwise
    bsf
                l2, 2
                LED, 3
    btfsc
                       ; skip if the 1st bit not set, set
l* register otherwise
    bsf
                l2, 3
    return
regLight 3
    ; check the led register and log the info onto the l*
register
    ; the l* register already cleared if the light is
present
    btfsc
                LED, 1 ; skip if the 1st bit not set, set
l* register otherwise
    bsf
                l3, 1
    btfsc
                LED, 2
                       ; skip if the 1st bit not set, set
l* register otherwise
                l3, 2
    bsf
                       ; skip if the 1st bit not set, set
    btfsc
                LED, 3
l* register otherwise
    bsf
                13, 3
    return
regLight 4
    ; check the led register and log the info onto the l*
register
    ; the l* register already cleared if the light is
present
                LED, 1 ; skip if the 1st bit not set, set
    btfsc
l* register otherwise
                l4, 1
    bsf
                LED, 2 ; skip if the 1st bit not set, set
    btfsc
l* register otherwise
    bsf
                14, 2
    btfsc
                LED, 3
                       ; skip if the 1st bit not set, set
l* register otherwise
    bsf
                14, 3
    return
regLight 5
    ; check the led register and log the info onto the l*
register
```

```
; the l* register already cleared if the light is
present
                LED, 1 ; skip if the 1st bit not set, set
    btfsc
l* register otherwise
    bsf
                l5, 1
    btfsc
                LED, 2
                       ; skip if the 1st bit not set, set
l* register otherwise
    bsf
                l5, 2
    btfsc
                LED, 3
                       ; skip if the 1st bit not set, set
l* register otherwise
    bsf
                l5, 3
    return
regLight 6
    ; check the led register and log the info onto the l*
register
    ; the l* register already cleared if the light is
present
    btfsc
                LED, 1
                       ; skip if the 1st bit not set, set
l* register otherwise
                l6, 1
    bsf
    btfsc
                LED, 2
                        ; skip if the 1st bit not set, set
l* register otherwise
    bsf
                16, 2
    btfsc
                LED, 3
                        ; skip if the 1st bit not set, set
l* register otherwise
    bsf
                16, 3
    return
regLight 7
    ; check the led register and log the info onto the l*
register
    ; the l* register already cleared if the light is
present
                LED, 1 ; skip if the 1st bit not set, set
    btfsc
l* register otherwise
    bsf
                l7, 1
                LED, 2 ; skip if the 1st bit not set, set
    btfsc
l* register otherwise
    bsf
                17, 2
    btfsc
                LED, 3
                       ; skip if the 1st bit not set, set
l* register otherwise
    bsf
                17, 3
    return
regLight_8
```

```
; check the led register and log the info onto the l*
register
    ; the l* register already cleared if the light is
present
   btfsc
               LED, 1 ; skip if the 1st bit not set, set
l* register otherwise
   bsf
               l8, 1
   btfsc
               LED, 2
                      ; skip if the 1st bit not set, set
l* register otherwise
               18, 2
   bsf
               LED, 3
   btfsc
                      ; skip if the 1st bit not set, set
l* register otherwise
   bsf
               18, 3
   return
regLight 9
    ; check the led register and log the info onto the l*
register
    ; the l* register already cleared if the light is
present
               LED, 1 ; skip if the 1st bit not set, set
   btfsc
l* register otherwise
   bsf
               l9, 1
   btfsc
               LED, 2
                      ; skip if the 1st bit not set, set
l* register otherwise
   bsf
               19, 2
               LED, 3
                      ; skip if the 1st bit not set, set
   btfsc
l* register otherwise
   bsf
               19, 3
   return
; Result checking
******
checkLog
               RESULTS
       call
       delayForTimeInterval 6
       qoto
               DisplayOptions
logLight 1
    ; provide the logging funcion of reading and parsing
each l* register
               l1, 0
   btfsc
               "N"
   movlw
   btfsc
               l1, 1
               πĽņ
   movlw
```

```
l1, 2
    btfsc
                 "F"
    movlw
    btfsc
                 l1, 3
                 ייםיי
    movlw
    call WR DATA
    return
logLight_2
    ; provide the logging funcion of reading and parsing
each l* register
    btfsc
                   12, 0
                 "N"
    movlw
                   l2, 1
    btfsc
                 nj n
    movlw
    btfsc
                 l2, 2
    movlw
                l2, 3
"P"
    btfsc
    movlw
    call WR_DATA
   return
logLight_3
    ; provide the logging funcion of reading and parsing
each l* register
    btfsc
                   13, 0
                 "N"
    movlw
    btfsc
                  l3, 1
                 ոլու
    movlw
                13, 2
"F"
    btfsc
    movlw
                13, 3
"P"
    btfsc
    movlw
    call WR_DATA
   return
logLight 4
    ; provide the logging funcion of reading and parsing
each l* register
                   14, 0
    btfsc
                 "N"
    movlw
    btfsc
                  l4, 1
                 ոլու
    movlw
                14, 2
    btfsc
    movlw
    btfsc
                  l4, 3
                 пЪп
    movlw
```

```
call WR_DATA
   return
logLight 5
    ; provide the logging funcion of reading and parsing
each l* register
                   15, 0
    btfsc
                 "N"
    movlw
    btfsc
                  l5, 1
                 ոլու
    movlw
    btfsc
                   l5, 2
                 <sup>U</sup>E<sup>U</sup>
    movlw
                   l5, 3
    btfsc
                 ייםיי
    movlw
    call WR_DATA
   return
logLight 6
    ; provide the logging funcion of reading and parsing
each l* register
                   16, 0
    btfsc
                 "N"
    movlw
    btfsc
                   l6, 1
                 ուո
    movlw
    btfsc
                   16, 2
                 "F"
    movlw
    btfsc
                   16, 3
                 пЪп
    movlw
    call WR DATA
   return
logLight 7
    ; provide the logging funcion of reading and parsing
each l* register
    btfsc
                   l7, 0
                 "N"
    movlw
    btfsc
                   l7, 1
                 ոլո
    movlw
    btfsc
                   17, 2
                 n En l
    movlw
                 17, 3
"P"
    btfsc
    movlw
    call WR_DATA
   return
logLight_8
```

```
; provide the logging funcion of reading and parsing
each l* register
   btfsc
                 18, 0
   movlw
               "N"
   btfsc
                 l8, 1
               ոլու
   movlw
   btfsc
                 1<mark>8,</mark> 2
               11 E II
   movlw
   btfsc
                 18, 3
               ייםיי
   movlw
   call WR_DATA
   return
logLight 9
    ; provide the logging funcion of reading and parsing
each l* register
   btfsc
                 19, 0
               "N"
   movlw
   btfsc
                 l9, 1
               ոլու
   movlw
                 19, 2
   btfsc
               u Eu l
   movlw
   btfsc
                19, 3
               пЪп
   movlw
   call WR DATA
   return
logLights
   call
               logLight 1
   call
               logLight 2
   call
               logLight 3
   call
               logLight 4
   call
               logLight_5
   call
               logLight 6
   call
               logLight 7
   call
               logLight 8
   call
               logLight 9
   return
; REEPROM module
writeEEPROM
    ; you have to set the EADDR register yourslef in the
code
```

; you have to set the EDATA by yourself

|      | banksel<br>bsf<br>bsf<br>btfsc<br>goto             | EECON1<br>STATUS, RP1<br>STATUS, RP0<br>EECON1, WR<br>\$-1      | ;; | bank3<br>wait for write to finish |  |
|------|----------------------------------------------------|-----------------------------------------------------------------|----|-----------------------------------|--|
|      | banksel<br>bcf<br>movf<br>movwf<br>movf<br>movf    | EEADR<br>STATUS, RP1<br>EADDR, W<br>EEADR<br>EDATA, W<br>EEDATA | ;  | bank2                             |  |
|      | bsf<br>bcf<br>bsf                                  | STATUS, RP1<br>EECON1, EEPGD<br>EECON1, WREN                    | ;  | bank3                             |  |
|      | bcf                                                | INTCON, GIE                                                     |    |                                   |  |
|      | movlw<br>movwf<br>movlw<br>movwf                   | 0x55<br>EECON2<br>0xAA<br>EECON2                                |    |                                   |  |
|      | bsf<br>bsf                                         | EECON1, WR<br>INTCON, GIE                                       |    |                                   |  |
|      | btfsc<br>goto                                      | EECON1, WR<br>\$-1                                              | ;  | wait for write to finish          |  |
|      | banksel<br><b>return</b>                           | PORTA                                                           |    |                                   |  |
| read | EEPROM<br>; set the EA<br>banksel<br>movf<br>movwf | ADDR to read, out<br>EEDATA<br>EADDR, W<br>EEADR                | pι | ıt data to W                      |  |
|      | banksel<br><b>bsf</b>                              | EECON1<br>EECON1, RD                                            |    |                                   |  |
|      | banksel<br><b>movf</b>                             | EEDATA<br>EEDATA, W                                             |    |                                   |  |

| banksel<br><b>return</b>                                                      | PORTA                                                                     |
|-------------------------------------------------------------------------------|---------------------------------------------------------------------------|
| <pre>loadEEPROM_1 ; set the    movlw    movwf    movlw    movwf    call</pre> | run number<br><b>b'00000001'</b><br>EDATA<br>0x00<br>EADDR<br>writeEEPROM |
| ; set the                                                                     | light parameters                                                          |
| movf                                                                          | l1, W                                                                     |
| movwf                                                                         | EDATA                                                                     |
| movlw                                                                         | 0x01                                                                      |
| movwf                                                                         | EADDR                                                                     |
| call                                                                          | writeEEPROM                                                               |
| movf                                                                          | l2, W                                                                     |
| movwf                                                                         | EDATA                                                                     |
| movlw                                                                         | 0x02                                                                      |
| movwf                                                                         | EADDR                                                                     |
| call                                                                          | writeEEPROM                                                               |
| movf                                                                          | l3, W                                                                     |
| movwf                                                                         | EDATA                                                                     |
| movlw                                                                         | 0x03                                                                      |
| movwf                                                                         | EADDR                                                                     |
| call                                                                          | writeEEPROM                                                               |
| movf                                                                          | l4, W                                                                     |
| movwf                                                                         | EDATA                                                                     |
| movlw                                                                         | 0x04                                                                      |
| movwf                                                                         | EADDR                                                                     |
| call                                                                          | writeEEPROM                                                               |
| movf                                                                          | l5, W                                                                     |
| movwf                                                                         | EDATA                                                                     |
| movlw                                                                         | 0x05                                                                      |
| movwf                                                                         | EADDR                                                                     |
| call                                                                          | writeEEPROM                                                               |
| movf                                                                          | l6, W                                                                     |
| movwf                                                                         | EDATA                                                                     |
| movlw                                                                         | 0×06                                                                      |
| movwf                                                                         | EADDR                                                                     |

```
call
                writeEEPROM
    movf
                 17, W
    movwf
                 EDATA
    movlw
                 0x07
    movwf
                 EADDR
    call
                writeEEPROM
    movf
                 18, W
                 EDATA
    movwf
    movlw
                 80x0
                 EADDR
    movwf
    call
                writeEEPROM
    movf
                 19, W
    movwf
                 EDATA
    movlw
                 0x09
    movwf
                 EADDR
    call
                writeEEPROM
    ; set the time used
                 totalSecond, W
    movf
    movwf
                 EDATA
    movlw
                 0x0A
    movwf
                 EADDR
    call
                writeEEPROM
    ; set the number of lights
                 LED Counter, W
    movf
    movwf
                 EDATA
    movlw
                 0x0B
    movwf
                 EADDR
    call
                writeEEPROM
return
readEEPROM 1
    ; read the registeres, and load into corresponding reg
    ; read turn
    movlw
                 0x00
    movwf
                 EADDR
    call
                 readEEPROM
    movwf
                turn
    ; read lights
    movlw
                 0x01
```

| movwf | EADDR       |
|-------|-------------|
| call  | readEEPROM  |
| movwf | l1          |
| movlw | 0x02        |
| movwf | EADDR       |
| call  | readEEPROM  |
| movwf | l2          |
| movlw | 0x03        |
| movwf | EADDR       |
| call  | readEEPROM  |
| movwf | l3          |
| movlw | <b>0x04</b> |
| movwf | EADDR       |
| call  | readEEPROM  |
| movwf | l4          |
| movlw | 0x05        |
| movwf | EADDR       |
| call  | readEEPROM  |
| movwf | l5          |
| movlw | 0x06        |
| movwf | EADDR       |
| call  | readEEPROM  |
| movwf | l6          |
| movlw | 0x07        |
| movwf | EADDR       |
| call  | readEEPROM  |
| movwf | l7          |
| movlw | 0x08        |
| movwf | EADDR       |
| call  | readEEPROM  |
| movwf | l8          |
| movlw | 0x09        |
| movwf | EADDR       |
| call  | readEEPROM  |
| movwf | l9          |
| movlw | 0×0A        |
| movwf | EADDR       |

| call   | readEEPROM  |  |  |  |  |  |  |
|--------|-------------|--|--|--|--|--|--|
| movwf  | totalSecond |  |  |  |  |  |  |
| movlw  | 0x0B        |  |  |  |  |  |  |
| movwf  | EADDR       |  |  |  |  |  |  |
| call   | readEEPROM  |  |  |  |  |  |  |
| movwf  | LED_Counter |  |  |  |  |  |  |
| return |             |  |  |  |  |  |  |
| END    |             |  |  |  |  |  |  |



High-Voltage Types (20-Volt Rating)

## **CMOS** Analog **Multiplexers/Demultiplexers**

CD4067B and CD4097B CMOS

analog multiplexers/demultiplexers' are digi-tally controlled analog switches having low ON impedance, Ivw OFF leakage current, and internal address decoding. In addition, the ON resistance is relatively constant over the full input-signal range. The CD4067B is a 16-channel multiplexer

with four binary control inputs, A,B,C,D, and

an inhibit input, arranged so that any com-bination of the inputs selects one switch.

The CD4097B is a differential 8-channel multi

plexer having three binary control inputs A, B, C, and an inhibit input. The inputs permit selection of one of eight pairs of switches.

A logic "1" present at the inhibit input turns all channels off.

The CD4067B and CD4097B types are supplied in 24-lead hermetic dual-in-line ceramic packages (F3A suffix), 24-lead dual-in-line

plastic packages (E suffix), 24-lead small-outline packages (M, M96, and NSR

suffixes), and 24-lead thin shrink small-outline

\*When these devices are used as demultiplexers, the channel in/out terminals are the outputs and the common out/in terminals are the inputs.

Recommended Operating Conditions at  $T_A = 25^{\circ}C$  (Unless Otherwise Specified)

For maximum reliability, nominal operating conditions should be selected so that opera-tion is always within the following ranges.

packages (P and PWR suffixes).

Features:

- Low ON resistance: 125 Ω (typ.) over 15 V<sub>p-p</sub> signal-input range for V<sub>DD</sub>-V<sub>SS</sub>=15 V
- CD4067B Single 16-Channel Multiplexer/Demultiplexer CD4097B Differential 8-Channel Multiplexer/Demultiplexer
  - High OFF resistance: channel leakage of  $\pm 10 \text{ pA}$  (typ.) @ VDD-VSS=10 V Matched switch characteristics: RON=5  $\Omega$  (typ.) for VDD-VSS=15 V
  - for VDD-VSS=15 V Very low quiescent power dissipation under all digital-control input and supply conditions: 0.2  $\mu$ W (typ.) @ VDD-VSS=10 V Binary address decoding on chip 5-V, 10-V, and 15-V parametric ratings 100% tested for quiescent current at 20 V Standardized symmetrical output characteristic.

  - characteristics
  - Maximum input current of 1  $\mu$ A at 18 V over full package temperature range; 100 nA at 18 V and 25°C
  - Meets all requirements of JEDEC Tentative Standard No. 138, "Standard Specifications for Description of 'B' Series CMOS Devices"

#### Applications:

Analog and digital multiplexing and demultiplexing
 A/D and D/A conversion

4 I OF IS DECODERS

- CD4067 functional diagram.

CD4067 TRUTH TABLE

000 0000

0 0

с

0 0 1 1 1 0000 -0

9205-249241

Selecte Channe

0

3

7

8

10 11

00 0

N/OUT

15 Ö-

Fig. 1

Signal gating

VDD = 24

# CD4067B, CD4097B Types







I OF 8 DECODERS 3 OUT/IN IN/OL V<sub>DD</sub> = 24 V<sub>SS</sub> = 12 92C5-24980R2

Fig. 2—CD4097 functional diagram.

|    | CD4097 TRUTH TABLE |   |     |                     |  |  |  |
|----|--------------------|---|-----|---------------------|--|--|--|
|    | в                  | с | Inh | Selected<br>Channel |  |  |  |
| X  | х                  | x | 1   | None                |  |  |  |
| 0  | 0                  | 0 | 0   | 0X, 0Y              |  |  |  |
| 1  | 0                  | 0 | 0   | 1X, 1Y              |  |  |  |
| 0  | 1                  | 0 | 0   | 2X, 2Y              |  |  |  |
| 1  | 1                  | 0 | 0   | 3X, 3Y              |  |  |  |
| 0  | 0                  | 1 | 0   | 4X, 4Y              |  |  |  |
| 11 | 0                  | 1 | 0   | 5X, 5Y              |  |  |  |
| 0  | 1                  | 1 | 0   | 6X, 6Y              |  |  |  |
| 1  | 1                  | 1 | 0   | 7X, 7Y              |  |  |  |

Copyright © 2003, Texas Instruments Incorporated

#### Values shown apply to all types except as Min. Max. Units Characteristic

| Supply-Voltage Range<br>(T <sub>A</sub> =Full Package-<br>Temp. Range) | 3   | 18 | v  |
|------------------------------------------------------------------------|-----|----|----|
| Multiplexer Switch Input<br>Current Capability                         | -   | 25 | mA |
| Output Load Resistance                                                 | 100 |    | ·Ω |
|                                                                        |     |    |    |

NOTE:

noted.

NOTE: In certain applications, the external load-resistor current may include both  $V_{DD}$  and signal-line components. To avoid drawing  $V_{DD}$  current when switch current flows into the transmission gate inputs, the voltage drop across the bidirectional switch must not exceed 0.2 wolt (calculated from RON values shown in ELECTRICAL CHARAC-TERNSTICS CHART). No VDD current will flow through RL if the switch current flows into the CD4097.

3-171



# General Purpose Silicon Rectifiers

Voltage: 50 to 1000 V Current: 1.0 A RoHS Device

#### Features

-Low cost construction.

-Fast forward voltage drop.

-Low reverse leakage.

-High forward surge current capability.

-High soldering temperature guarantee: 260 °C/10 seconds, 0.375"(9.5mm) lead length at 5lbs(2.3kg) tension.

#### **Mechanical data**

-Case: transfer molded plastic, DO-41

-Epoxy: UL 94V-0 rate flame retardant

-Polarity: Indicated by cathode band

-Lead: Plated axial lead, solderable per MIL-STD-202E, method 208C

-Mounting position: Any

-Weight: 0.012ounce, 0.33 grams

### Electrical Characteristics (at TA=25 °C unless otherwise noted)

Ratings at 25 °C ambient temperature unless otherwise specified. Single phase, half wave, 60Hz, resistive or inductive load.

For capacitive load derate current by 20%.

| Parameter                                                                                           |                                                 | Symbol | 1N4001<br>-G | 1N4002<br>-G | 1N4003<br>-G | 1N4004<br>-G | 1N4005<br>-G | 1N4006<br>-G | 1N4007<br>-G | Unit |
|-----------------------------------------------------------------------------------------------------|-------------------------------------------------|--------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|------|
| Maximum Repetitive Peak Reverse Voltage                                                             |                                                 | VRRM   | 50           | 100          | 200          | 400          | 600          | 800          | 1000         | V    |
| Maximum RMS Voltage                                                                                 |                                                 | VRMS   | 35           | 70           | 140          | 280          | 420          | 560          | 700          | V    |
| Maximum DC Blocking Voltage                                                                         | aximum DC Blocking Voltage V <sub>DC</sub>      |        | 50           | 100          | 200          | 400          | 600          | 800          | 1000         | V    |
| Maximum Average Forward Rectified Cur<br>0.375"(9.5mm) Lead Length @T <sub>A</sub> =55 °C           | I(AV)                                           | 1.0    |              |              |              |              | А            |              |              |      |
| Peak Forward Surge Current,<br>8.3mS single half sine-wave superimpose<br>rated load (JEDEC method) | IFSM                                            | 30     |              |              |              |              | A            |              |              |      |
| Maximum Instantaneous Forward Voltage @1.0A                                                         |                                                 | VF     | 1.1          |              |              |              |              |              | V            |      |
| Maximum DC Reverse Current at Rated<br>DC Blocking voltage per element                              | T <sub>A</sub> =25 °C<br>T <sub>A</sub> =100 °C | IR     |              |              |              | 5.0<br>50    |              |              |              | μA   |
| Maximum Full Load Reverse Current,full cycle average 0.375"(9.5mm)lead length at TL=75 $^\circ\!C$  |                                                 | IR(AV) | 30           |              |              |              |              | μA           |              |      |
| Typical Junction Capacitance (Note 1)                                                               |                                                 | CJ     | 15           |              |              |              |              | РF           |              |      |
| Typical Thermal Resistance (Note 2) R <sub>BJA</sub>                                                |                                                 | Reja   | 60           |              |              |              |              |              | °C/W         |      |
| Operating Temperature Range                                                                         |                                                 | TJ     | -55 ~ +150   |              |              |              |              | °C           |              |      |
| Storage Ttemperature Range Tsrg                                                                     |                                                 | Тята   | -55 ~ +150   |              |              |              | °C           |              |              |      |

NOTES:

Measured at 1.0MHz and Applied Reverse Voltage of 4.0V DC.
 Thermal Resistance from junction to terminal 6.0mm<sup>2</sup> copper pads to each terminal.

QW-BG013

Comchip Technology CO., LTD.

REV:A Page 1


### **General Purpose Silicon Rectifiers**



Fig.2 Maximum. Non-Repetitive Peak Forward Surge Current

10

Number of Cycles at 60Hz

Fig.4 Typical Reverse Characteristics

20

80 100

Percent of Peak Reverse Voltage (%)

120 140

50 100

5

5=25

8.3mS, single half sine-wave, JEDEC

35

30

25

20

15

10

5

0

10

1.0

0.1

0.01

0

20 40 60

IR, Instantaneous Reverse Current (mA)

1

2

IFSM, Peak Forward Surge Current (A)

Rating and Characteristic Curves (1N4001-G Thru. 1N4007-G)









Fig.5 Typical Junction Capacitance



QW-BG013

REV:A Page 2

Comchip Technology CO., LTD.



#### description/ordering information

The 'HC00 devices contain four independent 2-input NAND gates. They perform the Boolean function  $Y = \overline{A \bullet B}$  or  $Y = \overline{A} + \overline{B}$  in positive logic.

| TA             | PACKA      | GET          | ORDERABLE<br>PART NUMBER | TOP-SIDE<br>MARKING |  |
|----------------|------------|--------------|--------------------------|---------------------|--|
|                | PDIP – N   | Tube of 25   | SN74HC00N                | SN74HC00N           |  |
|                |            | Tube of 50   | SN74HC00D                |                     |  |
|                | SOIC – D   | Reel of 2500 | SN74HC00DR               | HC00                |  |
|                |            | Reel of 250  | SN74HC00DT               |                     |  |
| -40°C to 85°C  | SOP – NS   | Reel of 2000 | SN74HC00NSR              | HC00                |  |
|                | SSOP – DB  | Reel of 2000 | SN74HC00DBR              | HC00                |  |
|                |            | Tube of 90   | SN74HC00PW               |                     |  |
|                | TSSOP – PW | Reel of 2000 | SN74HC00PWR              | HC00                |  |
|                |            | Reel of 250  | SN74HC00PWT              |                     |  |
|                | CDIP – J   | Tube of 25   | SNJ54HC00J               | SNJ54HC00J          |  |
| -55°C to 125°C | CFP – W    | Tube of 150  | SNJ54HC00W               | SNJ54HC00W          |  |
|                | LCCC – FK  | Tube of 55   | SNJ54HC00FK              | SNJ54HC00FK         |  |

#### **ORDERING INFORMATION**

<sup>†</sup> Package drawings, standard packing quantities, thermal data, symbolization, and PCB design guidelines are available at www.ti.com/sc/package.



Please be aware that an important notice concerning availability, standard warranty, and use in critical applications of Texas Instruments semiconductor products and disclaimers thereto appears at the end of this data sheet.

PRODUCTION DATA information is current as of publication date. Products conform to specifications per the terms of Texas Instruments standard warranty. Production processing does not necessarily include testing of all parameters.



Copyright © 2003, Texas Instruments Incorporated On products compliant to MIL-PRF-38535, all parameters are tested unless otherwise noted. On all other products, production processing does not necessarily include testing of all parameters.

1

#### SN54HC00, SN74HC00 **QUADRUPLE 2-INPUT POSITIVE-NAND GATES**

SCLS181E - DECEMBER 1982 - REVISED AUGUST 2003



logic diagram (positive logic)



absolute maximum ratings over operating free-air temperature range (unless otherwise noted)<sup>†</sup>

| Supply voltage range, V <sub>CC</sub>                                                        |                | 0.5 V to 7 V   |
|----------------------------------------------------------------------------------------------|----------------|----------------|
| Input clamp current, $I_{IK}$ (V <sub>I</sub> < 0 or V <sub>I</sub> > V <sub>CC</sub> ) (see | e Note 1)      | ±20 mA         |
| Output clamp current, $I_{OK}$ (V <sub>O</sub> < 0 or V <sub>O</sub> > V <sub>CC</sub>       | ) (see Note 1) | ±20 mA         |
| Continuous output current, $I_O (V_O = 0 \text{ to } V_{CC})$                                |                | ±25 mA         |
| Continuous current through V <sub>CC</sub> or GND                                            |                | ±50 mA         |
| Package thermal impedance, $\theta_{JA}$ (see Note 2):                                       | D package      | 86°C/W         |
|                                                                                              | DB package     | 96°C/W         |
|                                                                                              | N package      | 80°C/W         |
|                                                                                              | NS package     |                |
|                                                                                              | PW package     | 113°C/W        |
| Storage temperature range, T <sub>stg</sub>                                                  |                | -65°C to 150°C |

<sup>†</sup> Stresses beyond those listed under "absolute maximum ratings" may cause permanent damage to the device. These are stress ratings only, and functional operation of the device at these or any other conditions beyond those indicated under "recommended operating conditions" is not implied. Exposure to absolute-maximum-rated conditions for extended periods may affect device reliability.

 The input and output voltage ratings may be exceeded if the input and output current ratings are observed.
 The package thermal impedance is calculated in accordance with JESD 51-7. NOTES:

#### recommended operating conditions (see Note 3)

|                             |                                      |                            | S            | SN54HC00 |           | S       | N74HC0    | 0        |           |
|-----------------------------|--------------------------------------|----------------------------|--------------|----------|-----------|---------|-----------|----------|-----------|
|                             |                                      |                            | MIN          | NOM      | MAX       | MIN     | NOM       | MAX      | UNIT      |
| VCC                         | Supply voltage                       |                            | 2            | 5        | 6         | 2       | 5         | 6        | V         |
|                             |                                      | V <sub>CC</sub> = 2 V      | 1.5          |          |           | 1.5     |           |          |           |
| VIH                         | High-level input voltage             | V <sub>CC</sub> = 4.5 V    | 3.15         |          |           | 3.15    |           |          | v         |
|                             | V <sub>CC</sub> = 6 V                | 4.2                        |              |          | 4.2       |         |           |          |           |
| VIL Low-level input voltage | V <sub>CC</sub> = 2 V                |                            |              | 0.5      |           |         | 0.5       |          |           |
|                             | Low-level input voltage              | V <sub>CC</sub> = 4.5 V    |              |          | 1.35      |         |           | 1.35     | v         |
|                             |                                      | V <sub>CC</sub> = 6 V      |              |          | 1.8       |         |           | 1.8      |           |
| VI                          | Input voltage                        |                            | 0            |          | VCC       | 0       |           | VCC      | V         |
| VO                          | Output voltage                       |                            | 0            |          | VCC       | 0       |           | VCC      | V         |
|                             |                                      | V <sub>CC</sub> = 2 V      |              |          | 1000      |         |           | 1000     |           |
| Δt/Δv                       | Input transition rise/fall time      | V <sub>CC</sub> = 4.5 V    |              |          | 500       |         |           | 500      | ns        |
|                             |                                      | V <sub>CC</sub> = 6 V      |              |          | 400       |         |           | 400      |           |
| TA                          | Operating free-air temperature       |                            | -55          |          | 125       | -40     |           | 85       | °C        |
| OTE 3:                      | All unused inputs of the device must | be held at Voc or GND to e | nsure proper | device ( | operation | Befer t | to the TI | applicat | ion repor |

Implications of Slow or Floating CMOS Inputs, literature number SCBA004.



2



#### LM158-N, LM258-N, LM2904-N, LM358-N

www.ti.com

SNOSBT3H-JANUARY 2000-REVISED MARCH 2013

#### LM158/LM258/LM358/LM2904 Low Power Dual Operational Amplifiers Check for Samples: LM158-N, LM258-N, LM2904-N, LM358-N

#### FEATURES

- Available in 8-Bump DSBGA Chip-Sized Package, (See AN-1112 (SNVA009))
- Internally Frequency Compensated for Unity Gain
- Large DC Voltage Gain: 100 dB
- Wide Bandwidth (Unity Gain): 1 MHz (Temperature Compensated)
- Wide Power Supply Range:
- Single Supply: 3V to 32V
- Or Dual Supplies: ±1.5V to ±16V
- Very Low Supply Current Drain (500 μA)—Essentially Independent of Supply Voltage
- Low Input Offset Voltage: 2 mV
- Input Common-Mode Voltage Range Includes Ground
- Differential Input Voltage Range Equal to the Power Supply Voltage
- Large Output Voltage Swing

#### UNIQUE CHARACTERISTICS

- In the Llinear Mode the Input Common-Mode Voltage Range Includes Ground and the Output Voltage Can Also Swing to Ground, even though Operated from Only a Single Power Supply Voltage.
- The Unity Gain Cross Frequency is Temperature Compensated.
- The Input Bias Current is also Temperature Compensated.

#### ADVANTAGES

- Two Internally Compensated Op Amps
- Eliminates Need for Dual Supplies
- Allows Direct Sensing Near GND and V<sub>OUT</sub> Also Goes to GND
- · Compatible with All Forms of Logic
- Power Drain Suitable for Battery Operation

#### DESCRIPTION

The LM158 series consists of two independent, high gain, internally frequency compensated operational amplifiers which were designed specifically to operate from a single power supply over a wide range of voltages. Operation from split power supplies is also possible and the low power supply current drain is independent of the magnitude of the power supply voltage.

Application areas include transducer amplifiers, dc gain blocks and all the conventional op amp circuits which now can be more easily implemented in single power supply systems. For example, the LM158 series can be directly operated off of the standard +5V power supply voltage which is used in digital systems and will easily provide the required interface electronics without requiring the additional ±15V power supplies.

The LM358 and LM2904 are available in a chip sized package (8-Bump DSBGA) using TI's DSBGA package technology.

Please be aware that an important notice concerning availability, standard warranty, and use in critical applications of Texas Instruments semiconductor products and disclaimers thereto appears at the end of this data sheet. All trademarks are the property of their respective owners.

PRODUCTION DATA information is current as of publication date. Products conform to specifications per the terms of the Texas Instruments standard warranty. Production processing does not necessarily include testing of all parameters.

Copyright © 2000–2013, Texas Instruments Incorporated

### LM158-N, LM258-N, LM2904-N, LM358-N



www.ti.com

SNOSBT3H - JANUARY 2000 - REVISED MARCH 2013 Voltage Controlled Oscillator (VCO)





These devices have limited built-in ESD protection. The leads should be shorted together or the device placed in conductive foam during storage or handling to prevent electrostatic damage to the MOS gates.

2 Submit Documentation Feedback Copyright © 2000-2013, Texas Instruments Incorporated Product Folder Links: LM158-N LM258-N LM2904-N LM358-N

ATX12V Power Supply Design Guide

#### 3.1.5. Catastrophic Failure Protection

Should a component failure occur, the power supply should not exhibit any of the following:

- Flame
- Excessive smoke
- Charred PCB
- Fused PCB conductor
- Startling noise
- Emission of molten material

### 3.2. DC Output

### 3.2.1. DC Voltage Regulation

The DC output voltages shall remain within the regulation ranges shown in Table 2 when measured at the load end of the output connectors under all line, load, and environmental conditions. The voltage regulation limits shall be maintained under continuous operation for any steady state temperature and operating conditions specified in Section 5.

#### Table 2. DC Output Voltage Regulation

|             | -     | -      |        |        |       |
|-------------|-------|--------|--------|--------|-------|
| Output      | Range | Min.   | Nom.   | Max.   | Unit  |
| +12V1DC     | ±5%   | +11.40 | +12.00 | +12.60 | Volts |
| +12V2DC (1) | ±5%   | +11.40 | +12.00 | +12.60 | Volts |
| +5VDC       | ±5%   | +4.75  | +5.00  | +5.25  | Volts |
| +3.3VDC (2) | ±5%   | +3.14  | +3.30  | +3.47  | Volts |
| -12VDC      | ±10%  | -10.80 | -12.00 | -13.20 | Volts |
| +5VSB       | ±5%   | +4.75  | +5.00  | +5.25  | Volts |

 $^{(1)}$  At +12 VDC peak loading, regulation at the +12 VDC output can go to  $\pm$  10%.  $^{(2)}$  Voltage tolerance is required at main connector and S-ATA connector (if used).

12

ATX12V Power Supply Design Guide



Figure 10. ATX12V Power Supply Connectors (Pin-side view, not to scale)

34



#### Suitable for visible and near infrared radiation

- · Fast response times
- Angle of half sensitivity:  $\phi=\pm~65^\circ$
- Compliant to RoHS Directive 2002/95/EC and in accordance to WEEE 2002/96/EC

(5-2008

Note \*\* Please see document "Vishay Material Category Policy": www.vishay.com/doc?99902

#### APPLICATIONS

· High speed photo detector

#### DESCRIPTION

BPW34 is a PIN photodiode with high speed and high radiant sensitivity in miniature, flat, top view, clear plastic package. It is sensitive to visible and near infrared radiation. BPW34S is packed in tubes, specifications like BPW34.

| PRODUCT SUMMARY |                      |         |                       |  |  |  |  |
|-----------------|----------------------|---------|-----------------------|--|--|--|--|
| COMPONENT       | I <sub>ra</sub> (μΑ) | φ (deg) | λ <sub>0.1</sub> (nm) |  |  |  |  |
| BPW34           | 50                   | ± 65    | 430 to 1100           |  |  |  |  |
| BPW34S          | 50                   | ± 65    | 430 to 1100           |  |  |  |  |

Note

Test condition see table "Basic Characteristics"

| ORDERING INFORMATION |           |                              |              |  |  |  |  |  |
|----------------------|-----------|------------------------------|--------------|--|--|--|--|--|
| ORDERING CODE        | PACKAGING | REMARKS                      | PACKAGE FORM |  |  |  |  |  |
| BPW34                | Bulk      | MOQ: 3000 pcs, 3000 pcs/bulk | Top view     |  |  |  |  |  |
| BPW34S               | Tube      | MOQ: 1800 pcs, 45 pcs/tube   | Top view     |  |  |  |  |  |

Note

MOQ: minimum order quantity

| ABSOLUTE MAXIMUM RATINGS (Tamb = 25 °C, unless otherwise specified) |                                              |                   |               |      |  |  |  |  |  |
|---------------------------------------------------------------------|----------------------------------------------|-------------------|---------------|------|--|--|--|--|--|
| PARAMETER                                                           | TEST CONDITION                               | SYMBOL            | VALUE         | UNIT |  |  |  |  |  |
| Reverse voltage                                                     |                                              | V <sub>R</sub>    | 60            | V    |  |  |  |  |  |
| Power dissipation                                                   | $T_{amb} \le 25 \ ^{\circ}C$                 | Pv                | 215           | mW   |  |  |  |  |  |
| Junction temperature                                                |                                              | Tj                | 100           | °C   |  |  |  |  |  |
| Operating temperature range                                         |                                              | T <sub>amb</sub>  | - 40 to + 100 | °C   |  |  |  |  |  |
| Storage temperature range                                           |                                              | T <sub>stg</sub>  | - 40 to + 100 | °C   |  |  |  |  |  |
| Soldering temperature                                               | t ≤ 3 s                                      | T <sub>sd</sub>   | 260           | °C   |  |  |  |  |  |
| Thermal resistance junction/ambient                                 | Connected with Cu wire, 0.14 mm <sup>2</sup> | R <sub>thJA</sub> | 350           | K/W  |  |  |  |  |  |

Rev. 2.1, 23-Aug-11

Document Number: 81521

1 For technical questions, contact: <u>detectortechsupport@vishay.com</u> THIS DOCUMENT IS SUBJECT TO CHANGE WITHOUT NOTICE. THE PRODUCTS DESCRIBED HEREIN AND THIS DOCUMENT ARE SUBJECT TO SPECIFIC DISCLAIMERS, SET FORTH AT <a href="http://www.vishay.com/doc?91000">www.vishay.com/doc?91000</a>



### BPW34, BPW34S

www.vishay.com

Vishay Semiconductors

| <b>BASIC CHARACTERISTICS</b> (T <sub>amb</sub> = 25 °C, unless otherwise specified) |                                                                                             |                   |      |                       |      |       |  |  |  |
|-------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|-------------------|------|-----------------------|------|-------|--|--|--|
| PARAMETER                                                                           | TEST CONDITION                                                                              | SYMBOL            | MIN. | TYP.                  | MAX. | UNIT  |  |  |  |
| Breakdown voltage                                                                   | I <sub>R</sub> = 100 μA, E = 0                                                              | V <sub>(BR)</sub> | 60   |                       |      | V     |  |  |  |
| Reverse dark current                                                                | V <sub>R</sub> = 10 V, E = 0                                                                | I <sub>ro</sub>   |      | 2                     | 30   | nA    |  |  |  |
| Diada conscitance                                                                   | $V_R = 0 V, f = 1 MHz, E = 0$                                                               | CD                |      | 70                    |      | pF    |  |  |  |
| Diode capacitance                                                                   | $V_{R} = 3 V, f = 1 MHz, E = 0$                                                             | CD                |      | 25                    | 40   | pF    |  |  |  |
| Open circuit voltage                                                                | $E_e = 1 \text{ mW/cm}^2$ , $\lambda = 950 \text{ nm}$                                      | Vo                |      | 350                   |      | mV    |  |  |  |
| Temperature coefficient of Vo                                                       | $E_e = 1 \text{ mW/cm}^2$ , $\lambda = 950 \text{ nm}$                                      | TK <sub>Vo</sub>  |      | - 2.6                 |      | mV/K  |  |  |  |
| Ob ant allocult annualt                                                             | E <sub>A</sub> = 1 klx                                                                      | l <sub>k</sub>    |      | 70                    |      | μΑ    |  |  |  |
| Short circuit current                                                               | $E_e = 1 \text{ mW/cm}^2$ , $\lambda = 950 \text{ nm}$                                      | l <sub>k</sub>    |      | 47                    |      | μΑ    |  |  |  |
| Temperature coefficient of Ik                                                       | $E_e = 1 \text{ mW/cm}^2$ , $\lambda = 950 \text{ nm}$                                      | TK <sub>lk</sub>  |      | 0.1                   |      | %/K   |  |  |  |
|                                                                                     | $E_A = 1 \text{ klx}, V_R = 5 \text{ V}$                                                    | I <sub>ra</sub>   |      | 75                    |      | μΑ    |  |  |  |
| Reverse light current                                                               | $E_e = 1 \text{ mW/cm}^2, \lambda = 950 \text{ nm},$<br>$V_R = 5 \text{ V}$                 | I <sub>ra</sub>   | 40   | 50                    |      | μΑ    |  |  |  |
| Angle of half sensitivity                                                           |                                                                                             | φ                 |      | ± 65                  |      | deg   |  |  |  |
| Wavelength of peak sensitivity                                                      |                                                                                             | λρ                |      | 900                   |      | nm    |  |  |  |
| Range of spectral bandwidth                                                         |                                                                                             | λ <sub>0.1</sub>  |      | 430 to 1100           |      | nm    |  |  |  |
| Noise equivalent power                                                              | $V_R = 10 \text{ V}, \lambda = 950 \text{ nm}$                                              | NEP               |      | 4 x 10 <sup>-14</sup> |      | W/√Hz |  |  |  |
| Rise time                                                                           | $V_R$ = 10 V, $R_L$ = 1 k $\Omega$ , $\lambda$ = 820 nm                                     | tr                |      | 100                   |      | ns    |  |  |  |
| Fall time                                                                           | $V_{\rm B} = 10 \text{ V}, \text{ R}_{\rm I} = 1 \text{ k}\Omega, \lambda = 820 \text{ nm}$ | t <sub>f</sub>    |      | 100                   |      | ns    |  |  |  |

BASIC CHARACTERISTICS (T<sub>amb</sub> = 25 °C, unless otherwise specified)







Fig. 2 - Relative Reverse Light Current vs. Ambient Temperature

Rev. 2.1, 23-Aug-11

Document Number: 81521

2 For technical questions, contact: detectortechsupport@vishay.com THIS DOCUMENT IS SUBJECT TO CHANGE WITHOUT NOTICE. THE PRODUCTS DESCRIBED HEREIN AND THIS DOCUMENT ARE SUBJECT TO SPECIFIC DISCLAIMERS, SET FORTH AT <a href="http://www.vishay.com/doc?91000">www.vishay.com/doc?91000</a>



©2002 Fairchild Semiconductor Corporation

Rev. B1, December 2002





©2002 Fairchild Semiconductor Corporation

Rev. B, December 2002





### DS1307

### 64 x 8, Serial, I<sup>2</sup>C Real-Time Clock

#### **GENERAL DESCRIPTION**

The DS1307 serial real-time clock (RTC) is a lowpower, full binary-coded decimal (BCD) clock/calendar plus 56 bytes of NV SRAM. Address and data are transferred serially through an I<sup>2</sup>C, bidirectional bus. The clock/calendar provides seconds, minutes, hours, day, date, month, and year information. The end of the month date is automatically adjusted for months with fewer than 31 days, including corrections for leap year. The clock operates in either the 24-hour or 12hour format with AM/PM indicator. The DS1307 has a built-in power-sense circuit that detects power failures and automatically switches to the backup supply. Timekeeping operation continues while the part operates from the backup supply.

#### TYPICAL OPERATING CIRCUIT



### **ORDERING INFORMATION**

#### **FEATURES**

- Real-Time Clock (RTC) Counts Seconds, Minutes, Hours, Date of the Month, Month, Day of the week, and Year with Leap-Year Compensation Valid Up to 2100
- 56-Byte, Battery-Backed, General-Purpose RAM with Unlimited Writes
- I<sup>2</sup>C Serial Interface
- Programmable Square-Wave Output Signal
- Automatic Power-Fail Detect and Switch Circuitry Consumes Less than 500nA in Battery-Backup
- Mode with Oscillator Running Optional Industrial Temperature Range:
- -40°C to +85°C
- Available in 8-Pin Plastic DIP or SO
- Underwriters Laboratories (UL) Recognized

#### **PIN CONFIGURATIONS**

| TOP VIE          | W |                    |                    |            |                  |
|------------------|---|--------------------|--------------------|------------|------------------|
| X10              |   | IIIV <sub>cc</sub> | X1                 | $\square$  | □v <sub>cc</sub> |
| Х2Ш              |   | ≣sqw/ou            | JT X2⊑             | 1          | ⊐sqw/out         |
| V <sub>BAT</sub> |   | III SCL            | V <sub>BAT</sub> ⊏ | 1          | SCL              |
| GNDⅢ             |   | ∭ISDA              | GND⊑               |            | ⊐SDA             |
| SO (150 mils)    |   |                    | PD                 | 0IP (300 m | nils)            |

| PART         | TEMP RANGE     | VOLTAGE (V) | PIN-PACKAGE                   | TOP MARK* |
|--------------|----------------|-------------|-------------------------------|-----------|
| DS1307+      | 0°C to +70°C   | 5.0         | 8 PDIP (300 mils)             | DS1307    |
| DS1307N+     | -40°C to +85°C | 5.0         | 8 PDIP (300 mils)             | DS1307N   |
| DS1307Z+     | 0°C to +70°C   | 5.0         | 8 SO (150 mils)               | DS1307    |
| DS1307ZN+    | -40°C to +85°C | 5.0         | 8 SO (150 mils)               | DS1307N   |
| DS1307Z+T&R  | 0°C to +70°C   | 5.0         | 8 SO (150 mils) Tape and Reel | DS1307    |
| DS1307ZN+T&R | -40°C to +85°C | 5.0         | 8 SO (150 mils) Tape and Reel | DS1307N   |

+Denotes a lead-free/RoHS-compliant package.

\*A "+" anywhere on the top mark indicates a lead-free package. An "N" anywhere on the top mark indicates an industrial temperature range device.

For pricing, delivery, and ordering information, please contact Maxim Direct at 1-888-629-4642, or visit Maxim's website at www.maximintegrated.com.

REV: 100208



### 28/40-Pin 8-Bit CMOS FLASH Microcontrollers

Pin Diagram

PDIP

#### **Devices Included in this Data Sheet:**

- PIC16F876 PIC16E873
- PIC16F874 • PIC16F877

#### **Microcontroller Core Features:**

- · High performance RISC CPU
- · Only 35 single word instructions to learn
- · All single cycle instructions except for program branches which are two cycle
- · Operating speed: DC 20 MHz clock input DC - 200 ns instruction cycle
- Up to 8K x 14 words of FLASH Program Memory, Up to 368 x 8 bytes of Data Memory (RAM) Up to 256 x 8 bytes of EEPROM Data Memory
- · Pinout compatible to the PIC16C73B/74B/76/77
- · Interrupt capability (up to 14 sources)
- · Eight level deep hardware stack
- · Direct, indirect and relative addressing modes
- · Power-on Reset (POR) · Power-up Timer (PWRT) and
- Oscillator Start-up Timer (OST)
- · Watchdog Timer (WDT) with its own on-chip RC oscillator for reliable operation
- · Programmable code protection
- · Power saving SLEEP mode
- Selectable oscillator options
- · Low power, high speed CMOS FLASH/EEPROM technology
- · Fully static design
- In-Circuit Serial Programming<sup>™</sup> (ICSP) via two pins
- · Single 5V In-Circuit Serial Programming capability
- · In-Circuit Debugging via two pins
- · Processor read/write access to program memory
- · Wide operating voltage range: 2.0V to 5.5V
- · High Sink/Source Current: 25 mA
- Commercial, Industrial and Extended temperature ranges
- · Low-power consumption:
- < 0.6 mA typical @ 3V, 4 MHz
- 20 μA typical @ 3V, 32 kHz
- <1 μA typical standby current

#### 40 RB7/PGD 39 - → RB6/PGC RA1/AN1 🗲 38 ☐ ← → RB5 37 ] ← → RB4 RA2/AN2/VREF-36 - RB3/PGM RA3/AN3/VREF+ + RA4/TOCKI 35 - ---- RB2 34 □ ←→ RB1 33 □ ←→ RB0/INT BA5/AN4/SS PIC16F877/874 RE0/RD/AN5 + + □ 32 - VDD 31 - VSS RE1/WR/AN6 9 10 RE2/CS/AN7 🗲 30 -→ RD7/PSP7 VDD --> □ 11 Vss -12 29 → RD6/PSP6 28 → RD5/PSP5 +□ OSC1/CLKIN -> □ 13 14 27 - RD4/PSP4 RC0/T1OSO/T1CKI -26 RC7/RX/DT 15

25 - RC6/TX/CK

22 → RD2/PSP2

RC5/SDO

RD3/PSP3

24

23

22

**Peripheral Features:** 

RC1/T1OSI/CCP2 ← ☐ 16 RC2/CCP1 ← ☐ 17

RD1/PSP1 +

RC3/SCK/SCL + 18 RD0/PSP0 + 19

• Timer0: 8-bit timer/counter with 8-bit prescaler

19

► □ 20

- · Timer1: 16-bit timer/counter with prescaler, can be incremented during SLEEP via external crystal/clock
- Timer2: 8-bit timer/counter with 8-bit period register, prescaler and postscaler
- Two Capture, Compare, PWM modules
- Capture is 16-bit, max. resolution is 12.5 ns - Compare is 16-bit, max. resolution is 200 ns
- PWM max. resolution is 10-bit
- · 10-bit multi-channel Analog-to-Digital converter Synchronous Serial Port (SSP) with SPI<sup>™</sup> (Master mode) and I<sup>2</sup>C<sup>™</sup> (Master/Slave)
- Universal Synchronous Asynchronous Receiver Transmitter (USART/SCI) with 9-bit address detection
- Parallel Slave Port (PSP) 8-bits wide, with external RD, WR and CS controls (40/44-pin only)
- Brown-out detection circuitry for Brown-out Reset (BOR)

© 2001 Microchip Technology Inc.

#### PIC16F874 AND PIC16F877 PINOUT DESCRIPTION TABLE 1-2:

| Pin Name          | DIP<br>Pin#    | PLCC<br>Pin#      | QFP<br>Pin# | l/O/P<br>Type        | Buffer<br>Type         | Description                                                                                                                                                                                                       |
|-------------------|----------------|-------------------|-------------|----------------------|------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| OSC1/CLKIN        | 13             | 14                | 30          | 1                    | ST/CMOS(4)             | Oscillator crystal input/external clock source input.                                                                                                                                                             |
| OSC2/CLKOUT       | 14             | 15                | 31          | 0                    | -                      | Oscillator crystal output. Connects to crystal or resonator<br>in crystal oscillator mode. In RC mode, OSC2 pin outputs<br>CLKOUT which has 1/4 the frequency of OSC1, and<br>denotes the instruction cycle rate. |
| MCLR/VPP          | 1              | 2                 | 18          | I/P                  | ST                     | Master Clear (Reset) input or programming voltage input.<br>This pin is an active low RESET to the device.                                                                                                        |
|                   |                |                   |             |                      |                        | PORTA is a bi-directional I/O port.                                                                                                                                                                               |
| RA0/AN0           | 2              | 3                 | 19          | I/O                  | TTL                    | RA0 can also be analog input0.                                                                                                                                                                                    |
| RA1/AN1           | 3              | 4                 | 20          | I/O                  | TTL                    | RA1 can also be analog input1.                                                                                                                                                                                    |
| RA2/AN2/VREF-     | 4              | 5                 | 21          | I/O                  | TTL                    | RA2 can also be analog input2 or negative<br>analog reference voltage.                                                                                                                                            |
| RA3/AN3/VREF+     | 5              | 6                 | 22          | I/O                  | TTL                    | RA3 can also be analog input3 or positive<br>analog reference voltage.                                                                                                                                            |
| RA4/T0CKI         | 6              | 7                 | 23          | I/O                  | ST                     | RA4 can also be the clock input to the Timer0 timer/<br>counter. Output is open drain type.                                                                                                                       |
| RA5/SS/AN4        | 7              | 8                 | 24          | I/O                  | TTL                    | RA5 can also be analog input4 or the slave select for<br>the synchronous serial port.                                                                                                                             |
|                   |                |                   |             |                      |                        | PORTB is a bi-directional I/O port. PORTB can be soft-<br>ware programmed for internal weak pull-up on all inputs.                                                                                                |
| RB0/INT           | 33             | 36                | 8           | I/O                  | TTL/ST <sup>(1)</sup>  | RB0 can also be the external interrupt pin.                                                                                                                                                                       |
| RB1               | 34             | 37                | 9           | I/O                  | TTL                    |                                                                                                                                                                                                                   |
| RB2               | 35             | 38                | 10          | I/O                  | TTL                    |                                                                                                                                                                                                                   |
| RB3/PGM           | 36             | 39                | 11          | I/O                  | TTL                    | RB3 can also be the low voltage programming input.                                                                                                                                                                |
| RB4               | 37             | 41                | 14          | I/O                  | TTL                    | Interrupt-on-change pin.                                                                                                                                                                                          |
| RB5               | 38             | 42                | 15          | I/O                  | TTL                    | Interrupt-on-change pin.                                                                                                                                                                                          |
| RB6/PGC           | 39             | 43                | 16          | I/O                  | TTL/ST <sup>(2)</sup>  | Interrupt-on-change pin or In-Circuit Debugger pin.<br>Serial programming clock.                                                                                                                                  |
| RB7/PGD           | 40             | 44                | 17          | I/O                  | TTL/ST <sup>(2)</sup>  | Interrupt-on-change pin or In-Circuit Debugger pin.<br>Serial programming data.                                                                                                                                   |
| Legend: I = input | O = 0<br>— = N | utput<br>lot used |             | I/O = inp<br>TTL = T | out/output<br>TL input | P = power<br>ST = Schmitt Trigger input                                                                                                                                                                           |

Note 1: This buffer is a Schmitt Trigger input when configured as an external interrupt.
2: This buffer is a Schmitt Trigger input when used in Serial Programming mode.
3: This buffer is a Schmitt Trigger input when configured as general purpose I/O and a TTL input when used in the Parallel Slave Port mode (for interfacing to a microprocessor bus).
4: This buffer is a Schmitt Trigger input when configured in RC oscillator mode and a CMOS input otherwise.

DS30292C-page 8

#### TABLE 1-2: PIC16F874 AND PIC16F877 PINOUT DESCRIPTION (CONTINUED)

| Pin Name          | DIP<br>Pin#    | PLCC<br>Pin#      | QFP<br>Pin#     | I/O/P<br>Type        | Buffer<br>Type        | Description                                                                                            |
|-------------------|----------------|-------------------|-----------------|----------------------|-----------------------|--------------------------------------------------------------------------------------------------------|
|                   |                |                   |                 |                      |                       | PORTC is a bi-directional I/O port.                                                                    |
| RC0/T1OSO/T1CKI   | 15             | 16                | 32              | I/O                  | ST                    | RC0 can also be the Timer1 oscillator output or a<br>Timer1 clock input.                               |
| RC1/T1OSI/CCP2    | 16             | 18                | 35              | I/O                  | ST                    | RC1 can also be the Timer1 oscillator input or<br>Capture2 input/Compare2 output/PWM2 output.          |
| RC2/CCP1          | 17             | 19                | 36              | I/O                  | ST                    | RC2 can also be the Capture1 input/Compare1<br>output/PWM1 output.                                     |
| RC3/SCK/SCL       | 18             | 20                | 37              | I/O                  | ST                    | RC3 can also be the synchronous serial clock input/<br>output for both SPI and I <sup>2</sup> C modes. |
| RC4/SDI/SDA       | 23             | 25                | 42              | I/O                  | ST                    | RC4 can also be the SPI Data In (SPI mode) or data I/O ( $I^2$ C mode).                                |
| RC5/SDO           | 24             | 26                | 43              | I/O                  | ST                    | RC5 can also be the SPI Data Out (SPI mode).                                                           |
| RC6/TX/CK         | 25             | 27                | 44              | I/O                  | ST                    | RC6 can also be the USART Asynchronous Transmit<br>or Synchronous Clock.                               |
| RC7/RX/DT         | 26             | 29                | 1               | I/O                  | ST                    | RC7 can also be the USART Asynchronous Receive<br>or Synchronous Data.                                 |
|                   |                |                   |                 |                      |                       | PORTD is a bi-directional I/O port or parallel slave port<br>when interfacing to a microprocessor bus. |
| RD0/PSP0          | 19             | 21                | 38              | I/O                  | ST/TTL <sup>(3)</sup> |                                                                                                        |
| RD1/PSP1          | 20             | 22                | 39              | I/O                  | ST/TTL <sup>(3)</sup> |                                                                                                        |
| RD2/PSP2          | 21             | 23                | 40              | I/O                  | ST/TTL <sup>(3)</sup> |                                                                                                        |
| RD3/PSP3          | 22             | 24                | 41              | I/O                  | ST/TTL <sup>(3)</sup> |                                                                                                        |
| RD4/PSP4          | 27             | 30                | 2               | I/O                  | ST/TTL <sup>(3)</sup> |                                                                                                        |
| RD5/PSP5          | 28             | 31                | 3               | I/O                  | ST/TTL <sup>(3)</sup> |                                                                                                        |
| RD6/PSP6          | 29             | 32                | 4               | I/O                  | ST/TTL <sup>(3)</sup> |                                                                                                        |
| RD7/PSP7          | 30             | 33                | 5               | I/O                  | ST/TTL <sup>(3)</sup> |                                                                                                        |
|                   |                |                   |                 |                      |                       | PORTE is a bi-directional I/O port.                                                                    |
| RE0/RD/AN5        | 8              | 9                 | 25              | I/O                  | ST/TTL <sup>(3)</sup> | RE0 can also be read control for the parallel slave<br>port, or analog input5.                         |
| RE1/WR/AN6        | 9              | 10                | 26              | I/O                  | ST/TTL <sup>(3)</sup> | RE1 can also be write control for the parallel slave<br>port, or analog input6.                        |
| RE2/CS/AN7        | 10             | 11                | 27              | I/O                  | ST/TTL <sup>(3)</sup> | RE2 can also be select control for the parallel slave<br>port, or analog input7.                       |
| Vss               | 12,31          | 13,34             | 6,29            | Р                    | -                     | Ground reference for logic and I/O pins.                                                               |
| VDD               | 11,32          | 12,35             | 7,28            | Р                    | -                     | Positive supply for logic and I/O pins.                                                                |
| NC                | -              | 1,17,28,<br>40    | 12,13,<br>33,34 |                      | -                     | These pins are not internally connected. These pins should be left unconnected.                        |
| Legend: I = input | 0 = 0<br>— = N | utput<br>lot used |                 | I/O = inp<br>TTL = T | ut/output<br>TL input | P = power<br>ST = Schmitt Trigger input                                                                |

TTL = TTL input - = Not used

Note 1: This buffer is a Schmitt Trigger input when configured as an external interrupt.
2: This buffer is a Schmitt Trigger input when used in Serial Programming mode.
3: This buffer is a Schmitt Trigger input when configured as general purpose I/O and a TTL input when used in the Parallel Slave Port mode (for interfacing to a microprocessor bus).

4: This buffer is a Schmitt Trigger input when configured in RC oscillator mode and a CMOS input otherwise.

© 2001 Microchip Technology Inc.

| /                                          | File<br>Address |                                            | File<br>Address |                                            | File<br>Address |                                            | l<br>Ad |
|--------------------------------------------|-----------------|--------------------------------------------|-----------------|--------------------------------------------|-----------------|--------------------------------------------|---------|
| Indirect addr.(*)                          | 00h             | Indirect addr.(*)                          | 80h             | Indirect addr.(*)                          | 100h            | Indirect addr.(*)                          | 1       |
| TMR0                                       | 01h             | OPTION_REG                                 | 81h             | TMR0                                       | 101h            | OPTION_REG                                 | 1       |
| PCL                                        | 02h             | PCL                                        | 82h             | PCL                                        | 102h            | PCL                                        | 1       |
| STATUS                                     | 03h             | STATUS                                     | 83h             | STATUS                                     | 103h            | STATUS                                     | 1       |
| FSR                                        | 04h             | FSR                                        | 84h             | FSR                                        | 104h            | FSR                                        | 1       |
| PORTA                                      | 05h             | TRISA                                      | 85h             | 1                                          | 105h            |                                            | 1       |
| PORTB                                      | 06h             | TRISB                                      | 86h             | PORTB                                      | 106h            | TRISB                                      | 1       |
| PORTC                                      | 07h             | TRISC                                      | 87h             |                                            | 107h            |                                            | 1       |
| PORTD <sup>(1)</sup>                       | 08h             | TRISD <sup>(1)</sup>                       | 88h             |                                            | 108h            |                                            | 1       |
| PORTE <sup>(1)</sup>                       | 09h             | TRISE <sup>(1)</sup>                       | 89h             |                                            | 109h            |                                            | 1       |
| PCLATH                                     | 0Ah             | PCLATH                                     | 8Ah             | PCLATH                                     | 10Ah            | PCLATH                                     | 1       |
| INTCON                                     | 0Bh             | INTCON                                     | 8Bh             | INTCON                                     | 10Bh            | INTCON                                     | 1       |
| PIR1                                       | 0Ch             | PIE1                                       | 8Ch             | EEDATA                                     | 10Ch            | EECON1                                     | 1       |
| PIR2                                       | 0Dh             | PIE2                                       | 8Dh             | EEADR                                      | 10Dh            | EECON2                                     | 1       |
| TMR1L                                      | 0Eh             | PCON                                       | 8Eh             | EEDATH                                     | 10Eh            | Reserved <sup>(2)</sup>                    | 1       |
| TMR1H                                      | 0Fh             |                                            | 8Fh             | EEADRH                                     | 10Fh            | Reserved <sup>(2)</sup>                    | 1       |
| T1CON                                      | 10h             |                                            | 90h             |                                            | 110h            |                                            | 1       |
| TMR2                                       | 11h             | SSPCON2                                    | 91h             |                                            | 111h            |                                            | 1       |
| T2CON                                      | 12h             | PR2                                        | 92h             |                                            | 112h            |                                            | 1       |
| SSPBUF                                     | 13h             | SSPADD                                     | 93h             |                                            | 113h            |                                            | 1       |
| SSPCON                                     | 14h             | SSPSTAT                                    | 94h             |                                            | 114h            |                                            | 1       |
| CCPR1L                                     | 15h             |                                            | 95h             |                                            | 115h            |                                            | 1       |
| CCPR1H                                     | 16h             |                                            | 96h             |                                            | 116h            |                                            | 1       |
| CCP1CON                                    | 17h             |                                            | 97h             | General                                    | 117h            | General                                    | 1       |
| RCSTA                                      | 18h             | TXSTA                                      | 98h             | Register                                   | 118h            | Register                                   | 1       |
| TXREG                                      | 19h             | SPBRG                                      | 99h             | 16 Bytes                                   | 119h            | 16 Bytes                                   | 1       |
| RCREG                                      | 1Ah             |                                            | 9Ah             |                                            | 11Ah            |                                            | 1       |
| CCPR2L                                     | 1Bh             |                                            | 9Bh             |                                            | 11Bh            |                                            | 1       |
| CCPR2H                                     | 1Ch             |                                            | 9Ch             |                                            | 11Ch            |                                            | 1       |
| CCP2CON                                    | 1Dh             |                                            | 9Dh             |                                            | 11Dh            |                                            | 1       |
| ADRESH                                     | 1Eh             | ADRESL                                     | 9Eh             |                                            | 11Eh            |                                            | 1       |
| ADCON0                                     | 1Fh             | ADCON1                                     | 9Fh             |                                            | 11Fh            |                                            | 1       |
|                                            | 20h             |                                            | A0h             |                                            | 120h            |                                            | 1       |
| General<br>Purpose<br>Register<br>96 Bytes |                 | General<br>Purpose<br>Register<br>80 Bytes | EFh             | General<br>Purpose<br>Register<br>80 Bytes | 16Fh            | General<br>Purpose<br>Register<br>80 Bytes | 1       |
|                                            | 754             | accesses<br>70h-7Fh                        | F0h             | accesses<br>70h-7Fh                        | 170h            | accesses<br>70h - 7Fh                      | 1       |
| Bank 0                                     | 750             | Bank 1                                     | FFN             | Bank 2                                     | 1750            | Bank 3                                     | ı 1     |
| Unimplem<br>* Not a physic                 | ented data      | a memory location<br>ter.                  | is, read a      | s '0'.                                     |                 |                                            |         |

© 2001 Microchip Technology Inc.

#### 2.2.2 SPECIAL FUNCTION REGISTERS

The Special Function Registers are registers used by the CPU and peripheral modules for controlling the desired operation of the device. These registers are implemented as static RAM. A list of these registers is given in Table 2-1.

The Special Function Registers can be classified into two sets: core (CPU) and peripheral. Those registers associated with the core functions are described in detail in this section. Those related to the operation of the peripheral features are described in detail in the peripheral features section.

SPECIAL FUNCTION REGISTER SUMMARY TABLE 2-1:

| Address              | Name    | Bit 7                | Bit 6                               | Bit 5         | Bit 4         | Bit 3          | Bit 2             | Bit 1          | Bit 0     | Value on:<br>POR,<br>BOR | Details<br>on<br>page: |
|----------------------|---------|----------------------|-------------------------------------|---------------|---------------|----------------|-------------------|----------------|-----------|--------------------------|------------------------|
| Bank 0               |         |                      |                                     |               |               |                |                   |                |           |                          |                        |
| 00h <sup>(3)</sup>   | INDF    | Addressing           | g this location                     | n uses conte  | nts of FSR to | address dat    | a memory (no      | t a physical r | egister)  | 0000 0000                | 27                     |
| 01h                  | TMR0    | Timer0 Mo            | dule Registe                        | er            |               |                |                   |                |           | XXXX XXXX                | 47                     |
| 02h <sup>(3)</sup>   | PCL     | Program C            | Counter (PC)                        | Least Signif  | icant Byte    |                |                   |                |           | 0000 0000                | 26                     |
| 03h <sup>(3)</sup>   | STATUS  | IRP                  | RP1                                 | RP0           | TO            | PD             | Z                 | DC             | С         | 0001 1xxx                | 18                     |
| 04h <sup>(3)</sup>   | FSR     | Indirect Da          | ndirect Data Memory Address Pointer |               |               |                |                   |                | XXXX XXXX | 27                       |                        |
| 05h                  | PORTA   | -                    | -                                   | PORTA Da      | ta Latch whe  | n written: POI | RTA pins wher     | n read         |           | 0x 0000                  | 29                     |
| 06h                  | PORTB   | PORTB Da             | ata Latch wh                        | en written: P | ORTB pins w   | hen read       |                   |                |           | XXXX XXXX                | 31                     |
| 07h                  | PORTC   | PORTC D              | ata Latch wh                        | en written: P | ORTC pins v   | vhen read      |                   |                |           | XXXX XXXX                | 33                     |
| 08h <sup>(4)</sup>   | PORTD   | PORTD D              | ata Latch wh                        | en written: P | ORTD pins v   | vhen read      |                   |                |           | XXXX XXXX                | 35                     |
| 09h <sup>(4)</sup>   | PORTE   | -                    | -                                   | -             | -             | -              | RE2               | RE1            | RE0       | xxx                      | 36                     |
| 0Ah <sup>(1,3)</sup> | PCLATH  | -                    | _                                   | -             | Write Buffer  | for the upper  | r 5 bits of the I | Program Cou    | unter     | 0 0000                   | 26                     |
| 0Bh <sup>(3)</sup>   | INTCON  | GIE                  | PEIE                                | T0IE          | INTE          | RBIE           | TOIF              | INTF           | RBIF      | 0000 000x                | 20                     |
| 0Ch                  | PIR1    | PSPIF <sup>(3)</sup> | ADIF                                | RCIF          | TXIF          | SSPIF          | CCP1IF            | TMR2IF         | TMR1IF    | 0000 0000                | 22                     |
| 0Dh                  | PIR2    | -                    | (5)                                 | -             | EEIF          | BCLIF          | -                 | —              | CCP2IF    | -r-0 00                  | 24                     |
| 0Eh                  | TMR1L   | Holding re           | gister for the                      | Least Signif  | icant Byte of | the 16-bit TN  | IR1 Register      |                |           | XXXX XXXX                | 52                     |
| 0Fh                  | TMR1H   | Holding re           | gister for the                      | Most Signifi  | cant Byte of  | the 16-bit TM  | R1 Register       |                |           | XXXX XXXX                | 52                     |
| 10h                  | T1CON   | -                    | -                                   | T1CKPS1       | T1CKPS0       | T1OSCEN        | T1SYNC            | TMR1CS         | TMR10N    | 00 0000                  | 51                     |
| 11h                  | TMR2    | Timer2 Mo            | dule Registe                        | r             |               |                |                   |                |           | 0000 0000                | 55                     |
| 12h                  | T2CON   | -                    | TOUTPS3                             | TOUTPS2       | TOUTPS1       | TOUTPS0        | TMR2ON            | T2CKPS1        | T2CKPS0   | -000 0000                | 55                     |
| 13h                  | SSPBUF  | Synchrono            | us Serial Po                        | rt Receive B  | uffer/Transm  | it Register    |                   |                |           | XXXX XXXX                | 70, 73                 |
| 14h                  | SSPCON  | WCOL                 | SSPOV                               | SSPEN         | CKP           | SSPM3          | SSPM2             | SSPM1          | SSPM0     | 0000 0000                | 67                     |
| 15h                  | CCPR1L  | Capture/C            | ompare/PWI                          | A Register1   | (LSB)         |                |                   |                |           | XXXX XXXX                | 57                     |
| 16h                  | CCPR1H  | Capture/C            | ompare/PWI                          | A Register1   | (MSB)         |                |                   |                |           | XXXX XXXX                | 57                     |
| 17h                  | CCP1CON | -                    | -                                   | CCP1X         | CCP1Y         | CCP1M3         | CCP1M2            | CCP1M1         | CCP1M0    | 00 0000                  | 58                     |
| 18h                  | RCSTA   | SPEN                 | RX9                                 | SREN          | CREN          | ADDEN          | FERR              | OERR           | RX9D      | 0000 000x                | 96                     |
| 19h                  | TXREG   | USART Tr             | ansmit Data                         | Register      |               |                |                   |                |           | 0000 0000                | 99                     |
| 1Ah                  | RCREG   | USART Re             | eceive Data I                       | Register      |               |                |                   |                |           | 0000 0000                | 101                    |
| 1Bh                  | CCPR2L  | Capture/C            | ompare/PWI                          | A Register2   | (LSB)         |                |                   |                |           | XXXX XXXX                | 57                     |
| 1Ch                  | CCPR2H  | Capture/C            | ompare/PWI                          | / Register2   | (MSB)         |                |                   |                |           | xxxx xxxx                | 57                     |
| 1Dh                  | CCP2CON | -                    | -                                   | CCP2X         | CCP2Y         | CCP2M3         | CCP2M2            | CCP2M1         | CCP2M0    | 00 0000                  | 58                     |
| 1Eh                  | ADRESH  | A/D Result           | t Register High                     | gh Byte       |               |                |                   |                |           | XXXX XXXX                | 116                    |
| 1Fh                  | ADCON0  | ADCS1                | ADCS0                               | CHS2          | CHS1          | CHS0           | GO/DONE           | -              | ADON      | 0000 00-0                | 111                    |

Legend: x = unknown, u = unchanged, q = value depends on condition, - = unimplemented, read as '0', r = reserved. Shaded locations are unimplemented, read as '0'.
 Note 1: The upper byte of the program counter is not directly accessible. PCLATH is a holding register for the PC<12.8> whose contents are transferred to the upper byte of the program counter.
 Bits PSPIE and PSPIF are reserved on PIC16F873/876 devices; always maintain these bits clear.
 These registers can be addressed from any bank.
 PORTD, PORTE, TRISD, and TRISE are not physically implemented on PIC16F873/876 devices; read as '0'.
 PIR2<6> and PIE2<6> are reserved on these devices; always maintain these bits clear.

© 2001 Microchip Technology Inc.

#### TABLE 2-1: SPECIAL FUNCTION REGISTER SUMMARY (CONTINUED)

| Address              | Name                                                                                         | Bit 7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Bit 6                                                                          | Bit 5                                                                     | Bit 4                                                             | Bit 3                                          | Bit 2                                          | Bit 1                   | Bit 0               | Value on:<br>POR,<br>BOR | Details<br>on<br>page: |
|----------------------|----------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------|---------------------------------------------------------------------------|-------------------------------------------------------------------|------------------------------------------------|------------------------------------------------|-------------------------|---------------------|--------------------------|------------------------|
| Bank 1               |                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                |                                                                           |                                                                   |                                                |                                                |                         |                     |                          |                        |
| 80h <sup>(3)</sup>   | INDF                                                                                         | Addressin                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | g this locatio                                                                 | n uses conte                                                              | ents of FSR to                                                    | address dat                                    | a memory (no                                   | t a physical r          | egister)            | 0000 0000                | 27                     |
| 81h                  | OPTION_REG                                                                                   | RBPU                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | INTEDG                                                                         | TOCS                                                                      | TOSE                                                              | PSA                                            | PS2                                            | PS1                     | PS0                 | 1111 1111                | 19                     |
| 82h <sup>(3)</sup>   | PCL                                                                                          | Program C                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Program Counter (PC) Least Significant Byte                                    |                                                                           |                                                                   |                                                |                                                |                         |                     | 0000 0000                | 26                     |
| 83h <sup>(3)</sup>   | STATUS                                                                                       | IRP                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | RP1                                                                            | RP0                                                                       | TO                                                                | PD                                             | Z                                              | DC                      | С                   | 0001 1xxx                | 18                     |
| 84h <sup>(3)</sup>   | FSR                                                                                          | Indirect Da                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | ata Memory A                                                                   | Address Poir                                                              | nter                                                              |                                                |                                                |                         |                     | хххх хххх                | 27                     |
| 85h                  | TRISA                                                                                        | _                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | -                                                                              | PORTA Da                                                                  | ta Direction F                                                    | legister                                       |                                                |                         |                     | 11 1111                  | 29                     |
| 86h                  | TRISB                                                                                        | PORTB D                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | ata Direction                                                                  | Register                                                                  |                                                                   |                                                |                                                |                         |                     | 1111 1111                | 31                     |
| 87h                  | TRISC                                                                                        | PORTC D                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | ata Direction                                                                  | Register                                                                  |                                                                   |                                                |                                                |                         |                     | 1111 1111                | 33                     |
| 88h <sup>(4)</sup>   | TRISD                                                                                        | PORTD D                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | ata Direction                                                                  | Register                                                                  |                                                                   |                                                |                                                |                         |                     | 1111 1111                | 35                     |
| 89h <sup>(4)</sup>   | TRISE                                                                                        | IBF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | OBF                                                                            | IBOV                                                                      | PSPMODE                                                           | -                                              | PORTE Data                                     | a Direction B           | ts                  | 0000 -111                | 37                     |
| 8Ah <sup>(1,3)</sup> | PCLATH                                                                                       | _                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | -                                                                              | -                                                                         | Write Buffer                                                      | for the uppe                                   | r 5 bits of the I                              | Program Cou             | Inter               | 0 0000                   | 26                     |
| 8Bh <sup>(3)</sup>   | INTCON                                                                                       | GIE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | PEIE                                                                           | TOIE                                                                      | INTE                                                              | RBIE                                           | TOIF                                           | INTF                    | RBIF                | x000 000x                | 20                     |
| 8Ch                  | PIE1                                                                                         | PSPIE <sup>(2)</sup>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | ADIE                                                                           | RCIE                                                                      | TXIE                                                              | SSPIE                                          | CCP1IE                                         | TMR2IE                  | TMR1IE              | 0000 0000                | 21                     |
| 8Dh                  | PIE2                                                                                         | _                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | (5)                                                                            | -                                                                         | EEIE                                                              | BCLIE                                          | -                                              | -                       | CCP2IE              | -r-0 00                  | 23                     |
| 8Eh                  | PCON                                                                                         | _                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | -                                                                              | -                                                                         | -                                                                 | -                                              | -                                              | POR                     | BOR                 | qq                       | 25                     |
| 8Fh                  | -                                                                                            | Unimplem                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | nimplemented                                                                   |                                                                           |                                                                   |                                                |                                                |                         |                     | -                        | -                      |
| 90h                  | -                                                                                            | Unimplem                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | ented                                                                          |                                                                           |                                                                   |                                                |                                                |                         |                     | -                        | -                      |
| 91h                  | SSPCON2                                                                                      | GCEN                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | ACKSTAT                                                                        | ACKDT                                                                     | ACKEN                                                             | RCEN                                           | PEN                                            | RSEN                    | SEN                 | 0000 0000                | 68                     |
| 92h                  | PR2                                                                                          | Timer2 Pe                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | riod Registe                                                                   | r                                                                         |                                                                   |                                                |                                                |                         |                     | 1111 1111                | 55                     |
| 93h                  | SSPADD                                                                                       | Synchrono                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | ous Serial Po                                                                  | ort (I <sup>2</sup> C mode                                                | e) Address Re                                                     | gister                                         |                                                |                         |                     | 0000 0000                | 73, 74                 |
| 94h                  | SSPSTAT                                                                                      | SMP                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | CKE                                                                            | D/A                                                                       | Р                                                                 | S                                              | R/W                                            | UA                      | BF                  | 0000 0000                | 66                     |
| 95h                  | -                                                                                            | Unimplem                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | ented                                                                          |                                                                           |                                                                   |                                                |                                                |                         |                     | -                        | -                      |
| 96h                  | -                                                                                            | Unimplem                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | ented                                                                          |                                                                           |                                                                   |                                                |                                                |                         |                     | -                        | -                      |
| 97h                  | -                                                                                            | Unimplem                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | ented                                                                          |                                                                           |                                                                   |                                                |                                                |                         |                     | -                        | -                      |
| 98h                  | TXSTA                                                                                        | CSRC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | TX9                                                                            | TXEN                                                                      | SYNC                                                              | -                                              | BRGH                                           | TRMT                    | TX9D                | 0000 -010                | 95                     |
| 99h                  | SPBRG                                                                                        | Baud Rate                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | e Generator I                                                                  | Register                                                                  |                                                                   |                                                |                                                |                         |                     | 0000 0000                | 97                     |
| 9Ah                  | -                                                                                            | Unimplem                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | ented                                                                          |                                                                           |                                                                   |                                                |                                                |                         |                     | -                        | -                      |
| 9Bh                  | -                                                                                            | Unimplem                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | ented                                                                          |                                                                           |                                                                   |                                                |                                                |                         |                     | -                        | -                      |
| 9Ch                  | -                                                                                            | Unimplem                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | ented                                                                          |                                                                           |                                                                   |                                                |                                                |                         |                     | -                        | -                      |
| 9Dh                  | -                                                                                            | Unimplem                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | ented                                                                          |                                                                           |                                                                   |                                                |                                                |                         |                     | -                        | -                      |
| 9Eh                  | ADRESL                                                                                       | A/D Resul                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | t Register Lo                                                                  | w Byte                                                                    |                                                                   |                                                |                                                |                         |                     | XXXX XXXX                | 116                    |
| 9Fh                  | ADCON1                                                                                       | ADFM                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | -                                                                              | -                                                                         | -                                                                 | PCFG3                                          | PCFG2                                          | PCFG1                   | PCFG0               | 0 0000                   | 112                    |
| Legend:<br>Note 1:   | x = unknown, u<br>Shaded location<br>The upper byte of                                       | = unchang<br>ns are unim<br>of the progra                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | ed, q = value<br>plemented, r<br>am counter is                                 | e depends or<br>ead as '0'.<br>s not directly                             | n condition, -<br>accessible, F                                   | = unimpleme<br>PCLATH is a l                   | nted, read as holding registe                  | '0', r = reserv         | ved.<br><12:8> whos | se .                     |                        |
| 2:<br>3:<br>4:<br>5: | contents are tran<br>Bits PSPIE and I<br>These registers o<br>PORTD, PORTE<br>PIR2<6> and PI | Sferred to the SPIF are read to the SPIF are read to the address of the second statement of the second | he upper byt<br>eserved on F<br>ressed from a<br>nd TRISE are<br>reserved on t | e of the prog<br>PIC16F873/8<br>any bank.<br>e not physica<br>hese device | gram counter.<br>376 devices; a<br>ally implemen<br>s; always mai | lways mainta<br>ted on PIC16<br>intain these b | ain these bits c<br>F873/876 dev<br>its clear. | clear.<br>ices; read as | s 'O'.              |                          |                        |

DS30292C-page 16

| Address               | Name       | Bit 7       | Bit 6                                              | Bit 5                                                    | Bit 4          | Bit 3         | Bit 2             | Bit 1          | Bit 0     | Value on:<br>POR,<br>BOR | Details<br>on<br>page: |
|-----------------------|------------|-------------|----------------------------------------------------|----------------------------------------------------------|----------------|---------------|-------------------|----------------|-----------|--------------------------|------------------------|
| Bank 2                |            |             |                                                    |                                                          |                |               |                   |                |           |                          |                        |
| 100h <sup>(3)</sup>   | INDF       | Addressin   | g this locatio                                     | n uses conte                                             | ents of FSR to | address dat   | a memory (no      | t a physical r | register) | 0000 0000                | 27                     |
| 101h                  | TMR0       | Timer0 Mo   | dule Registe                                       | ər                                                       |                |               |                   |                |           | XXXX XXXX                | 47                     |
| 102h <sup>(3)</sup>   | PCL        | Program C   | Counter's (PC                                      | ) Least Sigr                                             | nificant Byte  |               |                   |                |           | 0000 0000                | 26                     |
| 103h <sup>(3)</sup>   | STATUS     | IRP         | RP1                                                | RP0                                                      | TO             | PD            | Z                 | DC             | С         | 0001 1xxx                | 18                     |
| 104h <sup>(3)</sup>   | FSR        | Indirect Da | ata Memory /                                       | Address Poir                                             | nter           |               |                   |                |           | хххх хххх                | 27                     |
| 105h                  | -          | Unimplem    | ented                                              |                                                          |                |               |                   |                |           | -                        | -                      |
| 106h                  | PORTB      | PORTB D     | ata Latch wh                                       | en written: F                                            | ORTB pins w    | /hen read     |                   |                |           | хххх хххх                | 31                     |
| 107h                  | -          | Unimplem    | Inimplemented                                      |                                                          |                |               |                   |                |           | -                        | -                      |
| 108h                  | -          | Unimplem    | Inimplemented                                      |                                                          |                |               |                   |                |           | -                        | -                      |
| 109h                  | -          | Unimplem    | Jnimplemented                                      |                                                          |                |               |                   |                |           | -                        | -                      |
| 10Ah <sup>(1,3)</sup> | PCLATH     | -           | -                                                  | Write Buffer for the upper 5 bits of the Program Counter |                |               |                   |                |           | 0 0000                   | 26                     |
| 10Bh <sup>(3)</sup>   | INTCON     | GIE         | PEIE                                               | TOIE                                                     | INTE           | RBIE          | TOIF              | INTF           | RBIF      | 0000 000x                | 20                     |
| 10Ch                  | EEDATA     | EEPROM      | Data Registe                                       | er Low Byte                                              |                |               |                   |                |           | хххх хххх                | 41                     |
| 10Dh                  | EEADR      | EEPROM      | EEPROM Address Register Low Byte                   |                                                          |                |               |                   |                |           |                          | 41                     |
| 10Eh                  | EEDATH     | -           | <ul> <li>EEPROM Data Register High Byte</li> </ul> |                                                          |                |               |                   |                |           | хххх хххх                | 41                     |
| 10Fh                  | EEADRH     | -           | -                                                  | _                                                        | EEPROM A       | ddress Regis  | ter High Byte     |                |           | XXXX XXXX                | 41                     |
| Bank 3                |            |             |                                                    |                                                          |                |               |                   |                |           |                          |                        |
| 180h <sup>(3)</sup>   | INDF       | Addressin   | g this locatio                                     | n uses conte                                             | ents of FSR to | address dat   | a memory (no      | t a physical r | egister)  | 0000 0000                | 27                     |
| 181h                  | OPTION_REG | RBPU        | INTEDG                                             | TOCS                                                     | TOSE           | PSA           | PS2               | PS1            | PS0       | 1111 1111                | 19                     |
| 182h <sup>(3)</sup>   | PCL        | Program C   | Counter (PC)                                       | Least Signi                                              | ficant Byte    |               |                   |                |           | 0000 0000                | 26                     |
| 183h <sup>(3)</sup>   | STATUS     | IRP         | RP1                                                | RP0                                                      | TO             | PD            | Z                 | DC             | С         | 0001 1xxx                | 18                     |
| 184h <sup>(3)</sup>   | FSR        | Indirect Da | ata Memory /                                       | Address Poir                                             | nter           |               |                   |                |           | хххх хххх                | 27                     |
| 185h                  | -          | Unimplem    | ented                                              |                                                          |                |               |                   |                |           | -                        | _                      |
| 186h                  | TRISB      | PORTB D     | ata Direction                                      | Register                                                 |                |               |                   |                |           | 1111 1111                | 31                     |
| 187h                  | -          | Unimplem    | ented                                              |                                                          |                |               |                   |                |           | -                        | -                      |
| 188h                  | -          | Unimplem    | ented                                              |                                                          |                |               |                   |                |           | -                        | -                      |
| 189h                  | -          | Unimplem    | ented                                              |                                                          |                |               |                   |                |           | -                        | -                      |
| 18Ah <sup>(1,3)</sup> | PCLATH     | -           | -                                                  | -                                                        | Write Buffer   | for the upper | r 5 bits of the I | Program Cou    | unter     | 0 0000                   | 26                     |
| 18Bh <sup>(3)</sup>   | INTCON     | GIE         | PEIE                                               | TOIE                                                     | INTE           | RBIE          | TOIF              | INTF           | RBIF      | 0000 000x                | 20                     |
| 18Ch                  | EECON1     | EEPGD       | _                                                  | _                                                        | -              | WRERR         | WREN              | WR             | RD        | x x000                   | 41, 42                 |
| 18Dh                  | EECON2     | EEPROM      | Control Regi                                       | ster2 (not a                                             | physical regis | ster)         |                   |                |           |                          | 41                     |
| 18Eh                  | -          | Reserved    | maintain clea                                      | ar                                                       |                |               |                   |                |           | 0000 0000                | -                      |
| 18Fh                  | -          | Reserved    | maintain clea                                      | ar                                                       |                |               |                   |                |           | 0000 0000                | _                      |

#### TABLE 2-1: SPECIAL FUNCTION REGISTER SUMMARY (CONTINUED)

 Iterative
 Interaction
 Iterative
 Iterative

© 2001 Microchip Technology Inc.

#### 2.2.2.1 STATUS Register

The STATUS register contains the arithmetic status of the ALU, the RESET status and the bank select bits for data memory.

The STATUS register can be the destination for any instruction, as with any other register. If the STATUS register is the destination for an instruction that affects the Z, DC or C bits, then the write to these three bits is disabled. These bits are set or cleared according to the device logic. Furthermore, the TO and PD bits are not writable, therefore, the result of an instruction with the STATUS register as destination may be different than intended.

For example, CLRF STATUS will clear the upper three bits and set the Z bit. This leaves the STATUS register as 000u uluu (where u = unchanged).

It is recommended, therefore, that only BCF, BSF, SWAPF and MOWWF instructions are used to alter the STATUS register, because these instructions do not affect the Z, C or DC bits from the STATUS register. For other instructions not affecting any status bits, see the "Instruction Set Summary."

| Note: | The C and DC bits operate as a borrow       |
|-------|---------------------------------------------|
|       | and digit borrow bit, respectively, in sub- |
|       | traction. See the SUBLW and SUBWF           |
|       | instructions for examples.                  |
|       |                                             |

|         | R/W-0                      | R/W-0                                                        | R/W-0                            | R-1                            | R-1                                  | R/W-x                  | R/W-x                  | R/W-x          |  |  |  |
|---------|----------------------------|--------------------------------------------------------------|----------------------------------|--------------------------------|--------------------------------------|------------------------|------------------------|----------------|--|--|--|
|         | IRP                        | RP1                                                          | RP0                              | TO                             | PD                                   | Z                      | DC                     | С              |  |  |  |
|         | bit 7                      |                                                              |                                  |                                |                                      |                        |                        | bit 0          |  |  |  |
|         |                            |                                                              |                                  |                                |                                      |                        |                        |                |  |  |  |
| bit 7   | IRP: Regis                 | ter Bank Se                                                  | lect bit (use                    | d for indired                  | t addressing)                        |                        |                        |                |  |  |  |
|         | 1 = Bank 2<br>0 = Bank 0   | 2, 3 (100h - <sup>-</sup><br>), 1 (00h - Fl                  | IFFh)<br><sup>=</sup> h)         |                                |                                      |                        |                        |                |  |  |  |
| bit 6-5 | RP1:RP0:                   | Register Ba                                                  | nk Select bi                     | its (used for                  | direct addressi                      | ng)                    |                        |                |  |  |  |
|         | 11 = Bank                  | 3 (180h - 1l                                                 | Fh)                              |                                |                                      |                        |                        |                |  |  |  |
|         | 10 = Bank<br>01 = Bank     | 0 = Bank 2 (100h - 1/Fh)<br>1 = Bank 1 (80h - FFh)           |                                  |                                |                                      |                        |                        |                |  |  |  |
|         | 00 = Bank                  | 00 = Bank 0 (00h - 7Fh)                                      |                                  |                                |                                      |                        |                        |                |  |  |  |
|         | Each bank                  | Each bank is 128 bytes                                       |                                  |                                |                                      |                        |                        |                |  |  |  |
| bit 4   | TO: Time-c                 | TO: Time-out bit                                             |                                  |                                |                                      |                        |                        |                |  |  |  |
|         | 1 = After p                | 1 = After power-up, CLRWDT instruction, or SLEEP instruction |                                  |                                |                                      |                        |                        |                |  |  |  |
| hit 2   |                            | down bit                                                     | curreu                           |                                |                                      |                        |                        |                |  |  |  |
| DIL 3   | 1 = After n                | ower-up or l                                                 | w the CLRW                       | DT instructio                  | n                                    |                        |                        |                |  |  |  |
|         | 0 = By exe                 | cution of the                                                | SLEEP ins                        | truction                       |                                      |                        |                        |                |  |  |  |
| bit 2   | Z: Zero bit                |                                                              |                                  |                                |                                      |                        |                        |                |  |  |  |
|         | 1 = The res<br>0 = The res | sult of an ar<br>sult of an ar                               | ithmetic or le<br>ithmetic or le | ogic operatio<br>ogic operatio | on is zero<br>on is not zero         |                        |                        |                |  |  |  |
| bit 1   | DC: Digit c                | arry/borrow                                                  | bit (ADDWF,                      | ADDLW, SUR                     | BLW, SUBWF ins                       | tructions)             |                        |                |  |  |  |
|         | (for borrow                | , the polarity                                               | / is reversed                    | d)                             |                                      |                        |                        |                |  |  |  |
|         | 1 = A carry                | -out from th                                                 | e 4th low or                     | der bit of th                  | e result occurre                     | ed                     |                        |                |  |  |  |
| hit 0   | 0 = NO can                 | prrow bit (at                                                |                                  |                                |                                      | 200                    |                        |                |  |  |  |
| DILU    | 1 = A carry                | -out from th                                                 | e Most Siar                      | N, SUBLW, S                    | the result occu                      | urred                  |                        |                |  |  |  |
|         | 0 = No car                 | ry-out from                                                  | he Most Sig                      | gnificant bit                  | of the result occ                    | curred                 |                        |                |  |  |  |
|         | Note:                      | For borrow                                                   | the polarity                     | / is reversed                  | d. A subtraction                     | is execute             | d by adding            | g the two's    |  |  |  |
|         |                            | complement<br>loaded with                                    | t of the sec                     | ond operan                     | d. For rotate (R<br>order bit of the | RF, RLF)<br>source rea | instructions<br>ister. | 3, this bit is |  |  |  |
|         |                            |                                                              |                                  | 0                              |                                      | Ū                      |                        |                |  |  |  |
|         | Legend:                    |                                                              |                                  |                                |                                      |                        |                        |                |  |  |  |
|         | R = Reada                  | ble bit                                                      | W = V                            | Vritable bit                   | U = Unimpl                           | emented b              | it, read as '          | 0'             |  |  |  |
|         | - n – Value                | at POR                                                       | '1' – F                          | Rit is sot                     | '0' – Bit is c                       | loarod                 | v – Ritis u            | nknown         |  |  |  |

DS30292C-page 18

© 2001 Microchip Technology Inc.

#### REGISTER 2-1: STATUS REGISTER (ADDRESS 03h, 83h, 103h, 183h)

#### 2.2.2.3 INTCON Register

The INTCON Register is a readable and writable register, which contains various enable and flag bits for the TMR0 register overflow, RB Port change and External RB0/INT pin interrupts.

- n = Value at POR

| Note: | Interrupt flag bits are set when an interrupt |
|-------|-----------------------------------------------|
|       | condition occurs, regardless of the state of  |
|       | its corresponding enable bit or the global    |
|       | enable bit, GIE (INTCON<7>). User soft-       |
|       | ware should ensure the appropriate inter-     |
|       | rupt flag bits are clear prior to enabling an |
|       | interrupt.                                    |

#### REGISTER 2-3:

#### INTCON REGISTER (ADDRESS 0Bh, 8Bh, 10Bh, 18Bh)

| R/W-0 | R/W-x |
|-------|-------|-------|-------|-------|-------|-------|-------|
| GIE   | PEIE  | TOIE  | INTE  | RBIE  | T0IF  | INTF  | RBIF  |
| bit 7 |       |       |       |       |       |       | bit 0 |

| bit 7 | GIE: Global Interrupt Enable bit                                                                                                                                                                                          |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | 1 = Enables all unmasked interrupts                                                                                                                                                                                       |
|       | 0 = Disables all interrupts                                                                                                                                                                                               |
| bit 6 | PEIE: Peripheral Interrupt Enable bit                                                                                                                                                                                     |
|       | 1 = Enables all unmasked peripheral interrupts                                                                                                                                                                            |
|       | 0 = Disables all peripheral interrupts                                                                                                                                                                                    |
| bit 5 | TOIE: TMR0 Overflow Interrupt Enable bit                                                                                                                                                                                  |
|       | 1 = Enables the TMR0 interrupt                                                                                                                                                                                            |
|       | 0 = Disables the TMR0 interrupt                                                                                                                                                                                           |
| bit 4 | INTE: RB0/INT External Interrupt Enable bit                                                                                                                                                                               |
|       | 1 = Enables the RB0/INT external interrupt                                                                                                                                                                                |
|       | 0 = Disables the RBU/INT external interrupt                                                                                                                                                                               |
| bit 3 | <b>RBIE</b> : RB Port Change Interrupt Enable bit                                                                                                                                                                         |
|       | 1 = Enables the RB port change interrupt                                                                                                                                                                                  |
| h# 0  | TOLE: TMP0 Quarflow Interrupt Eleg hit                                                                                                                                                                                    |
| DIL Z | TMP0 register has sucrflowed (must be cleared in software)                                                                                                                                                                |
|       | 1 = TMR0 register has overflowed (must be cleared in software)<br>0 = TMR0 register did not overflow                                                                                                                      |
| bit 1 | INTF: RB0/INT External Interrupt Flag bit                                                                                                                                                                                 |
|       | 1 = The RB0/INT external interrupt occurred (must be cleared in software)                                                                                                                                                 |
|       | 0 = The RB0/INT external interrupt did not occur                                                                                                                                                                          |
| bit 0 | RBIF: RB Port Change Interrupt Flag bit                                                                                                                                                                                   |
|       | 1 = At least one of the RB7:RB4 pins changed state; a mismatch condition will continue to set<br>the bit. Reading PORTB will end the mismatch condition and allow the bit to be cleared<br>(must be cleared in software). |
|       | 0 = None of the RB7:RB4 pins have changed state                                                                                                                                                                           |
|       | Lagondi                                                                                                                                                                                                                   |
|       | Legend.                                                                                                                                                                                                                   |
|       | $H = Headable bit \qquad W = Writable bit \qquad U = Unimplemented bit read as '0'$                                                                                                                                       |

'1' = Bit is set

'0' = Bit is cleared

DS30292C-page 20

© 2001 Microchip Technology Inc.

x = Bit is unknown

#### 2.3 PCL and PCLATH

The program counter (PC) is 13-bits wide. The low byte comes from the PCL register, which is a readable and writable register. The upper bits (PC-12:8-) are not readable, but are indirectly writable through the PCLATH register. On any RESET, the upper bits of the PC will be cleared. Figure 2-5 shows the two situations for the loading of the PC. The upper example in the figure shows how the PC is loaded on a write to PCL (PCLATH<4:0>  $\rightarrow$  PCH). The lower example in the figure shows how the PC is loaded during a CALL or GOTO instruction (PCLATH<4:3>  $\rightarrow$  PCH).



### 2.3.1 COMPUTED GOTO

PCLATH

2 PCLATH<4:3>

A computed GOTO is accomplished by adding an offset to the program counter (ADDWF PCL). When doing a table read using a computed GOTO method, care should be exercised if the table location crosses a PCL memory boundary (each 256 byte block). Refer to the application note, *"Implementing a Table Read"* (AN556).

11

Opcode <10:0>

#### 2.3.2 STACK

The PIC16F87X family has an 8-level deep x 13-bit wide hardware stack. The stack space is not part of either program or data space and the stack pointer is not readable or writable. The PC is PUSHed onto the stack when a CALL instruction is executed, or an interrupt causes a branch. The stack is POPed in the event of a RETURN, RETLW or a RETFIE instruction execution. PCLATH is not affected by a PUSH or POP operation.

The stack operates as a circular buffer. This means that after the stack has been PUSHed eight times, the ninth push overwrites the value that was stored from the first push. The tenth push overwrites the second push (and so on).

DS30292C-page 26

- Note 1: There are no status bits to indicate stack overflow or stack underflow conditions.
  - 2: There are no instructions/mnemonics called PUSH or POP. These are actions that occur from the execution of the CALL, RETURN, RETLW and RETFIE instructions, or the vectoring to an interrupt address.

#### 2.4 Program Memory Paging

All PIC16F87X devices are capable of addressing a continuous 8K word block of program memory. The CALL and GOTO instructions provide only 11 bits of address to allow branching within any 2K program memory page. When doing a CALL or GOTO instruction, the upper 2 bits of the address are provided by PCLATH<4:3>. When doing a CALL or GOTO instruction, the user must ensure that the page select bits are programmed so that the desired program memory page is addressed. If a return from a CALL instruction (or interrupt) is executed, the entire 13-bit PC is popped off the stack. Therefore, manipulation of the PCLATH<4:3> bits is not required for the return instructions (which POPs the address from the stack).



Example 2-1 shows the calling of a subroutine in page 1 of the program memory. This example assumes that PCLATH is saved and restored by the Interrupt Service Routine (if interrupts are used).

| ORG 0x500<br>BCF PCLATH,4<br>BSF PCLATH,3 ;Select page 1<br>;(800h-FFFh)<br>CALL SUB1_P1 ;Call subroutine in<br>: ;page 1 (800h-FFFh)<br>:<br>ORG 0x900 ;page 1 (800h-FFFh)<br>SUB1_P1 | EXAMPL  | E 2-1: CAL<br>IN P                                                                              | L OF A SUBROUTINE<br>PAGE 1 FROM PAGE 0                                                                                                                                                                                               |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|-------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| : ;called subroutine<br>;page 1 (800h-FFFh)<br>:<br>RETURN ;return to<br>;Call subroutine<br>;in page 0<br>;(000h-7FFh)                                                                | SUB1_P1 | ORG 0x500<br>BCF PCLATH,4<br>BSF PCLATH,3<br>CALL SUB1_P1<br>:<br>ORG 0x900<br>:<br>:<br>RETURN | <pre>;Select page 1<br/>;(800h-FFFh)<br/>;Call subroutine in<br/>;page 1 (800h-FFFh)<br/>;page 1 (800h-FFFh)<br/>;called subroutine<br/>;page 1 (800h-FFFh)<br/>;return to<br/>;Call subroutine<br/>;in page 0<br/>;(000h-7FFh)</pre> |

#### 2.5 Indirect Addressing, INDF and FSR Registers

The INDF register is not a physical register. Addressing the INDF register will cause indirect addressing.

Indirect addressing is possible by using the INDF register. Any instruction using the INDF register actually accesses the register pointed to by the File Select Register, FSR. Reading the INDF register itself, indirectly (FSR = '0') will read 00h. Writing to the INDF register indirectly results in a no operation (although status bits may be affected). An effective 9-bit address is obtained by concatenating the 8-bit FSR register and the IRP bit (STATUS<7>), as shown in Figure 2-6. A simple program to clear RAM locations 20h-2Fh using indirect addressing is shown in Example 2-2.

| EXAMPL   | E 2-2: | IND   | IRECT ADDRESSING     |
|----------|--------|-------|----------------------|
|          | MOVLW  | 0x20  | ;initialize pointer  |
|          | MOVWF  | FSR   | ;to RAM              |
| NEXT     | CLRF   | INDF  | clear INDF register; |
|          | INCF   | FSR,F | ; inc pointer        |
|          | BTFSS  | FSR,4 | ;all done?           |
|          | GOTO   | NEXT  | ;no clear next       |
| CONTINUE |        |       |                      |
|          | :      |       | ;yes continue        |



FIGURE 2-6: DIRECT/INDIRECT ADDRESSING

© 2001 Microchip Technology Inc.

#### 3.0 I/O PORTS

Some pins for these I/O ports are multiplexed with an alternate function for the peripheral features on the device. In general, when a peripheral is enabled, that pin may not be used as a general purpose I/O pin.

Additional information on I/O ports may be found in the PICmicro™ Mid-Range Reference Manual, (DS33023).

#### 3.1 PORTA and the TRISA Register

PORTA is a 6-bit wide, bi-directional port. The corresponding data direction register is TRISA. Setting a TRISA bit (= 1) will make the corresponding PORTA pin an input (i.e., put the corresponding output driver in a Hi-Impedance mode). Clearing a TRISA bit (= 0) will make the corresponding PORTA pin an output (i.e., put the contents of the output latch on the selected pin).

Reading the PORTA register reads the status of the pins, whereas writing to it will write to the port latch. All write operations are read-modify-write operations. Therefore, a write to a port implies that the port pins are read, the value is modified and then written to the port data latch.

Pin RA4 is multiplexed with the Timer0 module clock input to become the RA4/T0CKI pin. The RA4/T0CKI pin is a Schmitt Trigger input and an open drain output. All other PORTA pins have TTL input levels and full CMOS output drivers.

Other PORTA pins are multiplexed with analog inputs and analog VREF input. The operation of each pin is selected by clearing/setting the control bits in the ADCON1 register (A/D Control Register1).

Note: On a Power-on Reset, these pins are configured as analog inputs and read as '0'.

The TRISA register controls the direction of the RA pins, even when they are being used as analog inputs. The user must ensure the bits in the TRISA register are maintained set when using them as analog inputs.

| BCF   | STATUS, | RP0 | ; |                       |
|-------|---------|-----|---|-----------------------|
| BCF   | STATUS, | RP1 | ; | Bank0                 |
| CLRF  | PORTA   |     | ; | Initialize PORTA by   |
|       |         |     | ; | clearing output       |
|       |         |     | ; | data latches          |
| BSF   | STATUS, | RP0 | ; | Select Bank 1         |
| MOVLW | 0x06    |     | ; | Configure all pins    |
| MOVWF | ADCON1  |     | ; | as digital inputs     |
| MOVLW | 0xCF    |     | ; | Value used to         |
|       |         |     | ; | initialize data       |
|       |         |     | ; | direction             |
| MOVWF | TRISA   |     | ; | Set RA<3:0> as inputs |
|       |         |     | ; | RA<5:4> as outputs    |
|       |         |     | ; | TRISA<7:6>are always  |
|       |         |     | ; | read as '0'.          |
|       |         |     |   |                       |
|       |         |     |   |                       |

© 2001 Microchip Technology Inc.

FIGURE 3-1: BI

BLOCK DIAGRAM OF RA3:RA0 AND RA5 PINS



FIGURE 3-2: BLOCK DIAGRAM OF RA4/T0CKI PIN



#### TABLE 3-1: PORTA FUNCTIONS

| Name         | Bit# | Buffer | Function                                                                        |
|--------------|------|--------|---------------------------------------------------------------------------------|
| RA0/AN0      | bit0 | TTL    | Input/output or analog input.                                                   |
| RA1/AN1      | bit1 | TTL    | Input/output or analog input.                                                   |
| RA2/AN2      | bit2 | TTL    | Input/output or analog input.                                                   |
| RA3/AN3/VREF | bit3 | TTL    | Input/output or analog input or VREF.                                           |
| RA4/T0CKI    | bit4 | ST     | Input/output or external clock input for Timer0. Output is open drain type.     |
| RA5/SS/AN4   | bit5 | TTL    | Input/output or slave select input for synchronous serial port or analog input. |

Legend: TTL = TTL input, ST = Schmitt Trigger input

#### TABLE 3-2: SUMMARY OF REGISTERS ASSOCIATED WITH PORTA

| Address | Name   | Bit 7 | Bit 6 | Bit 5 | Bit 4  | Bit 3      | Bit 2   | Bit 1   | Bit 0 | Value on:<br>POR,<br>BOR | Value on all<br>other<br>RESETS |
|---------|--------|-------|-------|-------|--------|------------|---------|---------|-------|--------------------------|---------------------------------|
| 05h     | PORTA  | -     | -     | RA5   | RA4    | RA3        | RA2     | RA1     | RA0   | 0x 0000                  | 0u 0000                         |
| 85h     | TRISA  | _     | _     | PORTA | Data D | irection F | 11 1111 | 11 1111 |       |                          |                                 |
| 9Fh     | ADCON1 | ADFM  | -     | _     | -      | PCFG3      | PCFG2   | PCFG1   | PCFG0 | 0- 0000                  | 0-0000                          |

 $\begin{array}{l} \mbox{Legend: $x$ = unknown, $u$ = unchanged, $-$ = unimplemented locations read as '0'.} \\ \mbox{Shaded cells are not used by PORTA.} \end{array}$ 

Note: When using the SSP module in SPI Slave mode and SS enabled, the A/D converter must be set to one of the following modes, where PCFG3:PCFG0 = 0100,0101, 011x, 1101, 1110, 1111.

DS30292C-page 30

#### 3.2 PORTB and the TRISB Register

PORTB is an 8-bit wide, bi-directional port. The corresponding data direction register is TRISB. Setting a TRISB bit (= 1) will make the corresponding PORTB pin an input (i.e., put the corresponding output driver in a Hi-Impedance mode). Clearing a TRISB bit (= 0) will make the corresponding PORTB pin an output (i.e., put the contents of the output latch on the selected pin).

Three pins of PORTB are multiplexed with the Low Voltage Programming function: RB3/PGM, RB6/PGC and RB7/PGD. The alternate functions of these pins are described in the Special Features Section.

Each of the PORTB pins has a weak internal pull-up. A single control bit can turn on all the pull-ups. This is performed by clearing bit  $\overline{RBPU}$  (OPTION\_REG<7>). The weak pull-up is automatically turned off when the port pin is configured as an output. The pull-ups are disabled on a Power-on Reset.



Four of the PORTB pins, RB7:RB4, have an interrupton-change feature. Only pins configured as inputs can cause this interrupt to occur (i.e., any RB7:RB4 pin configured as an output is excluded from the interrupton-change comparison). The input pins (of RB7:RB4) are compared with the old value latched on the last read of PORTB. The "mismatch" outputs of RB7:RB4 are OR'ed together to generate the RB Port Change Interrupt with flag bit RBIF (INTCON<0>).

© 2001 Microchip Technology Inc.

This interrupt can wake the device from SLEEP. The user, in the Interrupt Service Routine, can clear the interrupt in the following manner:

- a) Any read or write of PORTB. This will end the mismatch condition.
- b) Clear flag bit RBIF.

A mismatch condition will continue to set flag bit RBIF. Reading PORTB will end the mismatch condition and allow flag bit RBIF to be cleared.

The interrupt-on-change feature is recommended for wake-up on key depression operation and operations where PORTB is only used for the interrupt-on-change feature. Polling of PORTB is not recommended while using the interrupt-on-change feature.

This interrupt-on-mismatch feature, together with software configureable pull-ups on these four pins, allow easy interface to a keypad and make it possible for wake-up on key depression. Refer to the Embedded Control Handbook, *"Implementing Wake-up on Key Strokes*" (AN552).

RB0/INT is an external interrupt input pin and is configured using the INTEDG bit (OPTION\_REG<6>).

RB0/INT is discussed in detail in Section 12.10.1.



#### TABLE 3-3: PORTB FUNCTIONS

| Name                   | Bit# | Buffer                | Function                                                                                                                                          |
|------------------------|------|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| RB0/INT                | bit0 | TTL/ST <sup>(1)</sup> | Input/output pin or external interrupt input. Internal software<br>programmable weak pull-up.                                                     |
| RB1                    | bit1 | TTL                   | Input/output pin. Internal software programmable weak pull-up.                                                                                    |
| RB2                    | bit2 | TTL                   | Input/output pin. Internal software programmable weak pull-up.                                                                                    |
| RB3/PGM <sup>(3)</sup> | bit3 | TTL                   | Input/output pin or programming pin in LVP mode. Internal software<br>programmable weak pull-up.                                                  |
| RB4                    | bit4 | TTL                   | Input/output pin (with interrupt-on-change). Internal software programmable weak pull-up.                                                         |
| RB5                    | bit5 | TTL                   | Input/output pin (with interrupt-on-change). Internal software programmable weak pull-up.                                                         |
| RB6/PGC                | bit6 | TTL/ST <sup>(2)</sup> | Input/output pin (with interrupt-on-change) or In-Circuit Debugger pin.<br>Internal software programmable weak pull-up. Serial programming clock. |
| RB7/PGD                | bit7 | TTL/ST <sup>(2)</sup> | Input/output pin (with interrupt-on-change) or In-Circuit Debugger pin.<br>Internal software programmable weak pull-up. Serial programming data.  |

Legend: TTL = TTL input, ST = Schmitt Trigger input
Note 1: This buffer is a Schmitt Trigger input when configured as the external interrupt.
2: This buffer is a Schmitt Trigger input when used in Serial Programming mode.
3: Low Voltage ICSP Programming (LVP) is enabled by default, which disables the RB3 I/O function. LVP must be disabled to enable RB3 as an I/O pin and allow maximum compatibility to the other 28-pin and 10 pin and allow maximum compatibility to the other 28-pin and 40-pin mid-range devices.

| TABLE 3-4: | SUMMARY OF REGISTERS ASSOCIATE | D WITH PORTE |
|------------|--------------------------------|--------------|
|            |                                |              |

| Address   | Name       | Bit 7 | Bit 6                        | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Value on:<br>POR,<br>BOR | Value on<br>all other<br>RESETS |
|-----------|------------|-------|------------------------------|-------|-------|-------|-------|-------|-------|--------------------------|---------------------------------|
| 06h, 106h | PORTB      | RB7   | RB6                          | RB5   | RB4   | RB3   | RB2   | RB1   | RB0   | XXXX XXXX                | uuuu uuu                        |
| 86h, 186h | TRISB      | PORTB | ORTB Data Direction Register |       |       |       |       |       |       |                          | 1111 111                        |
| 81h, 181h | OPTION_REG | RBPU  | INTEDG                       | TOCS  | TOSE  | PSA   | PS2   | PS1   | PS0   | 1111 1111                | 1111 111                        |

Legend: x = unknown, u = unchanged. Shaded cells are not used by PORTB.

DS30292C-page 32

#### 3.3 PORTC and the TRISC Register

PORTC is an 8-bit wide, bi-directional port. The corresponding data direction register is TRISC. Setting a TRISC bit (= 1) will make the corresponding PORTC pin an input (i.e., put the corresponding output driver in a Hi-Impedance mode). Clearing a TRISC bit (= 0) will make the corresponding PORTC pin an output (i.e., put the contents of the output latch on the selected pin).

PORTC is multiplexed with several peripheral functions (Table 3-5). PORTC pins have Schmitt Trigger input buffers.

When the I<sup>2</sup>C module is enabled, the PORTC<4:3> pins can be configured with normal I<sup>2</sup>C levels, or with SMBus levels by using the CKE bit (SSPSTAT<6>).

When enabling peripheral functions, care should be taken in defining TRIS bits for each PORTC pin. Some peripherals override the TRIS bit to make a pin an output, while other peripherals override the TRIS bit to make a pin an input. Since the TRIS bit override is in effect while the peripheral is enabled, read-modify-write instructions (BSF, BCF, XORWF) with TRISC as destination, should be avoided. The user should refer to the corresponding peripheral section for the correct TRIS bit settings.



(PERIPHERAL OUTPUT OVERRIDE) RC<2:0>, RC<7:5>

PORTC BLOCK DIAGRAM



© 2001 Microchip Technology Inc.

FIGURE 3-6:

PORTC BLOCK DIAGRAM (PERIPHERAL OUTPUT OVERRIDE) RC<4:3>



#### TABLE 3-5: PORTC FUNCTIONS

| Name            | Bit# | Buffer Type | Function                                                                                            |
|-----------------|------|-------------|-----------------------------------------------------------------------------------------------------|
| RC0/T1OSO/T1CKI | bit0 | ST          | Input/output port pin or Timer1 oscillator output/Timer1 clock input.                               |
| RC1/T1OSI/CCP2  | bit1 | ST          | Input/output port pin or Timer1 oscillator input or Capture2 input/<br>Compare2 output/PWM2 output. |
| RC2/CCP1        | bit2 | ST          | Input/output port pin or Capture1 input/Compare1 output/<br>PWM1 output.                            |
| RC3/SCK/SCL     | bit3 | ST          | RC3 can also be the synchronous serial clock for both SPI and $I^2C$ modes.                         |
| RC4/SDI/SDA     | bit4 | ST          | RC4 can also be the SPI Data In (SPI mode) or data I/O (I <sup>2</sup> C mode).                     |
| RC5/SDO         | bit5 | ST          | Input/output port pin or Synchronous Serial Port data output.                                       |
| RC6/TX/CK       | bit6 | ST          | Input/output port pin or USART Asynchronous Transmit or<br>Synchronous Clock.                       |
| RC7/RX/DT       | bit7 | ST          | Input/output port pin or USART Asynchronous Receive or<br>Synchronous Data.                         |

Legend: ST = Schmitt Trigger input

#### TABLE 3-6: SUMMARY OF REGISTERS ASSOCIATED WITH PORTC

| Address | Name                                   | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Value on:<br>POR,<br>BOR | Value on all<br>other<br>RESETS |
|---------|----------------------------------------|-------|-------|-------|-------|-------|-------|-------|-------|--------------------------|---------------------------------|
| 07h     | PORTC                                  | RC7   | RC6   | RC5   | RC4   | RC3   | RC2   | RC1   | RC0   | xxxx xxxx                | uuuu uuuu                       |
| 87h     | 'h TRISC PORTC Data Direction Register |       |       |       |       |       |       |       |       |                          | 1111 1111                       |

Legend: x = unknown, u = unchanged

DS30292C-page 34

#### 3.4 PORTD and TRISD Registers

PORTD and TRISD are not implemented on the PIC16F873 or PIC16F876.

PORTD is an 8-bit port with Schmitt Trigger input buffers. Each pin is individually configureable as an input or output.

PORTD can be configured as an 8-bit wide microprocessor port (parallel slave port) by setting control bit PSPMODE (TRISE<4>). In this mode, the input buffers are TTL.



#### TABLE 3-7: PORTD FUNCTIONS

| Name     | Bit# | Buffer Type           | Function                                           |
|----------|------|-----------------------|----------------------------------------------------|
| RD0/PSP0 | bit0 | ST/TTL <sup>(1)</sup> | Input/output port pin or parallel slave port bit0. |
| RD1/PSP1 | bit1 | ST/TTL <sup>(1)</sup> | Input/output port pin or parallel slave port bit1. |
| RD2/PSP2 | bit2 | ST/TTL <sup>(1)</sup> | Input/output port pin or parallel slave port bit2. |
| RD3/PSP3 | bit3 | ST/TTL <sup>(1)</sup> | Input/output port pin or parallel slave port bit3. |
| RD4/PSP4 | bit4 | ST/TTL <sup>(1)</sup> | Input/output port pin or parallel slave port bit4. |
| RD5/PSP5 | bit5 | ST/TTL <sup>(1)</sup> | Input/output port pin or parallel slave port bit5. |
| RD6/PSP6 | bit6 | ST/TTL <sup>(1)</sup> | Input/output port pin or parallel slave port bit6. |
| RD7/PSP7 | bit7 | ST/TTL <sup>(1)</sup> | Input/output port pin or parallel slave port bit7. |

Legend: ST = Schmitt Trigger input, TTL = TTL input

Note 1: Input buffers are Schmitt Triggers when in I/O mode and TTL buffers when in Parallel Slave Port mode.

#### TABLE 3-8: SUMMARY OF REGISTERS ASSOCIATED WITH PORTD

| Address | Name  | Bit 7 | Bit 6  | Bit 5    | Bit 4   | Bit 3     | Bit 2     | Bit 1     | Bit 0     | Value on:<br>POR,<br>BOR | Value on<br>all other<br>RESETS |
|---------|-------|-------|--------|----------|---------|-----------|-----------|-----------|-----------|--------------------------|---------------------------------|
| 08h     | PORTD | RD7   | RD6    | RD5      | RD4     | RD3       | RD2       | RD1       | RD0       | xxxx xxxx                | uuuu uuuu                       |
| 88h     | TRISD | PORT  | D Data | Directio |         | 1111 1111 | 1111 1111 |           |           |                          |                                 |
| 89h     | TRISE | IBF   | OBF    | IBOV     | PSPMODE | —         | PORTE     | 0000 -111 | 0000 -111 |                          |                                 |

Legend: x = unknown, u = unchanged, - = unimplemented, read as '0'. Shaded cells are not used by PORTD.

© 2001 Microchip Technology Inc.

FIGURE 3-8:

### **PIC16F87X**

#### 3.5 PORTE and TRISE Register

PORTE and TRISE are not implemented on the PIC16F873 or PIC16F876.

PORTE has three pins (RE0/RD/AN5, RE1/WR/AN6, and RE2/CS/AN7) which are individually configureable as inputs or outputs. These pins have Schmitt Trigger input buffers.

The PORTE pins become the I/O control inputs for the microprocessor port when bit PSPMODE (TRISE<4>) is set. In this mode, the user must make certain that the TRISE<2:0> bits are set, and that the pins are configured as digital inputs. Also ensure that ADCON1 is configured for digital I/O. In this mode, the input buffers are TTL.

Register 3-1 shows the TRISE register, which also controls the parallel slave port operation.

PORTE pins are multiplexed with analog inputs. When selected for analog input, these pins will read as '0's.

TRISE controls the direction of the RE pins, even when they are being used as analog inputs. The user must make sure to keep the pins configured as inputs when using them as analog inputs.

Note: On a Power-on Reset, these pins are configured as analog inputs, and read as '0'.



PORTE BLOCK DIAGRAM

TABLE 3-9: PORTE FUNCTIONS

| Name       | Bit#    | Buffer Type           | Function                                                                                                                                                                                                |
|------------|---------|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RE0/RD/AN5 | bit0    | ST/TTL <sup>(1)</sup> | I/O port pin or read control input in Parallel Slave Port mode or analog input:<br>RD<br>1 = Idle                                                                                                       |
|            |         |                       | <ul> <li>Read operation. Contents of PORTD register are output to PORTD<br/>I/O pins (if chip selected)</li> </ul>                                                                                      |
| RE1/WR/AN6 | bit1    | ST/TTL <sup>(1)</sup> | I/O port pin or write control input in Parallel Slave Port mode or analog input:<br>WR<br>1 = Idle<br>0 = Write operation. Value of PORTD I/O pins is latched into PORTD<br>register (if chip selected) |
| RE2/CS/AN7 | bit2    | ST/TTL <sup>(1)</sup> | <u>I/O</u> port pin or chip select control input in Parallel Slave Port mode or analog input:<br>CS<br>1 = Device is not selected<br>0 = Device is selected                                             |
| Logand: CT | Cohmitt | Trigger input         | 0 = Device is selected                                                                                                                                                                                  |

Legend: ST = Schmitt Trigger input, TTL = TTL input Note 1: Input buffers are Schmitt Triggers when in I/O mode and TTL buffers when in Parallel Slave Port mode.

#### TABLE 3-10: SUMMARY OF REGISTERS ASSOCIATED WITH PORTE

| Address   | Name   | Bit 7       | Bit 6  | Bit 5 | Bit 4      | Bit 3    | Bit 2   | Bit 1      | Bit 0      | Value on:<br>POR, BOR | Value on<br>all other<br>RESETS |
|-----------|--------|-------------|--------|-------|------------|----------|---------|------------|------------|-----------------------|---------------------------------|
| 09h       | PORTE  | -           | -      | -     | -          | -        | RE2     | RE1        | RE0        | xxx                   | uuu                             |
| 89h       | TRISE  | IBF         | OBF    | IBOV  | PSPMODE    | -        | PORTE I | Data Direc | tion Bits  | 0000 -111             | 0000 -111                       |
| 9Fh       | ADCON1 | ADFM        | -      | -     | -          | PCFG3    | PCFG2   | PCFG1      | PCFG0      | 0- 0000               | 0- 0000                         |
| Logond: 1 |        | (n. 1) – II | nchang | d –   | inimplemen | tod road | 2 '0' 2 | haded co   | lle are no | t used by PC          | DTE                             |

Legend: x = unknown, u = unchanged, - = unimplemented, read as '0'. Shaded cells are not used by PORTE.

DS30292C-page 36

#### 4.0 DATA EEPROM AND FLASH PROGRAM MEMORY

The Data EEPROM and FLASH Program Memory are readable and writable during normal operation over the entire VDD range. These operations take place on a single byte for Data EEPROM memory and a single word for Program memory. A write operation causes an erase-then-write operation to take place on the specified byte or word. A bulk erase operation may not be issued from user code (which includes removing code protection).

Access to program memory allows for checksum calculation. The values written to program memory do not need to be valid instructions. Therefore, up to 14-bit numbers can be stored in memory for use as calibration parameters, serial numbers, packed 7-bit ASCII, etc. Executing a program memory location containing data that form an invalid instruction, results in the execution of a NOP instruction.

The EEPROM Data memory is rated for high erase/ write cycles (specification D120). The FLASH program memory is rated much lower (specification D130), because EEPROM data memory can be used to store frequently updated values. An on-chip timer controls the write time and it will vary with voltage and temperature, as well as from chip to chip. Please refer to the specifications for exact limits (specifications D122 and D133).

A byte or word write automatically erases the location and writes the new value (erase before write). Writing to EEPROM data memory does not impact the operation of the device. Writing to program memory will cease the execution of instructions until the write is complete. The program memory cannot be accessed during the write. During the write operation, the oscillator continues to run, the peripherals continue to function and interrupt events will be detected and essentially "queued" until the write is complete. When the write completes, the next instruction in the pipeline is executed and the branch to the interrupt vector will take place, if the interrupt is enabled and occurred during the write.

Read and write access to both memories take place indirectly through a set of Special Function Registers (SFR). The six SFRs used are:

- EEDATA
- EEDATH
- EEADR
- EEADRH
- EECON1
- · EECON2

The EEPROM data memory allows byte read and write operations without interfering with the normal operation of the microcontroller. When interfacing to EEPROM data memory, the EEADR register holds the address to be accessed. Depending on the operation, the EEDATA register holds the data to be written, or the data read, at the address in EEADR. The PIC16F873/874 devices have 128 bytes of EEPROM data memory and therefore, require that the MSb of EEADR remain clear. The EEPROM data memory on these devices do not wrap around to 0, i.e., 0x80 in the EEADR does not map to 0x00. The PIC16F876/877 devices have 256 bytes of EEPROM data memory and therefore, uses all 8-bits of the EEADR.

The FLASH program memory allows non-intrusive read access, but write operations cause the device to stop executing instructions, until the write completes. When interfacing to the program memory, the EEADRH:EEADR registers form a two-byte word, which holds the 13-bit address of the memory location being accessed. The register combination of EEDATH:EEDATA holds the 14-bit data for writes, or reflects the value of program memory after a read operation. Just as in EEPROM data memory accesses, the value of the EEADRH:EEADR registers must be within the valid range of program memory, depending on the device: 0000h to 1FFFh for the PIC16F873/874, or 0000h to 3FFFh for the PIC16F876/877. Addresses outside of this range do not wrap around to 0000h (i.e., 4000h does not map to 0000h on the PIC16F877)

#### 4.1 EECON1 and EECON2 Registers

The EECON1 register is the control register for configuring and initiating the access. The EECON2 register is not a physically implemented register, but is used exclusively in the memory write sequence to prevent inadvertent writes.

There are many bits used to control the read and write operations to EEPROM data and FLASH program memory. The EEPGD bit determines if the access will be a program or data memory access. When clear, any subsequent operations will work on the EEPROM data memory. When set, all subsequent operations will operate in the program memory.

Read operations only use one additional bit, RD, which initiates the read operation from the desired memory location. Once this bit is set, the value of the desired memory location will be available in the data registers. This bit cannot be cleared by firmware. It is automatically cleared at the end of the read operation. For EEPROM data memory reads, the data will be available in the EEDATA register in the very next instruction cycle after the RD bit is set. For program memory reads, the data will be loaded into the EEDATH:EEDATA registers, following the second instruction after the RD bit is set.

© 2001 Microchip Technology Inc.

Write operations have two control bits, WR and WREN, and two status bits, WRERR and EEIF. The WREN bit is used to enable or disable the write operation. When WREN is clear, the write operation will be disabled. Therefore, the WREN bit must be set before executing a write operation. The WR bit is used to initiate the write operation. It also is automatically cleared at the end of the write operation. The interrupt flag EEIF is used to determine when the memory write completes. This flag must be cleared in software before setting the WR bit. For EEPROM data memory, once the WREN bit and the WR bit have been set, the desired memory address in EEADR will be erased, followed by a write of the data in EEDATA. This operation takes place in parallel with the microcontroller continuing to execute normally. When the write is complete, the EEIF flag bit will be set. For program memory, once the WREN bit and the WR bit have been set, the microcontroller will cease to execute instructions. The desired memory location pointed to by EEADRH:EEADR will be erased. Then, the data value in EEDATH:EEDATA will be programmed. When complete, the EEIF flag bit will be set and the microcontroller will continue to execute code.

The WRERR bit is used to indicate when the PIC16F87X device has been reset during a write operation. WRERR should be cleared after Power-on Reset. Thereafter, it should be checked on any other RESET. The WRERR bit is set when a write operation is interrupted by a MCLR Reset, or a WDT Time-out Reset, during normal operation. In these situations, following a RESET, the user should check the WRERR bit and rewrite the memory location, if set. The contents of the data registers, address registers and EEPGD bit are not affected by either MCLR Reset, or WDT Time-out Reset, during normal operation.

#### REGISTER 4-1: EECON1 REGISTER (ADDRESS 18Ch)

|               | R/W-x                                                                                                                                                                  | U-0           | U-0     | U-0          | R/W-x          | R/W-0     | R/S-0         | R/S-0  |
|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|---------|--------------|----------------|-----------|---------------|--------|
|               | EEPGD                                                                                                                                                                  | -             | -       | -            | WRERR          | WREN      | WR            | RD     |
|               | bit 7                                                                                                                                                                  |               |         |              |                |           |               | bit 0  |
|               |                                                                                                                                                                        |               |         |              |                |           |               |        |
| bit 7         | EEPGD: Program/Data EEPROM Select bit                                                                                                                                  |               |         |              |                |           |               |        |
|               | <ul> <li>1 = Accesses program memory</li> <li>0 = Accesses data memory</li> <li>(This bit cannot be changed while a read or write operation is in progress)</li> </ul> |               |         |              |                |           |               |        |
| bit 6-4       | Unimplemented: Read as '0'                                                                                                                                             |               |         |              |                |           |               |        |
| bit 3         | WRERR: EEPROM Error Flag bit                                                                                                                                           |               |         |              |                |           |               |        |
|               | 1 = A write operation is prematurely terminated                                                                                                                        |               |         |              |                |           |               |        |
|               | (any MCLR Reset or any WDT Reset during normal operation)                                                                                                              |               |         |              |                |           |               |        |
| 1.1.0         | 0 = The write operation completed                                                                                                                                      |               |         |              |                |           |               |        |
| DIT 2         | WREN: EEPHOM Write Enable bit                                                                                                                                          |               |         |              |                |           |               |        |
|               | <ul> <li>a Allows write cycles</li> <li>a Inhibits write to the EEPROM</li> </ul>                                                                                      |               |         |              |                |           |               |        |
| bit 1         | WR: Write Control bit                                                                                                                                                  |               |         |              |                |           |               |        |
|               | 1 = Initiates a write cycle. (The bit is cleared by hardware once write is complete. The WR bit                                                                        |               |         |              |                |           |               |        |
|               | can only be set (not cleared) in software.)                                                                                                                            |               |         |              |                |           |               |        |
| <b>h</b> it 0 | 0 = Write C                                                                                                                                                            | ycie to the E |         | complete     |                |           |               |        |
| DIEU          | nu. nedu Control bit                                                                                                                                                   |               |         |              |                |           |               |        |
|               | cleared) in software.)                                                                                                                                                 |               |         |              |                |           |               |        |
|               | 0 = Does not initiate an EEPROM read                                                                                                                                   |               |         |              |                |           |               |        |
|               |                                                                                                                                                                        |               |         |              |                |           |               |        |
|               | Legend:                                                                                                                                                                |               |         |              |                |           |               |        |
|               | R = Reada                                                                                                                                                              | ble bit       | W = V   | Vritable bit | U = Unimpl     | emented b | it, read as ' | 0'     |
|               | - n = Value                                                                                                                                                            | at POR        | '1' = E | Bit is set   | '0' = Bit is c | leared    | x = Bit is u  | nknown |

DS30292C-page 42

#### 4.2 Reading the EEPROM Data Memory

Reading EEPROM data memory only requires that the desired address to access be written to the EEADR register and clear the EEPGD bit. After the RD bit is set, data will be available in the EEDATA register on the very next instruction cycle. EEDATA will hold this value until another read operation is initiated or until it is written by firmware.

The steps to reading the EEPROM data memory are:

- Write the address to EEDATA. Make sure that the address is not larger than the memory size of the PIC16F87X device.
- 2. Clear the EEPGD bit to point to EEPROM data memory.
- 3. Set the RD bit to start the read operation.
- 4. Read the data from the EEDATA register.

#### EXAMPLE 4-1: EEPROM DATA READ

| BSF   | STATUS, | RP1   | ;                     |
|-------|---------|-------|-----------------------|
| BCF   | STATUS, | RP0   | ;Bank 2               |
| MOVF  | ADDR, W |       | ;Write address        |
| MOVWF | EEADR   |       | ;to read from         |
| BSF   | STATUS, | RP0   | ;Bank 3               |
| BCF   | EECON1, | EEPGD | ;Point to Data memory |
| BSF   | EECON1, | RD    | ;Start read operation |
| BCF   | STATUS, | RP0   | ;Bank 2               |
| MOVF  | EEDATA, | W     | ;W = EEDATA           |

#### 4.3 Writing to the EEPROM Data Memory

There are many steps in writing to the EEPROM data memory. Both address and data values must be written to the SFRs. The EEPGD bit must be cleared, and the WREN bit must be set, to enable writes. The WREN bit should be kept clear at all times, except when writing to the EEPROM data. The WR bit can only be set if the WREN bit was set in a previous operation, i.e., they both cannot be set in the same operation. The WREN bit should then be cleared by firmware after the write. Clearing the WREN bit before the write actually completes will not terminate the write in progress.

Writes to EEPROM data memory must also be prefaced with a special sequence of instructions, that prevent inadvertent write operations. This is a sequence of five instructions that must be executed without interruptions. The firmware should verify that a write is not in progress, before starting another cycle. The steps to write to EEPROM data memory are:

- 1. If step 10 is not implemented, check the WR bit to see if a write is in progress.
- Write the address to EEADR. Make sure that the address is not larger than the memory size of the PIC16F87X device.
- 3. Write the 8-bit data value to be programmed in the EEDATA register.
- Clear the EEPGD bit to point to EEPROM data memory.
- 5. Set the WREN bit to enable program operations.
- 6. Disable interrupts (if enabled).
- 7. Execute the special five instruction sequence:
   Write 55h to EECON2 in two steps (first to W, then to EECON2)
  - Write AAh to EECON2 in two steps (first to W. then to EECON2)
  - Set the WR bit
- 8. Enable interrupts (if using interrupts).
- Clear the WREN bit to disable program operations.
- At the completion of the write cycle, the WR bit is cleared and the EEIF interrupt flag bit is set. (EEIF must be cleared by firmware.) If step 1 is not implemented, then firmware should check for EEIF to be set, or WR to clear, to indicate the end of the program cycle.

#### EXAMPLE 4-2: EEPROM DATA WRITE

| BSF   | STATUS, 1 | RP1   | ;                        |
|-------|-----------|-------|--------------------------|
| BSF   | STATUS, 1 | RP0   | ;Bank 3                  |
| BTFSC | EECON1, N | WR    | ;Wait for                |
| GOTO  | \$-1      |       | ;write to finish         |
| BCF   | STATUS, 1 | RP0   | ;Bank 2                  |
| MOVF  | ADDR, W   |       | ;Address to              |
| MOVWF | EEADR     |       | ;write to                |
| MOVF  | VALUE, W  |       | ;Data to                 |
| MOVWF | EEDATA    |       | ;write                   |
| BSF   | STATUS, 1 | RP0   | ;Bank 3                  |
| BCF   | EECON1, 1 | EEPGD | ;Point to Data memory    |
| BSF   | EECON1, N | WREN  | ;Enable writes           |
|       |           |       | ;Only disable interrupts |
| BCF   | INTCON, ( | GIE   | ;if already enabled,     |
|       |           |       | ;otherwise discard       |
| MOVLW | 0x55      |       | ;Write 55h to            |
| MOVWF | EECON2    |       | ; EECON2                 |
| MOVLW | 0xAA      |       | ;Write AAh to            |
| MOVWF | EECON2    |       | ; EECON2                 |
| BSF   | EECON1, N | WR    | ;Start write operation   |
|       |           |       | ;Only enable interrupts  |
| BSF   | INTCON, ( | GIE   | ; if using interrupts,   |
|       |           |       | ;otherwise discard       |
| BCF   | EECON1, N | WREN  | ;Disable writes          |
|       |           |       |                          |

© 2001 Microchip Technology Inc.
## 11.0 ANALOG-TO-DIGITAL CONVERTER (A/D) MODULE

The Analog-to-Digital (A/D) Converter module has five inputs for the 28-pin devices and eight for the other devices.

The analog input charges a sample and hold capacitor. The output of the sample and hold capacitor is the input into the converter. The converter then generates a digital result of this analog level via successive approximation. The A/D conversion of the analog input signal results in a corresponding 10-bit digital number. The A/D module has high and low voltage reference input that is software selectable to some combination of VDD, VSs, RA2, or RA3.

The A/D converter has a unique feature of being able to operate while the device is in SLEEP mode. To operate in SLEEP, the A/D clock must be derived from the A/D's internal RC oscillator. The A/D module has four registers. These registers are:

- A/D Result High Register (ADRESH)
- · A/D Result Low Register (ADRESL)
- A/D Control Register0 (ADCON0)
- A/D Control Register1 (ADCON1)

The ADCON0 register, shown in Register 11-1, controls the operation of the A/D module. The ADCON1 register, shown in Register 11-2, configures the functions of the port pins. The port pins can be configured as analog inputs (RA3 can also be the voltage reference), or as digital I/O.

Additional information on using the A/D module can be found in the PICmicro™ Mid-Range MCU Family Reference Manual (DS33023).

### REGISTER 11-1: ADCON0 REGISTER (ADDRESS: 1Fh)

|         | R/W-0                                                                                                       | R/W-0                                                                                                                                                                 | R/W-0                                                                                                             | R/W-0                                   | R/W-0                          | R/W-0                       | U-0           | R/W-0   |
|---------|-------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------|-----------------------------------------|--------------------------------|-----------------------------|---------------|---------|
|         | ADCS1                                                                                                       | ADCS0                                                                                                                                                                 | CHS2                                                                                                              | CHS1                                    | CHS0                           | GO/DONE                     | -             | ADON    |
|         | bit 7                                                                                                       |                                                                                                                                                                       |                                                                                                                   |                                         |                                |                             |               | bit 0   |
| bit 7-6 | ADCS1:AD<br>00 = FOSC/2<br>01 = FOSC/2<br>10 = FOSC/2<br>11 = FRC (C                                        | <b>CS0:</b> A/D Co<br>2<br>3<br>32<br>lock derived                                                                                                                    | nversion Clo<br>from the inte                                                                                     | rnal A/D mod                            | s<br>lule RC oscill            | ator)                       |               |         |
| bit 5-3 | CHS2:CHS0<br>000 = chan<br>001 = chan<br>010 = chan<br>011 = chan<br>100 = chan<br>110 = chan<br>111 = chan | 0: Analog Ch<br>nel 0, (RA0/A<br>nel 1, (RA1/A<br>nel 2, (RA2/A<br>nel 3, (RA3/A<br>nel 3, (RA3/A<br>nel 4, (RA5/A<br>nel 5, (RE0/A<br>nel 6, (RE1/A<br>nel 7, (RE2/A | annel Select<br>N0)<br>N1)<br>N2)<br>N3)<br>N4)<br>N5) <sup>(1)</sup><br>N6) <sup>(1)</sup><br>N7) <sup>(1)</sup> | bits                                    |                                |                             |               |         |
| bit 2   | <b>GO/DONE:</b><br><u>If ADON = 1</u><br>1 = A/D con<br>0 = A/D con<br>convers                              | A/D Convers<br><u>:</u><br>version in pr<br>version not in<br>ion is comple                                                                                           | ion Status bi<br>ogress (settii<br>n progress (t<br>ete)                                                          | t<br>ng this bit sta<br>his bit is auto | rts the A/D c<br>matically cle | onversion)<br>ared by hardw | ware when t   | ne A/D  |
| bit 1   | Unimpleme                                                                                                   | nted: Read                                                                                                                                                            | as '0'                                                                                                            |                                         |                                |                             |               |         |
| bit 0   | <b>ADON</b> : A/D<br>1 = A/D con<br>0 = A/D con<br><b>Note 1:</b> T                                         | On bit<br>verter modul<br>verter modul<br>hese channe                                                                                                                 | e is operating<br>e is shut-off a<br>Is are not av                                                                | g<br>and consume<br>railable on Ple     | es no operatii<br>C16F873/876  | ng current<br>6 devices.    |               |         |
|         | Logond:                                                                                                     |                                                                                                                                                                       |                                                                                                                   |                                         |                                |                             |               |         |
|         | R - Roadok                                                                                                  | lo hit                                                                                                                                                                | 10/ - 10/-                                                                                                        | ritabla bit                             |                                | alomontod bit               | road as '0'   |         |
|         |                                                                                                             |                                                                                                                                                                       | VV = VVI<br>'1' - Rit                                                                                             | ic cot                                  | '0' - Bit is                   | cleared                     | y - Bit is up | known   |
|         | - II - Value                                                                                                | arron                                                                                                                                                                 | i = Dit                                                                                                           | 19 901                                  |                                | ueai eu                     |               | KIIOWII |

© 2001 Microchip Technology Inc.

DS30292C-page 111

#### REGISTER 11-2: ADCON1 REGISTER (ADDRESS 9Fh)

| U-0   | U-0 | R/W-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 |
|-------|-----|-------|-----|-------|-------|-------|-------|
| ADFM  | —   | -     | _   | PCFG3 | PCFG2 | PCFG1 | PCFG0 |
| bit 7 |     |       |     |       |       |       | bit 0 |

bit 7

**ADFM:** A/D Result Format Select bit 1 = Right justified. 6 Most Significant bits of ADRESH are read as '0'.

0 = Left justified. 6 Least Significant bits of ADRESL are read as '0'.

bit 6-4 Unimplemented: Read as '0'

bit 3-0 PCFG3:PCFG0: A/D Port Configuration Control bits:

| PCFG | : AN7 <sup>(1)</sup><br>RE2 | AN6 <sup>(1)</sup><br>RE1 | AN5 <sup>(1)</sup><br>RE0 | AN4<br>RA5 | AN3<br>RA3 | AN2<br>RA2 | AN1<br>RA1 | AN0<br>RA0 | VREF+ | VREF- | CHAN/<br>Refs <sup>(2)</sup> |
|------|-----------------------------|---------------------------|---------------------------|------------|------------|------------|------------|------------|-------|-------|------------------------------|
| 0000 | A                           | Α                         | Α                         | А          | Α          | Α          | Α          | Α          | VDD   | Vss   | 8/0                          |
| 0001 | А                           | Α                         | А                         | А          | VREF+      | Α          | Α          | Α          | RA3   | Vss   | 7/1                          |
| 0010 | D                           | D                         | D                         | А          | Α          | Α          | А          | Α          | VDD   | Vss   | 5/0                          |
| 0011 | D                           | D                         | D                         | А          | VREF+      | Α          | Α          | Α          | RA3   | Vss   | 4/1                          |
| 0100 | D                           | D                         | D                         | D          | Α          | D          | А          | Α          | VDD   | Vss   | 3/0                          |
| 0101 | D                           | D                         | D                         | D          | VREF+      | D          | Α          | Α          | RA3   | Vss   | 2/1                          |
| 011x | D                           | D                         | D                         | D          | D          | D          | D          | D          | VDD   | Vss   | 0/0                          |
| 1000 | А                           | Α                         | А                         | А          | VREF+      | VREF-      | Α          | Α          | RA3   | RA2   | 6/2                          |
| 1001 | D                           | D                         | А                         | А          | А          | Α          | Α          | Α          | VDD   | Vss   | 6/0                          |
| 1010 | D                           | D                         | А                         | А          | VREF+      | Α          | А          | Α          | RA3   | Vss   | 5/1                          |
| 1011 | D                           | D                         | А                         | А          | VREF+      | VREF-      | Α          | Α          | RA3   | RA2   | 4/2                          |
| 1100 | D                           | D                         | D                         | А          | VREF+      | VREF-      | А          | Α          | RA3   | RA2   | 3/2                          |
| 1101 | D                           | D                         | D                         | D          | VREF+      | VREF-      | Α          | Α          | RA3   | RA2   | 2/2                          |
| 1110 | D                           | D                         | D                         | D          | D          | D          | D          | Α          | VDD   | Vss   | 1/0                          |
| 1111 | D                           | D                         | D                         | D          | VREF+      | VREF-      | D          | А          | RA3   | RA2   | 1/2                          |

A = Analog input D = Digital I/O

Note 1: These channels are not available on PIC16F873/876 devices.

This column indicates the number of analog channels available as A/D inputs and the number of analog channels used as voltage reference inputs.

| Legend.                                          |                              |
|--------------------------------------------------|------------------------------|
| R = Readable bit W = Writable bit U = Unin       | nplemented bit, read as '0'  |
| - n = Value at POR '1' = Bit is set '0' = Bit is | s cleared x = Bit is unknown |

The ADRESH:ADRESL registers contain the 10-bit result of the A/D conversion. When the A/D conversion is complete, the result is loaded into this A/D result register pair, the GO/DONE bit (ADCON0<2>) is cleared and the A/D interrupt flag bit ADIF is set. The block diagram of the A/D module is shown in Figure 11-1.

After the A/D module has been configured as desired, the selected channel must be acquired before the con-version is started. The analog input channels must have their corresponding TRIS bits selected as inputs. To determine sample time, see Section 11.1. After this acquisition time has elapsed, the A/D conversion can be started.

DS30292C-page 112

© 2001 Microchip Technology Inc.

### 10.0 ADDRESSABLE UNIVERSAL SYNCHRONOUS ASYNCHRONOUS RECEIVER TRANSMITTER (USART)

The Universal Synchronous Asynchronous Receiver Transmitter (USART) module is one of the two serial I/O modules. (USART is also known as a Serial Communications Interface or SCI.) The USART can be configured as a full duplex asynchronous system that can communicate with peripheral devices such as CRT terminals and personal computers, or it can be configured as a half duplex synchronous system that can communicate with peripheral devices such as A/D or D/A integrated circuits, serial EEPROMs etc.

- The USART can be configured in the following modes:
- Asynchronous (full duplex)
- Synchronous Master (half duplex)
- Synchronous Slave (half duplex)

Bit SPEN (RCSTA<7>) and bits TRISC<7:6> have to be set in order to configure pins RC6/TX/CK and RC7/RX/DT as the Universal Synchronous Asynchronous Receiver Transmitter.

The USART module also has a multi-processor communication capability using 9-bit address detection.

| REGISTER 10-1: | TXSTA: TRANSMIT STATUS AND CONTROL REGISTER (ADDRESS 98h) |
|----------------|-----------------------------------------------------------|
|----------------|-----------------------------------------------------------|

|               | R/W-0                                                                    | R/W-0                                          | R/W-0                       | R/W-0                  | U-0            | R/W-0     | R-1            | R/W-0  |  |  |  |
|---------------|--------------------------------------------------------------------------|------------------------------------------------|-----------------------------|------------------------|----------------|-----------|----------------|--------|--|--|--|
|               | CSRC                                                                     | TX9                                            | TXEN                        | SYNC                   | _              | BRGH      | TRMT           | TX9D   |  |  |  |
|               | bit 7                                                                    |                                                |                             |                        |                |           |                | bit 0  |  |  |  |
|               |                                                                          |                                                |                             |                        |                |           |                |        |  |  |  |
| bit 7         | CSRC: Clock Source Select bit                                            |                                                |                             |                        |                |           |                |        |  |  |  |
|               | <u>Asynchronous mode:</u><br>Don't care                                  |                                                |                             |                        |                |           |                |        |  |  |  |
|               | 1 = Master r<br>0 = Slave m                                              | <u>s mode:</u><br>node (clock<br>ode (clock fr | generated ir<br>om external | nternally from source) | n BRG)         |           |                |        |  |  |  |
| bit 6         | <b>TX9</b> : 9-bit Transmit Enable bit<br>1 = Selects 9-bit transmission |                                                |                             |                        |                |           |                |        |  |  |  |
|               | 0 = Selects                                                              | B-bit transmi                                  | ssion                       |                        |                |           |                |        |  |  |  |
| bit 5         | TXEN: Tran                                                               | smit Enable                                    | bit                         |                        |                |           |                |        |  |  |  |
|               | 0 = Transmi                                                              | t disabled                                     |                             |                        |                |           |                |        |  |  |  |
|               |                                                                          |                                                |                             |                        | ada            |           |                |        |  |  |  |
| <b>L</b> :1 4 | NOTE: SHEN                                                               | DT Mada O                                      |                             | IN SYNC II             | lode.          |           |                |        |  |  |  |
| DIT 4         | 1 = Synchro                                                              | NRT MODE 5<br>nous mode                        | elect dit                   |                        |                |           |                |        |  |  |  |
|               | 0 = Asynchr                                                              | onous mode                                     |                             |                        |                |           |                |        |  |  |  |
| bit 3         | Unimpleme                                                                | nted: Read                                     | as '0'                      |                        |                |           |                |        |  |  |  |
| bit 2         | BRGH: High                                                               | Baud Rate                                      | Select bit                  |                        |                |           |                |        |  |  |  |
|               | Asynchrono                                                               | us mode:                                       |                             |                        |                |           |                |        |  |  |  |
|               | 1 = High spe                                                             | ed                                             |                             |                        |                |           |                |        |  |  |  |
|               | 0 = Low spe                                                              | ea<br>e modo:                                  |                             |                        |                |           |                |        |  |  |  |
|               | Unused in this mode                                                      |                                                |                             |                        |                |           |                |        |  |  |  |
| bit 1         | TRMT: Trans                                                              | smit Shift Re                                  | gister Statu                | s bit                  |                |           |                |        |  |  |  |
|               | 1 = TSR em                                                               | pty                                            |                             |                        |                |           |                |        |  |  |  |
| hit 0         | 0 = ISH TUII                                                             | it of Tronomi                                  | t Data can                  | ho parity hit          |                |           |                |        |  |  |  |
| DILU          | · <b>/ 3D</b> . 901 D                                                    |                                                | i Daia, call                | be parity bit          |                |           |                |        |  |  |  |
|               | Legend:                                                                  |                                                |                             |                        |                |           |                |        |  |  |  |
|               | R = Readab                                                               | le bit                                         | W = Wri                     | table bit              | U = Unimpl     | emented I | bit, read as ' | D'     |  |  |  |
|               | - n = Value a                                                            | at POR                                         | '1' = Bit                   | is set                 | '0' = Bit is c | leared    | x = Bit is ur  | nknown |  |  |  |
|               |                                                                          |                                                |                             |                        |                |           |                |        |  |  |  |

© 2001 Microchip Technology Inc.

DS30292C-page 95

| REGISTER 10-2: | RCSTA: RECEIVE STATUS AND CONTROL REGISTER (ADDRESS 18h)                                                                                                                                                                                       |             |              |              |              |              |               |           |  |  |  |  |
|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|--------------|--------------|--------------|---------------|-----------|--|--|--|--|
|                | R/W-0                                                                                                                                                                                                                                          | R/W-0       | R/W-0        | R/W-0        | R/W-0        | R-0          | R-0           | R-x       |  |  |  |  |
|                | SPEN                                                                                                                                                                                                                                           | RX9         | SREN         | CREN         | ADDEN        | FERR         | OERR          | RX9D      |  |  |  |  |
|                | bit 7                                                                                                                                                                                                                                          |             |              |              | 1            |              |               | bit 0     |  |  |  |  |
| bit 7          | <b>SPEN:</b> Serial Port Enable bit<br>1 = Serial port enabled (configures RC7/RX/DT and RC6/TX/CK pins as serial port pins)<br>0 = Serial port disabled                                                                                       |             |              |              |              |              |               |           |  |  |  |  |
| bit 6          | <b>RX9</b> : 9-bit Receive Enable bit<br>1 = Selects 9-bit reception<br>0 = Selects 8-bit reception                                                                                                                                            |             |              |              |              |              |               |           |  |  |  |  |
| bit 5          | SREN: Sing                                                                                                                                                                                                                                     | gle Receive | Enable bit   |              |              |              |               |           |  |  |  |  |
|                | Asynchronous mode:<br>Don't care                                                                                                                                                                                                               |             |              |              |              |              |               |           |  |  |  |  |
|                | <u>Synchronous mode - master:</u><br>1 = Enables single receive<br>0 = Disables single receive<br>This bit is cleared after reception is complete.                                                                                             |             |              |              |              |              |               |           |  |  |  |  |
|                | <u>Synchronous mode - slave:</u><br>Don't care                                                                                                                                                                                                 |             |              |              |              |              |               |           |  |  |  |  |
| bit 4          | CREN: Continuous Receive Enable bit                                                                                                                                                                                                            |             |              |              |              |              |               |           |  |  |  |  |
|                | Asynchronous mode:<br>1 = Enables continuous receive<br>0 = Disables continuous receive                                                                                                                                                        |             |              |              |              |              |               |           |  |  |  |  |
|                | Synchronous mode:<br>1 = Enables continuous receive until enable bit CREN is cleared (CREN overrides SREN)<br>0 = Disables continuous receive                                                                                                  |             |              |              |              |              |               |           |  |  |  |  |
| bit 3          | ADDEN: Address Detect Enable bit                                                                                                                                                                                                               |             |              |              |              |              |               |           |  |  |  |  |
|                | Asynchronous mode 9-bit (RX9 = 1):<br>1 = Enables address detection, enables interrupt and load of the receive buffer when<br>RSR<8> is set<br>0 = Disables address detection, all bytes are received, and ninth bit can be used as parity bit |             |              |              |              |              |               |           |  |  |  |  |
| bit 2          | FERR: Framing Error bit<br>1 = Framing error (can be updated by reading RCREG register and receive next valid byte)<br>0 = No framing error                                                                                                    |             |              |              |              |              |               |           |  |  |  |  |
| bit 1          | <b>OERR</b> : Overrun Error bit<br>1 = Overrun error (can be cleared by clearing bit CREN)<br>0 = No overrun error                                                                                                                             |             |              |              |              |              |               |           |  |  |  |  |
| bit 0          | <b>RX9D:</b> 9th                                                                                                                                                                                                                               | bit of Rece | ived Data (c | an be parity | bit, but mus | t be calcula | ted by user t | firmware) |  |  |  |  |
|                | Legend:                                                                                                                                                                                                                                        |             |              |              |              |              |               |           |  |  |  |  |
|                | R = Reada                                                                                                                                                                                                                                      | ble bit     | W = W        | /ritable bit | U = Unim     | plemented    | bit, read as  | ʻ0'       |  |  |  |  |
|                | - n = Value                                                                                                                                                                                                                                    | at POR      | '1' = B      | it is set    | '0' = Bit is | cleared      | x = Bit is u  | nknown    |  |  |  |  |

DS30292C-page 96

© 2001 Microchip Technology Inc.