# AN13101 LPC804 PLU Config Tool Demo

Rev. 0 — December 21, 2020

by: NXP Semiconductors

### 1 Introduction

LPC804 has a Programmable Logic Unit (PLU) module. The PLU is used to create small combinatorial and/or sequential logic circuits that operate completely independently from the Arm<sup>®</sup> Cortex<sup>®</sup> M0+ Core. The logic operation can be programmed using software, and NXP provides free tools to help designers easily implement circuit designs and automatically generate the required register settings.

PLU features are listed as below:

- · Up to 6 inputs from I/O pads
- Up to 8 outputs to I/O pads
- Up to 26 Look Up Tables (LUTs)
- Up to 4 state Flip Flops (FFs)
- Clock input from external I/O pad
- · Feedback to MCU via I/O pads or through switch matrix

### 1.1 Look Up Tables (LUTs)

The PLU module has 26 LUTs, which can implement any combinational function of up to five possible inputs.

The inputs include:

- · Other LUT outputs
- State FF outputs
- · All inputs available from PLU I/O pads

#### Contents

| Introduction                        | .1                                                                                                                                                                                                                              |
|-------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Look Up Tables (LUTs)               | .1                                                                                                                                                                                                                              |
| Multiplexer                         | .2                                                                                                                                                                                                                              |
| Steps for using the PLU             | 4                                                                                                                                                                                                                               |
| Build user App. with PLU Config too | b                                                                                                                                                                                                                               |
|                                     | 5                                                                                                                                                                                                                               |
| Required environment for demos      |                                                                                                                                                                                                                                 |
|                                     | 5                                                                                                                                                                                                                               |
| Direct, LUT-based design demo       |                                                                                                                                                                                                                                 |
|                                     | 5                                                                                                                                                                                                                               |
| Schematic design demo               | 9                                                                                                                                                                                                                               |
| Reference1                          | 4                                                                                                                                                                                                                               |
|                                     | Introduction<br>Look Up Tables (LUTs)<br>Multiplexer<br>Steps for using the PLU<br>Build user App. with PLU Config too<br>Required environment for demos<br>Direct, LUT-based design demo<br>Schematic design demo<br>Reference |



Application Note



Each LUT is programmable using LPC804 registers which implements the logic mapping from 5 input lines to 1 output line with the **Logic Truth Value Table**. The output is immediately determined (allowing for propagation delays) by matching the input values of input lines with the entry in the table that matches the input values.

|     | An      | exai     | nple    | of Lo   | gic T  | ruth \    | /alue    | Та   | able fo   | r a 5-i | input | custo | omize | d LUT |     |
|-----|---------|----------|---------|---------|--------|-----------|----------|------|-----------|---------|-------|-------|-------|-------|-----|
|     | IDX     | IN4      | IN3     | IN2     | IN1    | IN0       | OUT      |      | IDX       | IN4     | IN3   | IN2   | IN1   | IN0   | OUT |
|     | 0x0     | 0        | 0       | 0       | 0      | 0         | 0        |      | 0x10      | 1       | 0     | 0     | 0     | 0     | 1   |
|     | 0x1     | 0        | 0       | 0       | 0      | 1         | 0        |      | 0x11      | 1       | 0     | 0     | 0     | 1     | 1   |
|     | 0x2     | 0        | 0       | 0       | 1      | 0         | 0        |      | 0x12      | 1       | 0     | 0     | 1     | 0     | 1   |
|     | 0x3     | 0        | 0       | 0       | 1      | 1         | 0        |      | 0x13      | 1       | 0     | 0     | 1     | 1     | 1   |
|     | 0x4     | 0        | 0       | 1       | 0      | 0         | 0        |      | 0x14      | 1       | 0     | 1     | 0     | 0     | 1   |
|     | 0x5     | 0        | 0       | 1       | 0      | 1         | 0        |      | 0x15      | 1       | 0     | 1     | 0     | 1     | 1   |
|     | 0x6     | 0        | 0       | 1       | 1      | 0         | 0        |      | 0x16      | 1       | 0     | 1     | 1     | 0     | 1   |
|     | 0x7     | 0        | 0       | 1       | 1      | 1         | 0        |      | 0x17      | 1       | 0     | 1     | 1     | 1     | 1   |
|     | 0x8     | 0        | 1       | 0       | 0      | 0         | 1        |      | 0x18      | 1       | 1     | 0     | 0     | 0     | 1   |
|     | 0x9     | 0        | 1       | 0       | 0      | 1         | 1        |      | 0x19      | 1       | 1     | 0     | 0     | 1     | 0   |
|     | 0xA     | 0        | 1       | 0       | 1      | 0         | 1        |      | 0x1A      | 1       | 1     | 0     | 1     | 0     | 0   |
|     | 0xB     | 0        | 1       | 0       | 1      | 1         | 1        |      | 0x1B      | 1       | 1     | 0     | 1     | 1     | 0   |
|     | 0xC     | 0        | 1       | 1       | 0      | 0         | 1        |      | 0x1C      | 1       | 1     | 1     | 0     | 0     | 0   |
|     | 0xD     | 0        | 1       | 1       | 0      | 1         | 1        |      | 0x1D      | 1       | 1     | 1     | 0     | 1     | 0   |
|     | 0xE     | 0        | 1       | 1       | 1      | 0         | 1        |      | 0x1E      | 1       | 1     | 1     | 1     | 0     | 0   |
|     | 0xF     | 0        | 1       | 1       | 1      | 1         | 1        |      | 0x1F      | 1       | 1     | 1     | 1     | 1     | 0   |
| . A | n examp | ole of L | .ogic T | ruth Va | lue Ta | ble for a | a 5-inpu | ıt c | customize | ed LUT  |       |       |       |       |     |

