

**SEL-0629**

# Aplicação de Microprocessadores I

# Aula 2b

# PIC 18F4550

# **Marcelo Andrade da Costa Vieira**

# Família de Microcontroladores PIC



- Microprocessadores de 8-bit, 16-bit e 32-bit;
- A linha de 32-bit possui ULA de 32-bit, clock de até 200 MHZ e Pipeline de 5 estágios

# Família PIC de 8-bits

Classificados de acordo com o tamanho do barramento de instruções. Isso define o tamanho da palavra de instruções, o número de instruções e a sua velocidade

PIC Microcontroller



1. Baseline: 12-bits
2. Mid-range: 14-bits
  1. Enhanced Mid-range: 14-bits
  2. High-performance: 16-bits

# Família PIC de 8-bits

## Compare 8-bit PIC® MCU Architectures

|                         | Baseline Architecture                                                                                                                | Mid-Range Architecture                                                                                                                                                           | Enhanced Mid-Range Architecture                                                                                                                                                             | PIC18 Architecture                                                                                                                                                                              |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Pin Count               | 6-40                                                                                                                                 | 8-64                                                                                                                                                                             | 8-64                                                                                                                                                                                        | 18-100                                                                                                                                                                                          |
| Interrupts              | No                                                                                                                                   | Single interrupt capability                                                                                                                                                      | Single interrupt capability with hardware context save                                                                                                                                      | Multiple interrupt capability with hardware context save                                                                                                                                        |
| Performance             | 5 MIPS                                                                                                                               | 5 MIPS                                                                                                                                                                           | 8 MIPS                                                                                                                                                                                      | Up to 16 MIPS                                                                                                                                                                                   |
| Instructions            | 33, 12-bit                                                                                                                           | 35, 14-bit                                                                                                                                                                       | 49, 14-bit                                                                                                                                                                                  | 83, 16-bit                                                                                                                                                                                      |
| Program Memory          | Up to 3 KB                                                                                                                           | Up to 14 KB                                                                                                                                                                      | Up to 28 KB                                                                                                                                                                                 | Up to 128 KB                                                                                                                                                                                    |
| Data Memory             | Up to 138 Bytes                                                                                                                      | Up to 368 Bytes                                                                                                                                                                  | Up to 1,5 KB                                                                                                                                                                                | Up to 4 KB                                                                                                                                                                                      |
| Hardware Stack          | 2 level                                                                                                                              | 8 level                                                                                                                                                                          | 16 level                                                                                                                                                                                    | 32 level                                                                                                                                                                                        |
| Features                | <ul style="list-style-type: none"><li>▪ Comparator</li><li>▪ 8-bit ADC</li><li>▪ Data Memory</li><li>▪ Internal Oscillator</li></ul> | In addition to Baseline: <ul style="list-style-type: none"><li>▪ SPI/I<sup>2</sup>C™</li><li>▪ UART</li><li>▪ PWMs</li><li>▪ LCD</li><li>▪ 10-bit ADC</li><li>▪ Op Amp</li></ul> | In addition to Mid-Range: <ul style="list-style-type: none"><li>▪ Multiple Communication Peripherals</li><li>▪ Linear Programming Space</li><li>▪ PWMs with Independent Time Base</li></ul> | In addition to Enhanced Mid-Range: <ul style="list-style-type: none"><li>▪ 8x8 Hardware Multiplier</li><li>▪ CAN</li><li>▪ CTMU</li><li>▪ USB</li><li>▪ Ethernet</li><li>▪ 12-bit ADC</li></ul> |
| Highlights              | Lowest cost in the smallest form factor                                                                                              | Optimal cost to performance ratio                                                                                                                                                | Cost effective with more performance and memory                                                                                                                                             | High performance, optimized for C programming, advanced peripherals                                                                                                                             |
| Total Number of Devices | 16                                                                                                                                   | 58                                                                                                                                                                               | 29                                                                                                                                                                                          | 193                                                                                                                                                                                             |
| Families                | PIC10, PIC12, PIC16                                                                                                                  | PIC12, PIC16                                                                                                                                                                     | PIC12FXXX, PIC16F1XX                                                                                                                                                                        | PIC18                                                                                                                                                                                           |

# Família PIC de 8 Bits



# **PIC 18F4550**

# PIC 18F4550

- Memória de Instruções de 16K x 16 bits (High-Performance) – FLASH – 32KB
- Memória de dados (SRAM) com 2 Kbytes de uso geral – endereçamento de 12 bits (4096 bytes) divididos em 16 bancos de 256 bytes cada;
- 40 pinos – 35 portas de I/O configuráveis como entrada ou saída;
- Memória adicional interna do tipo EEPROM não volátil de 256bytes;
- 20 fontes de interrupções diferentes com 2 níveis de prioridade;
- Programação com 75 instruções (otimizadas para C)
- Frequência máxima de operação de até 48 MHz (12 MIPS)
- Pilha (Stack) de 31 posições;
- Periféricos: 4 Timers, PWM, Conversor A/D, USB, etc...
- Multiplicador 8 x 8 de um ciclo de máquina.

