## Microcontroladores

Engenharia de Computação Maio – 2019

Prof. Mardson Freitas de Amorim

Trabalhando com PIC

- **►** Introdução
- ✓ O ambiente de programação: MPLab
- ✓ Um programa:
  - ✓ A estrutura
  - ✓ Entendendo um exemplo

#### Trabalhando com o PIC

- Arquitetura
- Memórias
- Interrupções
- O microcontrolador PIC12F675
- Registradores especiais
- Conjunto de instruções

### Arquitetura

- Harvard
- Estruturação interna



- Arquitetura
  - Ciclos de máquina



#### Trabalhando com o PIC

### Memórias de programa

- 14 bits
- Vetor de RESET
  - Endereço: 0x00
- Vetor de interrupção
  - Endereço: 0x04
- Pilha (*STACK*)
  - 8 níveis

#### Trabalhando com o PIC

#### Memórias de dados

- Registradores especiais
  - SFR (Special Function Registers)
- Registradores de uso geral
  - Armazenamento de dados do usuário
- EEPROM
  - 128 bytes

#### Trabalhando com o PIC

### Interrupções

- Internas e externa
  - *Timers* Contadores internos (2)
  - Externa
  - Mudança de estado
  - Fim de escrita na EEPROM
  - Comparador
- Desvio do "PC" para 0x04

### Registradores especiais

- Gerais (alguns)
  - STATUS
  - OPTIONS\_REG
  - INTCON, PIR, PIE
  - PCL
- Portas
  - TRISIO, GPIO
- Contadores
  - TMR0, TMR1L, TMR1H
- EEPROM, comparador, tensão de referência, endereçamento indireto

| ,                     | File<br>Address | File<br>Address       |     |  |
|-----------------------|-----------------|-----------------------|-----|--|
| Indirect addr. (1)    | 00h             | Indirect addr. (1)    | 80h |  |
| TMR0                  | 01h             | OPTION REG            | 81h |  |
| PCL                   | 02h             | PCL PCL               | 82h |  |
| STATUS                | 03h             | STATUS                | 83h |  |
| FSR                   | 04h             | FSR                   | 84h |  |
| GPIO                  | 05h             | TRISIO                | 85h |  |
| PCLATH                | 0Ah             | PCLATH                | 8Ah |  |
| INTCON                | 0Bh             | INTCON                | 8Bh |  |
| PIR1                  | 0Ch             | PIE1                  | 8Ch |  |
| TMR1L                 | 0Eh             | PCON                  | 8Eh |  |
| TMR1H                 | 0Fh             |                       | 8Fh |  |
| T1CON                 | 10h             | OSCCAL                | 90h |  |
|                       | 15h             | WPU                   | 95h |  |
|                       | 16h             | IOC                   | 96h |  |
| CMCON                 | 19h             | VRCON                 | 99h |  |
|                       | 1Ah             | EEDATA                | 9Ah |  |
|                       | 1Bh             | EEADR                 | 9Bh |  |
|                       | 1Ch             | EECON1                | 9Ch |  |
|                       | 1Dh             | EECON2 <sup>(1)</sup> | 9Dh |  |
| ADRESH(2)             | 1Eh             | ADRESL <sup>(2)</sup> | 9Eh |  |
| ADCON0 <sup>(2)</sup> | 1Fh             | ANSEL <sup>(2)</sup>  | 9Fh |  |
| General               | 20h             | accesses              | A0h |  |
| Purpose<br>Registers  |                 | 20h-5Fh               |     |  |
| 64 Bytes              | 5Fh             |                       | DFh |  |
| ,                     | 60h             |                       | E0h |  |
|                       | 7Fh             |                       | FFh |  |
| Bank 0                |                 | Bank 1                |     |  |

### Registradores especiais gerais (alguns)

- STATUS
  - ULA

| Reserved | Reserved | 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 |

- RESET
- Banco de memória