### 1.2 Multiplexer

Multiplexers in the PLU are used to set up the connections between units and select the right output signal.

Figure 3 shows the LUT input and output multiplexers for each channel.



Figure 4 shows the PLU output mux for each LUT.



### 1.3 Steps for using the PLU

The PLU works as a general peripheral. Configure the PLU as below:

#### 1. Enable clocks

Enable PLU and SWM clock in SYSCON\_SYSAHBCLKCTRLx register and toggle the PLU Reset bit in the SYSCON\_PRESETCTRLx register.

#### 2. Assign pins

Assign PLU inputs and outputs to specific pins using SWM\_PINASSIGNFIXED0. Some pins can be configured as both input and output of the PLU. For example, PIO0\_08 can be assigned to both PLU\_OUT1 and PLU\_INPUT0.

#### 3. Create a logic network

Perform as below to implement a logic design with the PLU:

- Considering the approach to be used, direct LUT implementation or using primitive logic gates (or a mix of both approaches)
- · Programming the customized LUTs, if primitive logic gates are not used
- · Programming the connection of PLU inputs and outputs to LUTs

To help developers create a logic design, NXP provides a PLU Config Tool to help user create logic networks easily. This tool can be downloaded for free from PLU configuration tool page. The following illustrates how to build a simple design with the PLU Design Tool. MCUXpresso Configuration tools also include support for setting up the PLU, assistant to pin connection and error checking.

## 2 Build user App. with PLU Config tool

PLU Config tool can run on Windows 8 or 10.

With the PLU Config tool, a user can:

- Create customized LUTs by direct, LUT-based and/or gate-level design.
- Automatically generate LUT configurations from a schematic design.
- Implement a design from Verilog.
- Generate C code to set up the PLU configuration registers automatically.

Users still need to connect PLU inputs, outputs, PLU clk in to the physical pins via the switch matrix.

In this document, we build two example circuits to illustrate how to use the PLU Config tool, one using the direct LUT-based design and the other using a schematic design approach.

### 2.1 Required environment for demos

### 2.1.1 Hardware

- · LPCXpresso804 evaluation board
- · A USB cable
- Host computer

#### Board rework:

PLU input pins connection (using wires to connect):

- Input1 CN3\_7 (GPIO0\_8) to CN8\_2 (PLU\_IN2, GPIO0\_21).
- Input2 CN3\_6 (GPIO0\_9) to CN3\_10 (PLU\_IN3, GPIO0\_20).
- Input3 CN5\_1 (GPIO0\_10) to CN8\_5 (PLU\_IN4, GPIO0\_19).

PLU output pins connection (using wires to connect):