# PIC 18F4550



# Memória de Programa



# Memória RAM

FIGURE 5-5: DATA MEMORY MAP FOR PIC18F2455/2550/4455/4550 DEVICES



- Memória de dados de 2K x 8 bits;
- Endereçado por duto de 12 bits (4096 bytes);
- 16 bancos de 256 bytes cada;
- Registrador BSR para seleção do banco:
  - 4 bits do BSR (MSB)
  - 8 bits da instrução (LSB)
- 256 bytes de acesso direto (0 e 15)
  - (GPR + SFR)
- Seleção na instrução se o acesso é direto ( $a = 0$ ) ou via banco ( $a = 1$ ).

# SFR

TABLE 5-1: SPECIAL FUNCTION REGISTER MAP FOR PIC18F2455/2550/4455/4550 DEVICES

| Address | Name                    | Address | Name                    | Address | Name                  | Address | Name                 | Address | Name                   |
|---------|-------------------------|---------|-------------------------|---------|-----------------------|---------|----------------------|---------|------------------------|
| FFFh    | TOSU                    | FDFh    | INDF2 <sup>(1)</sup>    | FBFh    | CCPR1H                | F9Fh    | IPR1                 | F7Fh    | UEP15                  |
| FFEh    | TOSH                    | FDEh    | POSTINC2 <sup>(1)</sup> | FBEh    | CCPR1L                | F9Eh    | PIR1                 | F7Eh    | UEP14                  |
| FFDh    | TOSL                    | FDDh    | POSTDEC2 <sup>(1)</sup> | FBDh    | CCP1CON               | F9Dh    | PIE1                 | F7Dh    | UEP13                  |
| FFCh    | STKPTR                  | FDCh    | PREINC2 <sup>(1)</sup>  | FBCh    | CCPR2H                | F9Ch    | _ <sup>(2)</sup>     | F7Ch    | UEP12                  |
| FFBh    | PCLATU                  | FDBh    | PLUSW2 <sup>(1)</sup>   | FBBh    | CCPR2L                | F9Bh    | OSCTUNE              | F7Bh    | UEP11                  |
| FFAh    | PCLATH                  | FDAh    | FSR2H                   | FBAh    | CCP2CON               | F9Ah    | _ <sup>(2)</sup>     | F7Ah    | UEP10                  |
| FF9h    | PCL                     | FD9h    | FSR2L                   | FB9h    | _ <sup>(2)</sup>      | F99h    | _ <sup>(2)</sup>     | F79h    | UEP9                   |
| FF8h    | TBLPTRU                 | FD8h    | STATUS                  | FB8h    | BAUDCON               | F98h    | _ <sup>(2)</sup>     | F78h    | UEP8                   |
| FF7h    | TBLPTRH                 | FD7h    | TMR0H                   | FB7h    | ECCP1DEL              | F97h    | _ <sup>(2)</sup>     | F77h    | UEP7                   |
| FF6h    | TBLPTRL                 | FD6h    | TMR0L                   | FB6h    | ECCP1AS               | F96h    | TRISE <sup>(3)</sup> | F76h    | UEP6                   |
| FF5h    | TABLAT                  | FD5h    | T0CON                   | FB5h    | CVRCON                | F95h    | TRISD <sup>(3)</sup> | F75h    | UEP5                   |
| FF4h    | PRODH                   | FD4h    | _ <sup>(2)</sup>        | FB4h    | CMCON                 | F94h    | TRISC                | F74h    | UEP4                   |
| FF3h    | PRODL                   | FD3h    | OSCCON                  | FB3h    | TMR3H                 | F93h    | TRISB                | F73h    | UEP3                   |
| FF2h    | INTCON                  | FD2h    | HLVDCON                 | FB2h    | TMR3L                 | F92h    | TRISA                | F72h    | UEP2                   |
| FF1h    | INTCON2                 | FD1h    | WDTCON                  | FB1h    | T3CON                 | F91h    | _ <sup>(2)</sup>     | F71h    | UEP1                   |
| FF0h    | INTCON3                 | FD0h    | RCON                    | FB0h    | SPBRGH                | F90h    | _ <sup>(2)</sup>     | F70h    | UEP0                   |
| FEFh    | INDF0 <sup>(1)</sup>    | FCFh    | TMR1H                   | FAFh    | SPBRG                 | F8Fh    | _ <sup>(2)</sup>     | F6Fh    | UCFG                   |
| FEEh    | POSTINC0 <sup>(1)</sup> | FCEh    | TMR1L                   | FAEh    | RCREG                 | F8Eh    | _ <sup>(2)</sup>     | F6Eh    | UADDR                  |
| FEDh    | POSTDEC0 <sup>(1)</sup> | FCDh    | T1CON                   | FADh    | TXREG                 | F8Dh    | LATE <sup>(3)</sup>  | F6Dh    | UCON                   |
| FECh    | PREINC0 <sup>(1)</sup>  | FCCh    | TMR2                    | FACH    | TXSTA                 | F8Ch    | LATD <sup>(3)</sup>  | F6Ch    | USTAT                  |
| FEBh    | PLUSW0 <sup>(1)</sup>   | FCBh    | PR2                     | FABh    | RCSTA                 | F8Bh    | LATC                 | F6Bh    | UEIE                   |
| FEAh    | FSR0H                   | FCAh    | T2CON                   | FAAh    | _ <sup>(2)</sup>      | F8Ah    | LATB                 | F6Ah    | UEIR                   |
| FE9h    | FSR0L                   | FC9h    | SSPBUF                  | FA9h    | EEADR                 | F89h    | LATA                 | F69h    | UIE                    |
| FE8h    | WREG                    | FC8h    | SSPADD                  | FA8h    | EEDATA                | F88h    | _ <sup>(2)</sup>     | F68h    | UIR                    |
| FE7h    | INDF1 <sup>(1)</sup>    | FC7h    | SSPSTAT                 | FA7h    | EECON2 <sup>(1)</sup> | F87h    | _ <sup>(2)</sup>     | F67h    | UFRMH                  |
| FE6h    | POSTINC1 <sup>(1)</sup> | FC6h    | SSPCON1                 | FA6h    | EECON1                | F86h    | _ <sup>(2)</sup>     | F66h    | UFRML                  |
| FE5h    | POSTDEC1 <sup>(1)</sup> | FC5h    | SSPCON2                 | FA5h    | _ <sup>(2)</sup>      | F85h    | _ <sup>(2)</sup>     | F65h    | SPPCON <sup>(3)</sup>  |
| FE4h    | PREINC1 <sup>(1)</sup>  | FC4h    | ADRESH                  | FA4h    | _ <sup>(2)</sup>      | F84h    | PORTE                | F64h    | SPPEPS <sup>(3)</sup>  |
| FE3h    | PLUSW1 <sup>(1)</sup>   | FC3h    | ADRESL                  | FA3h    | _ <sup>(2)</sup>      | F83h    | PORTD <sup>(3)</sup> | F63h    | SPPCFG <sup>(3)</sup>  |
| FE2h    | FSR1H                   | FC2h    | ADCON0                  | FA2h    | IPR2                  | F82h    | PORTC                | F62h    | SPPDATA <sup>(3)</sup> |
| FE1h    | FSR1L                   | FC1h    | ADCON1                  | FA1h    | PIR2                  | F81h    | PORTB                | F61h    | _ <sup>(2)</sup>       |
| FE0h    | BSR                     | FC0h    | ADCON2                  | FA0h    | PIE2                  | F80h    | PORTA                | F60h    | _ <sup>(2)</sup>       |