| bit 7<br>bit 6 | IRP: This bit is reserved and should be maintained as '0' RP1: This bit is reserved and should be maintained as '0' | bit 2 | <b>Z</b> : Zero bit<br>1 = The result of an arithmetic or logic operation is zero                                                                                                                          |
|----------------|---------------------------------------------------------------------------------------------------------------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit 5          | RP0: Register Bank Select bit (used for direct addressing)                                                          |       | 0 = The result of an arithmetic or logic operation is not zero                                                                                                                                             |
|                | 0 = Bank 0 (00h - 7Fh)<br>1 = Bank 1 (80h - FFh)                                                                    | bit 1 | <b>DC</b> : Digit carry/borrow bit (ADDWF, ADDLW, SUBLW, SUBWF instructions) For borrow, the polarity is reversed.                                                                                         |
| bit 4          | TO: Time-out bit  1 = After power-up, CLRWDT instruction, or SLEEP instruction  0 = A WDT time-out occurred         |       | 1 = A carry-out from the 4th low order bit of the result occurred 0 = No carry-out from the 4th low order bit of the result                                                                                |
| bit 3          | PD: Power-down bit  1 = After power-up or by the CLRWDT instruction  0 = By execution of the SLEEP instruction      | bit 0 | C: Carry/borrow bit (ADDWF, ADDLW, SUBLW, SUBWF instructions)  1 = A carry-out from the Most Significant bit of the result occurred  0 = No carry-out from the Most Significant bit of the result occurred |

### Registradores especiais gerais (alguns)

- OPTIONS\_REG
  - Prescaler
  - Interrupção

| R/W-1 | R/W-1  | R/W-1 | R/W-1 | R/W-1 | R/W-1 | R/W-1 | R/W-1 |
|-------|--------|-------|-------|-------|-------|-------|-------|
| GPPU  | INTEDG | TOCS  | T0SE  | PSA   | PS2   | PS1   | PS0   |
| bit 7 | •      |       | •     | •     | •     | •     | bit 0 |

- Timer 0
- Pull-up

| bit 7 | GPPU: GPIO Pull-up Enable bit  1 = GPIO pull-ups are disabled  0 = GPIO pull-ups are enabled by individual port latch values | bit 3   | PSA: Pre<br>1 = Presc<br>0 = Presc |
|-------|------------------------------------------------------------------------------------------------------------------------------|---------|------------------------------------|
| bit 6 | INTEDG: Interrupt Edge Select bit                                                                                            | bit 2-0 | PS2:PS0                            |
|       | 1 = Interrupt on rising edge of GP2/INT pin                                                                                  |         |                                    |

- bit 5 **T0CS:** TMR0 Clock Source Select bit 1 = Transition on GP2/T0CKI pin
  - 0 = Internal instruction cycle clock (CLKOUT)

0 = Interrupt on falling edge of GP2/INT pin

bit 4 T0SE: TMR0 Source Edge Select bit

1 = Increment on high-to-low transition on GP2/T0CKI pin

0 = Increment on low-to-high transition on GP2/T0CKI pin

oit 3 **PSA**: Prescaler Assignment bit

1 = Prescaler is assigned to the WDT

0 = Prescaler is assigned to the TIMER0 module

oit 2-0 PS2:PS0: Prescaler Rate Select bits

| Bit ∀alue                                     | TMR0 Rate                                                   | WDT Rate                                                  |
|-----------------------------------------------|-------------------------------------------------------------|-----------------------------------------------------------|
| 000<br>001<br>010<br>011<br>100<br>101<br>110 | 1:2<br>1:4<br>1:8<br>1:16<br>1:32<br>1:64<br>1:128<br>1:256 | 1:1<br>1:2<br>1:4<br>1:8<br>1:16<br>1:32<br>1:64<br>1:128 |

### Registradores especiais gerais (alguns)

- INTCON
  - Timer 0

| R/W-0 |
|-------|-------|-------|-------|-------|-------|-------|-------|
| GIE   | PEIE  | TOIE  | INTE  | GPIE  | TOIF  | INTF  | GPIF  |
| bit 7 |       |       |       |       |       |       | bit 0 |

- Portas
- Interrupção
- 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 T0IE: TMR0 Overflow Interrupt Enable bit
  - 1 = Enables the TMR0 interrupt
  - 0 = Disables the TMR0 interrupt