• Output1 - CN3\_1 (PLU\_OUT0, GPIO0\_14) to CN8\_4 (LED\_RED, GPIO0\_13).

### 2.1.2 Software

Examples built using MCUXpresso IDE v11.2.1 and SDK 2.8.0 are provided on NXP to complement this application note. Two sets of demo code are included:

- Using direct, LUT-based design to generate C code to set up PLU configuration register
- Using schematic design to generate C code to set up PLU configuration register

### 2.2 Direct, LUT-based design demo

This demo illustrates how to use LUT-based method in PLU config tool to create an example LUT-based design with no specific purpose, just for illustrative purpose, which has the logic needed between inputs and outputs as below.

### 2.2.1 Logic between inputs and outputs

For this demo, we set up the design for the relationship between inputs and outputs, as shown in Table 1.

#### LPC804 PLU Config Tool Demo, Rev. 0, December 21, 2020

| Input3  | Input2  | Input1  | Output1                           |
|---------|---------|---------|-----------------------------------|
| PLU_IN4 | PLU_IN3 | PLU_IN2 | PLU_OUT0                          |
| P0_19   | P0_20   | P0_21   | P0_14 (Red LED, ON for <b>0</b> ) |
| LUT_IN2 | LUT_IN1 | LUT_IN0 | LUT_OUT0                          |
| 0       | 0       | 0       | 1                                 |
| 0       | 0       | 1       | 0                                 |
| 0       | 1       | 0       | 1                                 |
| 0       | 1       | 1       | 0                                 |
| 1       | 0       | 0       | 1                                 |
| 1       | 0       | 1       | 0                                 |
| 1       | 1       | 0       | 1                                 |
| 1       | 1       | 1       | 0                                 |

Table 1. Logic between inputs and outputs for LUT-based design demo

### 2.2.2 PLU Config tool usage

1. Open the PLU Config tool and choose working flow for Direct, LUT-based design. Place Input ports 1, 2, and 3, then output1 and LUT0 in the schematic, draw the connections between inputs, LUT and output, as shown in Figure 5.



2. After finishing the connections, on the left of the window, there is a **mapping** setup window ready for setup. It specifies connections from the inputs and outputs to specific PLU resources. Map PLU inputs and output to the LUT by choosing the needed pins from the pull-down menu. The demo code uses PLU\_INPUT2 for input1, PLU\_INPUT3 for input2, PLU\_INPUT4 for input3, and PLU\_OUTPUT0 for output1. These relationships are shown in Table 1.

| File Edit Tools                            | File Edit Tools PLD Help |  |  |
|--------------------------------------------|--------------------------|--|--|
| Schematic Name<br>Input1                   | Mapped<br>IN2            |  |  |
| Input2                                     | IN3                      |  |  |
| Input3                                     | IN4                      |  |  |
| LUTO                                       | LUT0                     |  |  |
| Output1                                    | OUT0                     |  |  |
|                                            |                          |  |  |
| Figure 6. Map PLU input and output to LUTs |                          |  |  |

3. In the right panel of the Config Tool, there is a LUT setup form which can be used to set up the LUT values directly, according to Table 1. Click on the table output column to change the **0** or **1** value as desired.