Note 1: Not a physical register.

2: Unimplemented registers are read as '0'.

3: These registers are implemented only on 40/44-pin devices.

# **Conversor A/D**

# 10 bits - 13 canais multiplexados

FIGURE 21-1: A/D BLOCK DIAGRAM



# Equações

$$Resolução = \frac{Vref_+ - Vref_-}{2^n - 1}$$

$$V_{Analógica} = \frac{\text{Valor binário} \cdot (Vref_+ - Vref_-) + Vref_- \cdot (2^n - 1)}{2^n - 1}$$

$$V_{Analógica(Vref_- = 0)} = \frac{\text{Valor binário} \cdot Vref}{2^n - 1}$$

# **Portas I/O**

# Portas de I/O

---

- Definir se é entrada ou saída (TRISA, TRISB, etc.);
- Quando for escrever na porta (saída), usar os registradores LAT $\textcolor{red}{A}$ , LAT $\textcolor{red}{B}$ , etc.
- Quando for ler o estado de um pino (entrada), usar os registradores PORT $\textcolor{red}{A}$ , PORT $\textcolor{red}{B}$ , etc.
- Definir se a porta é analógica ou digital, devido ao conversor A/D: ( $\textcolor{red}{ADCON1}$ );
- Não existe registrador ANSEL\_ nesse microcontrolador!

# ADCON1

**REGISTER 21-2: ADCON1: A/D CONTROL REGISTER 1**

| U-0   | U-0 | R/W-0 | R/W-0 | R/W-0 <sup>(1)</sup> | R/W <sup>(1)</sup> | R/W <sup>(1)</sup> | R/W <sup>(1)</sup> |
|-------|-----|-------|-------|----------------------|--------------------|--------------------|--------------------|
| —     | —   | VCFG0 | VCFG0 | PCFG3                | PCFG2              | PCFG1              | PCFG0              |
| bit 7 |     |       |       |                      |                    |                    | bit 0              |