- bit 4 INTE: GP2/INT External Interrupt Enable bit
  - 1 = Enables the GP2/INT external interrupt
  - 0 = Disables the GP2/INT external interrupt

- bit 3 GPIE: Port Change Interrupt Enable bit(1)
  - 1 = Enables the GPIO port change interrupt
  - 0 = Disables the GPIO port change interrupt
- bit 2 T0IF: TMR0 Overflow Interrupt Flag bit(2)
  - 1 = TMR0 register has overflowed (must be cleared in software)
  - 0 = TMR0 register did not overflow
- bit 1 INTF: GP2/INT External Interrupt Flag bit
  - 1 = The GP2/INT external interrupt occurred (must be cleared in software)
  - 0 = The GP2/INT external interrupt did not occur
- bit 0 GPIF: Port Change Interrupt Flag bit
  - 1 = When at least one of the GP5:GP0 pins changed state (must be cleared in software)
  - 0 = None of the GP5:GP0 pins have changed state

### Registradores especiais gerais (alguns)

• PIE1

Interrupção

| R/W-0 | R/W-0 | U-0 | U-0 | R/W-0 | U-0 | U-0 | R/W-0  |
|-------|-------|-----|-----|-------|-----|-----|--------|
| EEIE  | ADIE  | _   | _   | CMIE  | _   | _   | TMR1IE |
| bit 7 |       | •   |     | •     |     |     | bit 0  |

| bit 7   | <b>EEIE:</b> EE Write Complete Interrupt Enable bit 1 = Enables the EE write complete interrupt 0 = Disables the EE write complete interrupt |
|---------|----------------------------------------------------------------------------------------------------------------------------------------------|
| bit 6   | ADIE: A/D Converter Interrupt Enable bit<br>1 = Enables the A/D converter interrupt<br>0 = Disables the A/D converter interrupt              |
| bit 5-4 | Unimplemented: Read as '0'                                                                                                                   |
| bit 3   | CMIE: Comparator Interrupt Enable bit  1 = Enables the comparator interrupt  0 = Disables the comparator interrupt                           |
| bit 2-1 | Unimplemented: Read as '0'                                                                                                                   |
| bit 0   | <b>TMR1IE:</b> TMR1 Overflow Interrupt Enable bit 1 = Enables the TMR1 overflow interrupt 0 = Disables the TMR1 overflow interrupt           |

### Registradores especiais gerais (alguns)

• PIR1

Interrupção

| R/W-0 | R/W-0 | U-0 | U-0 | R/W-0 | U-0 | U-0 | R/W-0  |
|-------|-------|-----|-----|-------|-----|-----|--------|
| EEIF  | ADIF  | _   | _   | CMIF  | _   | _   | TMR1IF |
| bit 7 |       | •   |     |       |     | •   | bit 0  |

| bit 7   | <b>EEIF:</b> EEPROM Write Operation Interrupt Flag bit  1 = The write operation completed (must be cleared in software)  0 = The write operation has not completed or has not been started |
|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit 6   | <b>ADIF:</b> A/D Converter Interrupt Flag bit (PIC12F675 only)  1 = The A/D conversion is complete (must be cleared in software)  0 = The A/D conversion is not complete                   |
| bit 5-4 | Unimplemented: Read as '0'                                                                                                                                                                 |
| bit 3   | CMIF: Comparator Interrupt Flag bit  1 = Comparator input has changed (must be cleared in software)  0 = Comparator input has not changed                                                  |
| bit 2-1 | Unimplemented: Read as '0'                                                                                                                                                                 |
| bit 0   | TMR1IF: TMR1 Overflow Interrupt Flag bit  1 = TMR1 register overflowed (must be cleared in software)  0 = TMR1 register did not overflow                                                   |

### Registradores especiais gerais (alguns)

- PCL
  - Parte acessível do PC



Trabalhando com o **PIC** – RISC (35 instruções)

### Conjunto de instruções – termos utilizados

 $Work \rightarrow W$ 

Literal  $\rightarrow$  L e k

Bit  $\rightarrow$  B e b

Skip  $\rightarrow$  S

 $Clear \rightarrow C$ 

File  $\rightarrow$  F e f

Destino  $\rightarrow$  F e W