|                             |        |     |      |     |     |      | _      |   |  |  |
|-----------------------------|--------|-----|------|-----|-----|------|--------|---|--|--|
| I LUT                       | د<br>S | our | ces  | Ø   | Tim | ning |        |   |  |  |
|                             |        |     |      |     |     |      |        |   |  |  |
| A ->                        | > Inp  | ut1 |      |     |     |      |        |   |  |  |
| В ->                        | > Inp  | ut2 |      |     |     |      |        |   |  |  |
| C ->                        | > Inp  | ut3 |      |     |     |      |        |   |  |  |
| D                           | > x    |     |      |     |     |      |        |   |  |  |
| E ->                        | ×      |     |      |     |     |      |        |   |  |  |
| Level 1                     | -      |     | D    | 6   | D   | •    | OUT    | • |  |  |
| ind                         | ex     | E   | U    | 0   | B   | A    | 1001   |   |  |  |
| 0.0                         | ,      |     | X    | 0   | 0   | 1    | 0      |   |  |  |
| 0.1                         |        |     |      | 0   | 1   | 0    | 1      |   |  |  |
| 0x2                         |        |     | X    | 0   | 1   | 1    | 0      |   |  |  |
| 0x3                         |        |     | X    | 1   | -   | -    | 1      |   |  |  |
| 0x4                         |        |     | X    | 1   | 0   | 1    | 0      |   |  |  |
| 0x5                         |        |     |      | 1   | 1   | 0    | 1      |   |  |  |
| 0.7                         | ,      |     |      | 1   | 1   | 1    | 0      |   |  |  |
| 0.7                         |        |     | X    | -   |     |      | U      | _ |  |  |
| 0.40                        | >      | X   | X    | X   | ×   | ×    | ×      |   |  |  |
| 0/3                         |        |     |      |     |     |      | ~      |   |  |  |
| 0x8                         |        |     | ×    | ×   | ÷   | Ŷ    | Ŷ      |   |  |  |
| 0x0                         |        |     | ×    | ×   | ÷   | ŷ    | Ŷ      |   |  |  |
| 0x0                         | 1      |     | x    | ×   | Ŷ   | Ŷ    | x      |   |  |  |
| 0xe                         |        |     | x    | X   | x   | x    | x      |   |  |  |
| Oxf                         |        |     | X    | X   | x   | x    | x      |   |  |  |
| 0.1                         | 0      |     |      |     |     |      |        | ~ |  |  |
| Nan                         | ne:    | L   | UTO  | )   |     |      |        |   |  |  |
| Llav                        |        |     | 0v5  | 555 | 555 | 5    |        |   |  |  |
| Hex                         |        |     | 0.00 | 555 |     | ,    | _      |   |  |  |
| Туре                        | e:     |     | Cu   | sto | m   |      | $\sim$ |   |  |  |
| Inpu                        | it:    |     | 2    |     |     |      | ~      |   |  |  |
| inpe                        |        |     | 3    |     |     |      | -      |   |  |  |
|                             |        |     |      |     |     |      |        |   |  |  |
| t up the LUT value directly |        |     |      |     |     |      |        |   |  |  |
|                             |        |     |      |     |     |      |        |   |  |  |

4. After completing the LUT setup, press the **Sources** tab in this window. The tool generates the C code automatically and this code can be used to set up PLU configuration registers.

| 1                        | 표 LUT 🗟 Sources 🛱 Timing                                                                                                                                                                                                                                                                 |                                                                                                                                                                      |  |
|--------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|                          | plu_tool.c                                                                                                                                                                                                                                                                               | Output format: SDK v2.7.x 🗸 🔛                                                                                                                                        |  |
|                          | <pre>/*  * This file was generated by the  * 6 Inputs 26 LUTs 4 flip flops a  /* LUT0 (LUT0) */</pre>                                                                                                                                                                                    | <pre>PLU Config Tool. nd 8 outputs */</pre>                                                                                                                          |  |
|                          | <pre>PLU-&gt;LUT[0].INP_MUX[0] = 0x0000000 PLU-&gt;LUT[0].INP_MUX[1] = 0x00000000 PLU-&gt;LUT[0].INP_MUX[2] = 0x00000000 PLU-&gt;LUT[0].INP_MUX[3] = 0x00000003 PLU-&gt;LUT[0].INP_MUX[4] = 0x00000003 PLU-&gt;LUT_TRUTH[0] = 0x55555555; /* PLU-&gt;OUTPUT_MUX[0] = 0x00000000; /</pre> | 2; /* IN2 (Input1) */<br>3; /* IN3 (Input2) */<br>4; /* IN4 (Input3) */<br>F; /* default */<br>F; /* default */<br>LUT0 (LUT0) CUSTOM */<br>* LUT0 (LUT0) -> Output1 |  |
| Figure 8. Generate the C | code to set up PLU configuration regis                                                                                                                                                                                                                                                   | ster                                                                                                                                                                 |  |

5. Refer to the SDK PLU demo code in the example project, *lpcxpresso804\_plu\_AN\_direct\_LUT\_design*. The example code has a value of 0x5555555 for LUT\_TRUTH[0]. Because in this demo only three inputs are used, as shown in Table 1, the LUT\_OUT0 only uses eight values in the truth table, only the first eight bits are needed to configure the LUT, so the configuration value, 0x0000055, could be used in the output code.

