

# Configurable Logic Cell (CLC)

## HIGHLIGHTS

This section of the manual contains the following major topics:

| Introduction            | 2            |
|-------------------------|--------------|
| Registers               | 5            |
| CLC Setup               | 11           |
| Input Providers         | 11           |
| Output                  | 13           |
| Application Logic       | 13           |
| CLC Interrupts          | 13           |
| Operation in Sleep Mode | 14           |
| Operation in Idle Mode  | 14           |
| Reset                   | 14           |
| Revision History        | 15           |
|                         | Introduction |

**Note:** This family reference manual section is meant to serve as a complement to device data sheets.

Please consult the note at the beginning of the "**Configurable Logic Cell (CLC)**" chapter in the current device data sheet to check whether this document supports the device you are using.

Device data sheets and family reference manual sections are available for download from the Microchip Worldwide Web site at: http://www.microchip.com.

This document supersedes the following PIC24 and dsPIC33 Family Reference Manual sections:

| DS Number | Section Number | Title                         |  |  |  |
|-----------|----------------|-------------------------------|--|--|--|
| DS33949A  | 63             | Configurable Logic Cell (CLC) |  |  |  |

#### 1.0 INTRODUCTION

The Configurable Logic Cell (CLC) module allows the user to specify combinations of signals as inputs to a logic function, and to use the logic output to control other peripherals or I/O pins. This provides greater flexibility and potential in embedded designs, since the CLC module can operate outside the limitations of software execution, and supports a vast amount of output designs.

The CLC consists of four main sections, as shown in Figure 1-1. First, the input data selection MUXes route input signals to the four data gates, as shown in Figure 1-2. Each of the four data gates can then select any of the 32 input signals to pass along to the logic functions shown in Figure 1-3. The output of the logic function is then supplied to the internal logic and external pin, and can generate interrupts. The output of a CLC module can be routed to the input of another CLC module to create more complex logic functions.



Figure 1-1: Configurable Logic Cell



Figure 1-2: CLC Input Source Selection Diagram

# dsPIC33/PIC24 Family Reference Manual



DS70005298A-page 4

### 2.0 REGISTERS

The CLC module is controlled by the following registers:

- CLCxCONL
- CLCxCONH
- CLCxSEL
- CLCxGLSL
- CLCxGLSH

The CLCx Control registers (CLCxCONL and CLCxCONH) are used to enable the module and interrupts, control the output enable bit, select output polarity, and select the logic function. The CLCx Control registers also allow the user to control the logic polarity of not only the cell output, but also some intermediate variables.

The CLCx Input MUX Select register (CLCxSEL) allows the user to select one out of eight input signals for each of the four data selection multiplexers, pictured inside the dotted line in Figure 1-2. The output of each of the four data selection multiplexers is connected to the inputs of the logic function selected by the MODE<2:0> bits (CLCxCONL<2:0>), see Figure 1-3.

The CLCx Source Enable registers (CLCxGLSL and CLCxGLSH) allow the user to create any four variable boolean expressions from the four input data sources configured by CLCxSEL. Both the true and complimentary values for each of the four signals, chosen by the CLCx Input MUX Select register (CLCxSEL), are available to the sum-of-products circuit pictured in the data gate in Figure 1-2.