Teste  $\rightarrow$  T

 $Set \rightarrow S$ 

 $Zero \rightarrow Z$ 

### Conjunto de instruções – Mnemônicos base

 $ADD \rightarrow soma$ 

 $CLR \rightarrow limpar, zerar (clear)$ 

DEC → decremento de um

IOR → lógica "OU"

RL → rotacionar 1 bit p/ esquerda

SUB → subtração

XOR → lógica "OU exclusivo"

AND → lógica "E"

 $COM \rightarrow complemento$ 

INC → incremento de um

MOV → mover, transferir para algum lugar

RL → rotacionar 1 bit p/ direita

SWAP → inversão

### Trabalhando com o PIC

#### Exemplos

• Decrementar um registrador →

#### Conjunto de instruções – termos utilizados

| $Work \rightarrow W$        | $File \rightarrow F e f$    |
|-----------------------------|-----------------------------|
| Literal $\rightarrow$ L e k | Destino $\rightarrow$ F e W |
| $Bit \rightarrow B e b$     | $Teste \rightarrow T$       |
| $Skip \rightarrow S$        | $Set \rightarrow S$         |
| $Clear \rightarrow C$       | $Zero \rightarrow Z$        |

#### Conjunto de instruções – Mnemônicos base

```
ADD \rightarrow soma AND \rightarrow lógica "E"

CLR \rightarrow limpar, zerar (clear) COM \rightarrow complemento

DEC \rightarrow decremento de um INC \rightarrow incremento de um

IOR \rightarrow lógica "OU" MOV \rightarrow mover, transferir para algum lugar

RL \rightarrow rotacionar 1 bit p/ esquerda RL \rightarrow rotacionar 1 bit p/ direita

SUB \rightarrow subtração SWAP \rightarrow inversão

XOR \rightarrow lógica "OU exclusivo"
```

### Trabalhando com o PIC

#### Exemplos

• Decrementar um registrador → DECF

#### Conjunto de instruções – termos utilizados

| $Work \rightarrow W$        | $File \rightarrow F e f$    |
|-----------------------------|-----------------------------|
| Literal $\rightarrow$ L e k | Destino $\rightarrow$ F e W |
| $Bit \rightarrow B e b$     | $Teste \rightarrow T$       |
| $Skip \rightarrow S$        | $Set \rightarrow S$         |
| $Clear \rightarrow C$       | $Zero \rightarrow Z$        |

#### Conjunto de instruções – Mnemônicos base

```
ADD → soma

AND → lógica "E"

CLR → limpar, zerar (clear)

COM → complemento

INC → incremento de um

IOR → lógica "OU"

MOV → mover, transferir para algum lugar

RL → rotacionar 1 bit p/ esquerda

SUB → subtração

XOR → lógica "OU exclusivo"
```

### Trabalhando com o PIC

#### Exemplos

- Decrementar um registrador → DECF
- DECFSZ →

#### Conjunto de instruções – termos utilizados

Work  $\rightarrow$  W File  $\rightarrow$  F e f

Literal  $\rightarrow$  L e k Destino  $\rightarrow$  F e W

 $Bit \rightarrow B e b$  Teste  $\rightarrow T$ 

 $Skip \rightarrow S \qquad Set \rightarrow S$ 

 $Clear \rightarrow C \qquad Zero \rightarrow Z$ 

#### Conjunto de instruções – Mnemônicos base

ADD → soma AND → lógica "E"

 $CLR \rightarrow limpar, zerar (clear)$   $COM \rightarrow complemento$ 

 $DEC \rightarrow decremento de um$  INC  $\rightarrow incremento de um$ 

IOR → lógica "OU" MOV → mover, transferir para algum lugar

RL → rotacionar 1 bit p/ esquerda RL → rotacionar 1 bit p/ direita

SUB → subtração SWAP → inversão

XOR → lógica "OU exclusivo"

### Trabalhando com o PIC

#### Exemplos

- Decrementar um registrador → DECF
- DECFSZ → decrementa (DEC) o registrador (F) e pula (S) se o resultado for zero (Z)

#### Conjunto de instruções – termos utilizados