In line30 of the *plu\_combination.c* file, modify the configured value according to the generated C code. And in order to watch the Red LED only, configure LUT1 (Green) and LUT2 (Blue) to 0xFF.

```
11 #include "fsl_debug_console.h"
12
13 #include "pin mux.h"
                          149 /***
   * Definitions
15
16 ***
17
18 /* PLU module */
19 #define DEMO PLU BASE
                                PLU
20 #define DEMO_PLU_LUT_IN_SRC_0 kPLU_LUT_IN_SRC_PLU_IN_2
21 #define DEMO PLU LUT IN SRC 1 kPLU LUT IN SRC PLU IN 3
22 #define DEMO_PLU_LUT_IN_SRC_2 kPLU_LUT_IN_SRC_PLU_IN_4
23
24 #define DEMO_PLU_LUT_OUT_SRC_0
                                     kPLU_OUT_SRC_LUT_0
25 #define DEMO PLU LUT OUT SRC 1
                                     kPLU OUT SRC LUT 1
26 #define DEMO_PLU_LUT_OUT_SRC_2
                                     kPLU_OUT_SRC_LUT_2
27<sup>©</sup> //#define DEMO_PLU_LUT_0_TRUTH_TABLE 0x000004D /* 0b01001101 */
28 //#define DEMO_PLU_LUT_1_TRUTH_TABLE 0x000002B /* 0b00101011 */
29 //#define DEMO PLU LUT 2 TRUTH TABLE 0x0000017 /* 0b00010111 */
30 #define DEMO_PLU_LUT_0_TRUTH_TABLE 0x0000055 /* 0b01010101 using for AN demo code for direct LUT design */
31 #define DEMO_PLU_LUT_1_TRUTH_TABLE 0x00000FF /* 0b11111111 Let only RED LED Lighting in the Demo*/
32 #define DEMO PLU LUT 2 TRUTH TABLE 0x00000FF /* 0b11111111 Let only RED LED Lighting in the Demo*/
33
Figure 9. Modify the SDK PLU demo code according generated C code
```

#### 2.2.3 Direct\_LUT design demo result

- 1. Set up the board as described in Board rework.
- 2. Build and run the provided demo code, *lpcxpresso804\_plu\_AN\_direct\_LUT\_design.zip*.
- 3. Input **0** or **1** for input 1, 2, 3 from the MCUXpresso IDE Console window, and watch the Red LED status. The results are shown in Table 2.

| Input3 | Input2 | Input1 | Output1 - RED LED |
|--------|--------|--------|-------------------|
| 0      | 0      | 0      | OFF               |
| 0      | 0      | 1      | ON                |
| 0      | 1      | 0      | OFF               |
| 0      | 1      | 1      | ON                |
| 1      | 0      | 0      | OFF               |
| 1      | 0      | 1      | ON                |
| 1      | 1      | 0      | OFF               |
| 1      | 1      | 1      | ON                |

Table 2. Direct\_LUT design demo result

### 2.3 Schematic design demo

The difference between LUT-based method and schematic method is that in LUT-based method the user defines the LUT truth table directly. In the Schematic method, the users place inputs, outputs and logic primitive gates, such as **AND**, **OR**, **XOR**, etc., connect them, and allows the tool to synthesize the logic network into LUTs.

This demo illustrates how to use schematic method in PLU config tool to configure a wanted LUT which is used to make synthesis according to the logic units used.

In the schematic design demo, we config an example LUT with no real purpose, just for illustration, which has the logic needed between inputs and outputs as below.

### 2.3.1 Logic between inputs and outputs

For this demo, we set logic between inputs and outputs as shown in Table 3.

Table 3. Logic between input and output for LUT-based design demo

| Input3  | Input2  | Input1  | Output1<br>(Red LED, ON for 0) | Output2<br>(Green LED, ON for 0) |
|---------|---------|---------|--------------------------------|----------------------------------|
| PLU_IN4 | PLU_IN3 | PLU_IN2 | PLU_OUT0                       | PLU_OUT1                         |
| P0_19   | P0_20   | P0_21   | P0_14                          | P0_15                            |
| LUT_IN2 | LUT_IN1 | LUT_IN0 | LUT_OUT0                       | LUT_OUT1                         |
|         | 0       | 0       | 0                              |                                  |
|         | 0       | 1       | 0                              |                                  |
|         | 1       | 0       | 0                              |                                  |
|         | 1       | 1       | 1                              |                                  |