**Legend:**

R = Readable bit

W = Writable bit

U = Unimplemented bit, read as '0'

-n = Value at POR

'1' = Bit is set

'0' = Bit is cleared

x = Bit is unknown

bit 7-6      **Unimplemented:** Read as '0'

bit 5      **VCFG0:** Voltage Reference Configuration bit (VREF- source)

1 = VREF- (AN2)

0 = VSS

bit 4      **VCFG0:** Voltage Reference Configuration bit (VREF+ source)

1 = VREF+ (AN3)

0 = VDD

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

| PCFG3:<br>PCFG0     | AN12 | AN11 | AN10 | AN9 | AN8 | AN7 <sup>(2)</sup> | AN6 <sup>(2)</sup> | AN5 <sup>(2)</sup> | AN4 | AN3 | AN2 | AN1 | AN0 |
|---------------------|------|------|------|-----|-----|--------------------|--------------------|--------------------|-----|-----|-----|-----|-----|
| 0000 <sup>(1)</sup> | A    | A    | A    | A   | A   | A                  | A                  | A                  | A   | A   | A   | A   | A   |
| 0001                | A    | A    | A    | A   | A   | A                  | A                  | A                  | A   | A   | A   | A   | A   |
| 0010                | A    | A    | A    | A   | A   | A                  | A                  | A                  | A   | A   | A   | A   | A   |
| 0011                | D    | A    | A    | A   | A   | A                  | A                  | A                  | A   | A   | A   | A   | A   |
| 0100                | D    | D    | A    | A   | A   | A                  | A                  | A                  | A   | A   | A   | A   | A   |
| 0101                | D    | D    | D    | A   | A   | A                  | A                  | A                  | A   | A   | A   | A   | A   |
| 0110                | D    | D    | D    | A   | A   | A                  | A                  | A                  | A   | A   | A   | A   | A   |
| 0111 <sup>(1)</sup> | D    | D    | D    | D   | A   | A                  | A                  | A                  | A   | A   | A   | A   | A   |
| 1000                | D    | D    | D    | D   | D   | A                  | A                  | A                  | A   | A   | A   | A   | A   |
| 1001                | D    | D    | D    | D   | D   | D                  | A                  | A                  | A   | A   | A   | A   | A   |
| 1010                | D    | D    | D    | D   | D   | D                  | D                  | A                  | A   | A   | A   | A   | A   |
| 1011                | D    | D    | D    | D   | D   | D                  | D                  | D                  | A   | A   | A   | A   | A   |
| 1100                | D    | D    | D    | D   | D   | D                  | D                  | D                  | D   | A   | A   | A   | A   |
| 1101                | D    | D    | D    | D   | D   | D                  | D                  | D                  | D   | D   | A   | A   | A   |
| 1110                | D    | D    | D    | D   | D   | D                  | D                  | D                  | D   | D   | D   | D   | A   |
| 1111                | D    | D    | D    | D   | D   | D                  | D                  | D                  | D   | D   | D   | D   | D   |

A = Analog input

D = Digital I/O

**Note 1:** The POR value of the PCFG bits depends on the value of the PBADEN Configuration bit. When PBADEN = 1, PCFG<3:0> = 0000; when PBADEN = 0, PCFG<3:0> = 0111.

**2:** AN5 through AN7 are available only on 40/44-pin devices.

# Portas de I/O

## **FIGURE 10-1: GENERIC I/O PORT OPERATION**



# Módulo CCP

# Módulo CCP

- CCP = Capture, Compare, PWM;
- Periférico presente em alguns microcontroladores PIC
- Modo Capture: contagem de tempo entre dois eventos ocorridos no pino do PIC (borda de descida ou subida)
- Modo Compare: contagem de tempo entre dois eventos ocorridos no pino do PIC e comparação com um valor pré determinado
- Modo PWM: geração de um pulso PWM no pino do PIC
- Pode gerar interrupção
- Utiliza os temporizadores do PIC para geração da base de tempo:

| CCP/ECCP Mode | Timer Resource   |
|---------------|------------------|
| Capture       | Timer1 or Timer3 |
| Compare       | Timer1 or Timer3 |
| PWM           | Timer2           |

# PWM

- *Pulse Width Modulation* = Modulação por largura de pulso
  - Onda de frequência constante mas com largura de pulso variável (ciclo de trabalho ou *duty cycle*)
  - Obtenção de uma tensão analógica a partir de um sinal digital (conversor D/A)



# PWM

- Uso um filtro passa baixa com frequência de corte menor do que a frequência do PWM



$$f_c = \frac{1}{2\pi RC}$$

**FIM**