| $Work \rightarrow W$        | $File \rightarrow F e f$    |
|-----------------------------|-----------------------------|
| $Literal \rightarrow L e k$ | Destino $\rightarrow$ F e W |
| $Bit \rightarrow B e b$     | Teste $\rightarrow$ T       |
| $Skip \rightarrow S$        | $Set \rightarrow S$         |
| Clear → C                   | $Zero \rightarrow Z$        |

#### Conjunto de instruções – Mnemônicos base

```
ADD → soma

CLR → limpar, zerar (clear)

DEC → decremento de um

IOR → lógica "OU"

RL → rotacionar 1 bit p/ esquerda

SUB → subtração

XOR → lógica "OU exclusivo"

AND → lógica "E"

COM → complemento

INC → incremento de um

MOV → mover, transferir para algum lugar

RL → rotacionar 1 bit p/ direita

SWAP → inversão
```

### Trabalhando com o **PIC**

#### Exemplos

- Decrementar um registrador → DECF
- DECFSZ  $\rightarrow$  decrementa (DEC) o registrador (F) e pula (S) se o resultado for zero (Z)

| DECFSZ           | Decrement f, Skip if 0                                                                                                                                                                                                                                                                              |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [label] DECFSZ f,d                                                                                                                                                                                                                                                                                  |
| Operands:        | $0 \le f \le 127$<br>$d \in [0,1]$                                                                                                                                                                                                                                                                  |
| Operation:       | (f) - 1 → (destination); skip if result = 0                                                                                                                                                                                                                                                         |
| Status Affected: | None                                                                                                                                                                                                                                                                                                |
| Description:     | The contents of register 'f' are decremented. If 'd' is 0, the result is placed in the W register. If 'd' is 1, the result is placed back in register 'f'.  If the result is 1, the next instruction is executed. If the result is 0, then a NOP is executed instead, making it a 2Tcy instruction. |

### Trabalhando com o **PIC**

### Conjunto de instruções: operações com registradores

| Mnemonic,<br>Operands |                                        | Description                  | Cycles - | 14-Bit Opcode |      |      |      | Status   | Notes |
|-----------------------|----------------------------------------|------------------------------|----------|---------------|------|------|------|----------|-------|
|                       |                                        |                              |          | MSb           |      |      | LSb  | Affected | Notes |
|                       | BYTE-ORIENTED FILE REGISTER OPERATIONS |                              |          |               |      |      |      |          |       |
| ADDWF                 | f, d                                   | Add W and f                  | 1        | 0.0           | 0111 | dfff | ffff | C,DC,Z   | 1,2   |
| ANDWF                 | f, d                                   | AND W with f                 | 1        | 0.0           | 0101 | dfff | ffff | Ζ        | 1,2   |
| CLRF                  | f                                      | Clear f                      | 1        | 0.0           | 0001 | lfff | ffff | Ζ        | 2     |
| CLRW                  | -                                      | Clear W                      | 1        | 0.0           | 0001 | 0xxx | xxxx | Z        |       |
| COMF                  | f, d                                   | Complement f                 | 1        | 0.0           | 1001 | dfff | ffff | Ζ        | 1,2   |
| DECF                  | f, d                                   | Decrement f                  | 1        | 0.0           | 0011 | dfff | ffff | Z        | 1,2   |
| DECFSZ                | f, d                                   | Decrement f, Skip if 0       | 1(2)     | 0.0           | 1011 | dfff | ffff |          | 1,2,3 |
| INCF                  | f, d                                   | Increment f                  | 1        | 0.0           | 1010 | dfff | ffff | Ζ        | 1,2   |
| INCFSZ                | f, d                                   | Increment f, Skip if 0       | 1(2)     | 0.0           | 1111 | dfff | ffff |          | 1,2,3 |
| IORWF                 | f, d                                   | Inclusive OR W with f        | 1        | 0.0           | 0100 | dfff | ffff | Z        | 1,2   |
| MOVF                  | f, d                                   | Move f                       | 1        | 0.0           | 1000 | dfff | ffff | Z        | 1,2   |
| MOVWF                 | f                                      | Move W to f                  | 1        | 0.0           | 0000 | lfff | ffff |          |       |
| NOP                   | -                                      | No Operation                 | 1        | 0.0           | 0000 | 0xx0 | 0000 |          |       |
| RLF                   | f, d                                   | Rotate Left f through Carry  | 1        | 0.0           | 1101 | dfff | ffff | С        | 1,2   |
| RRF                   | f, d                                   | Rotate Right f through Carry | 1        | 0.0           | 1100 | dfff | ffff | С        | 1,2   |
| SUBWF                 | f, d                                   | Subtract W from f            | 1        | 0.0           | 0010 | dfff | ffff | C,DC,Z   | 1,2   |
| SWAPF                 | f, d                                   | Swap nibbles in f            | 1        | 0.0           | 1110 | dfff | ffff |          | 1,2   |
| XORWF                 | f, d                                   | Exclusive OR W with f        | 1        | 0.0           | 0110 | dfff | ffff | Z        | 1,2   |