Table continues on the next page ....

| Input3 | Input2 | Input1 | Output1<br>(Red LED, ON for 0) | Output2<br>(Green LED, ON for 0) |
|--------|--------|--------|--------------------------------|----------------------------------|
| 0      | 0      |        |                                | 0                                |
| 0      | 1      |        |                                | 1                                |
| 1      | 0      |        |                                | 1                                |
| 1      | 1      |        |                                | 1                                |

Table 3. Logic between input and output for LUT-based design demo (continued)

### 2.3.2 PLU Config tool usage

1. Open a new design in the PLU Config tool to choose the schematic design option. Place needed Inputs 1, 2, and 3, and output 1 and 2, add logic gates AND1, OR1 in the schematic, and draw the connections between inputs, logic units and output, as shown in Figure 10. The number of gates that can be added is unlimited. Only inputs, outputs and flip-flops have a restricted quantity.



2. After completing the schematic, on the left panel of the tool, to map PLU input and output to specific input/output resources, click the **mapping** and select from the pull-down menu. The demo code uses PLU\_INPUT2 for input1, PLU\_INPUT3 for input2, PLU\_INPUT4 for input3, PLU\_OUTPUT0 for output1, PLU\_OUTPUT1 for output2, as shown in Table 3.

| Mapping         |        |
|-----------------|--------|
| Schematic Name  | Mapped |
| Input1          | IN2    |
| Input2          | IN3    |
| Input3          | IN4    |
| Output1_PLU_OUT | OUT0   |
| Output2_PLU_OUT | OUT1   |
|                 |        |
|                 |        |

3. In the top-level menu, select PLD menu and then click **Finalize**. PLD is a tool to optimize the logic design, mapping it to the available LUTs. It is implemented using an open source and a third party (UCLA) tool, and is integrated in the PLU Config Tool installation. If you want to use the standard versions of these tools just click next when the Optimize wizard dialog appears.



4. Once the finalize operation has completed, click on the **Sources** tab in the right-hand panel of the tool and observe the C code that has been generated. This C code can now be used to set up the PLU configuration register.

