



Welcome to E-XFL.COM

# What is "Embedded - Microcontrollers"?

"Embedded - Microcontrollers" refer to small, integrated circuits designed to perform specific tasks within larger systems. These microcontrollers are essentially compact computers on a single chip, containing a processor core, memory, and programmable input/output peripherals. They are called "embedded" because they are embedded within electronic devices to control various functions, rather than serving as standalone computers. Microcontrollers are crucial in modern electronics, providing the intelligence and control needed for a wide range of applications.

Applications of "<u>Embedded -</u> <u>Microcontrollers</u>"

# Details

| Details                    |                                                                             |
|----------------------------|-----------------------------------------------------------------------------|
| Product Status             | Active                                                                      |
| Core Processor             | PIC                                                                         |
| Core Size                  | 8-Bit                                                                       |
| Speed                      | 4MHz                                                                        |
| Connectivity               | -                                                                           |
| Peripherals                | POR, WDT                                                                    |
| Number of I/O              | 5                                                                           |
| Program Memory Size        | 768B (512 x 12)                                                             |
| Program Memory Type        | OTP                                                                         |
| EEPROM Size                | 16 x 8                                                                      |
| RAM Size                   | 25 x 8                                                                      |
| Voltage - Supply (Vcc/Vdd) | 3V ~ 5.5V                                                                   |
| Data Converters            | -                                                                           |
| Oscillator Type            | Internal                                                                    |
| Operating Temperature      | 0°C ~ 70°C (TA)                                                             |
| Mounting Type              | Surface Mount                                                               |
| Package / Case             | 8-SOIC (0.209", 5.30mm Width)                                               |
| Supplier Device Package    | 8-SOIJ                                                                      |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic12ce518t-04-sm |
|                            |                                                                             |

Email: info@E-XFL.COM

Address: Room A, 16/F, Full Win Commercial Centre, 573 Nathan Road, Mongkok, Hong Kong

NOTES:

NOTES:





#### 4.2 Data Memory Organization

Data memory is composed of registers, or bytes of RAM. Therefore, data memory for a device is specified by its register file. The register file is divided into two functional groups: special function registers and general purpose registers.

The special function registers include the TMR0 register, the Program Counter (PC), the Status Register, the I/O registers (ports), and the File Select Register (FSR). In addition, special purpose registers are used to control the I/O port configuration and prescaler options.

The general purpose registers are used for data and control information under command of the instructions.

For the PIC12C508, PIC12C508A and PIC12CE518, the register file is composed of 7 special function registers and 25 general purpose registers (Figure 4-2).

For the PIC12C509, PIC12C509A, PIC12CR509A, and PIC12CE519 the register file is composed of 7 special function registers, 25 general purpose registers, and 16 general purpose registers that may be addressed using a banking scheme (Figure 4-3).

### 4.2.1 GENERAL PURPOSE REGISTER FILE

The general purpose register file is accessed either directly or indirectly through the file select register FSR (Section 4.8).

#### FIGURE 4-2: PIC12C508, PIC12C508A AND PIC12CE518 REGISTER FILE MAP



| FSR<6:5>-    | •    | 00                  | 01                       |
|--------------|------|---------------------|--------------------------|
| File Address | · ·  |                     | 1                        |
| 00h          |      | INDF <sup>(1)</sup> | 20h                      |
| <b>∲</b> 01h |      | TMR0                |                          |
| 02h          |      | PCL                 | _                        |
| 03h          |      | STATUS              | Addresses map<br>back to |
| 04h          |      | FSR                 | addresses                |
| 05h          |      | OSCCAL              | in Bank 0.               |
| 06h          |      | GPIO                |                          |
| 07h          |      |                     | 1                        |
|              |      | General<br>Purpose  |                          |
|              |      | Registers           |                          |
| 0Fh          |      | 0                   | 2Fh                      |
|              | 10h  |                     | 30h                      |
|              |      | General             | General                  |
|              |      | Purpose             | Purpose                  |
|              |      | Registers           | Registers                |
|              | 1Fh  |                     | 3Fh                      |
|              |      | Bank 0              | Bank 1                   |
| Note 1       | : No | t a physical regi   | ster. See Section 4.8    |
|              |      |                     |                          |

#### FIGURE 4-3: PIC12C509, PIC12C509A, PIC12CR509A AND PIC12CE519 REGISTER FILE MAP

### 4.3 STATUS Register

This register contains the arithmetic status of the ALU, the RESET status, and the page preselect bit for program memories larger than 512 words.

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 and MOVWF instructions be used to alter the STATUS register because these instructions do not affect the Z, DC or C bits from the STATUS register. For other instructions, which do affect STATUS bits, see Instruction Set Summary.

# FIGURE 4-4: STATUS REGISTER (ADDRESS:03h)

| <u>R/W-0</u><br>GPWUF | R/W-0                                                                     | R/W-0<br>PA0                                           | <u>R-1</u><br>TO                               | R-1<br>PD                                          | R/W-x<br>Z                                                                        | R/W-x<br>DC             | R/W-x<br>C                    | R = Readable bit                                   |
|-----------------------|---------------------------------------------------------------------------|--------------------------------------------------------|------------------------------------------------|----------------------------------------------------|-----------------------------------------------------------------------------------|-------------------------|-------------------------------|----------------------------------------------------|
| t7                    | 6                                                                         | 5                                                      | 4                                              | 3                                                  | 2                                                                                 | 1                       | bit0                          | W = Writable bit<br>- n = Value at POR reset       |
|                       | <b>GPWUF</b> : G<br>1 = Reset o<br>0 = After po                           | due to wake                                            | -up from S                                     | LEEP on pi                                         | n change                                                                          |                         |                               |                                                    |
| it 6:                 | Unimplem                                                                  | ented                                                  |                                                |                                                    |                                                                                   |                         |                               |                                                    |
|                       | 0 = Page 0<br>Each page<br>Using the F                                    | (200h - 3F<br>(000h - 1F<br>is 512 byte<br>A0 bit as a | Fh) - PIC12<br>Fh) - PIC12<br>s.<br>general pu | 2C509, PIC<br>2C5XX<br>irpose read                 |                                                                                   | evices whic             | h do not use                  | 2CE519<br>e it for program<br>ith future products. |
|                       | <b>TO</b> : Time-o<br>1 = After po<br>0 = A WDT                           | ower-up, CL                                            |                                                | uction, or S                                       | LEEP instruc                                                                      | tion                    |                               |                                                    |
|                       | <b>PD</b> : Power-<br>1 = After po<br>0 = By exec                         | ower-up or l                                           |                                                |                                                    | tion                                                                              |                         |                               |                                                    |
|                       | <b>Z</b> : Zero bit<br>1 = The res<br>0 = The res                         |                                                        |                                                | •                                                  | tion is zero<br>tion is not ze                                                    | ro                      |                               |                                                    |
|                       | <b>ADDWF</b><br>1 = A carry<br>0 = A carry<br><b>SUBWF</b><br>1 = A borro | from the 41<br>from the 41<br>ow from the              | th low orde<br>th low orde<br>4th low ord      | r bit of the r<br>r bit of the r<br>ler bit of the | BWF instructi<br>esult occurre<br>esult did not<br>result did not<br>result occur | ed<br>occur<br>ot occur |                               |                                                    |
|                       | ADDWF<br>1 = A carry                                                      |                                                        |                                                | SUBWF<br>1 = A bor                                 | RF, RLF instr<br>row did not c<br>row occurred                                    | occur                   | <b>RRF or R</b><br>Load bit w | LF<br>vith LSB or MSB, respectively                |



# FIGURE 6-2: TIMER0 TIMING: INTERNAL CLOCK/NO PRESCALE

# FIGURE 6-3: TIMER0 TIMING: INTERNAL CLOCK/PRESCALE 1:2



### TABLE 6-1: REGISTERS ASSOCIATED WITH TIMER0

| Address | Name   | Bit 7    | Bit 6      | Bit 5     | Bit 4    | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Value on<br>Power-On<br>Reset | Value on<br>All Other<br>Resets |
|---------|--------|----------|------------|-----------|----------|-------|-------|-------|-------|-------------------------------|---------------------------------|
| 01h     | TMR0   | Timer0 - | 8-bit real | -time clo | ck/count | er    |       |       |       | xxxx xxxx                     | uuuu uuuu                       |
| N/A     | OPTION | GPWU     | GPPU       | T0CS      | T0SE     | PSA   | PS2   | PS1   | PS0   | 1111 1111                     | 1111 1111                       |
| N/A     | TRIS   | —        |            | GP5       | GP4      | GP3   | GP2   | GP1   | GP0   | 11 1111                       | 11 1111                         |

Legend: Shaded cells not used by Timer0, - = unimplemented, x = unknown, u = unchanged,

# 7.5 READ OPERATIONS

Read operations are initiated in the same way as write operations with the exception that the  $R/\overline{W}$  bit of the slave address is set to one. There are three basic types of read operations: current address read, random read, and sequential read.

#### 7.5.1 CURRENT ADDRESS READ

It contains an address counter that maintains the address of the last word accessed, internally incremented by one. Therefore, if the previous read access was to address n, the next current address read operation would access data from address n + 1. Upon receipt of the slave address with the R/W bit set to one, the device issues an acknowledge and transmits the eight bit data word. The master will not acknowledge the transfer but does generate a stop condition and the device discontinues transmission (Figure 7-8).

#### 7.5.2 RANDOM READ

Random read operations allow the master to access any memory location in a random manner. To perform this type of read operation, first the word address must be set. This is done by sending the word address to the device as part of a write operation. After the word address is sent, the master generates a start condition following the acknowledge. This terminates the write operation, but not before the internal address pointer is set. Then the master issues the control byte again but with the  $R/\overline{W}$  bit set to a one. It will then issue an acknowledge and transmits the eight bit data word. The master will not acknowledge the transfer but does generate a stop condition and the device discontinues transmission (Figure 7-9). After this command, the internal address counter will point to the address location following the one that was just read.

#### 7.5.3 SEQUENTIAL READ

Sequential reads are initiated in the same way as a random read except that after the device transmits the first data byte, the master issues an acknowledge as opposed to a stop condition in a random read. This directs the device to transmit the next sequentially addressed 8-bit word (Figure 7-10).

To provide sequential reads, it contains an internal address pointer which is incremented by one at the completion of each read operation. This address pointer allows the entire memory contents to be serially read during one operation.



#### FIGURE 7-9: RANDOM READ



### FIGURE 7-10: SEQUENTIAL READ



#### FIGURE 8-8: SIMPLIFIED BLOCK DIAGRAM OF ON-CHIP RESET CIRCUIT



FIGURE 8-9: TIME-OUT SEQUENCE ON POWER-UP (MCLR PULLED LOW)







#### 8.9 Power-Down Mode (SLEEP)

A device may be powered down (SLEEP) and later powered up (Wake-up from SLEEP).

#### 8.9.1 SLEEP

The Power-Down mode is entered by executing a SLEEP instruction.

If enabled, the Watchdog Timer will be cleared but keeps running, the  $\overline{TO}$  bit (STATUS<4>) is set, the  $\overline{PD}$  bit (STATUS<3>) is cleared and the oscillator driver is turned off. The I/O ports maintain the status they had before the SLEEP instruction was executed (driving high, driving low, or hi-impedance).

It should be noted that a RESET generated by a WDT time-out does not drive the  $\overline{\text{MCLR}}$  pin low.

For lowest current consumption while powered down, the T0CKI input should be at VDD or VSs and the GP3/ MCLR/VPP pin must be at a logic high level (VIHMC) if MCLR is enabled.

#### 8.9.2 WAKE-UP FROM SLEEP

The device can wake-up from SLEEP through one of the following events:

- 1. An external reset input on GP3/MCLR/VPP pin, when configured as MCLR.
- 2. A Watchdog Timer time-out reset (if WDT was enabled).
- A change on input pin GP0, GP1, or GP3/ MCLR/VPP when wake-up on change is enabled.

These events cause a device reset. The  $\overline{\text{TO}}$ ,  $\overline{\text{PD}}$ , and GPWUF bits can be used to determine the cause of device reset. The  $\overline{\text{TO}}$  bit is cleared if a WDT time-out occurred (and caused wake-up). The  $\overline{\text{PD}}$  bit, which is set on power-up, is cleared when SLEEP is invoked. The GPWUF bit indicates a change in state while in SLEEP at pins GP0, GP1, or GP3 (since the last time there was a file or bit operation on GP port).

Caution: Right before entering SLEEP, read the input pins. When in SLEEP, wake up occurs when the values at the pins change from the state they were in at the last reading. If a wake-up on change occurs and the pins are not read before reentering SLEEP, a wake up will occur immediately even if no pins change while in SLEEP mode.

The WDT is cleared when the device wakes from sleep, regardless of the wake-up source.

### 8.10 Program Verification/Code Protection

If the code protection bit has not been programmed, the on-chip program memory can be read out for verification purposes.

The first 64 locations can be read by the PIC12C5XX regardless of the code protection bit setting.

The last memory location cannot be read if code protection is enabled on the PIC12C508/509.

The last memory location can be read regardless of the code protection bit setting on the PIC12C508A/509A/CR509A/CE518/CE519.

### 8.11 ID Locations

Four memory locations are designated as ID locations where the user can store checksum or other codeidentification numbers. These locations are not accessible during normal execution but are readable and writable during program/verify.

Use only the lower 4 bits of the ID locations and always program the upper 8 bits as '0's.

### 8.12 In-Circuit Serial Programming

The PIC12C5XX microcontrollers with EPROM program memory can be serially programmed while in the end application circuit. This is simply done with two lines for clock and data, and three other lines for power, ground, and the programming voltage. This allows customers to manufacture boards with unprogrammed devices, and then program the microcontroller just before shipping the product. This also allows the most recent firmware or a custom firmware to be programmed.

The device is placed into a program/verify mode by holding the GP1 and GP0 pins low while raising the MCLR (VPP) pin from VIL to VIHH (see programming specification). GP1 becomes the programming clock and GP0 becomes the programming data. Both GP1 and GP0 are Schmitt Trigger inputs in this mode.

After reset, a 6-bit command is then supplied to the device. Depending on the command, 14-bits of program data are then supplied to or from the device, depending if the command was a load or a read. For complete details of serial programming, please refer to the PIC12C5XX Programming Specifications.

A typical in-circuit serial programming connection is shown in Figure 8-16.

#### FIGURE 8-16: TYPICAL IN-CIRCUIT SERIAL PROGRAMMING CONNECTION



| TABLE 9-2: | INSTRUCTION SET SUMMARY |
|------------|-------------------------|
|------------|-------------------------|

| Mnemonic, |         |                              |        | 12-  | Bit Opc | ode  | Status   |       |
|-----------|---------|------------------------------|--------|------|---------|------|----------|-------|
| Operar    |         | Description                  | Cycles | MSb  |         | LSb  | Affected | Notes |
| ADDWF     | f,d     | Add W and f                  | 1      | 0001 | 11df    | ffff | C,DC,Z   | 1,2,4 |
| ANDWF     | f,d     | AND W with f                 | 1      | 0001 | 01df    | ffff | Z        | 2,4   |
| CLRF      | f       | Clear f                      | 1      | 0000 | 011f    | ffff | Z        | 4     |
| CLRW      | -       | Clear W                      | 1      | 0000 | 0100    | 0000 | Z        |       |
| COMF      | f, d    | Complement f                 | 1      | 0010 | 01df    | ffff | Z        |       |
| DECF      | f, d    | Decrement f                  | 1      | 0000 | 11df    | ffff | Z        | 2,4   |
| DECFSZ    | f, d    | Decrement f, Skip if 0       | 1(2)   | 0010 | 11df    | ffff | None     | 2,4   |
| INCF      | f, d    | Increment f                  | 1      | 0010 | 10df    | ffff | Z        | 2,4   |
| INCFSZ    | f, d    | Increment f, Skip if 0       | 1(2)   | 0011 | 11df    | ffff | None     | 2,4   |
| IORWF     | f, d    | Inclusive OR W with f        | 1      | 0001 | 00df    | ffff | Z        | 2,4   |
| MOVF      | f, d    | Move f                       | 1      | 0010 | 00df    | ffff | Z        | 2,4   |
| MOVWF     | f       | Move W to f                  | 1      | 0000 | 001f    | ffff | None     | 1,4   |
| NOP       | _       | No Operation                 | 1      | 0000 | 0000    | 0000 | None     |       |
| RLF       | f, d    | Rotate left f through Carry  | 1      | 0011 | 01df    | ffff | С        | 2,4   |
| RRF       | f, d    | Rotate right f through Carry | 1      | 0011 | 00df    | ffff | С        | 2,4   |
| SUBWF     | f, d    | Subtract W from f            | 1      | 0000 | 10df    | ffff | C,DC,Z   | 1,2,4 |
| SWAPF     | f, d    | Swap f                       | 1      | 0011 | 10df    | ffff | None     | 2,4   |
| XORWF     | f, d    | Exclusive OR W with f        | 1      | 0001 | 10df    | ffff | Z        | 2,4   |
| BIT-ORIEN | TED FIL | E REGISTER OPERATIONS        |        |      |         |      |          |       |
| BCF       | f, b    | Bit Clear f                  | 1      | 0100 | bbbf    | ffff | None     | 2,4   |
| BSF       | f, b    | Bit Set f                    | 1      | 0101 | bbbf    | ffff | None     | 2,4   |
| BTFSC     | f, b    | Bit Test f, Skip if Clear    | 1 (2)  | 0110 | bbbf    | ffff | None     |       |
| BTFSS     | f, b    | Bit Test f, Skip if Set      | 1 (2)  | 0111 | bbbf    | ffff | None     |       |
| LITERAL A | ND CO   | NTROL OPERATIONS             |        |      |         |      |          |       |
| ANDLW     | k       | AND literal with W           | 1      | 1110 | kkkk    | kkkk | Z        |       |
| CALL      | k       | Call subroutine              | 2      | 1001 | kkkk    | kkkk | None     | 1     |
| CLRWDT    | k       | Clear Watchdog Timer         | 1      | 0000 | 0000    | 0100 | TO, PD   |       |
| GOTO      | k       | Unconditional branch         | 2      | 101k | kkkk    | kkkk | None     |       |
| IORLW     | k       | Inclusive OR Literal with W  | 1      | 1101 | kkkk    | kkkk | Z        |       |
| MOVLW     | k       | Move Literal to W            | 1      | 1100 | kkkk    | kkkk | None     |       |
| OPTION    | -       | Load OPTION register         | 1      | 0000 | 0000    | 0010 | None     |       |
| RETLW     | k       | Return, place Literal in W   | 2      | 1000 | kkkk    | kkkk | None     |       |
| SLEEP     | -       | Go into standby mode         | 1      | 0000 | 0000    | 0011 | TO, PD   |       |
| TRIS      | f       | Load TRIS register           | 1      | 0000 | 0000    | Offf | None     | 3     |
| XORLW     | k       | Exclusive OR Literal to W    | 1      | 1111 | kkkk    | kkkk | Z        |       |

Note 1: The 9th bit of the program counter will be forced to a '0' by any instruction that writes to the PC except for GOTO. (Section 4.6)

2: When an I/O register is modified as a function of itself (e.g. MOVF GPIO, 1), the value used will be that value present on the pins themselves. For example, if the data latch is '1' for a pin configured as input and is driven low by an external device, the data will be written back with a '0'.

3: The instruction TRIS f, where f = 6 causes the contents of the W register to be written to the tristate latches of GPIO. A '1' forces the pin to a hi-impedance state and disables the output buffers.

4: If this instruction is executed on the TMR0 register (and, where applicable, d = 1), the prescaler will be cleared (if assigned to TMR0).

| INCF                      | Increment f                                                                                                                                                         |
|---------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:                   | [label] INCF f,d                                                                                                                                                    |
| Operands:                 | $\begin{array}{l} 0 \leq f \leq 31 \\ d \in \left[0,1\right] \end{array}$                                                                                           |
| Operation:                | (f) + 1 $\rightarrow$ (dest)                                                                                                                                        |
| Status Affected:          | Z                                                                                                                                                                   |
| Encoding:                 | 0010 10df ffff                                                                                                                                                      |
| Description:              | The contents of register 'f' are incre-<br>mented. If 'd' is 0 the result is placed in<br>the W register. If 'd' is 1 the result is<br>placed back in register 'f'. |
| Words:                    | 1                                                                                                                                                                   |
| Cycles:                   | 1                                                                                                                                                                   |
| Example:                  | INCF CNT, 1                                                                                                                                                         |
| Before Instru<br>CNT<br>Z | = 0xFF<br>= 0                                                                                                                                                       |
| After Instruct<br>CNT     | = 0x00                                                                                                                                                              |
| Z                         | = 1                                                                                                                                                                 |
|                           |                                                                                                                                                                     |
| INCFSZ                    | Increment f, Skip if 0                                                                                                                                              |
| Syntax:                   | [label] INCFSZ f,d                                                                                                                                                  |
| Operands:                 | $0 \le f \le 31$                                                                                                                                                    |

| Syntax:                                               | [label] INCFSZ f,d                                                                                                                                                                                                |  |  |  |  |  |  |  |  |
|-------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|
| Operands:                                             | $\begin{array}{l} 0 \leq f \leq 31 \\ d \in \ [0,1] \end{array}$                                                                                                                                                  |  |  |  |  |  |  |  |  |
| Operation:                                            | (f) + 1 $\rightarrow$ (dest), skip if result = 0                                                                                                                                                                  |  |  |  |  |  |  |  |  |
| Status Affected:                                      | None                                                                                                                                                                                                              |  |  |  |  |  |  |  |  |
| Encoding:                                             | 0011 11df ffff                                                                                                                                                                                                    |  |  |  |  |  |  |  |  |
| Description:                                          | The contents of register 'f' are incre-<br>mented. If 'd' is 0 the result is placed in<br>the W register. If 'd' is 1 the result is<br>placed back in register 'f'.<br>If the result is 0, then the next instruc- |  |  |  |  |  |  |  |  |
|                                                       | tion, which is already fetched, is dis-<br>carded and an NOP is executed<br>instead making it a two cycle instruc-<br>tion.                                                                                       |  |  |  |  |  |  |  |  |
| Words:                                                | 1                                                                                                                                                                                                                 |  |  |  |  |  |  |  |  |
| Cycles:                                               | 1(2)                                                                                                                                                                                                              |  |  |  |  |  |  |  |  |
| Example:                                              | HERE INCFSZ CNT, 1<br>GOTO LOOP                                                                                                                                                                                   |  |  |  |  |  |  |  |  |
|                                                       | CONTINUE •                                                                                                                                                                                                        |  |  |  |  |  |  |  |  |
| Before Instru                                         | ction                                                                                                                                                                                                             |  |  |  |  |  |  |  |  |
| PC                                                    | = address (HERE)                                                                                                                                                                                                  |  |  |  |  |  |  |  |  |
| After Instruct<br>CNT<br>if CNT<br>PC<br>if CNT<br>PC | <pre>ion = CNT + 1; = 0, = address (CONTINUE); ≠ 0, = address (HERE +1)</pre>                                                                                                                                     |  |  |  |  |  |  |  |  |

| IORLW                       | Inclusive OR literal with W                                                                                      |  |  |  |  |  |
|-----------------------------|------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Syntax:                     | [ <i>label</i> ] IORLW k                                                                                         |  |  |  |  |  |
| Operands:                   | $0 \le k \le 255$                                                                                                |  |  |  |  |  |
| Operation:                  | (W) .OR. (k) $\rightarrow$ (W)                                                                                   |  |  |  |  |  |
| Status Affected:            | Z                                                                                                                |  |  |  |  |  |
| Encoding:                   | 1101 kkkk kkkk                                                                                                   |  |  |  |  |  |
| Description:                | The contents of the W register are OR'ed with the eight bit literal 'k'. The result is placed in the W register. |  |  |  |  |  |
| Words:                      | 1                                                                                                                |  |  |  |  |  |
| Cycles:                     | 1                                                                                                                |  |  |  |  |  |
| Example:                    | IORLW 0x35                                                                                                       |  |  |  |  |  |
| Before Instru<br>W =        | uction<br>0x9A                                                                                                   |  |  |  |  |  |
| After Instruc<br>W =<br>Z = | tion<br>0xBF<br>0                                                                                                |  |  |  |  |  |

| IORWF                                     | Inclusive OR W with f                                                                                                                                                |
|-------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:                                   | [ label ] IORWF f,d                                                                                                                                                  |
| Operands:                                 | $\begin{array}{l} 0\leq f\leq 31\\ d\in \ [0,1] \end{array}$                                                                                                         |
| Operation:                                | (W).OR. (f) $\rightarrow$ (dest)                                                                                                                                     |
| Status Affected                           | I: Z                                                                                                                                                                 |
| Encoding:                                 | 0001 00df ffff                                                                                                                                                       |
| Description:                              | Inclusive OR the W register with regis-<br>ter 'f'. If 'd' is 0 the result is placed in<br>the W register. If 'd' is 1 the result is<br>placed back in register 'f'. |
| Words:                                    | 1                                                                                                                                                                    |
| Cycles:                                   | 1                                                                                                                                                                    |
| Example:                                  | IORWF RESULT, 0                                                                                                                                                      |
| Before Inst<br>RESUL<br>W<br>After Instru | LT = 0x13<br>= 0x91                                                                                                                                                  |
| RESUL<br>W<br>Z                           |                                                                                                                                                                      |

| MOVF                                           | Move f                                                                                                                                                                                                                               |  |  |  |  |  |  |  |
|------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| Syntax:                                        | [label] MOVF f,d                                                                                                                                                                                                                     |  |  |  |  |  |  |  |
| Operands:                                      | $\begin{array}{l} 0 \leq f \leq 31 \\ d \in \left[0,1\right] \end{array}$                                                                                                                                                            |  |  |  |  |  |  |  |
| Operation:                                     | $(f) \rightarrow (dest)$                                                                                                                                                                                                             |  |  |  |  |  |  |  |
| Status Affected:                               | Z                                                                                                                                                                                                                                    |  |  |  |  |  |  |  |
| Encoding:                                      | 0010 00df ffff                                                                                                                                                                                                                       |  |  |  |  |  |  |  |
| Description:                                   | The contents of register 'f' is moved to destination 'd'. If 'd' is 0, destination is the W register. If 'd' is 1, the destination is file register 'f'. 'd' is 1 is useful to test a file register since status flag Z is affected. |  |  |  |  |  |  |  |
| Words:                                         | 1                                                                                                                                                                                                                                    |  |  |  |  |  |  |  |
| Cycles:                                        | 1                                                                                                                                                                                                                                    |  |  |  |  |  |  |  |
| Example:                                       | MOVF FSR, 0                                                                                                                                                                                                                          |  |  |  |  |  |  |  |
| After Instruction<br>W = value in FSR register |                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |

| MOVLW                         | Move Lit          | eral to W                     | I    |  |  |  |  |  |
|-------------------------------|-------------------|-------------------------------|------|--|--|--|--|--|
| Syntax:                       | [ label ]         | MOVLW                         | k    |  |  |  |  |  |
| Operands:                     | $0 \le k \le 255$ |                               |      |  |  |  |  |  |
| Operation:                    | $k \to (W)$       |                               |      |  |  |  |  |  |
| Status Affected:              | None              |                               |      |  |  |  |  |  |
| Encoding:                     | 1100              | kkkk                          | kkkk |  |  |  |  |  |
| Description:                  | 0                 | bit literal 'k<br>r. The don' |      |  |  |  |  |  |
| Words:                        | 1                 |                               |      |  |  |  |  |  |
| Cycles:                       | 1                 |                               |      |  |  |  |  |  |
| Example:                      | MOVLW             | 0x5A                          |      |  |  |  |  |  |
| After Instruction<br>W = 0x5A |                   |                               |      |  |  |  |  |  |

| MOVWF                         | Move W                | to f         |            |           |
|-------------------------------|-----------------------|--------------|------------|-----------|
| Syntax:                       | [ label ]             | MOVWF        | f          |           |
| Operands:                     | $0 \le f \le 3$       | 1            |            |           |
| Operation:                    | $(W) \to (f$          | )            |            |           |
| Status Affected:              | None                  |              |            |           |
| Encoding:                     | 0000                  | 001f         | ffff       |           |
| Description:                  | Move data<br>ter 'f'. | a from the \ | N register | to regis- |
| Words:                        | 1                     |              |            |           |
| Cycles:                       | 1                     |              |            |           |
| Example:                      | MOVWF                 | TEMP_REC     | 3          |           |
| Before Instru<br>TEMP_R<br>W  |                       | 0xFF<br>0x4F |            |           |
| After Instruct<br>TEMP_R<br>W |                       | 0x4F<br>0x4F |            |           |

| NOP              | No Oper   | No Operation |      |  |  |  |  |
|------------------|-----------|--------------|------|--|--|--|--|
| Syntax:          | [ label ] | NOP          |      |  |  |  |  |
| Operands:        | None      |              |      |  |  |  |  |
| Operation:       | No opera  | ation        |      |  |  |  |  |
| Status Affected: | None      |              |      |  |  |  |  |
| Encoding:        | 0000      | 0000         | 0000 |  |  |  |  |
| Description:     | No opera  | ation.       |      |  |  |  |  |
| Words:           | 1         |              |      |  |  |  |  |
| Cycles:          | 1         |              |      |  |  |  |  |
| Example:         | NOP       |              |      |  |  |  |  |

### 11.4 Timing Diagrams and Specifications





| AC Chara         | cteristics |                                         |            |        |        |     |                |
|------------------|------------|-----------------------------------------|------------|--------|--------|-----|----------------|
| Parameter<br>No. | Sym        | Characteristic                          | Conditions |        |        |     |                |
|                  | Fosc       | External CLKIN Frequency <sup>(2)</sup> |            |        |        |     |                |
|                  |            |                                         | DC         | —      | 4      | MHz | XT osc mode    |
|                  |            |                                         | DC         | —      | 200    | kHz | LP osc mode    |
|                  |            | Oscillator Frequency <sup>(2)</sup>     |            |        |        |     |                |
|                  |            |                                         | 0.1        | —      | 4      | MHz | XT osc mode    |
|                  |            |                                         | DC         | —      | 200    | kHz | LP osc mode    |
| 1                | Tosc       | External CLKIN Period <sup>(2)</sup>    | 250        | —      | _      | ns  | EXTRC osc mode |
|                  |            |                                         | 250        | —      | —      | ns  | XT osc mode    |
|                  |            |                                         | 5          | —      | —      | ms  | LP osc mode    |
|                  |            | Oscillator Period <sup>(2)</sup>        | 250        | _      | _      | ns  | EXTRC osc mode |
|                  |            |                                         | 250        | —      | 10,000 | ns  | XT osc mode    |
|                  |            |                                         | 5          | —      | —      | ms  | LP osc mode    |
| 2                | Тсу        | Instruction Cycle Time <sup>(3)</sup>   | —          | 4/Fosc | —      |     |                |
| 3                | TosL, TosH | Clock in (OSC1) Low or High Time        | 50*        | —      | —      | ns  | XT oscillator  |
|                  |            |                                         | 2*         | —      | —      | ms  | LP oscillator  |
| 4                | TosR, TosF | Clock in (OSC1) Rise or Fall Time       | —          | —      | 25*    | ns  | XT oscillator  |
|                  |            |                                         | -          | _      | 50*    | ns  | LP oscillator  |

\* These parameters are characterized but not tested.

Note 1: Data in the Typical ("Typ") column is at 5V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested.

2: All specified values are based on characterization data for that particular oscillator type under standard operating conditions with the device executing code. Exceeding these specified limits may result in an unstable oscillator operation and/or higher than expected current consumption. When an external clock input is used, the "max" cycle time limit is "DC" (no clock) for all devices.

Instruction cycle period (Tcy) equals four times the input oscillator time base period.

# TABLE 11-3: CALIBRATED INTERNAL RC FREQUENCIES - PIC12C508/C509

| AC CharacteristicsStandard Operating Conditions (unless otherwise specified)<br>Operating Temperature $0^{\circ}C \leq TA \leq +70^{\circ}C$ (commercial),<br>$-40^{\circ}C \leq TA \leq +85^{\circ}C$ (industrial),<br>$-40^{\circ}C \leq TA \leq +125^{\circ}C$ (extended)<br>Operating Voltage VDD range is described in Section 10.1 |     |                                                                               |  |      |      |     |            |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-------------------------------------------------------------------------------|--|------|------|-----|------------|
| Parameter<br>No.                                                                                                                                                                                                                                                                                                                         | Sym | Characteristic Min <sup>*</sup> Typ <sup>(1)</sup> Max <sup>*</sup> Units Con |  |      |      |     | Conditions |
|                                                                                                                                                                                                                                                                                                                                          |     | Internal Calibrated RC Frequency                                              |  | 4.00 | 4.32 | MHz | VDD = 5.0V |
|                                                                                                                                                                                                                                                                                                                                          |     | Internal Calibrated RC Frequency                                              |  | —    | 4.26 | MHz | VDD = 2.5V |

\* These parameters are characterized but not tested.

Note 1: Data in the Typical ("Typ") column is at 5V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested.



# FIGURE 11-3: I/O TIMING - PIC12C508/C509

# TABLE 11-5: RESET, WATCHDOG TIMER, AND DEVICE RESET TIMER - PIC12C508/C509

| AC Charac        | teristics |                                                  |       |                    |       |       |                        |
|------------------|-----------|--------------------------------------------------|-------|--------------------|-------|-------|------------------------|
| Parameter<br>No. | Sym       | Characteristic                                   | Min   | Typ <sup>(1)</sup> | Max   | Units | Conditions             |
| 30               | TmcL      | MCLR Pulse Width (low)                           | 2000* | _                  | —     | ns    | VDD = 5 V              |
| 31               | Twdt      | Watchdog Timer Time-out Period<br>(No Prescaler) | 9*    | 18*                | 30*   | ms    | VDD = 5 V (Commercial) |
| 32               | TDRT      | Device Reset Timer Period <sup>(2)</sup>         | 9*    | 18*                | 30*   | ms    | VDD = 5 V (Commercial) |
| 34               | Tioz      | I/O Hi-impedance from MCLR Low                   | —     | —                  | 2000* | ns    |                        |

\* These parameters are characterized but not tested.

Note 1: Data in the Typical ("Typ") column is at 5V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested.

Note 2: See Table 11-6.

### TABLE 11-6: DRT (DEVICE RESET TIMER PERIOD - PIC12C508/C509)

| Oscillator Configuration | ator Configuration POR Reset |                  |
|--------------------------|------------------------------|------------------|
| IntRC & ExtRC            | 18 ms (typical)              | 300 µs (typical) |
| XT & LP                  | 18 ms (typical)              | 18 ms (typical)  |

# FIGURE 14-9: IOL vs. VOL, VDD = 2.5 V



### FIGURE 14-10: IOL vs. VOL, VDD = 3.5 V





FIGURE 14-12: IOL vs. VOL, VDD = 5.5 V



# Package Type: K04-018 8-Lead Plastic Dual In-line (P) - 300 mil



| Units                        |                 | INCHES* |       |       | М    | MILLIMETERS |      |  |
|------------------------------|-----------------|---------|-------|-------|------|-------------|------|--|
| Dimension Limits             |                 | MIN     | NOM   | MAX   | MIN  | NOM         | MAX  |  |
| PCB Row Spacing              |                 |         | 0.300 |       |      | 7.62        |      |  |
| Number of Pins               | n               |         | 8     |       |      | 8           |      |  |
| Pitch                        | р               |         | 0.100 |       |      | 2.54        |      |  |
| Lower Lead Width             | В               | 0.014   | 0.018 | 0.022 | 0.36 | 0.46        | 0.56 |  |
| Upper Lead Width             | B1 <sup>†</sup> | 0.055   | 0.060 | 0.065 | 1.40 | 1.52        | 1.65 |  |
| Shoulder Radius              | R               | 0.000   | 0.005 | 0.010 | 0.00 | 0.13        | 0.25 |  |
| Lead Thickness               | с               | 0.006   | 0.012 | 0.015 | 0.20 | 0.29        | 0.38 |  |
| Top to Seating Plane         | A               | 0.140   | 0.150 | 0.160 | 3.56 | 3.81        | 4.06 |  |
| Top of Lead to Seating Plane | A1              | 0.060   | 0.080 | 0.100 | 1.52 | 2.03        | 2.54 |  |
| Base to Seating Plane        | A2              | 0.005   | 0.020 | 0.035 | 0.13 | 0.51        | 0.89 |  |
| Tip to Seating Plane         | L               | 0.120   | 0.130 | 0.140 | 3.05 | 3.30        | 3.56 |  |
| Package Length               | D‡              | 0.355   | 0.370 | 0.385 | 9.02 | 9.40        | 9.78 |  |
| Molded Package Width         | E‡              | 0.245   | 0.250 | 0.260 | 6.22 | 6.35        | 6.60 |  |
| Radius to Radius Width       | E1              | 0.267   | 0.280 | 0.292 | 6.78 | 7.10        | 7.42 |  |
| Overall Row Spacing          | eB              | 0.310   | 0.342 | 0.380 | 7.87 | 8.67        | 9.65 |  |
| Mold Draft Angle Top         | α               | 5       | 10    | 15    | 5    | 10          | 15   |  |
| Mold Draft Angle Bottom      | β               | 5       | 10    | 15    | 5    | 10          | 15   |  |

\* Controlling Parameter.

- <sup>†</sup> Dimension "B1" does not include dam-bar protrusions. Dam-bar protrusions shall not exceed 0.003" (0.076 mm) per side or 0.006" (0.152 mm) more than dimension "B1."
- <sup>‡</sup> Dimensions "D" and "E" do not include mold flash or protrusions. Mold flash or protrusions shall not exceed 0.010" (0.254 mm) per side or 0.020" (0.508 mm) more than dimensions "D" or "E."

### Note the following details of the code protection feature on PICmicro<sup>®</sup> MCUs.

- The PICmicro family meets the specifications contained in the Microchip Data Sheet.
- Microchip believes that its family of PICmicro microcontrollers is one of the most secure products of its kind on the market today, when used in the intended manner and under normal conditions.
- There are dishonest and possibly illegal methods used to breach the code protection feature. All of these methods, to our knowledge, require using the PICmicro microcontroller in a manner outside the operating specifications contained in the data sheet. The person doing so may be engaged in theft of intellectual property.
- Microchip is willing to work with the customer who is concerned about the integrity of their code.
- Neither Microchip nor any other semiconductor manufacturer can guarantee the security of their code. Code protection does not mean that we are guaranteeing the product as "unbreakable".
- Code protection is constantly evolving. We at Microchip are committed to continuously improving the code protection features of our product.

If you have any further questions about this matter, please contact the local sales office nearest to you.

Information contained in this publication regarding device applications and the like is intended through suggestion only and may be superseded by updates. It is your responsibility to ensure that your application meets with your specifications. No representation or warranty is given and no liability is assumed by Microchip Technology Incorporated with respect to the accuracy or use of such information, or infringement of patents or other intellectual property rights arising from such use or otherwise. Use of Microchip's products as critical components in life support systems is not authorized except with express written approval by Microchip. No licenses are conveyed, implicitly or otherwise, under any intellectual property rights.

#### Trademarks

The Microchip name and logo, the Microchip logo, FilterLab, KEELOQ, microID, MPLAB, PIC, PICmicro, PICMASTER, PICSTART, PRO MATE, SEEVAL and The Embedded Control Solutions Company are registered trademarks of Microchip Technology Incorporated in the U.S.A. and other countries.

dsPIC, ECONOMONITOR, FanSense, FlexROM, fuzzyLAB, In-Circuit Serial Programming, ICSP, ICEPIC, microPort, Migratable Memory, MPASM, MPLIB, MPLINK, MPSIM, MXDEV, PICC, PICDEM, PICDEM.net, rfPIC, Select Mode and Total Endurance are trademarks of Microchip Technology Incorporated in the U.S.A.

Serialized Quick Turn Programming (SQTP) is a service mark of Microchip Technology Incorporated in the U.S.A.

All other trademarks mentioned herein are property of their respective companies.

© 2002, Microchip Technology Incorporated, Printed in the U.S.A., All Rights Reserved.





Microchip received QS-9000 quality system certification for its worldwide headquarters, design and wafer fabrication facilities in Chandler and Tempe, Arizona in July 1999. The Company's quality system processes and procedures are QS-9000 compliant for its PICmicro® 8-bit MCUs, KEELoq® code hopping devices, Serial EEPROMs and microperipheral products. In addition, Microchip's quality system for the design and manufacture of development systems is ISO 9001 certified.



# WORLDWIDE SALES AND SERVICE

# AMERICAS

**Corporate Office** 2355 West Chandler Blvd. Chandler, AZ 85224-6199 Tel: 480-792-7200 Fax: 480-792-7277 Technical Support: 480-792-7627 Web Address: http://www.microchip.com

#### **Rocky Mountain**

2355 West Chandler Blvd. Chandler, AZ 85224-6199 Tel: 480-792-7966 Fax: 480-792-7456

#### Atlanta

500 Sugar Mill Road, Suite 200B Atlanta, GA 30350 Tel: 770-640-0034 Fax: 770-640-0307

#### Boston

2 Lan Drive, Suite 120 Westford, MA 01886 Tel: 978-692-3848 Fax: 978-692-3821

### Chicago

333 Pierce Road, Suite 180 Itasca, IL 60143 Tel: 630-285-0071 Fax: 630-285-0075

Dallas

4570 Westgrove Drive, Suite 160 Addison, TX 75001 Tel: 972-818-7423 Fax: 972-818-2924

Detroit Tri-Atria Office Building

32255 Northwestern Highway, Suite 190 Farmington Hills, MI 48334 Tel: 248-538-2250 Fax: 248-538-2260 Kokomo

# 2767 S. Albright Road

Kokomo, Indiana 46902 Tel: 765-864-8360 Fax: 765-864-8387 Los Angeles

18201 Von Karman, Suite 1090 Irvine, CA 92612

Tel: 949-263-1888 Fax: 949-263-1338 New York

150 Motor Parkway, Suite 202 Hauppauge, NY 11788 Tel: 631-273-5305 Fax: 631-273-5335 San Jose

Microchip Technology Inc. 2107 North First Street, Suite 590 San Jose, CA 95131 Tel: 408-436-7950 Fax: 408-436-7955

Toronto

6285 Northam Drive, Suite 108 Mississauga, Ontario L4V 1X5, Canada Tel: 905-673-0699 Fax: 905-673-6509

# ASIA/PACIFIC

Australia

Microchip Technology Australia Pty Ltd Suite 22, 41 Rawson Street Epping 2121, NSW Australia

Tel: 61-2-9868-6733 Fax: 61-2-9868-6755 China - Beijing

Microchip Technology Consulting (Shanghai) Co., Ltd., Beijing Liaison Office Unit 915 Bei Hai Wan Tai Bldg. No. 6 Chaoyangmen Beidajie Beijing, 100027, No. China Tel: 86-10-85282100 Fax: 86-10-85282104

#### China - Chengdu

Microchip Technology Consulting (Shanghai) Co., Ltd., Chengdu Liaison Office Rm. 2401, 24th Floor, Ming Xing Financial Tower No. 88 TIDU Street Chengdu 610016, China Tel: 86-28-6766200 Fax: 86-28-6766599

### China - Fuzhou

Microchip Technology Consulting (Shanghai) Co., Ltd., Fuzhou Liaison Office Unit 28F, World Trade Plaza No. 71 Wusi Road Fuzhou 350001, China Tel: 86-591-7503506 Fax: 86-591-7503521 China - Shanghai

Microchip Technology Consulting (Shanghai) Co., Ltd. Room 701, Bldg. B Far East International Plaza No. 317 Xian Xia Road Shanghai, 200051 Tel: 86-21-6275-5700 Fax: 86-21-6275-5060

#### China - Shenzhen

Microchip Technology Consulting (Shanghai) Co., Ltd., Shenzhen Liaison Office Rm. 1315, 13/F, Shenzhen Kerry Centre, Renminnan Lu Shenzhen 518001, China Tel: 86-755-2350361 Fax: 86-755-2366086 Hong Kong Microchip Technology Hongkong Ltd. Unit 901-6, Tower 2, Metroplaza

223 Hing Fong Road Kwai Fong, N.T., Hong Kong Tel: 852-2401-1200 Fax: 852-2401-3431

# India

Microchip Technology Inc. India Liaison Office **Divvasree Chambers** 1 Floor, Wing A (A3/A4) No. 11, O'Shaugnessey Road Bangalore, 560 025, India Tel: 91-80-2290061 Fax: 91-80-2290062

# Japan

Microchip Technology Japan K.K. Benex S-1 6F 3-18-20, Shinyokohama Kohoku-Ku, Yokohama-shi Kanagawa, 222-0033, Japan Tel: 81-45-471- 6166 Fax: 81-45-471-6122 Korea Microchip Technology Korea 168-1, Youngbo Bldg. 3 Floor Samsung-Dong, Kangnam-Ku Seoul, Korea 135-882 Tel: 82-2-554-7200 Fax: 82-2-558-5934 Singapore Microchip Technology Singapore Pte Ltd. 200 Middle Road #07-02 Prime Centre Singapore, 188980 Tel: 65-334-8870 Fax: 65-334-8850 Taiwan Microchip Technology Taiwan 11F-3, No. 207 Tung Hua North Road Taipei, 105, Taiwan Tel: 886-2-2717-7175 Fax: 886-2-2545-0139

# EUROPE

Denmark

Microchip Technology Nordic ApS **Regus Business Centre** Lautrup hoj 1-3 Ballerup DK-2750 Denmark Tel: 45 4420 9895 Fax: 45 4420 9910 France Microchip Technology SARL Parc d'Activite du Moulin de Massy 43 Rue du Saule Trapu Batiment A - ler Etage 91300 Massy, France Tel: 33-1-69-53-63-20 Fax: 33-1-69-30-90-79 Germany Microchip Technology GmbH

Gustav-Heinemann Ring 125 D-81739 Munich, Germany Tel: 49-89-627-144 0 Fax: 49-89-627-144-44 Italy

Microchip Technology SRL Centro Direzionale Colleoni Palazzo Taurus 1 V. Le Colleoni 1 20041 Agrate Brianza Milan, Italy Tel: 39-039-65791-1 Fax: 39-039-6899883

#### United Kinadom

Arizona Microchip Technology Ltd. 505 Eskdale Road Winnersh Triangle Wokingham Berkshire, England RG41 5TU Tel: 44 118 921 5869 Fax: 44-118 921-5820

01/18/02