### Trabalhando com o **PIC**

### Conjunto de instruções: operações com bits

| Mnemonic,<br>Operands                 |      | Description               | Cycles |     | 14-Bit Opcode | Status | Natas    |       |  |
|---------------------------------------|------|---------------------------|--------|-----|---------------|--------|----------|-------|--|
|                                       |      |                           |        | MSb |               | LSb    | Affected | Notes |  |
| BIT-ORIENTED FILE REGISTER OPERATIONS |      |                           |        |     |               |        |          |       |  |
| BCF                                   | f, b | Bit Clear f               | 1      | 01  | 00bb bfff     | ffff   |          | 1,2   |  |
| BSF                                   | f, b | Bit Set f                 | 1      | 01  | 01bb bfff     | ffff   |          | 1,2   |  |
| BTFSC                                 | f, b | Bit Test f, Skip if Clear | 1 (2)  | 01  | 10bb bfff     | ffff   |          | 3     |  |
| BTFSS                                 | f, b | Bit Test f, Skip if Set   | 1 (2)  | 01  | 11bb bfff     | ffff   |          | 3     |  |

### Trabalhando com o PIC

### Conjunto de instruções: controle e operações com literais

| Mnemonic,<br>Operands          |   | Description                 | Cycles | 14-Bit Opcode |      |      |      | Status   | Natas |
|--------------------------------|---|-----------------------------|--------|---------------|------|------|------|----------|-------|
|                                |   |                             |        | MSb           |      |      | LSb  | Affected | Notes |
| LITERAL AND CONTROL OPERATIONS |   |                             |        |               |      |      |      |          |       |
| ADDLW                          | k | Add literal and W           | 1      | 11            | 111x | kkkk | kkkk | C,DC,Z   |       |
| ANDLW                          | k | AND literal with W          | 1      | 11            | 1001 | kkkk | kkkk | Ζ        |       |
| CALL                           | k | Call subroutine             | 2      | 10            | 0kkk | kkkk | kkkk |          |       |
| CLRWDT                         | - | Clear Watchdog Timer        | 1      | 0.0           | 0000 | 0110 | 0100 | TO,PD    |       |
| GOTO                           | k | Go to address               | 2      | 10            | 1kkk | kkkk | kkkk |          |       |
| IORLW                          | k | Inclusive OR literal with W | 1      | 11            | 1000 | kkkk | kkkk | Z        |       |
| MOVLW                          | k | Move literal to W           | 1      | 11            | 00xx | kkkk | kkkk |          |       |
| RETFIE                         | - | Return from interrupt       | 2      | 0.0           | 0000 | 0000 | 1001 |          |       |
| RETLW                          | k | Return with literal in W    | 2      | 11            | 01xx | kkkk | kkkk |          |       |
| RETURN                         | - | Return from Subroutine      | 2      | 0.0           | 0000 | 0000 | 1000 |          |       |
| SLEEP                          | - | Go into Standby mode        | 1      | 0.0           | 0000 | 0110 | 0011 | TO,PD    |       |
| SUBLW                          | k | Subtract W from literal     | 1      | 11            | 110x | kkkk | kkkk | C,DC,Z   |       |
| XORLW                          | k | Exclusive OR literal with W | 1      | 11            | 1010 | kkkk | kkkk | Ζ        |       |