| Register 2-1. | CLCxCONI · Configurable Logic Cell x Control Register /Log | <b>۸</b> /۱ |
|---------------|------------------------------------------------------------|-------------|
| Register Z-1. | CLEXCONE. Configurable Logic Cell X Control Register (Lo   | vj          |

| R/W-0                                   | U-0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | U-0              | U-0 | R/W-0            | R/W-0            | U-0             | U-0   |  |
|-----------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|-----|------------------|------------------|-----------------|-------|--|
| LCEN                                    | —                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | —                | —   | INTP             | INTN             | —               | —     |  |
| bit 15                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | ·                |     |                  |                  |                 | bit 8 |  |
|                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                  |     |                  |                  |                 |       |  |
| R-0                                     | R-0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | R/W-0            | U-0 | U-0              | R/W-0            | R/W-0           | R/W-0 |  |
| LCOE                                    | LCOUT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | LCPOL            |     | —                | MODE2            | MODE1           | MODE0 |  |
| bit 7                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                  |     |                  |                  |                 | bit 0 |  |
|                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                  |     |                  |                  |                 |       |  |
| Legend:                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                  |     |                  |                  |                 |       |  |
| R = Readable                            | e bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | W = Writable     | oit | U = Unimpler     | nented bit, read | d as '0'        |       |  |
| -n = Value at                           | POR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | '1' = Bit is set |     | '0' = Bit is cle | ared             | x = Bit is unkn | iown  |  |
| bit 15<br>bit 14-12<br>bit 11<br>bit 10 | bit 15       LCEN: Configurable Logic Cell Enable bit         1 = Configurable Logic Cell is enabled and mixing input signals         0 = Configurable Logic Cell is disabled and has logic zero outputs         bit 14-12       Unimplemented: Read as '0'         bit 11       INTP: Configurable Logic Cell Positive Edge Interrupt Enable bit         1 = Interrupt will be generated when a rising edge occurs on LCOUT         0 = Interrupt will not be generated         bit 10 |                  |     |                  |                  |                 |       |  |
| bit 9-8<br>bit 7                        | <ul> <li>1 = Interrupt will be generated when a falling edge occurs on LCOUT</li> <li>0 = Interrupt will not be generated</li> <li>Unimplemented: Read as '0'</li> <li>LCOE: Configurable Logic Cell Port Enable bit</li> <li>1 = Configurable Logic Cell port pin output is enabled</li> <li>0 = Configurable Logic Cell port pin output is disabled</li> </ul>                                                                                                                        |                  |     |                  |                  |                 |       |  |
|                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                  |     |                  |                  |                 |       |  |

#### Register 2-1: CLCxCONL: Configurable Logic Cell x Control Register (Low) (Continued)

| bit 6   | LCOUT: Configurable Logic Cell Data Output Status bit                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |
|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
|         | <ul><li>1 = Configurable Logic Cell output high</li><li>0 = Configurable Logic Cell output low</li></ul>                                                                                                                                                                                                                                                     |  |  |  |  |  |
| bit 5   | LCPOL: Configurable Logic Cell Output Polarity Control bit                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |
|         | <ul><li>1 = The output of the module is inverted</li><li>0 = The output of the module is not inverted</li></ul>                                                                                                                                                                                                                                              |  |  |  |  |  |
| bit 4-3 | Unimplemented: Read as '0'                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |
| bit 2-0 | MODE<2:0>: Configurable Logic Cell Mode bits                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |
|         | <ul> <li>111 = Cell is 1-input transparent latch with S and R</li> <li>110 = Cell is JK flip-flop with R</li> <li>101 = Cell is 2-input D flip-flop with R</li> <li>100 = Cell is 1-input D flip-flop with S and R</li> <li>011 = Cell is SR latch</li> <li>010 = Cell is 4-input AND</li> <li>001 = Cell is OR-XOR</li> <li>000 = Cell is AND-OR</li> </ul> |  |  |  |  |  |

#### Register 2-2: CLCxCONH: Configurable Logic Cell x Control Register (High)

| U-0                                | U-0                                 | U-0          | U-0                                      | U-0          | U-0              | U-0      | U-0   |  |  |  |
|------------------------------------|-------------------------------------|--------------|------------------------------------------|--------------|------------------|----------|-------|--|--|--|
|                                    | _                                   | _            | _                                        | _            | _                | _        |       |  |  |  |
| bit 15                             |                                     |              |                                          |              |                  |          | bit 8 |  |  |  |
|                                    |                                     |              |                                          |              |                  |          |       |  |  |  |
| U-0                                | U-0                                 | U-0          | U-0                                      | R/W-0        | R/W-0            | R/W-0    | R/W-0 |  |  |  |
| —                                  | —                                   | —            | —                                        | G4POL        | G3POL            | G2POL    | G1POL |  |  |  |
| bit 7                              |                                     |              |                                          |              |                  |          | bit 0 |  |  |  |
|                                    |                                     |              |                                          |              |                  |          |       |  |  |  |
| Legend:                            |                                     |              |                                          |              |                  |          |       |  |  |  |
| R = Readable                       | bit                                 | W = Writable | bit                                      | U = Unimplem | nented bit, read | l as '0' |       |  |  |  |
| -n = Value at POR (1' = Bit is set |                                     |              | 0' = Bit is cleared $x = Bit is unknown$ |              |                  | nown     |       |  |  |  |
|                                    |                                     |              |                                          |              |                  |          |       |  |  |  |
| bit 15-4                           | bit 15-4 Unimplemented: Read as '0' |              |                                          |              |                  |          |       |  |  |  |

| bit 3 | G4POL: Gate 4 Polarity Control bit                                                                                                                 |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------|
|       | <ul><li>1 = The output of Gate 4 logic is inverted when applied to the logic cell</li><li>0 = The output of Gate 4 logic is not inverted</li></ul> |
| bit 2 | G3POL: Gate 3 Polarity Control bit                                                                                                                 |
|       | <ul><li>1 = The output of Gate 3 logic is inverted when applied to the logic cell</li><li>0 = The output of Gate 3 logic is not inverted</li></ul> |
| bit 1 | G2POL: Gate 2 Polarity Control bit                                                                                                                 |
|       | <ul><li>1 = The output of Gate 2 logic is inverted when applied to the logic cell</li><li>0 = The output of Gate 2 logic is not inverted</li></ul> |
| bit 0 | G1POL: Gate 1 Polarity Control bit                                                                                                                 |
|       | <ul><li>1 = The output of Gate 1 logic is inverted when applied to the logic cell</li><li>0 = The output of Gate 1 logic is not inverted</li></ul> |

| U-0                           | R/W-0                                                                                   | R/W-0                                                                                                                                                        | R/W-0            | U-0              | R/W-0           | R/W-0          | R/W-0 |  |  |
|-------------------------------|-----------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|------------------|-----------------|----------------|-------|--|--|
| —                             |                                                                                         | DS4<2:0>                                                                                                                                                     |                  | —                |                 | DS3<2:0>       |       |  |  |
| bit 15                        |                                                                                         |                                                                                                                                                              |                  |                  |                 |                | bit 8 |  |  |
|                               |                                                                                         |                                                                                                                                                              |                  |                  |                 |                |       |  |  |
| U-0                           | R/W-0                                                                                   | R/W-0                                                                                                                                                        | R/W-0            | U-0              | R/W-0           | R/W-0          | R/W-0 |  |  |
|                               |                                                                                         | DS2<2:0>                                                                                                                                                     |                  |                  |                 | DS1<2:0>       |       |  |  |
| bit 7                         |                                                                                         |                                                                                                                                                              |                  |                  |                 |                | bit 0 |  |  |
| r                             |                                                                                         |                                                                                                                                                              |                  |                  |                 |                |       |  |  |
| Legend:                       |                                                                                         |                                                                                                                                                              |                  |                  |                 |                |       |  |  |
| R = Readable                  | e bit                                                                                   | W = Writable I                                                                                                                                               | oit              | U = Unimpler     | nented bit, rea | d as '0'       |       |  |  |
| -n = Value at POR '1' = Bit i |                                                                                         |                                                                                                                                                              |                  | '0' = Bit is cle | own             |                |       |  |  |
|                               |                                                                                         |                                                                                                                                                              |                  |                  |                 |                |       |  |  |
| bit 15                        | Unimpleme                                                                               | nted: Read as 'o                                                                                                                                             | )'               |                  |                 |                |       |  |  |
| bit 14-12                     | DS4<2:0>: [                                                                             | Data Selection M                                                                                                                                             | UX 4 Signal S    | Selection bits   |                 |                |       |  |  |
|                               | xxx = Devic                                                                             | e-specific; refer                                                                                                                                            | to the device of | lata sheet for g | ate select map  | ping for MUX 4 |       |  |  |
| bit 11                        | Unimpleme                                                                               | nted: Read as '0                                                                                                                                             | )'               |                  |                 |                |       |  |  |
| bit 10-8                      | DS3<2:0>: [                                                                             | Data Selection M                                                                                                                                             | UX 3 Signal S    | Selection bits   |                 |                |       |  |  |
|                               | xxx = Devic                                                                             | e-specific; refer                                                                                                                                            | to the device of | lata sheet for g | ate select map  | ping for MUX 3 |       |  |  |
| bit 7                         | Unimpleme                                                                               | nted: Read as 'o                                                                                                                                             | )'               |                  |                 |                |       |  |  |
| bit 6-4                       | DS2<2:0>: [                                                                             | Data Selection M                                                                                                                                             | UX 2 Signal S    | Selection bits   |                 |                |       |  |  |
|                               | xxx = Device-specific; refer to the device data sheet for gate select mapping for MUX 2 |                                                                                                                                                              |                  |                  |                 |                |       |  |  |
| bit 3                         | Unimpleme                                                                               | nted: Read as 'o                                                                                                                                             | )'               |                  |                 |                |       |  |  |
| bit 2-0                       | DS1<2:0>: [<br>xxx = Devic                                                              | <b>DS1&lt;2:0&gt;:</b> Data Selection MUX 1 Signal Selection bits<br>xxx = Device-specific; refer to the device data sheet for gate select mapping for MUX 1 |                  |                  |                 |                |       |  |  |

#### Register 2-3: CLCxSEL: Configurable Logic Cell x Input MUX Select Register

| R/W-0         | R/W-0                                                       | R/W-0                    | R/W-0                                 | R/W-0                     | R/W-0           | R/W-0           | R/W-0 |  |  |  |
|---------------|-------------------------------------------------------------|--------------------------|---------------------------------------|---------------------------|-----------------|-----------------|-------|--|--|--|
| G2D4T         | G2D4N                                                       | G2D3T                    | G2D3N                                 | G2D2T                     | G2D2N           | G2D1T           | G2D1N |  |  |  |
| bit 15        |                                                             |                          |                                       |                           |                 |                 | bit 8 |  |  |  |
|               |                                                             |                          |                                       |                           |                 |                 |       |  |  |  |
| R/W-0         | R/W-0                                                       | R/W-0                    | R/W-0                                 | R/W-0                     | R/W-0           | R/W-0           | R/W-0 |  |  |  |
| G1D4T         | G1D4N                                                       | G1D3T                    | G1D3N                                 | G1D2T                     | G1D2N           | G1D1T           | G1D1N |  |  |  |
| bit 7         |                                                             |                          |                                       |                           |                 |                 | bit 0 |  |  |  |
|               |                                                             |                          |                                       |                           |                 |                 |       |  |  |  |
| Legend:       | - 1- ia                                                     |                          | - 14                                  |                           |                 | -1 (0)          |       |  |  |  |
| R = Readable  |                                                             | VV = VVritable I         | DIt                                   |                           | nented bit, rea |                 |       |  |  |  |
| -n = value at | POR                                                         | $1^{\circ} = Bit is set$ |                                       | $0^{\circ} = Bit is clea$ | ared            | x = Bit is unkr | nown  |  |  |  |
| hit 15        | CODAT: Cata                                                 | 2 Data / True I          | Enable bit                            |                           |                 |                 |       |  |  |  |
| DIL 15        | 1 – The Data                                                | 4 (non-inverted          | Enable bit<br>1) signal is ena        | bled for Gate 2           |                 |                 |       |  |  |  |
|               | 0 = The Data                                                | 4 (non-inverted          | l) signal is disa                     | bled for Gate 2           | 2               |                 |       |  |  |  |
| bit 14        | G2D4N: Gate                                                 | e 2 Data 4 Nega          | ited Enable bit                       |                           |                 |                 |       |  |  |  |
|               | 1 = The Data                                                | 4 (inverted) sig         | nal is enabled                        | for Gate 2                |                 |                 |       |  |  |  |
|               | 0 = The Data                                                | 4 (inverted) sig         | nal is disabled                       | for Gate 2                |                 |                 |       |  |  |  |
| bit 13        | G2D3T: Gate                                                 | 2 Data 3 True            | Enable bit                            |                           |                 |                 |       |  |  |  |
|               | 1 =  The Data                                               | 3 (non-inverted          | l) signal is ena<br>l) signal is disa | bled for Gate 2           | )<br>)          |                 |       |  |  |  |
| hit 12        | G2D3N: Gate                                                 | 2 Data 3 Nega            | ited Enable hit                       |                           | -               |                 |       |  |  |  |
| SIT 12        | 1 = The Data                                                | 3 (inverted) sig         | nal is enabled                        | for Gate 2                |                 |                 |       |  |  |  |
|               | 0 = The Data                                                | 3 (inverted) sig         | nal is disabled                       | for Gate 2                |                 |                 |       |  |  |  |
| bit 11        | G2D2T: Gate                                                 | 2 Data 2 True            | Enable bit                            |                           |                 |                 |       |  |  |  |
|               | 1 = The Data                                                | 2 (non-inverted          | l) signal is ena                      | bled for Gate 2           |                 |                 |       |  |  |  |
|               | 0 =  The Data                                               | 2 (non-inverted          | I) signal is disa                     | ibled for Gate 2          | 2               |                 |       |  |  |  |
| bit 10        | G2D2N: Gate                                                 | e 2 Data 2 Nega          | ited Enable bit                       | for Coto 2                |                 |                 |       |  |  |  |
|               | 1 = The Data 0 = The Data                                   | 2 (inverted) sig         | nal is enabled                        | for Gate 2                |                 |                 |       |  |  |  |
| bit 9         | G2D1T: Gate                                                 | 2 Data 1 True            | Enable bit                            |                           |                 |                 |       |  |  |  |
|               | 1 = The Data                                                | 1 (non-inverted          | I) signal is ena                      | bled for Gate 2           |                 |                 |       |  |  |  |
|               | 0 = The Data 1 (non-inverted) signal is disabled for Gate 2 |                          |                                       |                           |                 |                 |       |  |  |  |
| bit 8         | G2D1N: Gate                                                 | e 2 Data 1 Nega          | ted Enable bit                        |                           |                 |                 |       |  |  |  |
|               | 1 = The Data                                                | 1 (inverted) sig         | nal is enabled                        | for Gate 2                |                 |                 |       |  |  |  |
| hit 7         |                                                             | 1 (inverted) sig         | nal is disabled                       | for Gale 2                |                 |                 |       |  |  |  |
|               | 1 – The input                                               | src/ (non-inve           | rted) signal is                       | enabled Gate 1            | 1               |                 |       |  |  |  |
|               | 0 = The input                                               | _src4 (non-inve          | erted) signal is                      | disabled for Ga           | te 1            |                 |       |  |  |  |
| bit 6         | G1D4N: Gate                                                 | e 1 Data 4 Nega          | ted Enable bit                        |                           |                 |                 |       |  |  |  |
|               | 1 = The Data                                                | 4 (inverted) sig         | nal is enabled                        | for Gate 1                |                 |                 |       |  |  |  |
|               | 0 = The Data                                                | 4 (inverted) sig         | nal is disabled                       | for Gate 1                |                 |                 |       |  |  |  |
| bit 5         | G1D3T: Gate                                                 | 1 Data 3 True            | Enable bit                            |                           |                 |                 |       |  |  |  |
|               | 1 = The Data                                                | 3 (non-inverted          | I) signal is ena                      | bled for Gate 1           |                 |                 |       |  |  |  |
|               |                                                             |                          |                                       |                           |                 |                 |       |  |  |  |
| hit 1         | G1D3N+ Cate                                                 | 3 (non-inverted          | ted Enable bit                        |                           |                 |                 |       |  |  |  |
| bit 4         | <b>G1D3N:</b> Gate                                          | e 1 Data 3 Nega          | ited Enable bit                       | for Gate 1                |                 |                 |       |  |  |  |

#### . */*•

#### Register 2-4: CLCxGLSL: Configurable Logic Cell x Source Enable Register (Low) (Continued)

| bit 3 | G1D2T: Gate 1 Data 2 True Enable bit                                                                                                                |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
|       | 1 = The Data 2 (non-inverted) signal is enabled for Gate 1<br>0 = The Data 2 (non-inverted) signal is disabled for Gate 1                           |
| bit 2 | G1D2N: Gate 1 Data 2 Negated Enable bit                                                                                                             |
|       | <ul> <li>1 = The Data 2 (inverted) signal is enabled for Gate 1</li> <li>0 = The Data 2 (inverted) signal is disabled for Gate 1</li> </ul>         |
| bit 1 | G1D1T: Gate 1 Data 1 True Enable bit                                                                                                                |
|       | <ul> <li>1 = The Data 1 (non-inverted) signal is enabled for Gate 1</li> <li>0 = The Data 1 (non-inverted) signal is disabled for Gate 1</li> </ul> |
| bit 0 | G1D1N: Gate 1 Data 1 Negated Enable bit                                                                                                             |
|       | <ul> <li>1 = The Data 1 (inverted) signal is enabled for Gate 1</li> <li>0 = The Data 1 (inverted) signal is disabled for Gate 1</li> </ul>         |

| R/W-0  | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 |
|--------|-------|-------|-------|-------|-------|-------|-------|
| G4D4T  | G4D4N | G4D3T | G4D3N | G4D2T | G4D2N | G4D1T | G4D1N |
| bit 15 |       | •     |       |       | ·     |       | bit 8 |
|        |       |       |       |       |       |       |       |
| R/W-0  | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 |

#### Register 2-5: CLCxGLSH: Configurable Logic Cell x Source Enable Register (High)

| R/W-0 |
|-------|-------|-------|-------|-------|-------|-------|-------|
| G3D4T | G3D4N | G3D3T | G3D3N | G3D2T | G3D2N | G3D1T | G3D1N |
| bit 7 |       |       |       |       |       |       | bit 0 |
|       |       |       |       |       |       |       |       |

| Legend:           |                  |                             |                    |
|-------------------|------------------|-----------------------------|--------------------|
| R = Readable bit  | W = Writable bit | U = Unimplemented bit, read | l as '0'           |
| -n = Value at POR | '1' = Bit is set | '0' = Bit is cleared        | x = Bit is unknown |

| bit 15 | G4D4T: Gate 4 Data 4 True Enable bit                                                                                                                |  |  |
|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|        | <ul> <li>1 = The Data 4 (non-inverted) signal is enabled for Gate 4</li> <li>0 = The Data 4 (non-inverted) signal is disabled for Gate 4</li> </ul> |  |  |
| bit 14 | G4D4N: Gate 4 Data 4 Negated Enable bit                                                                                                             |  |  |
|        | <ul><li>1 = The Data 4 (inverted) signal is enabled for Gate 4</li><li>0 = The Data 4 (inverted) signal is disabled for Gate 4</li></ul>            |  |  |
| bit 13 | G4D3T: Gate 4 Data 3 True Enable bit                                                                                                                |  |  |
|        | <ul> <li>1 = The Data 3 (non-inverted) signal is enabled for Gate 4</li> <li>0 = The Data 3 (non-inverted) signal is disabled for Gate 4</li> </ul> |  |  |
| bit 12 | G4D3N: Gate 4 Data 3 Negated Enable bit                                                                                                             |  |  |
|        | <ul> <li>1 = The Data 3 (inverted) signal is enabled for Gate 4</li> <li>0 = The Data 3 (inverted) signal is disabled for Gate 4</li> </ul>         |  |  |
| bit 11 | G4D2T: Gate 4 Data 2 True Enable bit                                                                                                                |  |  |
|        | <ul> <li>1 = The Data 2 (non-inverted) signal is enabled for Gate 4</li> <li>0 = The Data 2 (non-inverted) signal is disabled for Gate 4</li> </ul> |  |  |
| bit 10 | G4D2N: Gate 4 Data 2 Negated Enable bit                                                                                                             |  |  |
|        | <ul> <li>1 = The Data 2 (inverted) signal is enabled for Gate 4</li> <li>0 = The Data 2 (inverted) signal is disabled for Gate 4</li> </ul>         |  |  |
| bit 9  | G4D1T: Gate 4 Data 1 True Enable bit                                                                                                                |  |  |
|        | <ul> <li>1 = The Data 1 (non-inverted) signal is enabled for Gate 4</li> <li>0 = The Data 1 (non-inverted) signal is disabled for Gate 4</li> </ul> |  |  |
|        |                                                                                                                                                     |  |  |

| Register 2-5: | CLCxGLSH: Configurable Logic Cell x Source Enable Register (High) (Continued)                                                                       |
|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| bit 8         | G4D1N: Gate 4 Data 1 Negated Enable bit                                                                                                             |
|               | <ul> <li>1 = The Data 1 (inverted) signal is enabled for Gate 4</li> <li>0 = The Data 1 (inverted) signal is disabled for Gate 4</li> </ul>         |
| bit 7         | G3D4T: Gate 3 Data 4 True Enable bit                                                                                                                |
|               | <ul> <li>1 = The Data 4 (non-inverted) signal is enabled Gate 3</li> <li>0 = The Data 4 (non-inverted) signal is disabled for Gate 3</li> </ul>     |
| bit 6         | G3D4N: Gate 3 Data 4 Negated Enable bit                                                                                                             |
|               | <ul> <li>1 = The Data 4 (inverted) signal is enabled for Gate 3</li> <li>0 = The Data 4 (inverted) signal is disabled for Gate 3</li> </ul>         |
| bit 5         | G3D3T: Gate 3 Data 3 True Enable bit                                                                                                                |
|               | <ul> <li>1 = The Data 3 (non-inverted) signal is enabled for Gate 3</li> <li>0 = The Data 3 (non-inverted) signal is disabled for Gate 3</li> </ul> |
| bit 4         | G3D3N: Gate 3 Data 3 Negated Enable bit                                                                                                             |
|               | <ul> <li>1 = The Data 3 (inverted) signal is enabled for Gate 3</li> <li>0 = The Data 3 (inverted) signal is disabled for Gate 3</li> </ul>         |
| bit 3         | G3D2T: Gate 3 Data 2 True Enable bit                                                                                                                |
|               | <ul> <li>1 = The Data 2 (non-inverted) signal is enabled for Gate 3</li> <li>0 = The Data 2 (non-inverted) signal is disabled for Gate 3</li> </ul> |
| bit 2         | G3D2N: Gate 3 Data 2 Negated Enable bit                                                                                                             |
|               | <ul> <li>1 = The Data 2 (inverted) signal is enabled for Gate 3</li> <li>0 = The Data 2 (inverted) signal is disabled for Gate 3</li> </ul>         |
| bit 1         | G3D1T: Gate 3 Data 1 True Enable bit                                                                                                                |
|               | <ul> <li>1 = The Data 1 (non-inverted) signal is enabled for Gate 3</li> <li>0 = The Data 1 (non-inverted) signal is disabled for Gate 3</li> </ul> |
| bit 0         | G3D1N: Gate 3 Data 1 Negated Enable bit                                                                                                             |
|               | <ul> <li>1 = The Data 1 (inverted) signal is enabled for Gate 3</li> <li>0 = The Data 1 (inverted) signal is disabled for Gate 3</li> </ul>         |

#### 3.0 CLC SETUP

CLCxCONL selects the logic function, and determines and controls the I/O pins. CLCxCONH controls output signal polarity. LCEN (CLCxCONL<15>) must be set for the CLC to operate. All registers can be programmed while LCEN is clear.

The CLCxSEL (Register 2-3) register controls which input signals are routed to the input bus of Figure 1-2. Both the True (T) and Negated (N) values are made available in the data bus.

The CLCxGLSL (Register 2-4) and CLCxGLSH (Register 2-5) registers select which signals from the data bus are applied to the input OR gates. True and Negated inputs are separately enabled; do not enable both for the same signal.

The final polarity of the CLC module output is controlled by LCPOL (CLCxCONL<5>). The output is inverted when LCPOL = 1 and uninverted when LCPOL = 0. The GxPOL bits (CLCxCONH<3:0>) control the polarity of the logic function inputs.

The INTP and INTN pins (CLCxCONL<11:10>) enable interrupts on the rising and falling edge of the CLC output.

The LCOUT bit is read-only and reflects the status of the logic cell output. To output the CLCxOUT signal to an I/O pin, set the LCOE bit and configure the I/O as a digital output. On some devices, the CLCxOUT signal is made available through Peripheral Pin Select (PPS) and will need to be configured.

### 4.0 INPUT PROVIDERS

Each logic cell in the CLC takes four inputs, one from each of the four data gates. Each data gate is connected to eight input sources. The data gate allows the selection between the inverted or non-inverted polarity of each input source. Input sources available for use with the CLC vary by device. Refer to the specific device data sheet for available options.

#### 4.1 Source Multiplexers

The module has four input source multiplexers. Multiplexer inputs are selected by setting control bits in the CLCxSEL register to define the data source selected through each of the four data selection multiplexers. Each of the four data selection multiplexers feeds one of the four logic function input gates, shown in Figure 1-3. The module has an internal data bus created from the output of each input source multiplexer (see Figure 1-2). The data bus has both True (T) and Negated (N) versions of each selected input source. Therefore, up to eight signals are available on the internal data bus to connect to the input gates of the logic function.

#### 4.2 Logic Input Gates

Four logic input gates are used to route input sources from the data selection multiplexers into the four logic function inputs. The True and Negated forms of each input source signal are available for use by each logic gate. The input signal sources are enabled for use by each logic function input using the CLCxGLS registers. There are up to eight signals that can be enabled for use by each logic function input. Any number of the eight signal sources may be enabled for each of the four logic function inputs. Each logic gate provides a logical OR of the input signals. The selected (True or Negated) signals are OR'd to form the gate output data. The logical NAND is obtained by changing the output polarity with the GxPOL bits. If the logical AND is required instead, select negated inputs and invert the output polarity according to DeMorgan's theorem. If all inputs are negated and applied to a NOR, the result is identical to an AND operation. Written algebraically:

C = A AND B

is the same as:

C = NOT(NOT(A) OR NOT(B)).

Table 4-1 summarizes the basic functions that can be obtained by using the gate control bits. The table shows the use of all four input multiplexer sources, but the input gates can be configured to use less. If no inputs are selected (CLCxGLS =  $0 \ge 000$ ), the output will be zero or one, depending on the GxPOL bits.

| Table 4-1: | Example Logic Functions |
|------------|-------------------------|
|------------|-------------------------|

| CLCxGLS | GxPOL Bits | Function              |
|---------|------------|-----------------------|
| 0xAAAA  | 0          | OR (D1, D2, D3, D4)   |
| 0xAAAA  | 1          | NOR (D1, D2, D3, D4)  |
| 0x5555  | 0          | NAND (D1, D2, D3, D4) |
| 0x5555  | 1          | AND (D1, D2, D3, D4)  |
| 0x0000  | 0          | Logic '0'             |
| 0x0000  | 1          | Logic '1'             |

If the output of a gate must be zero or one, the recommended method is to set all of the bits related to that gate in CLCxGLS to zero and use the Gate Polarity bit, GxPOL, to set the desired level.

#### 4.3 Logic Function

There are eight available logic functions, including:

- AND-OR
- OR-XOR
- AND
- S-R Latch
- D Flip-Flop with Set and Reset
- D Flip-Flop with Reset
- J-K Flip-Flop with Reset
- Transparent Latch with Set and Reset

Logic functions are shown in Figure 1-3. Each logic function has four inputs and one output. The MODE<2:0> bits (CLCxCONL<2:0>) set the functional behavior of the logic cell. There are four combinatorial options and four state options. Three of the state options define Input Gate 1 as a rising edge clock, with the traditional meanings of D and J-K flip-flops. The 4th state option, MODE<2:0> bits = 111, is a transparent latch; Q follows D when Latch Enable (LE) is true; Q holds state when LE is false. For options with both S (Set) and R (Reset) inputs, the output changes asynchronously to the clock when S or R is a logic '1'; R is dominant.

#### 4.4 Software Inputs

The gate data input to the logic function can be directly controlled by software by setting all of the CLCxGLSL/H bits associated with the logic gate to '0', and writing to the appropriate GxPOL bit (see Table 4-1). The gate output will be equal to the value of the GxPOL bit.

#### 5.0 OUTPUT

LCOUT (CLCxCONL<6>) is the logic cell output and is routed to the I/O port pin or to other modules within the device. In all cases, the signal value is taken after the LCPOL inverter. To observe this output on an I/O pin, the user will need to set LCOE (CLCxCONL<7>).

### 6.0 APPLICATION LOGIC

The CLC provides both combinatorial and state (see Figure 1-3) logic function options. The outputs of the input gates are applied to the logic function. If CLCxGLS =  $0 \times 00$ , the function receives a logic '0' when the GxPOL bits (CLCxCONH<3:0>) are clear or a logic '1' when the GxPOL bits are set.

#### 6.1 Combinatorial Logic

The combinatorial functions (MODE<2:0> = 010, 001, 000) build on the AND/OR logic of the input gate. The 4-input AND can provide an OR function by inverting the inputs and outputs using DeMorgan's theorem. Inverting the output of the XOR is the same as inverting one input (but not both).

The SR function (MODE<2:0> = 011) is not affected when LCEN (CLCxCONL<15>) is cleared, as is the case with the State Logic register. The latch is Reset-dominant, meaning that the Reset signal takes precedent over any Set signal that may be present.

#### 6.2 State Logic

The state functions include both D and J-K flip-flops with asynchronous Set (S) and Reset (R). Input Gate 1 provides a rising edge clock. If a falling edge clock is required, Gate 1 can be inverted in the gate logic (G1POL). Input Gate 2, and sometimes also Gate 4, provide data to the register or latch input(s). When operating in Transparent Latch mode (MODE<2:0> = 111), the output, Q, follows D while LE is high and holds state while LE is low.

The various modes may or may not share state memory and switching modes may or may not change the state of the state variable. For all modes, the register is Reset-dominant.

#### 7.0 CLC INTERRUPTS

The CLC module has two types of interrupts that can be enabled: rising edge interrupt events and falling edge interrupt events. These events are enabled by the INTP (CLCxCONL<11>) and INTN (CLCxCONL<10>) control bits, respectively.

A valid occurrence of either interrupt will set the CLC Interrupt Flag, CLCIF. This will occur when the module is enabled (LCEN = 1) and either a rising edge output occurs when INTP = 1, or a falling edge event occurs when INTN = 1.

If the initial output state of the CLC logic is '1' and INTP = 1, an interrupt will be generated when LCEN is set to '1'. Likewise, an interrupt will be generated if the initial output state of the CLC is '0' and INTN = 1. These conditions must be detected and cleared in software. Similarly, a false interrupt could be generated if INTP or INTN is set while the CLC module is enabled.

The user should be sure to clear any spurious interrupt events that may occur in the initialization process of the CLC module.

If the CLC Interrupt Enable bit, CLCIE, is cleared, an interrupt will not be generated. However, the CLCIF bit will still be set if an interrupt condition occurs. The user can clear the interrupt in the Interrupt Service Routine (ISR) by clearing CLCIF. See "Interrupts" (DS70000600) in the "dsPIC33/PIC24 Family Reference Manual" for more information.

### 8.0 OPERATION IN SLEEP MODE

The CLC module is not affected by Sleep mode, since it does not rely on system clock sources for operation. However, some input sources might be disabled during Sleep, so the function could be disrupted. If the source continues to operate, so will the module. Refer to the specific device data sheet for more information.

### 9.0 OPERATION IN IDLE MODE

The CLC module is not affected by Idle mode, since it does not rely on system clock sources for operation. However, some input sources might be disabled during Idle and the function could be disrupted. If the sources continues to operate, so will the module. Refer to the specific device data sheet for more information.

#### 10.0 **RESET**

When the LCEN bit is written to '0', the output of all state logic functions will be reset to '0'. A system Reset returns the CLCxCONL, CLCxCONH, CLCxSEL, CLCxGLSL and CLCxGLSH registers to the default state and disables the module.

Asserting a device Reset returns all bits in the module registers to the default state. The output of all logic functions is '0' after a Reset; this includes both latch and flip-flop functions. When a device Reset is asserted, LCEN (CLCxCONL<15>) = 0, the state logic is reset and the output of the logic function is forced low.

## 11.0 REVISION HISTORY

#### **Revision A (November 2016)**

This is the initial released revision of this document.

NOTES:

#### Note the following details of the code protection feature on Microchip devices:

- Microchip products meet the specification contained in their particular Microchip Data Sheet.
- Microchip believes that its family of products is one of the most secure families 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 Microchip products in a manner outside the operating specifications contained in Microchip's Data Sheets. Most likely, the person doing so is 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 products. Attempts to break Microchip's code protection feature may be a violation of the Digital Millennium Copyright Act. If such acts allow unauthorized access to your software or other copyrighted work, you may have a right to sue for relief under that Act.

Information contained in this publication regarding device applications and the like is provided only for your convenience and may be superseded by updates. It is your responsibility to ensure that your application meets with your specifications. MICROCHIP MAKES NO REPRESENTATIONS OR WARRANTIES OF ANY KIND WHETHER EXPRESS OR IMPLIED, WRITTEN OR ORAL, STATUTORY OR OTHERWISE, RELATED TO THE INFORMATION, INCLUDING BUT NOT LIMITED TO ITS CONDITION, QUALITY, PERFORMANCE, MERCHANTABILITY OR FITNESS FOR PURPOSE. Microchip disclaims all liability arising from this information and its use. Use of Microchip devices in life support and/or safety applications is entirely at the buyer's risk, and the buyer agrees to defend, indemnify and hold harmless Microchip from any and all damages, claims, suits, or expenses resulting from such use. No licenses are conveyed, implicitly or otherwise, under any Microchip intellectual property rights unless otherwise stated.

Microchip received ISO/TS-16949:2009 certification for its worldwide headquarters, design and wafer fabrication facilities in Chandler and Tempe, Arizona; Gresham, Oregon and design centers in California and India. The Company's quality system processes and procedures are for its PIC® MCUs and dsPIC® DSCs, KEELoQ® code hopping devices, Serial EEPROMs, microperipherals, nonvolatile memory and analog products. In addition, Microchip's quality system for the design and manufacture of development systems is ISO 9001:2000 certified.

# QUALITY MANAGEMENT SYSTEM CERTIFIED BY DNV = ISO/TS 16949=

#### Trademarks

The Microchip name and logo, the Microchip logo, AnyRate, dsPIC, FlashFlex, flexPWR, Heldo, JukeBlox, KeeLoq, KeeLoq logo, Kleer, LANCheck, LINK MD, MediaLB, MOST, MOST logo, MPLAB, OptoLyzer, PIC, PICSTART, PIC32 logo, RightTouch, SpyNIC, SST, SST Logo, SuperFlash and UNI/O are registered trademarks of Microchip Technology Incorporated in the U.S.A. and other countries.

ClockWorks, The Embedded Control Solutions Company, ETHERSYNCH, Hyper Speed Control, HyperLight Load, IntelliMOS, mTouch, Precision Edge, and QUIET-WIRE are registered trademarks of Microchip Technology Incorporated in the U.S.A.

Analog-for-the-Digital Age, Any Capacitor, AnyIn, AnyOut, BodyCom, chipKIT, chipKIT logo, CodeGuard, dsPICDEM, dsPICDEM.net, Dynamic Average Matching, DAM, ECAN, EtherGREEN, In-Circuit Serial Programming, ICSP, Inter-Chip Connectivity, JitterBlocker, KleerNet, KleerNet logo, MiWi, motorBench, MPASM, MPF, MPLAB Certified logo, MPLIB, MPLINK, MultiTRAK, NetDetach, Omniscient Code Generation, PICDEM, PICDEM.net, PICkit, PICtail, PureSilicon, RightTouch logo, REAL ICE, Ripple Blocker, Serial Quad I/O, SQI, SuperSwitcher, SuperSwitcher II, Total Endurance, TSHARC, USBCheck, VariSense, ViewSpan, WiperLock, Wireless DNA, and ZENA are trademarks of Microchip Technology Incorporated in the U.S.A. and other countries.

SQTP is a service mark of Microchip Technology Incorporated in the U.S.A.

Silicon Storage Technology is a registered trademark of Microchip Technology Inc. in other countries.

GestIC is a registered trademarks of Microchip Technology Germany II GmbH & Co. KG, a subsidiary of Microchip Technology Inc., in other countries.

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

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

ISBN: 978-1-5224-1077-5



# **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: http://www.microchip.com/ support

Web Address: www.microchip.com

Atlanta Duluth, GA Tel: 678-957-9614 Fax: 678-957-1455

Austin, TX Tel: 512-257-3370

Boston Westborough, MA Tel: 774-760-0087 Fax: 774-760-0088

Chicago Itasca, IL Tel: 630-285-0071 Fax: 630-285-0075

**Dallas** Addison, TX Tel: 972-818-7423 Fax: 972-818-2924

**Detroit** Novi, MI Tel: 248-848-4000

Houston, TX Tel: 281-894-5983

Indianapolis Noblesville, IN Tel: 317-773-8323 Fax: 317-773-5453 Tel: 317-536-2380

Los Angeles Mission Viejo, CA Tel: 949-462-9523 Fax: 949-462-9608 Tel: 951-273-7800

Raleigh, NC Tel: 919-844-7510

New York, NY Tel: 631-435-6000

**San Jose, CA** Tel: 408-735-9110 Tel: 408-436-4270

**Canada - Toronto** Tel: 905-695-1980 Fax: 905-695-2078

#### ASIA/PACIFIC

Asia Pacific Office Suites 3707-14, 37th Floor Tower 6, The Gateway

Harbour City, Kowloon Hong Kong Tel: 852-2943-5100 Fax: 852-2401-3431

Australia - Sydney Tel: 61-2-9868-6733 Fax: 61-2-9868-6755

**China - Beijing** Tel: 86-10-8569-7000 Fax: 86-10-8528-2104

**China - Chengdu** Tel: 86-28-8665-5511 Fax: 86-28-8665-7889

China - Chongqing Tel: 86-23-8980-9588 Fax: 86-23-8980-9500

China - Dongguan Tel: 86-769-8702-9880

China - Guangzhou Tel: 86-20-8755-8029

**China - Hangzhou** Tel: 86-571-8792-8115 Fax: 86-571-8792-8116

China - Hong Kong SAR Tel: 852-2943-5100

**China - Nanjing** Tel: 86-25-8473-2460 Fax: 86-25-8473-2470

Fax: 852-2401-3431

**China - Qingdao** Tel: 86-532-8502-7355 Fax: 86-532-8502-7205

China - Shanghai Tel: 86-21-3326-8000 Fax: 86-21-3326-8021

China - Shenyang Tel: 86-24-2334-2829 Fax: 86-24-2334-2393

**China - Shenzhen** Tel: 86-755-8864-2200 Fax: 86-755-8203-1760

**China - Wuhan** Tel: 86-27-5980-5300 Fax: 86-27-5980-5118

**China - Xian** Tel: 86-29-8833-7252 Fax: 86-29-8833-7256

#### ASIA/PACIFIC

**China - Xiamen** Tel: 86-592-2388138 Fax: 86-592-2388130

**China - Zhuhai** Tel: 86-756-3210040 Fax: 86-756-3210049

India - Bangalore Tel: 91-80-3090-4444 Fax: 91-80-3090-4123

India - New Delhi Tel: 91-11-4160-8631 Fax: 91-11-4160-8632

India - Pune Tel: 91-20-3019-1500

Japan - Osaka Tel: 81-6-6152-7160 Fax: 81-6-6152-9310

**Japan - Tokyo** Tel: 81-3-6880- 3770 Fax: 81-3-6880-3771

**Korea - Daegu** Tel: 82-53-744-4301 Fax: 82-53-744-4302

Korea - Seoul Tel: 82-2-554-7200 Fax: 82-2-558-5932 or 82-2-558-5934

Malaysia - Kuala Lumpur Tel: 60-3-6201-9857 Fax: 60-3-6201-9859

Malaysia - Penang Tel: 60-4-227-8870 Fax: 60-4-227-4068

Philippines - Manila Tel: 63-2-634-9065 Fax: 63-2-634-9069

**Singapore** Tel: 65-6334-8870 Fax: 65-6334-8850

**Taiwan - Hsin Chu** Tel: 886-3-5778-366 Fax: 886-3-5770-955

Taiwan - Kaohsiung Tel: 886-7-213-7830 Taiwan - Taipei

Tel: 886-2-2508-8600 Fax: 886-2-2508-0102

**Thailand - Bangkok** Tel: 66-2-694-1351 Fax: 66-2-694-1350

#### EUROPE

Austria - Wels Tel: 43-7242-2244-39 Fax: 43-7242-2244-393

**Denmark - Copenhagen** Tel: 45-4450-2828 Fax: 45-4485-2829

Finland - Espoo Tel: 358-9-4520-820

France - Paris Tel: 33-1-69-53-63-20 Fax: 33-1-69-30-90-79

France - Saint Cloud Tel: 33-1-30-60-70-00

**Germany - Garching** Tel: 49-8931-9700 **Germany - Haan** Tel: 49-2129-3766400

Germany - Heilbronn Tel: 49-7131-67-3636

Germany - Karlsruhe Tel: 49-721-625370

**Germany - Munich** Tel: 49-89-627-144-0 Fax: 49-89-627-144-44

**Germany - Rosenheim** Tel: 49-8031-354-560

Israel - Ra'anana Tel: 972-9-744-7705

Italy - Milan Tel: 39-0331-742611 Fax: 39-0331-466781

Italy - Padova Tel: 39-049-7625286

Netherlands - Drunen Tel: 31-416-690399 Fax: 31-416-690340

Norway - Trondheim Tel: 47-7289-7561

Poland - Warsaw Tel: 48-22-3325737

**Romania - Bucharest** Tel: 40-21-407-87-50

**Spain - Madrid** Tel: 34-91-708-08-90 Fax: 34-91-708-08-91

Sweden - Gothenberg Tel: 46-31-704-60-40

**Sweden - Stockholm** Tel: 46-8-5090-4654

**UK - Wokingham** Tel: 44-118-921-5800 Fax: 44-118-921-5820