| Source                                                                   | s 🛱 Timing                                                                                                                                                                                                                                                                                                          | -                                                        | - D        |
|--------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------|------------|
| plu_tool.c                                                               | Output format: S                                                                                                                                                                                                                                                                                                    | SDK v2.7.x ∨                                             | <u>ila</u> |
| /*<br>* Thi:<br>* 6 In<br>/* UIT                                         | s file was generated by the PLU Config To<br>nputs 26 LUTs 4 flip flops and 8 outputs                                                                                                                                                                                                                               | ool.<br>*/                                               | ^          |
| PLU->LU<br>PLU->LU<br>PLU->LU<br>PLU->LU<br>PLU->LU<br>PLU->LU           | <pre>I (040001) */<br/>JT[4].INP_MUX[0] = 0x000000003; /* IN3 (In<br/>JT[4].INP_MUX[1] = 0x00000002; /* IN2 (In<br/>JT[4].INP_MUX[2] = 0x0000003F; /* default<br/>JT[4].INP_MUX[3] = 0x0000003F; /* default<br/>JT[4].INP_MUX[4] = 0x0000003F; /* default<br/>JT_TRUTH[4] = 0x888888888; /* Output1 CUST<br/></pre> | nput2) */<br>nput1) */<br>t */<br>t */<br>t */<br>TOM */ |            |
| /* LUT<br>PLU->LU<br>PLU->LU<br>PLU->LI<br>PLU->LI<br>PLU->LI<br>PLU->LI | 5 (Output2) */<br>JT[5].INP_MUX[0] = 0x00000004; /* IN4 (Ir<br>JT[5].INP_MUX[1] = 0x00000003; /* IN3 (Ir<br>JT[5].INP_MUX[2] = 0x0000003F; /* default<br>JT[5].INP_MUX[3] = 0x0000003F; /* default<br>JT[5].INP_MUX[4] = 0x0000003F; /* default<br>JT_TRUTH[5] = 0xeeeeeee; /* Output2 CUST                         | nput3) */<br>nput2) */<br>t */<br>t */<br>TOM */         |            |
| PLU->00<br>PLU->00                                                       | JTPUT_MUX[0] = 0x00000004; /* LUT4 (Outpu<br>JTPUT_MUX[1] = 0x00000005; /* LUT5 (Outpu                                                                                                                                                                                                                              | ut1) -> Out;<br>ut2) -> Out;                             | p<br>p     |
| Generate C code to se                                                    | et up PLU configuration register                                                                                                                                                                                                                                                                                    |                                                          |            |

5. Finally, we can modify the SDK PLU demo code in the *lpcxpresso804\_plu\_AN\_Schematic\_design* project. The LUT4 and LUT5 are used by default by the tool, while in the demo we used LUT0 and LUT1, so the LUT4 and LUT5 in the C Code, can be changed to LUT0 and LUT1 in the output code.

The generated C code sets a value of 0x888888888 for LUT\_TRUTH[4], and 0xeeeeeeee for LUT\_TRUTH[5], because in this demo, only two inputs are used. As shown in Table 3, the LUT\_OUT0 and LUT\_OUT1 only use four values in the truth table, so we need only the first four bits to configure the LUT, the configuration value can use 0x0000008 for LUT0 and 0x000000E for LUT1.

In lines 30 and 31 of the *plu\_combination.c* file, modify the configured value according to the generated C code, and in order to enabled changes of the Red and Green LEDs only, configure LUT2 (Blue) to **0xFF**.

```
13 #include "pin_mux.h"
 148 /******
 15 * Definitions
 16
    ******
                  17
 18 /* PLU module */
 19 #define DEMO_PLU_BASE
                                PLU
 20 #define DEMO PLU LUT IN SRC 0 kPLU LUT IN SRC PLU IN 2
 21 #define DEMO PLU LUT IN SRC 1 kPLU LUT IN SRC PLU IN 3
 22 #define DEMO_PLU_LUT_IN_SRC_2 kPLU_LUT_IN_SRC_PLU_IN_4
 23
 24 #define DEMO_PLU_LUT_OUT_SRC_0
                                     kPLU_OUT_SRC_LUT_0
                                     kPLU_OUT_SRC_LUT_1
 25 #define DEMO_PLU_LUT_OUT_SRC_1
 26 #define DEMO PLU LUT OUT SRC 2
                                     kPLU OUT SRC LUT 2
 279 //#define DEMO_PLU_LUT_0_TRUTH_TABLE 0x000004D /* 0b01001101 */
 28 //#define DEMO_PLU_LUT_1_TRUTH_TABLE 0x000002B /* 0b00101011 */
 29 //#define DEMO_PLU_LUT_2_TRUTH_TABLE 0x0000017 /* 0b00010111 */
 30 #define DEMO_PLU_LUT_0_TRUTH_TABLE 0x0000008 /* 0b1000 using for AN demo code for schematic design */
 31 #define DEMO_PLU_LUT_1_TRUTH_TABLE 0x000000E /* 0b1110 using for AN demo code for schematic design*/
 32 #define DEMO_PLU_LUT_2_TRUTH_TABLE 0x00000FF /* 0b11111111 Disable Blue LED Lighting in the Demo*/
 33
Figure 14. Modify SDK PLU demo code according generated C code
```

### 2.3.3 Schematic design demo result

Build and run the code. Input **0** or **1** for input1, 2, or 3 in the **Console** window, and observe the Red and Green LED status, as shown in Table 4.

| Input3 | Input2 | Input1 | Output1<br>Red LED | Output2<br>Green LED |
|--------|--------|--------|--------------------|----------------------|
| 0 or 1 | 0      | 0      | ON                 |                      |
| 0 or 1 | 0      | 1      | ON                 |                      |
| 0 or 1 | 1      | 0      | ON                 |                      |
| 0 or 1 | 1      | 1      | OFF                |                      |
| 0      | 0      | 0 or 1 |                    | ON                   |
| 0      | 1      | 0 or 1 |                    | OFF                  |
| 1      | 0      | 0 or 1 |                    | OFF                  |
| 1      | 1      | 0 or 1 |                    | OFF                  |

#### Table 4. Schematic design demo result

### 3 Reference

For further information, see Training Video.

How To Reach Us Home Page: nxp.com Web Support: nxp.com/support Information in this document is provided solely to enable system and software implementers to use NXP products. There are no express or implied copyright licenses granted hereunder to design or fabricate any integrated circuits based on the information in this document. NXP reserves the right to make changes without further notice to any products herein.

NXP makes no warranty, representation, or guarantee regarding the suitability of its products for any particular purpose, nor does NXP assume any liability arising out of the application or use of any product or circuit, and specifically disclaims any and all liability, including without limitation consequential or incidental damages. "Typical" parameters that may be provided in NXP data sheets and/or specifications can and do vary in different applications, and actual performance may vary over time. All operating parameters, including "typicals," must be validated for each customer application by customer's technical experts. NXP does not convey any license under its patent rights nor the rights of others. NXP sells products pursuant to standard terms and conditions of sale, which can be found at the following address: nxp.com/SalesTermsandConditions.

Security — Customer understands that all NXP products may be subject to unidentified or documented vulnerabilities. Customer is responsible for the design and operation of its applications and products throughout their lifecycles to reduce the effect of these vulnerabilities on customer's applications and products. Customer's responsibility also extends to other open and/or proprietary technologies supported by NXP products for use in customer's applications. NXP accepts no liability for any vulnerability. Customer should regularly check security updates from NXP and follow up appropriately. Customer shall select products with security features that best meet rules, regulations, and standards of the intended application and make the ultimate design decisions regarding its products and is solely responsible for compliance with all legal, regulatory, and security related requirements concerning its products, regardless of any information or support that may be provided by NXP. NXP has a Product Security Incident Response Team (PSIRT) (reachable at PSIRT@nxp.com) that manages the investigation, reporting, and solution release to security vulnerabilities of NXP products.

NXP, the NXP logo, NXP SECURE CONNECTIONS FOR A SMARTER WORLD, COOLFLUX, EMBRACE, GREENCHIP, HITAG, ICODE, JCOP, LIFE, VIBES, MIFARE, MIFARE CLASSIC, MIFARE DESFire, MIFARE PLUS, MIFARE FLEX, MANTIS, MIFARE ULTRALIGHT, MIFARE4MOBILE, MIGLO, NTAG, ROADLINK, SMARTLX, SMARTMX, STARPLUG, TOPFET, TRENCHMOS, UCODE, Freescale, the Freescale logo, AltiVec, CodeWarrior, ColdFire, ColdFire+, the Energy Efficient Solutions logo, Kinetis, Layerscape, MagniV, mobileGT, PEG, PowerQUICC, Processor Expert, QorIQ, QorIQ Qonverge, SafeAssure, the SafeAssure logo, StarCore, Symphony, VortiQa, Vybrid, Airfast, BeeKit, BeeStack, CoreNet, Flexis, MXC, Platform in a Package, QUICC Engine, Tower, TurboLink, EdgeScale, EdgeLock, elQ, and Immersive3D are trademarks of NXP B.V. All other product or service names are the property of their respective owners. AMBA, Arm, Arm7, Arm7TDMI, Arm9, Arm11, Artisan, big.LITTLE, Cordio, CoreLink, CoreSight, Cortex, DesignStart, DynamIQ, Jazelle, Keil, Mali, Mbed, Mbed Enabled, NEON, POP, RealView, SecurCore, Socrates, Thumb, TrustZone, ULINK, ULINK2, ULINK-ME, ULINK-PLUS, ULINKpro, µVision, Versatile are trademarks or registered trademarks of Arm Limited (or its subsidiaries) in the US and/or elsewhere. The related technology may be protected by any or all of patents, copyrights, designs and trade secrets. All rights reserved. Oracle and Java are registered trademarks of Oracle and/or its affiliates. The Power Architecture and Power.org word marks and the Power and Power.org logos and related marks are trademarks and service marks licensed by Power.org.

© NXP B.V. 2020.

#### All rights reserved.

For more information, please visit: http://www.nxp.com For sales office addresses, please send an email to: salesaddresses@nxp.com

> Date of release: December 21, 2020 Document identifier: AN13101

